mis-crystal-design-system 18.0.16-test-7 → 18.0.17-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/radio-button/radio-button.component.mjs +23 -102
- package/esm2022/table/actions-cell/actions-cell.component.mjs +11 -4
- 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 -3
- 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
|
@@ -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,
|
|
@@ -245,7 +253,6 @@ export class ActionsCellComponent {
|
|
|
245
253
|
}
|
|
246
254
|
onCheckboxChange(event) {
|
|
247
255
|
this.isChecked = event?.value ?? false;
|
|
248
|
-
// Just emit the event with the updated state
|
|
249
256
|
this.actionClick.emit({
|
|
250
257
|
isChecked: this.isChecked,
|
|
251
258
|
data: this.data
|
|
@@ -290,4 +297,4 @@ export class ActionsCellComponent {
|
|
|
290
297
|
args: ["document:click"]
|
|
291
298
|
}] }); })();
|
|
292
299
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ActionsCellComponent, { className: "ActionsCellComponent" }); })();
|
|
293
|
-
//# 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    \n    // Just emit the event with the updated state\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"]}
|
|
@@ -1,126 +1,47 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { EventEmitter,
|
|
2
|
+
import { EventEmitter, Component, Input, Output, NgModule } from '@angular/core';
|
|
3
3
|
import * as i1 from '@angular/forms';
|
|
4
|
-
import {
|
|
4
|
+
import { UntypedFormControl, ReactiveFormsModule } from '@angular/forms';
|
|
5
5
|
import { CommonModule } from '@angular/common';
|
|
6
6
|
|
|
7
7
|
class RadioButtonComponent {
|
|
8
|
-
set disabled(value) {
|
|
9
|
-
if (this._disabled !== value) {
|
|
10
|
-
this._disabled = value;
|
|
11
|
-
if (this._formControl && this._formControl.disabled !== value) {
|
|
12
|
-
if (value) {
|
|
13
|
-
this._formControl.disable({ emitEvent: false });
|
|
14
|
-
}
|
|
15
|
-
else {
|
|
16
|
-
this._formControl.enable({ emitEvent: false });
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
get disabled() {
|
|
22
|
-
return this._formControl ? this._formControl.disabled : this._disabled;
|
|
23
|
-
}
|
|
24
|
-
set formControl(control) {
|
|
25
|
-
if (control instanceof AbstractControl) {
|
|
26
|
-
this._formControl = control;
|
|
27
|
-
if (control.value !== null && control.value !== undefined) {
|
|
28
|
-
this._value = control.value;
|
|
29
|
-
}
|
|
30
|
-
if (this._disabled !== undefined && this._disabled !== control.disabled) {
|
|
31
|
-
if (this._disabled) {
|
|
32
|
-
control.disable({ emitEvent: false });
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
control.enable({ emitEvent: false });
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
this._formControl = new UntypedFormControl(control);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
get formControl() {
|
|
44
|
-
return this._formControl;
|
|
45
|
-
}
|
|
46
8
|
constructor() {
|
|
9
|
+
/** When multiple radio input fields are used
|
|
10
|
+
* an "id" can be given to keep track of them */
|
|
47
11
|
this.id = "";
|
|
12
|
+
/** Name of the attribute for which the radio
|
|
13
|
+
* selection is provided */
|
|
48
14
|
this.name = "";
|
|
15
|
+
/** Value of the attribute which is to be emitted
|
|
16
|
+
* when selected */
|
|
49
17
|
this.value = "";
|
|
50
|
-
|
|
18
|
+
/** Controls the state of the radio button */
|
|
19
|
+
this.disabled = false;
|
|
20
|
+
/** Can be used to attach the radio input field
|
|
21
|
+
* to a reactive form by passing in a
|
|
22
|
+
* “FormControl“ Object. It can also be
|
|
23
|
+
* used to set the default attribute value */
|
|
24
|
+
this.formControl = new UntypedFormControl(null);
|
|
25
|
+
/** Emits "value" of the radio button on selection */
|
|
51
26
|
this.valueChange = new EventEmitter();
|
|
52
|
-
// ControlValueAccessor properties
|
|
53
|
-
this._value = null;
|
|
54
|
-
this._disabled = false;
|
|
55
|
-
this.onChange = (value) => { };
|
|
56
|
-
this.onTouched = () => { };
|
|
57
27
|
}
|
|
58
28
|
ngOnInit() { }
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
if (this._value !== value) {
|
|
62
|
-
this._value = value;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
registerOnChange(fn) {
|
|
66
|
-
this.onChange = fn;
|
|
67
|
-
}
|
|
68
|
-
registerOnTouched(fn) {
|
|
69
|
-
this.onTouched = fn;
|
|
70
|
-
}
|
|
71
|
-
setDisabledState(isDisabled) {
|
|
72
|
-
if (this._disabled !== isDisabled) {
|
|
73
|
-
this._disabled = isDisabled;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
// Legacy onChange method - maintains backward compatibility
|
|
77
|
-
onInputChange(event) {
|
|
78
|
-
const newValue = event.target.checked ? this.value : this._value;
|
|
79
|
-
if (this._value !== newValue) {
|
|
80
|
-
this._value = newValue;
|
|
81
|
-
this.onChange(newValue);
|
|
82
|
-
this.onTouched();
|
|
83
|
-
if (this._formControl && this._formControl.value !== newValue) {
|
|
84
|
-
this._formControl.setValue(newValue, { emitEvent: false });
|
|
85
|
-
}
|
|
86
|
-
this.valueChange.emit(newValue);
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
get currentValue() {
|
|
90
|
-
return this._formControl ? this._formControl.value : this._value;
|
|
91
|
-
}
|
|
92
|
-
markAsTouched() {
|
|
93
|
-
this.onTouched();
|
|
94
|
-
if (this._formControl) {
|
|
95
|
-
this._formControl.markAsTouched();
|
|
96
|
-
this._formControl.updateValueAndValidity();
|
|
97
|
-
}
|
|
29
|
+
onChange(event) {
|
|
30
|
+
this.valueChange.emit(this.formControl.value);
|
|
98
31
|
}
|
|
99
32
|
static { this.ɵfac = function RadioButtonComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RadioButtonComponent)(); }; }
|
|
100
|
-
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" },
|
|
101
|
-
{
|
|
102
|
-
provide: NG_VALUE_ACCESSOR,
|
|
103
|
-
useExisting: forwardRef(() => RadioButtonComponent),
|
|
104
|
-
multi: true
|
|
105
|
-
}
|
|
106
|
-
])], 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) {
|
|
33
|
+
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) {
|
|
107
34
|
i0.ɵɵelementStart(0, "input", 0);
|
|
108
|
-
i0.ɵɵlistener("change", function RadioButtonComponent_Template_input_change_0_listener($event) { return ctx.
|
|
35
|
+
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); });
|
|
109
36
|
i0.ɵɵelementEnd();
|
|
110
37
|
} if (rf & 2) {
|
|
111
38
|
i0.ɵɵpropertyInterpolate("id", ctx.id);
|
|
112
|
-
i0.ɵɵproperty("name", ctx.name)("
|
|
39
|
+
i0.ɵɵproperty("name", ctx.name)("disabled", ctx.disabled)("value", ctx.value)("formControl", ctx.formControl);
|
|
113
40
|
} }, 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}"] }); }
|
|
114
41
|
}
|
|
115
42
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RadioButtonComponent, [{
|
|
116
43
|
type: Component,
|
|
117
|
-
args: [{ selector: "mis-radio",
|
|
118
|
-
{
|
|
119
|
-
provide: NG_VALUE_ACCESSOR,
|
|
120
|
-
useExisting: forwardRef(() => RadioButtonComponent),
|
|
121
|
-
multi: true
|
|
122
|
-
}
|
|
123
|
-
], 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"] }]
|
|
44
|
+
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"] }]
|
|
124
45
|
}], () => [], { id: [{
|
|
125
46
|
type: Input
|
|
126
47
|
}], name: [{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mis-crystal-design-system-radio-button.mjs","sources":["../../../projects/mis-components/radio-button/radio-button.component.ts","../../../projects/mis-components/radio-button/radio-button.component.html","../../../projects/mis-components/radio-button/radio-button.module.ts","../../../projects/mis-components/radio-button/mis-crystal-design-system-radio-button.ts"],"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/>","import { NgModule, ModuleWithProviders } from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\n\nimport { RadioButtonComponent } from \"./radio-button.component\";\nimport { ReactiveFormsModule } from \"@angular/forms\";\n\n@NgModule({\n declarations: [RadioButtonComponent],\n imports: [CommonModule, ReactiveFormsModule],\n exports: [RadioButtonComponent]\n})\nexport class RadioButtonModule {\n static forRoot(): ModuleWithProviders<RadioButtonModule> {\n return { ngModule: RadioButtonModule, providers: [] };\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"mis-crystal-design-system-radio-button.mjs","sources":["../../../projects/mis-components/radio-button/radio-button.component.ts","../../../projects/mis-components/radio-button/radio-button.component.html","../../../projects/mis-components/radio-button/radio-button.module.ts","../../../projects/mis-components/radio-button/mis-crystal-design-system-radio-button.ts"],"sourcesContent":["import { Component, Input, OnInit, Output, EventEmitter } from \"@angular/core\";\nimport { AbstractControl, UntypedFormControl } from \"@angular/forms\";\n\n@Component({\n selector: \"mis-radio\",\n templateUrl: \"./radio-button.component.html\",\n styleUrls: [\"./radio-button.component.scss\"]\n})\nexport class RadioButtonComponent implements OnInit {\n /** When multiple radio input fields are used\n * an \"id\" can be given to keep track of them */\n @Input() id: string | number = \"\";\n /** Name of the attribute for which the radio\n * selection is provided */\n @Input() name: string | number = \"\";\n /** Value of the attribute which is to be emitted\n * when selected */\n @Input() value: string | number = \"\";\n /** Controls the state of the radio button */\n @Input() disabled: boolean = false;\n\n /** Can be used to attach the radio input field\n * to a reactive form by passing in a\n * “FormControl“ Object. It can also be\n * used to set the default attribute value */\n @Input() formControl: AbstractControl = new UntypedFormControl(null);\n\n /** Emits \"value\" of the radio button on selection */\n @Output() valueChange = new EventEmitter<any>();\n\n constructor() {}\n ngOnInit() {}\n onChange(event) {\n this.valueChange.emit(this.formControl.value);\n }\n}\n","<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","import { NgModule, ModuleWithProviders } from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\n\nimport { RadioButtonComponent } from \"./radio-button.component\";\nimport { ReactiveFormsModule } from \"@angular/forms\";\n\n@NgModule({\n declarations: [RadioButtonComponent],\n imports: [CommonModule, ReactiveFormsModule],\n exports: [RadioButtonComponent]\n})\nexport class RadioButtonModule {\n static forRoot(): ModuleWithProviders<RadioButtonModule> {\n return { ngModule: RadioButtonModule, providers: [] };\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -1360,8 +1360,16 @@ class ActionsCellComponent {
|
|
|
1360
1360
|
this.containerStyle = {};
|
|
1361
1361
|
}
|
|
1362
1362
|
set rowData(value) {
|
|
1363
|
-
this.
|
|
1364
|
-
|
|
1363
|
+
if (this.actionType === 'checkbox') {
|
|
1364
|
+
// For checkbox, keep the rowData structure
|
|
1365
|
+
this.data = value?.rowData ?? {};
|
|
1366
|
+
this.isChecked = value?.isChecked ?? false;
|
|
1367
|
+
}
|
|
1368
|
+
else {
|
|
1369
|
+
// For other actions (dropdown, inline), use the value directly
|
|
1370
|
+
this.data = value;
|
|
1371
|
+
this.isChecked = false;
|
|
1372
|
+
}
|
|
1365
1373
|
}
|
|
1366
1374
|
set config(config) {
|
|
1367
1375
|
this.actionItems = config?.actionItems,
|
|
@@ -1431,7 +1439,6 @@ class ActionsCellComponent {
|
|
|
1431
1439
|
}
|
|
1432
1440
|
onCheckboxChange(event) {
|
|
1433
1441
|
this.isChecked = event?.value ?? false;
|
|
1434
|
-
// Just emit the event with the updated state
|
|
1435
1442
|
this.actionClick.emit({
|
|
1436
1443
|
isChecked: this.isChecked,
|
|
1437
1444
|
data: this.data
|