mis-crystal-design-system 18.0.14 → 18.0.16-test-1
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/loader/loader.component.mjs +2 -2
- package/esm2022/radio-button/radio-button.component.mjs +102 -23
- package/esm2022/table/actions-cell/actions-cell.component.mjs +284 -0
- package/esm2022/table/public_api.mjs +2 -1
- package/esm2022/table/table.component.mjs +195 -109
- package/esm2022/table/table.module.mjs +17 -5
- package/esm2022/toast/public_api.mjs +3 -1
- package/esm2022/toast/toast.component.mjs +73 -16
- package/esm2022/toast/toast.constants.mjs +7 -0
- package/esm2022/toast/toast.data.service.mjs +1 -1
- package/esm2022/toast/toast.interface.mjs +2 -0
- package/esm2022/toast/toast.service.mjs +14 -7
- package/fesm2022/mis-crystal-design-system-loader.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-radio-button.mjs +101 -22
- package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +845 -465
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-toast.mjs +93 -22
- package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
- package/package.json +7 -7
- package/radio-button/radio-button.component.d.ts +18 -17
- package/styles/mis-old-icon-styles.scss +498 -498
- package/table/actions-cell/actions-cell.component.d.ts +32 -0
- package/table/public_api.d.ts +1 -0
- package/table/table.component.d.ts +37 -10
- package/table/table.module.d.ts +5 -4
- package/toast/public_api.d.ts +2 -0
- package/toast/toast.component.d.ts +13 -1
- package/toast/toast.constants.d.ts +5 -0
- package/toast/toast.data.service.d.ts +3 -2
- package/toast/toast.interface.d.ts +6 -0
- package/toast/toast.service.d.ts +2 -1
|
@@ -13,11 +13,11 @@ export class LoaderComponent {
|
|
|
13
13
|
i0.ɵɵelement(0, "div", 0);
|
|
14
14
|
} if (rf & 2) {
|
|
15
15
|
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(1, _c0, ctx.mobileView));
|
|
16
|
-
} }, dependencies: [i1.NgClass], styles: ["#spinner[_ngcontent-%COMP%]{-webkit-animation:_ngcontent-%COMP%_frames 1s infinite linear;animation:_ngcontent-%COMP%_frames 1s infinite linear;background:transparent;border:4px solid #e0e0e0;border-radius:100%;border-top-color:#
|
|
16
|
+
} }, dependencies: [i1.NgClass], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-disabled: #929DAB;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3}#spinner[_ngcontent-%COMP%]{-webkit-animation:_ngcontent-%COMP%_frames 1s infinite linear;animation:_ngcontent-%COMP%_frames 1s infinite linear;background:transparent;border:4px solid #e0e0e0;border-radius:100%;border-top-color:#0937b2;width:40px;height:40px;padding:0;position:absolute}@keyframes _ngcontent-%COMP%_frames{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.mobile[_ngcontent-%COMP%]{height:20px!important;width:20px!important;border:2px solid #e0e0e0!important;border-top-color:#0937b2!important}"] }); }
|
|
17
17
|
}
|
|
18
18
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LoaderComponent, [{
|
|
19
19
|
type: Component,
|
|
20
|
-
args: [{ selector: "mis-loader", template: "<div\n id=\"spinner\"\n [ngClass]=\"{\n mobile: mobileView\n }\"\n></div>\n", styles: ["#spinner{-webkit-animation:frames 1s infinite linear;animation:frames 1s infinite linear;background:transparent;border:4px solid #e0e0e0;border-radius:100%;border-top-color:#
|
|
20
|
+
args: [{ selector: "mis-loader", template: "<div\n id=\"spinner\"\n [ngClass]=\"{\n mobile: mobileView\n }\"\n></div>\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-disabled: #929DAB;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3}#spinner{-webkit-animation:frames 1s infinite linear;animation:frames 1s infinite linear;background:transparent;border:4px solid #e0e0e0;border-radius:100%;border-top-color:#0937b2;width:40px;height:40px;padding:0;position:absolute}@keyframes frames{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.mobile{height:20px!important;width:20px!important;border:2px solid #e0e0e0!important;border-top-color:#0937b2!important}\n"] }]
|
|
21
21
|
}], () => [], { mobileView: [{
|
|
22
22
|
type: Input
|
|
23
23
|
}] }); })();
|
|
@@ -1,45 +1,124 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter } from "@angular/core";
|
|
2
|
-
import { UntypedFormControl } from "@angular/forms";
|
|
1
|
+
import { Component, Input, Output, EventEmitter, forwardRef } from "@angular/core";
|
|
2
|
+
import { AbstractControl, UntypedFormControl, NG_VALUE_ACCESSOR } 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
|
+
}
|
|
6
44
|
constructor() {
|
|
7
|
-
/** When multiple radio input fields are used
|
|
8
|
-
* an "id" can be given to keep track of them */
|
|
9
45
|
this.id = "";
|
|
10
|
-
/** Name of the attribute for which the radio
|
|
11
|
-
* selection is provided */
|
|
12
46
|
this.name = "";
|
|
13
|
-
/** Value of the attribute which is to be emitted
|
|
14
|
-
* when selected */
|
|
15
47
|
this.value = "";
|
|
16
|
-
|
|
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 */
|
|
48
|
+
this._formControl = new UntypedFormControl(null);
|
|
24
49
|
this.valueChange = new EventEmitter();
|
|
50
|
+
// ControlValueAccessor properties
|
|
51
|
+
this._value = null;
|
|
52
|
+
this._disabled = false;
|
|
53
|
+
this.onChange = (value) => { };
|
|
54
|
+
this.onTouched = () => { };
|
|
25
55
|
}
|
|
26
56
|
ngOnInit() { }
|
|
27
|
-
|
|
28
|
-
|
|
57
|
+
// ControlValueAccessor implementation
|
|
58
|
+
writeValue(value) {
|
|
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
|
+
}
|
|
29
96
|
}
|
|
30
97
|
static { this.ɵfac = function RadioButtonComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RadioButtonComponent)(); }; }
|
|
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" },
|
|
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" }, features: [i0.ɵɵProvidersFeature([
|
|
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) {
|
|
32
105
|
i0.ɵɵelementStart(0, "input", 0);
|
|
33
|
-
i0.ɵɵlistener("change", function RadioButtonComponent_Template_input_change_0_listener($event) { return ctx.
|
|
106
|
+
i0.ɵɵlistener("change", function RadioButtonComponent_Template_input_change_0_listener($event) { return ctx.onInputChange($event); })("keyup.enter", function RadioButtonComponent_Template_input_keyup_enter_0_listener($event) { return ctx.onInputChange($event); })("blur", function RadioButtonComponent_Template_input_blur_0_listener() { return ctx.markAsTouched(); });
|
|
34
107
|
i0.ɵɵelementEnd();
|
|
35
108
|
} if (rf & 2) {
|
|
36
109
|
i0.ɵɵpropertyInterpolate("id", ctx.id);
|
|
37
|
-
i0.ɵɵproperty("name", ctx.name)("
|
|
110
|
+
i0.ɵɵproperty("name", ctx.name)("value", ctx.value)("formControl", ctx.formControl)("checked", ctx.currentValue === ctx.value);
|
|
38
111
|
} }, 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}"] }); }
|
|
39
112
|
}
|
|
40
113
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RadioButtonComponent, [{
|
|
41
114
|
type: Component,
|
|
42
|
-
args: [{ selector: "mis-radio",
|
|
115
|
+
args: [{ selector: "mis-radio", providers: [
|
|
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"] }]
|
|
43
122
|
}], () => [], { id: [{
|
|
44
123
|
type: Input
|
|
45
124
|
}], name: [{
|
|
@@ -54,4 +133,4 @@ export class RadioButtonComponent {
|
|
|
54
133
|
type: Output
|
|
55
134
|
}] }); })();
|
|
56
135
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RadioButtonComponent, { className: "RadioButtonComponent" }); })();
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvbWlzLWNvbXBvbmVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBbUIsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBT3JFLE1BQU0sT0FBTyxvQkFBb0I7SUFzQi9CO1FBckJBO3dEQUNnRDtRQUN2QyxPQUFFLEdBQW9CLEVBQUUsQ0FBQztRQUNsQzttQ0FDMkI7UUFDbEIsU0FBSSxHQUFvQixFQUFFLENBQUM7UUFDcEM7MkJBQ21CO1FBQ1YsVUFBSyxHQUFvQixFQUFFLENBQUM7UUFDckMsNkNBQTZDO1FBQ3BDLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFFbkM7OztxREFHNkM7UUFDcEMsZ0JBQVcsR0FBb0IsSUFBSSxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVyRSxxREFBcUQ7UUFDM0MsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0lBRWpDLENBQUM7SUFDaEIsUUFBUSxLQUFJLENBQUM7SUFDYixRQUFRLENBQUMsS0FBSztRQUNaLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEQsQ0FBQztxSEExQlUsb0JBQW9CO29FQUFwQixvQkFBb0I7WUNSakMsZ0NBUUU7WUFORSxBQURBLHdHQUFVLG9CQUFnQixJQUFDLG1HQUNiLG9CQUFnQixJQUFDO1lBRm5DLGlCQVFFOztZQUpFLHNDQUFhO1lBR2IsQUFEQSxBQURjLEFBQWQsK0JBQWEsMEJBQXNCLG9CQUNwQixnQ0FDWTs7O2lGRENsQixvQkFBb0I7Y0FMaEMsU0FBUzsyQkFDRSxXQUFXO29CQU9aLEVBQUU7a0JBQVYsS0FBSztZQUdHLElBQUk7a0JBQVosS0FBSztZQUdHLEtBQUs7a0JBQWIsS0FBSztZQUVHLFFBQVE7a0JBQWhCLEtBQUs7WUFNRyxXQUFXO2tCQUFuQixLQUFLO1lBR0ksV0FBVztrQkFBcEIsTUFBTTs7a0ZBcEJJLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBVbnR5cGVkRm9ybUNvbnRyb2wgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcIm1pcy1yYWRpb1wiLFxuICB0ZW1wbGF0ZVVybDogXCIuL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQuaHRtbFwiLFxuICBzdHlsZVVybHM6IFtcIi4vcmFkaW8tYnV0dG9uLmNvbXBvbmVudC5zY3NzXCJdXG59KVxuZXhwb3J0IGNsYXNzIFJhZGlvQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqIFdoZW4gbXVsdGlwbGUgcmFkaW8gaW5wdXQgZmllbGRzIGFyZSB1c2VkXG4gICAqIGFuIFwiaWRcIiBjYW4gYmUgZ2l2ZW4gdG8ga2VlcCB0cmFjayBvZiB0aGVtICovXG4gIEBJbnB1dCgpIGlkOiBzdHJpbmcgfCBudW1iZXIgPSBcIlwiO1xuICAvKiogTmFtZSBvZiB0aGUgYXR0cmlidXRlIGZvciB3aGljaCB0aGUgcmFkaW9cbiAgICogc2VsZWN0aW9uIGlzIHByb3ZpZGVkICovXG4gIEBJbnB1dCgpIG5hbWU6IHN0cmluZyB8IG51bWJlciA9IFwiXCI7XG4gIC8qKiBWYWx1ZSBvZiB0aGUgYXR0cmlidXRlIHdoaWNoIGlzIHRvIGJlIGVtaXR0ZWRcbiAgICogd2hlbiBzZWxlY3RlZCAqL1xuICBASW5wdXQoKSB2YWx1ZTogc3RyaW5nIHwgbnVtYmVyID0gXCJcIjtcbiAgLyoqIENvbnRyb2xzIHRoZSBzdGF0ZSBvZiB0aGUgcmFkaW8gYnV0dG9uICovXG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqIENhbiBiZSB1c2VkIHRvIGF0dGFjaCB0aGUgcmFkaW8gaW5wdXQgZmllbGRcbiAgICogdG8gYSByZWFjdGl2ZSBmb3JtIGJ5IHBhc3NpbmcgaW4gYVxuICAgKiDigJxGb3JtQ29udHJvbOKAnCBPYmplY3QuIEl0IGNhbiBhbHNvIGJlXG4gICAqIHVzZWQgdG8gc2V0IHRoZSBkZWZhdWx0IGF0dHJpYnV0ZSB2YWx1ZSAqL1xuICBASW5wdXQoKSBmb3JtQ29udHJvbDogQWJzdHJhY3RDb250cm9sID0gbmV3IFVudHlwZWRGb3JtQ29udHJvbChudWxsKTtcblxuICAvKiogRW1pdHMgXCJ2YWx1ZVwiIG9mIHRoZSByYWRpbyBidXR0b24gb24gc2VsZWN0aW9uICovXG4gIEBPdXRwdXQoKSB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cbiAgbmdPbkluaXQoKSB7fVxuICBvbkNoYW5nZShldmVudCkge1xuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdCh0aGlzLmZvcm1Db250cm9sLnZhbHVlKTtcbiAgfVxufVxuIiwiPGlucHV0IFxuICAgIChjaGFuZ2UpPVwib25DaGFuZ2UoJGV2ZW50KVwiIFxuICAgIChrZXVwLmVudGVyKT1cIm9uQ2hhbmdlKCRldmVudClcIlxuICAgIHRhYmluZGV4PVwiLTFcIlxuICAgIGlkPVwie3sgaWQgfX1cIiB0eXBlPVwicmFkaW9cIiBcbiAgICBbbmFtZV09XCJuYW1lXCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgXG4gICAgW3ZhbHVlXT1cInZhbHVlXCJcbiAgICBbZm9ybUNvbnRyb2xdPVwiZm9ybUNvbnRyb2xcIiBcbi8+XG4iXX0=
|
|
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/>"]}
|
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, HostListener } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "mis-crystal-design-system/checkbox";
|
|
5
|
+
const _c0 = a0 => ({ disabled: a0 });
|
|
6
|
+
function ActionsCellComponent_div_1_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
7
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
8
|
+
i0.ɵɵelementStart(0, "div", 7);
|
|
9
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_1_div_1_Template_div_click_0_listener($event) { const item_r2 = i0.ɵɵrestoreView(_r1).$implicit; const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.onActionClick(item_r2, $event)); });
|
|
10
|
+
i0.ɵɵelement(1, "img", 8);
|
|
11
|
+
i0.ɵɵelementEnd();
|
|
12
|
+
} if (rf & 2) {
|
|
13
|
+
const item_r2 = ctx.$implicit;
|
|
14
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
15
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c0, ctx_r2.isDisabled(item_r2)));
|
|
16
|
+
i0.ɵɵadvance();
|
|
17
|
+
i0.ɵɵproperty("src", item_r2.icon, i0.ɵɵsanitizeUrl)("alt", item_r2.label);
|
|
18
|
+
} }
|
|
19
|
+
function ActionsCellComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
20
|
+
i0.ɵɵelementStart(0, "div", 5);
|
|
21
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_1_div_1_Template, 2, 5, "div", 6);
|
|
22
|
+
i0.ɵɵelementEnd();
|
|
23
|
+
} if (rf & 2) {
|
|
24
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
25
|
+
i0.ɵɵadvance();
|
|
26
|
+
i0.ɵɵproperty("ngForOf", ctx_r2.actionItems)("ngForTrackBy", ctx_r2.trackByAction);
|
|
27
|
+
} }
|
|
28
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_container_1_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
29
|
+
i0.ɵɵelementStart(0, "span", 26);
|
|
30
|
+
i0.ɵɵelement(1, "img", 27);
|
|
31
|
+
i0.ɵɵelementEnd();
|
|
32
|
+
} if (rf & 2) {
|
|
33
|
+
const item_r6 = i0.ɵɵnextContext(2).$implicit;
|
|
34
|
+
i0.ɵɵadvance();
|
|
35
|
+
i0.ɵɵproperty("src", item_r6.icon, i0.ɵɵsanitizeUrl);
|
|
36
|
+
} }
|
|
37
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_div_1_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
38
|
+
i0.ɵɵelementStart(0, "span", 26);
|
|
39
|
+
i0.ɵɵelement(1, "img", 27);
|
|
40
|
+
i0.ɵɵelementEnd();
|
|
41
|
+
} if (rf & 2) {
|
|
42
|
+
const child_r8 = i0.ɵɵnextContext().$implicit;
|
|
43
|
+
i0.ɵɵadvance();
|
|
44
|
+
i0.ɵɵproperty("src", child_r8.icon, i0.ɵɵsanitizeUrl);
|
|
45
|
+
} }
|
|
46
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
47
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
48
|
+
i0.ɵɵelementStart(0, "div", 18);
|
|
49
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_div_1_Template_div_click_0_listener($event) { const child_r8 = i0.ɵɵrestoreView(_r7).$implicit; const ctx_r2 = i0.ɵɵnextContext(6); return i0.ɵɵresetView(ctx_r2.onDropdownItemClick(child_r8, $event)); });
|
|
50
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_div_1_span_1_Template, 2, 1, "span", 20);
|
|
51
|
+
i0.ɵɵelementStart(2, "span", 21);
|
|
52
|
+
i0.ɵɵtext(3);
|
|
53
|
+
i0.ɵɵelementEnd()();
|
|
54
|
+
} if (rf & 2) {
|
|
55
|
+
const child_r8 = ctx.$implicit;
|
|
56
|
+
const ctx_r2 = i0.ɵɵnextContext(6);
|
|
57
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c0, ctx_r2.isDisabled(child_r8)));
|
|
58
|
+
i0.ɵɵadvance();
|
|
59
|
+
i0.ɵɵproperty("ngIf", child_r8.icon);
|
|
60
|
+
i0.ɵɵadvance(2);
|
|
61
|
+
i0.ɵɵtextInterpolate(child_r8.label);
|
|
62
|
+
} }
|
|
63
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
64
|
+
i0.ɵɵelementStart(0, "div", 28);
|
|
65
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_div_1_Template, 4, 5, "div", 17);
|
|
66
|
+
i0.ɵɵelementEnd();
|
|
67
|
+
} if (rf & 2) {
|
|
68
|
+
const item_r6 = i0.ɵɵnextContext(2).$implicit;
|
|
69
|
+
i0.ɵɵproperty("ngClass", item_r6.submenuAlign);
|
|
70
|
+
i0.ɵɵadvance();
|
|
71
|
+
i0.ɵɵproperty("ngForOf", item_r6.children);
|
|
72
|
+
} }
|
|
73
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
74
|
+
i0.ɵɵelementContainerStart(0);
|
|
75
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_2_div_6_div_1_ng_container_1_span_1_Template, 2, 1, "span", 20);
|
|
76
|
+
i0.ɵɵelementStart(2, "span", 21);
|
|
77
|
+
i0.ɵɵtext(3);
|
|
78
|
+
i0.ɵɵelementEnd();
|
|
79
|
+
i0.ɵɵelementStart(4, "span", 22);
|
|
80
|
+
i0.ɵɵnamespaceSVG();
|
|
81
|
+
i0.ɵɵelementStart(5, "svg", 23);
|
|
82
|
+
i0.ɵɵelement(6, "path", 24);
|
|
83
|
+
i0.ɵɵelementEnd()();
|
|
84
|
+
i0.ɵɵtemplate(7, ActionsCellComponent_div_2_div_6_div_1_ng_container_1_div_7_Template, 2, 2, "div", 25);
|
|
85
|
+
i0.ɵɵelementContainerEnd();
|
|
86
|
+
} if (rf & 2) {
|
|
87
|
+
const item_r6 = i0.ɵɵnextContext().$implicit;
|
|
88
|
+
i0.ɵɵadvance();
|
|
89
|
+
i0.ɵɵproperty("ngIf", item_r6.icon);
|
|
90
|
+
i0.ɵɵadvance(2);
|
|
91
|
+
i0.ɵɵtextInterpolate(item_r6.label);
|
|
92
|
+
i0.ɵɵadvance(4);
|
|
93
|
+
i0.ɵɵproperty("ngIf", item_r6.showSubmenu);
|
|
94
|
+
} }
|
|
95
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_template_2_span_0_Template(rf, ctx) { if (rf & 1) {
|
|
96
|
+
i0.ɵɵelementStart(0, "span", 26);
|
|
97
|
+
i0.ɵɵelement(1, "img", 27);
|
|
98
|
+
i0.ɵɵelementEnd();
|
|
99
|
+
} if (rf & 2) {
|
|
100
|
+
const item_r6 = i0.ɵɵnextContext(2).$implicit;
|
|
101
|
+
i0.ɵɵadvance();
|
|
102
|
+
i0.ɵɵproperty("src", item_r6.icon, i0.ɵɵsanitizeUrl);
|
|
103
|
+
} }
|
|
104
|
+
function ActionsCellComponent_div_2_div_6_div_1_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
105
|
+
i0.ɵɵtemplate(0, ActionsCellComponent_div_2_div_6_div_1_ng_template_2_span_0_Template, 2, 1, "span", 20);
|
|
106
|
+
i0.ɵɵelementStart(1, "span", 21);
|
|
107
|
+
i0.ɵɵtext(2);
|
|
108
|
+
i0.ɵɵelementEnd();
|
|
109
|
+
} if (rf & 2) {
|
|
110
|
+
const item_r6 = i0.ɵɵnextContext().$implicit;
|
|
111
|
+
i0.ɵɵproperty("ngIf", item_r6.icon);
|
|
112
|
+
i0.ɵɵadvance(2);
|
|
113
|
+
i0.ɵɵtextInterpolate(item_r6.label);
|
|
114
|
+
} }
|
|
115
|
+
function ActionsCellComponent_div_2_div_6_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
116
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
117
|
+
i0.ɵɵelementStart(0, "div", 18);
|
|
118
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_2_div_6_div_1_Template_div_click_0_listener($event) { const item_r6 = i0.ɵɵrestoreView(_r5).$implicit; const ctx_r2 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r2.onDropdownItemClick(item_r6, $event)); });
|
|
119
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_2_div_6_div_1_ng_container_1_Template, 8, 3, "ng-container", 19)(2, ActionsCellComponent_div_2_div_6_div_1_ng_template_2_Template, 3, 2, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
120
|
+
i0.ɵɵelementEnd();
|
|
121
|
+
} if (rf & 2) {
|
|
122
|
+
const item_r6 = ctx.$implicit;
|
|
123
|
+
const noChildren_r9 = i0.ɵɵreference(3);
|
|
124
|
+
const ctx_r2 = i0.ɵɵnextContext(3);
|
|
125
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c0, ctx_r2.isDisabled(item_r6)));
|
|
126
|
+
i0.ɵɵadvance();
|
|
127
|
+
i0.ɵɵproperty("ngIf", item_r6.children == null ? null : item_r6.children.length)("ngIfElse", noChildren_r9);
|
|
128
|
+
} }
|
|
129
|
+
function ActionsCellComponent_div_2_div_6_Template(rf, ctx) { if (rf & 1) {
|
|
130
|
+
i0.ɵɵelementStart(0, "div", 16);
|
|
131
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_2_div_6_div_1_Template, 4, 5, "div", 17);
|
|
132
|
+
i0.ɵɵelementEnd();
|
|
133
|
+
} if (rf & 2) {
|
|
134
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
135
|
+
i0.ɵɵproperty("ngClass", ctx_r2.menuAlign);
|
|
136
|
+
i0.ɵɵadvance();
|
|
137
|
+
i0.ɵɵproperty("ngForOf", ctx_r2.actionItems);
|
|
138
|
+
} }
|
|
139
|
+
function ActionsCellComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
140
|
+
const _r4 = i0.ɵɵgetCurrentView();
|
|
141
|
+
i0.ɵɵelementStart(0, "div", 9)(1, "div", 10);
|
|
142
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_2_Template_div_click_1_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.toggleDropdown($event)); });
|
|
143
|
+
i0.ɵɵnamespaceSVG();
|
|
144
|
+
i0.ɵɵelementStart(2, "svg", 11);
|
|
145
|
+
i0.ɵɵelement(3, "circle", 12)(4, "circle", 13)(5, "circle", 14);
|
|
146
|
+
i0.ɵɵelementEnd()();
|
|
147
|
+
i0.ɵɵtemplate(6, ActionsCellComponent_div_2_div_6_Template, 2, 2, "div", 15);
|
|
148
|
+
i0.ɵɵelementEnd();
|
|
149
|
+
} if (rf & 2) {
|
|
150
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
151
|
+
i0.ɵɵadvance(6);
|
|
152
|
+
i0.ɵɵproperty("ngIf", ctx_r2.isDropdownOpen);
|
|
153
|
+
} }
|
|
154
|
+
function ActionsCellComponent_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
155
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
|
156
|
+
i0.ɵɵelementStart(0, "div", 29)(1, "mis-checkbox", 30);
|
|
157
|
+
i0.ɵɵlistener("valueChange", function ActionsCellComponent_div_3_Template_mis_checkbox_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r10); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.onCheckboxChange($event)); });
|
|
158
|
+
i0.ɵɵelementEnd()();
|
|
159
|
+
} if (rf & 2) {
|
|
160
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
161
|
+
i0.ɵɵadvance();
|
|
162
|
+
i0.ɵɵproperty("checked", ctx_r2.isChecked);
|
|
163
|
+
} }
|
|
164
|
+
export class ActionsCellComponent {
|
|
165
|
+
constructor() {
|
|
166
|
+
this.isChecked = false;
|
|
167
|
+
this.actionItems = [];
|
|
168
|
+
this.actionType = "inline";
|
|
169
|
+
this.submenuAlign = "right";
|
|
170
|
+
this.menuAlign = "left";
|
|
171
|
+
this.actionClick = new EventEmitter();
|
|
172
|
+
this.isDropdownOpen = false;
|
|
173
|
+
this._style = {};
|
|
174
|
+
this.containerStyle = {};
|
|
175
|
+
}
|
|
176
|
+
set config(config) {
|
|
177
|
+
this.actionItems = config?.actionItems,
|
|
178
|
+
this.actionType = config.actionType,
|
|
179
|
+
this.submenuAlign = config.submenuAlign,
|
|
180
|
+
this.menuAlign = config.menuAlign;
|
|
181
|
+
this._style = config.style;
|
|
182
|
+
this.processStyle();
|
|
183
|
+
}
|
|
184
|
+
ngOnInit() { }
|
|
185
|
+
processStyle() {
|
|
186
|
+
// Remove width from style to avoid conflicts with table column width
|
|
187
|
+
const { width, ...restStyle } = this._style;
|
|
188
|
+
this.containerStyle = restStyle;
|
|
189
|
+
}
|
|
190
|
+
onActionClick(item, event) {
|
|
191
|
+
event.stopPropagation();
|
|
192
|
+
// Check permissions before executing action
|
|
193
|
+
if (this.isDisabled(item))
|
|
194
|
+
return;
|
|
195
|
+
// Execute action only if permitted
|
|
196
|
+
if (item.action) {
|
|
197
|
+
item.action(this.data);
|
|
198
|
+
}
|
|
199
|
+
this.actionClick.emit({ item, data: this.data });
|
|
200
|
+
}
|
|
201
|
+
trackByAction(index, item) {
|
|
202
|
+
return item.value;
|
|
203
|
+
}
|
|
204
|
+
isSvgFile(iconPath) {
|
|
205
|
+
if (!iconPath)
|
|
206
|
+
return false;
|
|
207
|
+
return iconPath.toLowerCase().includes(".svg") || iconPath.toLowerCase().includes("assets/icons/");
|
|
208
|
+
}
|
|
209
|
+
onDocumentClick() {
|
|
210
|
+
if (this.isDropdownOpen) {
|
|
211
|
+
this.isDropdownOpen = false;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
toggleDropdown(event) {
|
|
215
|
+
event.stopPropagation();
|
|
216
|
+
this.isDropdownOpen = !this.isDropdownOpen;
|
|
217
|
+
// Close all submenus when opening/closing main menu
|
|
218
|
+
this.actionItems.forEach((item) => (item.showSubmenu = false));
|
|
219
|
+
}
|
|
220
|
+
onDropdownItemClick(item, event) {
|
|
221
|
+
event.stopPropagation();
|
|
222
|
+
if (this.isDisabled(item))
|
|
223
|
+
return;
|
|
224
|
+
if (item?.children?.length) {
|
|
225
|
+
// Toggle submenu
|
|
226
|
+
item.showSubmenu = !item.showSubmenu;
|
|
227
|
+
// Optionally close other submenus
|
|
228
|
+
this.actionItems.forEach((i) => {
|
|
229
|
+
if (i !== item)
|
|
230
|
+
i.showSubmenu = false;
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
// Handle action
|
|
235
|
+
if (item.action)
|
|
236
|
+
item.action(this.data);
|
|
237
|
+
this.actionClick.emit({ item, data: this.data });
|
|
238
|
+
this.isDropdownOpen = false; // Only close if action was executed
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
onCheckboxChange(event) {
|
|
242
|
+
this.isChecked = event.value;
|
|
243
|
+
this.actionClick.emit({ isChecked: this.isChecked, data: this.data });
|
|
244
|
+
}
|
|
245
|
+
isDisabled(item) {
|
|
246
|
+
if (typeof item.disable === "function") {
|
|
247
|
+
return item.disable(this.data);
|
|
248
|
+
}
|
|
249
|
+
return false;
|
|
250
|
+
}
|
|
251
|
+
static { this.ɵfac = function ActionsCellComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ActionsCellComponent)(); }; }
|
|
252
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ActionsCellComponent, selectors: [["mis-actions-cell"]], hostBindings: function ActionsCellComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
253
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_click_HostBindingHandler() { return ctx.onDocumentClick(); }, false, i0.ɵɵresolveDocument);
|
|
254
|
+
} }, inputs: { data: "data", isChecked: "isChecked", config: "config" }, outputs: { actionClick: "actionClick" }, decls: 4, vars: 4, consts: [["noChildren", ""], [1, "actions-cell-container", 3, "ngStyle"], ["class", "inline-actions", 4, "ngIf"], ["class", "dropdown-actions", 4, "ngIf"], ["class", "checkbox-actions", 4, "ngIf"], [1, "inline-actions"], ["class", "action-item", 3, "ngClass", "click", 4, "ngFor", "ngForOf", "ngForTrackBy"], [1, "action-item", 3, "click", "ngClass"], [1, "action-icon-svg", 3, "src", "alt"], [1, "dropdown-actions"], ["title", "More actions", 1, "dropdown-trigger", 3, "click"], ["width", "20", "height", "20", "viewBox", "0 0 20 20", "fill", "none"], ["cx", "10", "cy", "4", "r", "2", "fill", "#333"], ["cx", "10", "cy", "10", "r", "2", "fill", "#333"], ["cx", "10", "cy", "16", "r", "2", "fill", "#333"], ["class", "dropdown-menu", 3, "ngClass", 4, "ngIf"], [1, "dropdown-menu", 3, "ngClass"], ["class", "dropdown-menu-item", 3, "ngClass", "click", 4, "ngFor", "ngForOf"], [1, "dropdown-menu-item", 3, "click", "ngClass"], [4, "ngIf", "ngIfElse"], ["class", "dropdown-icon", 4, "ngIf"], [1, "dropdown-label"], [1, "submenu-arrow"], ["width", "20", "height", "20", "viewBox", "0 0 24 24", "fill", "none"], ["d", "M9 6L15 12L9 18", "stroke", "#0D1321", "stroke-width", "2", "stroke-linecap", "round", "stroke-linejoin", "round"], ["class", "dropdown-submenu", 3, "ngClass", 4, "ngIf"], [1, "dropdown-icon"], [3, "src"], [1, "dropdown-submenu", 3, "ngClass"], [1, "checkbox-actions"], [3, "valueChange", "checked"]], template: function ActionsCellComponent_Template(rf, ctx) { if (rf & 1) {
|
|
255
|
+
i0.ɵɵelementStart(0, "div", 1);
|
|
256
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_1_Template, 2, 2, "div", 2)(2, ActionsCellComponent_div_2_Template, 7, 1, "div", 3)(3, ActionsCellComponent_div_3_Template, 2, 1, "div", 4);
|
|
257
|
+
i0.ɵɵelementEnd();
|
|
258
|
+
} if (rf & 2) {
|
|
259
|
+
i0.ɵɵproperty("ngStyle", ctx.containerStyle);
|
|
260
|
+
i0.ɵɵadvance();
|
|
261
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "inline");
|
|
262
|
+
i0.ɵɵadvance();
|
|
263
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "dropdown");
|
|
264
|
+
i0.ɵɵadvance();
|
|
265
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "checkbox");
|
|
266
|
+
} }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgStyle, i2.CheckboxComponent], styles: [".actions-cell-container[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;box-sizing:border-box}.inline-actions[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;flex-wrap:nowrap;padding:4px 0;flex-direction:row}.action-item[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;height:20px;border-radius:4px;cursor:pointer;transition:all .2s ease;background-color:transparent;border:none;outline:none;flex-shrink:0;min-height:20px}.action-item[_ngcontent-%COMP%]:hover:not(.disabled){background-color:#0000000a;transform:scale(1.05)}.action-item[_ngcontent-%COMP%]:active:not(.disabled){transform:scale(.95)}.action-item.disabled[_ngcontent-%COMP%]{opacity:.5;cursor:not-allowed}.action-item.disabled[_ngcontent-%COMP%]:hover{background-color:transparent;transform:none}.action-icon[_ngcontent-%COMP%]{font-size:16px;color:#666;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.action-icon-svg[_ngcontent-%COMP%]{width:18px;height:18px;object-fit:contain;filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(.6) contrast(1);flex-shrink:0}.action-icon-svg[_ngcontent-%COMP%]:hover{filter:brightness(0) saturate(100%) invert(0%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0) contrast(1)}.dropdown-trigger[_ngcontent-%COMP%]{cursor:pointer}.dropdown-actions[_ngcontent-%COMP%]{position:relative}.dropdown-trigger[_ngcontent-%COMP%]{cursor:pointer;display:flex;align-items:center;justify-content:center}.dropdown-menu[_ngcontent-%COMP%]{position:absolute;top:100%;width:232px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;z-index:1000;padding:8px 0}.dropdown-menu.left[_ngcontent-%COMP%]{right:0!important;left:auto!important}.dropdown-menu.right[_ngcontent-%COMP%]{left:0!important;right:auto!important}.dropdown-menu-item.disabled[_ngcontent-%COMP%]{color:#aaa;cursor:not-allowed}.dropdown-menu-item[_ngcontent-%COMP%]:hover:not(.disabled), .dropdown-menu-item.has-submenu[_ngcontent-%COMP%]:hover{background:#f5f5f5}.dropdown-menu-item[_ngcontent-%COMP%]{display:flex;align-items:center;padding:10px 18px;cursor:pointer;font-size:14px;position:relative}.dropdown-menu-item[_ngcontent-%COMP%] .dropdown-label[_ngcontent-%COMP%]{flex:1;margin-left:8px}.dropdown-menu-item[_ngcontent-%COMP%] .submenu-arrow[_ngcontent-%COMP%]{margin-left:auto;width:16px;height:16px}.submenu-container[_ngcontent-%COMP%]{position:absolute;top:0;left:100%;margin-left:4px;background:#fff;box-shadow:0 4px 8px #0000001a;border-radius:8px;z-index:1000;white-space:nowrap}.dropdown-submenu[_ngcontent-%COMP%]{position:absolute;top:0;min-width:132px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;padding:8px 0;z-index:1001}.dropdown-submenu.right[_ngcontent-%COMP%]{left:100%;margin-left:4px}.dropdown-submenu.left[_ngcontent-%COMP%]{left:auto;right:100%;background-color:#fff;border:1px solid #ddd;z-index:9999;position:absolute;margin-right:4px}.submenu-arrow[_ngcontent-%COMP%]{display:flex;align-items:center;margin-left:auto;z-index:9999}.dropdown-icon[_ngcontent-%COMP%]{display:flex;justify-content:center;align-items:center}.dropdown-menu-item.disabled[_ngcontent-%COMP%]{color:#181f33;filter:grayscale(100%) opacity(.3);cursor:not-allowed}"] }); }
|
|
267
|
+
}
|
|
268
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ActionsCellComponent, [{
|
|
269
|
+
type: Component,
|
|
270
|
+
args: [{ selector: "mis-actions-cell", template: "<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", styles: [".actions-cell-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;box-sizing:border-box}.inline-actions{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;flex-wrap:nowrap;padding:4px 0;flex-direction:row}.action-item{display:flex;align-items:center;justify-content:center;height:20px;border-radius:4px;cursor:pointer;transition:all .2s ease;background-color:transparent;border:none;outline:none;flex-shrink:0;min-height:20px}.action-item:hover:not(.disabled){background-color:#0000000a;transform:scale(1.05)}.action-item:active:not(.disabled){transform:scale(.95)}.action-item.disabled{opacity:.5;cursor:not-allowed}.action-item.disabled:hover{background-color:transparent;transform:none}.action-icon{font-size:16px;color:#666;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.action-icon-svg{width:18px;height:18px;object-fit:contain;filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(.6) contrast(1);flex-shrink:0}.action-icon-svg:hover{filter:brightness(0) saturate(100%) invert(0%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0) contrast(1)}.dropdown-trigger{cursor:pointer}.dropdown-actions{position:relative}.dropdown-trigger{cursor:pointer;display:flex;align-items:center;justify-content:center}.dropdown-menu{position:absolute;top:100%;width:232px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;z-index:1000;padding:8px 0}.dropdown-menu.left{right:0!important;left:auto!important}.dropdown-menu.right{left:0!important;right:auto!important}.dropdown-menu-item.disabled{color:#aaa;cursor:not-allowed}.dropdown-menu-item:hover:not(.disabled),.dropdown-menu-item.has-submenu:hover{background:#f5f5f5}.dropdown-menu-item{display:flex;align-items:center;padding:10px 18px;cursor:pointer;font-size:14px;position:relative}.dropdown-menu-item .dropdown-label{flex:1;margin-left:8px}.dropdown-menu-item .submenu-arrow{margin-left:auto;width:16px;height:16px}.submenu-container{position:absolute;top:0;left:100%;margin-left:4px;background:#fff;box-shadow:0 4px 8px #0000001a;border-radius:8px;z-index:1000;white-space:nowrap}.dropdown-submenu{position:absolute;top:0;min-width:132px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;padding:8px 0;z-index:1001}.dropdown-submenu.right{left:100%;margin-left:4px}.dropdown-submenu.left{left:auto;right:100%;background-color:#fff;border:1px solid #ddd;z-index:9999;position:absolute;margin-right:4px}.submenu-arrow{display:flex;align-items:center;margin-left:auto;z-index:9999}.dropdown-icon{display:flex;justify-content:center;align-items:center}.dropdown-menu-item.disabled{color:#181f33;filter:grayscale(100%) opacity(.3);cursor:not-allowed}\n"] }]
|
|
271
|
+
}], null, { data: [{
|
|
272
|
+
type: Input
|
|
273
|
+
}], isChecked: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], config: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], actionClick: [{
|
|
278
|
+
type: Output
|
|
279
|
+
}], onDocumentClick: [{
|
|
280
|
+
type: HostListener,
|
|
281
|
+
args: ["document:click"]
|
|
282
|
+
}] }); })();
|
|
283
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ActionsCellComponent, { className: "ActionsCellComponent" }); })();
|
|
284
|
+
//# 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() 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.processStyle();\n  }\n\n  actionItems: ActionItem[] = [];\n  actionType: \"inline\" | \"dropdown\" | \"checkbox\" = \"inline\";\n  submenuAlign: \"left\" | \"right\" = \"right\";\n  menuAlign: \"left\" | \"right\" = \"left\";\n\n  @Output() actionClick = new EventEmitter<{ item?: ActionItem; data: any; isChecked?: boolean }>();\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) {\n    this.isChecked = event.value;\n    this.actionClick.emit({ isChecked: this.isChecked, data: this.data });\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"]}
|
|
@@ -4,4 +4,5 @@ export * from './sort-icons.directive';
|
|
|
4
4
|
export { SubTableComponent } from "./sub-table/sub-table.component";
|
|
5
5
|
export { CustomTableCellDirective } from "./custom-table-cell.directive";
|
|
6
6
|
export { TableFilterComponent } from "./filter/filter.component";
|
|
7
|
-
|
|
7
|
+
export { ActionsCellComponent } from "./actions-cell/actions-cell.component";
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL3RhYmxlL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFHekUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFakUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NvcnQtaWNvbnMuZGlyZWN0aXZlJztcbmV4cG9ydCB7IFN1YlRhYmxlQ29tcG9uZW50IH0gZnJvbSBcIi4vc3ViLXRhYmxlL3N1Yi10YWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCB7IEN1c3RvbVRhYmxlQ2VsbERpcmVjdGl2ZSB9IGZyb20gXCIuL2N1c3RvbS10YWJsZS1jZWxsLmRpcmVjdGl2ZVwiO1xuZXhwb3J0IHsgVGFibGVDb25maWcsIFBhZ2luYXRpb25Db25maWcsIFJvd0NvbmZpZywgQ29sSGVhZGVyQ29uZmlnLCBDb2xDb25maWcgfSBmcm9tIFwiLi90YWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCB7IFN1YlRhYmxlQ29uZmlnLCBTdWJUYWJsZUNvbENvbmZpZywgU3ViVGFibGVDb2xIZWFkZXJDb25maWcsIFN1YlRhYmxlUm93Q29uZmlnIH0gZnJvbSBcIi4vc3ViLXRhYmxlL3N1Yi10YWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCB7IFRhYmxlRmlsdGVyQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsdGVyL2ZpbHRlci5jb21wb25lbnRcIjtcbmV4cG9ydCB7IEZpbHRlciB9IGZyb20gXCIuL2ZpbHRlci9maWx0ZXIuY29tcG9uZW50XCI7XG5leHBvcnQgeyBBY3Rpb25zQ2VsbENvbXBvbmVudCB9IGZyb20gXCIuL2FjdGlvbnMtY2VsbC9hY3Rpb25zLWNlbGwuY29tcG9uZW50XCI7Il19
|