@proximus/lavender-angular 1.0.0-alpha.3 → 1.0.0-alpha.5
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/index.mjs +3 -2
- package/esm2022/lavender.directive.mjs +34186 -0
- package/esm2022/px-form-accessor.directive.mjs +260 -0
- package/fesm2022/proximus-lavender-angular.mjs +34403 -11
- package/fesm2022/proximus-lavender-angular.mjs.map +1 -1
- package/index.d.ts +2 -1
- package/lavender.directive.d.ts +8176 -0
- package/package.json +4 -1
- package/px-form-accessor.directive.d.ts +62 -0
- package/esm2022/px-select-accessor.directive.mjs +0 -52
- package/px-select-accessor.directive.d.ts +0 -16
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
import { Directive, HostListener, NgModule, forwardRef, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
// ─── Base ────────────────────────────────────────────────────────────────────
|
|
5
|
+
class BaseValueAccessor {
|
|
6
|
+
elementRef;
|
|
7
|
+
onChange = () => { };
|
|
8
|
+
onTouched = () => { };
|
|
9
|
+
constructor(elementRef) {
|
|
10
|
+
this.elementRef = elementRef;
|
|
11
|
+
}
|
|
12
|
+
handleBlur() {
|
|
13
|
+
this.onTouched();
|
|
14
|
+
}
|
|
15
|
+
registerOnChange(fn) {
|
|
16
|
+
this.onChange = fn;
|
|
17
|
+
}
|
|
18
|
+
registerOnTouched(fn) {
|
|
19
|
+
this.onTouched = fn;
|
|
20
|
+
}
|
|
21
|
+
setDisabledState(isDisabled) {
|
|
22
|
+
this.elementRef.nativeElement.disabled = isDisabled;
|
|
23
|
+
}
|
|
24
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BaseValueAccessor, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
25
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: BaseValueAccessor, host: { listeners: { "blur": "handleBlur()" } }, ngImport: i0 });
|
|
26
|
+
}
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BaseValueAccessor, decorators: [{
|
|
28
|
+
type: Directive
|
|
29
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { handleBlur: [{
|
|
30
|
+
type: HostListener,
|
|
31
|
+
args: ['blur']
|
|
32
|
+
}] } });
|
|
33
|
+
// ─── Text-based (value) accessors ────────────────────────────────────────────
|
|
34
|
+
class TextValueAccessor extends BaseValueAccessor {
|
|
35
|
+
handleInput(value) {
|
|
36
|
+
this.onChange(value);
|
|
37
|
+
}
|
|
38
|
+
writeValue(value) {
|
|
39
|
+
this.elementRef.nativeElement.value = value ?? '';
|
|
40
|
+
}
|
|
41
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TextValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
42
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: TextValueAccessor, host: { listeners: { "input": "handleInput($event.target.value)" } }, usesInheritance: true, ngImport: i0 });
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TextValueAccessor, decorators: [{
|
|
45
|
+
type: Directive
|
|
46
|
+
}], propDecorators: { handleInput: [{
|
|
47
|
+
type: HostListener,
|
|
48
|
+
args: ['input', ['$event.target.value']]
|
|
49
|
+
}] } });
|
|
50
|
+
// ─── Boolean-based (checked) accessors ───────────────────────────────────────
|
|
51
|
+
class CheckedValueAccessor extends BaseValueAccessor {
|
|
52
|
+
handleChange(checked) {
|
|
53
|
+
this.onChange(checked);
|
|
54
|
+
}
|
|
55
|
+
writeValue(value) {
|
|
56
|
+
this.elementRef.nativeElement.checked = !!value;
|
|
57
|
+
}
|
|
58
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CheckedValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
59
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CheckedValueAccessor, host: { listeners: { "change": "handleChange($event.target.checked)" } }, usesInheritance: true, ngImport: i0 });
|
|
60
|
+
}
|
|
61
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CheckedValueAccessor, decorators: [{
|
|
62
|
+
type: Directive
|
|
63
|
+
}], propDecorators: { handleChange: [{
|
|
64
|
+
type: HostListener,
|
|
65
|
+
args: ['change', ['$event.target.checked']]
|
|
66
|
+
}] } });
|
|
67
|
+
// ─── px-select ───────────────────────────────────────────────────────────────
|
|
68
|
+
export class PxSelectValueAccessor extends BaseValueAccessor {
|
|
69
|
+
handleInput(value) {
|
|
70
|
+
this.onChange(value);
|
|
71
|
+
}
|
|
72
|
+
writeValue(value) {
|
|
73
|
+
this.elementRef.nativeElement.value = value;
|
|
74
|
+
}
|
|
75
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxSelectValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
76
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PxSelectValueAccessor, isStandalone: true, selector: "px-select[formControlName],px-select[formControl],px-select[ngModel]", host: { listeners: { "change": "handleInput($event.target.value)" } }, providers: [
|
|
77
|
+
{
|
|
78
|
+
provide: NG_VALUE_ACCESSOR,
|
|
79
|
+
useExisting: forwardRef(() => PxSelectValueAccessor),
|
|
80
|
+
multi: true,
|
|
81
|
+
},
|
|
82
|
+
], usesInheritance: true, ngImport: i0 });
|
|
83
|
+
}
|
|
84
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxSelectValueAccessor, decorators: [{
|
|
85
|
+
type: Directive,
|
|
86
|
+
args: [{
|
|
87
|
+
selector: 'px-select[formControlName],px-select[formControl],px-select[ngModel]',
|
|
88
|
+
providers: [
|
|
89
|
+
{
|
|
90
|
+
provide: NG_VALUE_ACCESSOR,
|
|
91
|
+
useExisting: forwardRef(() => PxSelectValueAccessor),
|
|
92
|
+
multi: true,
|
|
93
|
+
},
|
|
94
|
+
],
|
|
95
|
+
standalone: true,
|
|
96
|
+
}]
|
|
97
|
+
}], propDecorators: { handleInput: [{
|
|
98
|
+
type: HostListener,
|
|
99
|
+
args: ['change', ['$event.target.value']]
|
|
100
|
+
}] } });
|
|
101
|
+
// ─── px-input ────────────────────────────────────────────────────────────────
|
|
102
|
+
export class PxInputValueAccessor extends TextValueAccessor {
|
|
103
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxInputValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
104
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PxInputValueAccessor, isStandalone: true, selector: "px-input[formControlName],px-input[formControl],px-input[ngModel]", providers: [
|
|
105
|
+
{
|
|
106
|
+
provide: NG_VALUE_ACCESSOR,
|
|
107
|
+
useExisting: forwardRef(() => PxInputValueAccessor),
|
|
108
|
+
multi: true,
|
|
109
|
+
},
|
|
110
|
+
], usesInheritance: true, ngImport: i0 });
|
|
111
|
+
}
|
|
112
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxInputValueAccessor, decorators: [{
|
|
113
|
+
type: Directive,
|
|
114
|
+
args: [{
|
|
115
|
+
selector: 'px-input[formControlName],px-input[formControl],px-input[ngModel]',
|
|
116
|
+
providers: [
|
|
117
|
+
{
|
|
118
|
+
provide: NG_VALUE_ACCESSOR,
|
|
119
|
+
useExisting: forwardRef(() => PxInputValueAccessor),
|
|
120
|
+
multi: true,
|
|
121
|
+
},
|
|
122
|
+
],
|
|
123
|
+
standalone: true,
|
|
124
|
+
}]
|
|
125
|
+
}] });
|
|
126
|
+
// ─── px-textarea ─────────────────────────────────────────────────────────────
|
|
127
|
+
export class PxTextareaValueAccessor extends TextValueAccessor {
|
|
128
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxTextareaValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
129
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PxTextareaValueAccessor, isStandalone: true, selector: "px-textarea[formControlName],px-textarea[formControl],px-textarea[ngModel]", providers: [
|
|
130
|
+
{
|
|
131
|
+
provide: NG_VALUE_ACCESSOR,
|
|
132
|
+
useExisting: forwardRef(() => PxTextareaValueAccessor),
|
|
133
|
+
multi: true,
|
|
134
|
+
},
|
|
135
|
+
], usesInheritance: true, ngImport: i0 });
|
|
136
|
+
}
|
|
137
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxTextareaValueAccessor, decorators: [{
|
|
138
|
+
type: Directive,
|
|
139
|
+
args: [{
|
|
140
|
+
selector: 'px-textarea[formControlName],px-textarea[formControl],px-textarea[ngModel]',
|
|
141
|
+
providers: [
|
|
142
|
+
{
|
|
143
|
+
provide: NG_VALUE_ACCESSOR,
|
|
144
|
+
useExisting: forwardRef(() => PxTextareaValueAccessor),
|
|
145
|
+
multi: true,
|
|
146
|
+
},
|
|
147
|
+
],
|
|
148
|
+
standalone: true,
|
|
149
|
+
}]
|
|
150
|
+
}] });
|
|
151
|
+
// ─── px-checkbox ─────────────────────────────────────────────────────────────
|
|
152
|
+
export class PxCheckboxValueAccessor extends CheckedValueAccessor {
|
|
153
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxCheckboxValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
154
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PxCheckboxValueAccessor, isStandalone: true, selector: "px-checkbox[formControlName],px-checkbox[formControl],px-checkbox[ngModel]", providers: [
|
|
155
|
+
{
|
|
156
|
+
provide: NG_VALUE_ACCESSOR,
|
|
157
|
+
useExisting: forwardRef(() => PxCheckboxValueAccessor),
|
|
158
|
+
multi: true,
|
|
159
|
+
},
|
|
160
|
+
], usesInheritance: true, ngImport: i0 });
|
|
161
|
+
}
|
|
162
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxCheckboxValueAccessor, decorators: [{
|
|
163
|
+
type: Directive,
|
|
164
|
+
args: [{
|
|
165
|
+
selector: 'px-checkbox[formControlName],px-checkbox[formControl],px-checkbox[ngModel]',
|
|
166
|
+
providers: [
|
|
167
|
+
{
|
|
168
|
+
provide: NG_VALUE_ACCESSOR,
|
|
169
|
+
useExisting: forwardRef(() => PxCheckboxValueAccessor),
|
|
170
|
+
multi: true,
|
|
171
|
+
},
|
|
172
|
+
],
|
|
173
|
+
standalone: true,
|
|
174
|
+
}]
|
|
175
|
+
}] });
|
|
176
|
+
// ─── px-switch ───────────────────────────────────────────────────────────────
|
|
177
|
+
export class PxSwitchValueAccessor extends CheckedValueAccessor {
|
|
178
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxSwitchValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
179
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PxSwitchValueAccessor, isStandalone: true, selector: "px-switch[formControlName],px-switch[formControl],px-switch[ngModel]", providers: [
|
|
180
|
+
{
|
|
181
|
+
provide: NG_VALUE_ACCESSOR,
|
|
182
|
+
useExisting: forwardRef(() => PxSwitchValueAccessor),
|
|
183
|
+
multi: true,
|
|
184
|
+
},
|
|
185
|
+
], usesInheritance: true, ngImport: i0 });
|
|
186
|
+
}
|
|
187
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxSwitchValueAccessor, decorators: [{
|
|
188
|
+
type: Directive,
|
|
189
|
+
args: [{
|
|
190
|
+
selector: 'px-switch[formControlName],px-switch[formControl],px-switch[ngModel]',
|
|
191
|
+
providers: [
|
|
192
|
+
{
|
|
193
|
+
provide: NG_VALUE_ACCESSOR,
|
|
194
|
+
useExisting: forwardRef(() => PxSwitchValueAccessor),
|
|
195
|
+
multi: true,
|
|
196
|
+
},
|
|
197
|
+
],
|
|
198
|
+
standalone: true,
|
|
199
|
+
}]
|
|
200
|
+
}] });
|
|
201
|
+
// ─── px-radio-group ──────────────────────────────────────────────────────────
|
|
202
|
+
export class PxRadioGroupValueAccessor extends BaseValueAccessor {
|
|
203
|
+
handleChange(event) {
|
|
204
|
+
const radio = event.target;
|
|
205
|
+
this.onChange(radio.getAttribute('value'));
|
|
206
|
+
}
|
|
207
|
+
writeValue(value) {
|
|
208
|
+
const radios = this.elementRef.nativeElement.querySelectorAll('px-radio');
|
|
209
|
+
radios.forEach((radio) => {
|
|
210
|
+
radio.checked = radio.getAttribute('value') === value;
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxRadioGroupValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
214
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PxRadioGroupValueAccessor, isStandalone: true, selector: "px-radio-group[formControlName],px-radio-group[formControl],px-radio-group[ngModel]", host: { listeners: { "change": "handleChange($event)" } }, providers: [
|
|
215
|
+
{
|
|
216
|
+
provide: NG_VALUE_ACCESSOR,
|
|
217
|
+
useExisting: forwardRef(() => PxRadioGroupValueAccessor),
|
|
218
|
+
multi: true,
|
|
219
|
+
},
|
|
220
|
+
], usesInheritance: true, ngImport: i0 });
|
|
221
|
+
}
|
|
222
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PxRadioGroupValueAccessor, decorators: [{
|
|
223
|
+
type: Directive,
|
|
224
|
+
args: [{
|
|
225
|
+
selector: 'px-radio-group[formControlName],px-radio-group[formControl],px-radio-group[ngModel]',
|
|
226
|
+
providers: [
|
|
227
|
+
{
|
|
228
|
+
provide: NG_VALUE_ACCESSOR,
|
|
229
|
+
useExisting: forwardRef(() => PxRadioGroupValueAccessor),
|
|
230
|
+
multi: true,
|
|
231
|
+
},
|
|
232
|
+
],
|
|
233
|
+
standalone: true,
|
|
234
|
+
}]
|
|
235
|
+
}], propDecorators: { handleChange: [{
|
|
236
|
+
type: HostListener,
|
|
237
|
+
args: ['change', ['$event']]
|
|
238
|
+
}] } });
|
|
239
|
+
// ─── NgModule ────────────────────────────────────────────────────────────────
|
|
240
|
+
const VALUE_ACCESSORS = [
|
|
241
|
+
PxSelectValueAccessor,
|
|
242
|
+
PxInputValueAccessor,
|
|
243
|
+
PxTextareaValueAccessor,
|
|
244
|
+
PxCheckboxValueAccessor,
|
|
245
|
+
PxSwitchValueAccessor,
|
|
246
|
+
PxRadioGroupValueAccessor,
|
|
247
|
+
];
|
|
248
|
+
export class LavenderValueAccessors {
|
|
249
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LavenderValueAccessors, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
250
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.14", ngImport: i0, type: LavenderValueAccessors, imports: [PxSelectValueAccessor, PxInputValueAccessor, PxTextareaValueAccessor, PxCheckboxValueAccessor, PxSwitchValueAccessor, PxRadioGroupValueAccessor], exports: [PxSelectValueAccessor, PxInputValueAccessor, PxTextareaValueAccessor, PxCheckboxValueAccessor, PxSwitchValueAccessor, PxRadioGroupValueAccessor] });
|
|
251
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LavenderValueAccessors });
|
|
252
|
+
}
|
|
253
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LavenderValueAccessors, decorators: [{
|
|
254
|
+
type: NgModule,
|
|
255
|
+
args: [{
|
|
256
|
+
imports: VALUE_ACCESSORS,
|
|
257
|
+
exports: VALUE_ACCESSORS,
|
|
258
|
+
}]
|
|
259
|
+
}] });
|
|
260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"px-form-accessor.directive.js","sourceRoot":"","sources":["../../../../src/px-form-accessor.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,QAAQ,EACR,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;AAEzE,gFAAgF;AAEhF,MACe,iBAAiB;IAIR;IAHZ,QAAQ,GAAuB,GAAG,EAAE,GAAE,CAAC,CAAC;IACxC,SAAS,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;IAE3C,YAAsB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;IAAG,CAAC;IAGhD,UAAU;QACR,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAID,gBAAgB,CAAC,EAAsB;QACrC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,GAAG,UAAU,CAAC;IACtD,CAAC;wGAvBY,iBAAiB;4FAAjB,iBAAiB;;4FAAjB,iBAAiB;kBAD/B,SAAS;+EAQR,UAAU;sBADT,YAAY;uBAAC,MAAM;;AAoBtB,gFAAgF;AAEhF,MACe,iBAAkB,SAAQ,iBAA0B;IAEjE,WAAW,CAAC,KAAc;QACxB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,UAAU,CAAC,KAAc;QACvB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;IACpD,CAAC;wGARY,iBAAiB;4FAAjB,iBAAiB;;4FAAjB,iBAAiB;kBAD/B,SAAS;8BAGR,WAAW;sBADV,YAAY;uBAAC,OAAO,EAAE,CAAC,qBAAqB,CAAC;;AAUhD,gFAAgF;AAEhF,MACe,oBAAqB,SAAQ,iBAA0B;IAEpE,YAAY,CAAC,OAAgB;QAC3B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACzB,CAAC;IAED,UAAU,CAAC,KAAc;QACvB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,GAAG,CAAC,CAAC,KAAK,CAAC;IAClD,CAAC;wGARY,oBAAoB;4FAApB,oBAAoB;;4FAApB,oBAAoB;kBADlC,SAAS;8BAGR,YAAY;sBADX,YAAY;uBAAC,QAAQ,EAAE,CAAC,uBAAuB,CAAC;;AAUnD,gFAAgF;AAchF,MAAM,OAAO,qBAAsB,SAAQ,iBAAiB;IAE1D,WAAW,CAAC,KAAc;QACxB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,UAAU,CAAC,KAAc;QACvB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,GAAG,KAAK,CAAC;IAC9C,CAAC;wGARU,qBAAqB;4FAArB,qBAAqB,0LATrB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;gBACpD,KAAK,EAAE,IAAI;aACZ;SACF;;4FAGU,qBAAqB;kBAZjC,SAAS;mBAAC;oBACT,QAAQ,EACN,sEAAsE;oBACxE,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;qBACF;oBACD,UAAU,EAAE,IAAI;iBACjB;8BAGC,WAAW;sBADV,YAAY;uBAAC,QAAQ,EAAE,CAAC,qBAAqB,CAAC;;AAUjD,gFAAgF;AAahF,MAAM,OAAO,oBAAqB,SAAQ,iBAAiB;wGAA9C,oBAAoB;4FAApB,oBAAoB,gHATpB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;gBACnD,KAAK,EAAE,IAAI;aACZ;SACF;;4FAGU,oBAAoB;kBAXhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,mEAAmE;oBAC7E,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC;4BACnD,KAAK,EAAE,IAAI;yBACZ;qBACF;oBACD,UAAU,EAAE,IAAI;iBACjB;;AAGD,gFAAgF;AAchF,MAAM,OAAO,uBAAwB,SAAQ,iBAAiB;wGAAjD,uBAAuB;4FAAvB,uBAAuB,yHATvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACZ;SACF;;4FAGU,uBAAuB;kBAZnC,SAAS;mBAAC;oBACT,QAAQ,EACN,4EAA4E;oBAC9E,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACZ;qBACF;oBACD,UAAU,EAAE,IAAI;iBACjB;;AAGD,gFAAgF;AAchF,MAAM,OAAO,uBAAwB,SAAQ,oBAAoB;wGAApD,uBAAuB;4FAAvB,uBAAuB,yHATvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACZ;SACF;;4FAGU,uBAAuB;kBAZnC,SAAS;mBAAC;oBACT,QAAQ,EACN,4EAA4E;oBAC9E,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACZ;qBACF;oBACD,UAAU,EAAE,IAAI;iBACjB;;AAGD,gFAAgF;AAchF,MAAM,OAAO,qBAAsB,SAAQ,oBAAoB;wGAAlD,qBAAqB;4FAArB,qBAAqB,mHATrB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;gBACpD,KAAK,EAAE,IAAI;aACZ;SACF;;4FAGU,qBAAqB;kBAZjC,SAAS;mBAAC;oBACT,QAAQ,EACN,sEAAsE;oBACxE,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;qBACF;oBACD,UAAU,EAAE,IAAI;iBACjB;;AAGD,gFAAgF;AAchF,MAAM,OAAO,yBAA0B,SAAQ,iBAAiB;IAE9D,YAAY,CAAC,KAAY;QACvB,MAAM,KAAK,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,KAAc;QACvB,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;QAC1E,MAAM,CAAC,OAAO,CAAC,CAAC,KAAuB,EAAE,EAAE;YACzC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,KAAK,CAAC;QACxD,CAAC,CAAC,CAAC;IACL,CAAC;wGAZU,yBAAyB;4FAAzB,yBAAyB,6LATzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;gBACxD,KAAK,EAAE,IAAI;aACZ;SACF;;4FAGU,yBAAyB;kBAZrC,SAAS;mBAAC;oBACT,QAAQ,EACN,qFAAqF;oBACvF,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;4BACxD,KAAK,EAAE,IAAI;yBACZ;qBACF;oBACD,UAAU,EAAE,IAAI;iBACjB;8BAGC,YAAY;sBADX,YAAY;uBAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC;;AAcpC,gFAAgF;AAEhF,MAAM,eAAe,GAAG;IACtB,qBAAqB;IACrB,oBAAoB;IACpB,uBAAuB;IACvB,uBAAuB;IACvB,qBAAqB;IACrB,yBAAyB;CAC1B,CAAC;AAMF,MAAM,OAAO,sBAAsB;wGAAtB,sBAAsB;yGAAtB,sBAAsB,YAtHtB,qBAAqB,EAwBrB,oBAAoB,EAgBpB,uBAAuB,EAgBvB,uBAAuB,EAgBvB,qBAAqB,EAgBrB,yBAAyB,aAxFzB,qBAAqB,EAwBrB,oBAAoB,EAgBpB,uBAAuB,EAgBvB,uBAAuB,EAgBvB,qBAAqB,EAgBrB,yBAAyB;yGA8BzB,sBAAsB;;4FAAtB,sBAAsB;kBAJlC,QAAQ;mBAAC;oBACR,OAAO,EAAE,eAAe;oBACxB,OAAO,EAAE,eAAe;iBACzB","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  HostListener,\n  NgModule,\n  forwardRef,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n// ─── Base ────────────────────────────────────────────────────────────────────\n\n@Directive()\nabstract class BaseValueAccessor<T = unknown> implements ControlValueAccessor {\n  protected onChange: (value: T) => void = () => {};\n  protected onTouched: () => void = () => {};\n\n  constructor(protected elementRef: ElementRef) {}\n\n  @HostListener('blur')\n  handleBlur() {\n    this.onTouched();\n  }\n\n  abstract writeValue(value: T): void;\n\n  registerOnChange(fn: (value: T) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.elementRef.nativeElement.disabled = isDisabled;\n  }\n}\n\n// ─── Text-based (value) accessors ────────────────────────────────────────────\n\n@Directive()\nabstract class TextValueAccessor extends BaseValueAccessor<unknown> {\n  @HostListener('input', ['$event.target.value'])\n  handleInput(value: unknown) {\n    this.onChange(value);\n  }\n\n  writeValue(value: unknown): void {\n    this.elementRef.nativeElement.value = value ?? '';\n  }\n}\n\n// ─── Boolean-based (checked) accessors ───────────────────────────────────────\n\n@Directive()\nabstract class CheckedValueAccessor extends BaseValueAccessor<boolean> {\n  @HostListener('change', ['$event.target.checked'])\n  handleChange(checked: boolean) {\n    this.onChange(checked);\n  }\n\n  writeValue(value: boolean): void {\n    this.elementRef.nativeElement.checked = !!value;\n  }\n}\n\n// ─── px-select ───────────────────────────────────────────────────────────────\n\n@Directive({\n  selector:\n    'px-select[formControlName],px-select[formControl],px-select[ngModel]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PxSelectValueAccessor),\n      multi: true,\n    },\n  ],\n  standalone: true,\n})\nexport class PxSelectValueAccessor extends BaseValueAccessor {\n  @HostListener('change', ['$event.target.value'])\n  handleInput(value: unknown) {\n    this.onChange(value);\n  }\n\n  writeValue(value: unknown): void {\n    this.elementRef.nativeElement.value = value;\n  }\n}\n\n// ─── px-input ────────────────────────────────────────────────────────────────\n\n@Directive({\n  selector: 'px-input[formControlName],px-input[formControl],px-input[ngModel]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PxInputValueAccessor),\n      multi: true,\n    },\n  ],\n  standalone: true,\n})\nexport class PxInputValueAccessor extends TextValueAccessor {}\n\n// ─── px-textarea ─────────────────────────────────────────────────────────────\n\n@Directive({\n  selector:\n    'px-textarea[formControlName],px-textarea[formControl],px-textarea[ngModel]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PxTextareaValueAccessor),\n      multi: true,\n    },\n  ],\n  standalone: true,\n})\nexport class PxTextareaValueAccessor extends TextValueAccessor {}\n\n// ─── px-checkbox ─────────────────────────────────────────────────────────────\n\n@Directive({\n  selector:\n    'px-checkbox[formControlName],px-checkbox[formControl],px-checkbox[ngModel]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PxCheckboxValueAccessor),\n      multi: true,\n    },\n  ],\n  standalone: true,\n})\nexport class PxCheckboxValueAccessor extends CheckedValueAccessor {}\n\n// ─── px-switch ───────────────────────────────────────────────────────────────\n\n@Directive({\n  selector:\n    'px-switch[formControlName],px-switch[formControl],px-switch[ngModel]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PxSwitchValueAccessor),\n      multi: true,\n    },\n  ],\n  standalone: true,\n})\nexport class PxSwitchValueAccessor extends CheckedValueAccessor {}\n\n// ─── px-radio-group ──────────────────────────────────────────────────────────\n\n@Directive({\n  selector:\n    'px-radio-group[formControlName],px-radio-group[formControl],px-radio-group[ngModel]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PxRadioGroupValueAccessor),\n      multi: true,\n    },\n  ],\n  standalone: true,\n})\nexport class PxRadioGroupValueAccessor extends BaseValueAccessor {\n  @HostListener('change', ['$event'])\n  handleChange(event: Event) {\n    const radio = event.target as HTMLElement;\n    this.onChange(radio.getAttribute('value'));\n  }\n\n  writeValue(value: unknown): void {\n    const radios = this.elementRef.nativeElement.querySelectorAll('px-radio');\n    radios.forEach((radio: HTMLInputElement) => {\n      radio.checked = radio.getAttribute('value') === value;\n    });\n  }\n}\n\n// ─── NgModule ────────────────────────────────────────────────────────────────\n\nconst VALUE_ACCESSORS = [\n  PxSelectValueAccessor,\n  PxInputValueAccessor,\n  PxTextareaValueAccessor,\n  PxCheckboxValueAccessor,\n  PxSwitchValueAccessor,\n  PxRadioGroupValueAccessor,\n];\n\n@NgModule({\n  imports: VALUE_ACCESSORS,\n  exports: VALUE_ACCESSORS,\n})\nexport class LavenderValueAccessors {}\n"]}
|