@energinet/watt 4.0.6 → 4.0.7

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.
@@ -16,8 +16,8 @@
16
16
  * limitations under the License.
17
17
  */
18
18
  //#endregion
19
- import { Component, Input, ViewEncapsulation, HostBinding, ElementRef, ViewChild, forwardRef, inject, EventEmitter, Output, } from '@angular/core';
20
- import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule, } from '@angular/forms';
19
+ import { Component, ViewEncapsulation, ElementRef, forwardRef, inject, input, output, viewChild, signal, linkedSignal, } from '@angular/core';
20
+ import { NG_VALUE_ACCESSOR, ReactiveFormsModule, } from '@angular/forms';
21
21
  import { MatAutocomplete, MatAutocompleteModule } from '@angular/material/autocomplete';
22
22
  import { WattFieldComponent } from '@energinet/watt/field';
23
23
  import { WattIconComponent } from '@energinet/watt/icon';
@@ -25,37 +25,37 @@ import * as i0 from "@angular/core";
25
25
  import * as i1 from "@angular/material/autocomplete";
26
26
  import * as i2 from "@angular/forms";
27
27
  export class WattTextFieldComponent {
28
- value;
29
- type = 'text';
30
- placeholder;
31
- label = '';
32
- tooltip;
33
- prefix;
34
- maxLength = null;
35
- formControl;
36
- autocompleteOptions;
37
- autocompleteMatcherFn;
28
+ value = input('', ...(ngDevMode ? [{ debugName: "value" }] : []));
29
+ type = input('text', ...(ngDevMode ? [{ debugName: "type" }] : []));
30
+ placeholder = input('', ...(ngDevMode ? [{ debugName: "placeholder" }] : []));
31
+ label = input('', ...(ngDevMode ? [{ debugName: "label" }] : []));
32
+ tooltip = input('', ...(ngDevMode ? [{ debugName: "tooltip" }] : []));
33
+ prefix = input(...(ngDevMode ? [undefined, { debugName: "prefix" }] : []));
34
+ maxLength = input(null, ...(ngDevMode ? [{ debugName: "maxLength" }] : []));
35
+ formControl = input.required(...(ngDevMode ? [{ debugName: "formControl" }] : []));
36
+ autocompleteOptions = input([], ...(ngDevMode ? [{ debugName: "autocompleteOptions" }] : []));
37
+ autocompleteMatcherFn = input(...(ngDevMode ? [undefined, { debugName: "autocompleteMatcherFn" }] : []));
38
38
  /** @ignore */
39
- autocompleteRef;
39
+ autocompleteRef = viewChild.required(MatAutocomplete);
40
40
  /**
41
41
  * Emits the value of the input field when it changes.
42
42
  */
43
- searchChanged = new EventEmitter();
43
+ searchChanged = output();
44
44
  /**
45
45
  * Emits the value of the input field when an autocomplete option is selected.
46
46
  */
47
- autocompleteOptionSelected = new EventEmitter();
47
+ autocompleteOptionSelected = output();
48
48
  /**
49
49
  * Emits the value of the input field when an autocomplete option is selected.
50
50
  */
51
- autocompleteOptionDeselected = new EventEmitter();
51
+ autocompleteOptionDeselected = output();
52
52
  /** @ignore */
53
53
  element = inject(ElementRef);
54
54
  /** @ignore */
55
- inputField;
56
- model;
55
+ inputField = viewChild.required('inputField');
56
+ model = linkedSignal(this.value);
57
57
  /** @ignore */
58
- isDisabled = false;
58
+ isDisabled = signal(false, ...(ngDevMode ? [{ debugName: "isDisabled" }] : []));
59
59
  /** @ignore */
60
60
  onTouchedCallbacks = [];
61
61
  /** @ignore */
@@ -63,32 +63,29 @@ export class WattTextFieldComponent {
63
63
  const attrName = 'data-testid';
64
64
  const testIdAttribute = this.element.nativeElement.getAttribute(attrName);
65
65
  this.element.nativeElement.removeAttribute(attrName);
66
- this.inputField.nativeElement.setAttribute(attrName, testIdAttribute);
66
+ this.inputField().nativeElement.setAttribute(attrName, testIdAttribute);
67
67
  this.registerOnTouched(() => {
68
- const trimmedValue = this.inputField.nativeElement.value.trim();
69
- this.inputField.nativeElement.value = trimmedValue;
70
- this.formControl.setValue(trimmedValue);
68
+ const trimmedValue = this.inputField().nativeElement.value.trim();
69
+ this.inputField().nativeElement.value = trimmedValue;
70
+ this.formControl().setValue(trimmedValue);
71
71
  });
72
72
  }
73
73
  /** @ignore */
74
74
  onChanged(event) {
75
75
  const value = event.target.value;
76
- if (this.autocompleteRef) {
77
- // Reset the autocomplete selection if the value is not matching anymore, and auto-select if the value has a match
78
- this.autocompleteRef.options.forEach((option) => {
79
- const isMatchingOption = this.autocompleteMatcherFn
80
- ? this.autocompleteMatcherFn(value, option.value)
81
- : option.value === value;
82
- if (isMatchingOption) {
83
- option.select(false);
84
- this.autocompleteOptionSelected.emit(option.value);
85
- }
86
- else {
87
- option.deselect(false);
88
- this.autocompleteOptionDeselected.emit();
89
- }
90
- });
91
- }
76
+ // Reset the autocomplete selection if the value is not matching anymore, and auto-select if the value has a match
77
+ this.autocompleteRef().options.forEach((option) => {
78
+ const matcherFn = this.autocompleteMatcherFn();
79
+ const isMatchingOption = matcherFn ? matcherFn(value, option.value) : option.value === value;
80
+ if (isMatchingOption) {
81
+ option.select(false);
82
+ this.autocompleteOptionSelected.emit(option.value);
83
+ }
84
+ else {
85
+ option.deselect(false);
86
+ this.autocompleteOptionDeselected.emit();
87
+ }
88
+ });
92
89
  this.searchChanged.emit(value);
93
90
  this.onChange(value);
94
91
  }
@@ -104,7 +101,7 @@ export class WattTextFieldComponent {
104
101
  };
105
102
  /** @ignore */
106
103
  writeValue(value) {
107
- this.model = value;
104
+ this.model.set(value);
108
105
  }
109
106
  /** @ignore */
110
107
  registerOnChange(fn) {
@@ -116,53 +113,45 @@ export class WattTextFieldComponent {
116
113
  }
117
114
  /** @ignore */
118
115
  setDisabledState(isDisabled) {
119
- this.isDisabled = isDisabled;
116
+ this.isDisabled.set(isDisabled);
120
117
  }
121
118
  /** @ignore */
122
119
  setFocus() {
123
- this.inputField.nativeElement.focus();
120
+ const inputField = this.inputField();
121
+ if (inputField) {
122
+ inputField.nativeElement.focus();
123
+ }
124
124
  }
125
125
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattTextFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
126
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattTextFieldComponent, isStandalone: true, selector: "watt-text-field", inputs: { value: "value", type: "type", placeholder: "placeholder", label: "label", tooltip: "tooltip", prefix: "prefix", maxLength: "maxLength", formControl: "formControl", autocompleteOptions: "autocompleteOptions", autocompleteMatcherFn: "autocompleteMatcherFn" }, outputs: { searchChanged: "searchChanged", autocompleteOptionSelected: "autocompleteOptionSelected", autocompleteOptionDeselected: "autocompleteOptionDeselected" }, host: { properties: { "attr.watt-field-disabled": "this.isDisabled" } }, providers: [
126
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattTextFieldComponent, isStandalone: true, selector: "watt-text-field", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, tooltip: { classPropertyName: "tooltip", publicName: "tooltip", isSignal: true, isRequired: false, transformFunction: null }, prefix: { classPropertyName: "prefix", publicName: "prefix", isSignal: true, isRequired: false, transformFunction: null }, maxLength: { classPropertyName: "maxLength", publicName: "maxLength", isSignal: true, isRequired: false, transformFunction: null }, formControl: { classPropertyName: "formControl", publicName: "formControl", isSignal: true, isRequired: true, transformFunction: null }, autocompleteOptions: { classPropertyName: "autocompleteOptions", publicName: "autocompleteOptions", isSignal: true, isRequired: false, transformFunction: null }, autocompleteMatcherFn: { classPropertyName: "autocompleteMatcherFn", publicName: "autocompleteMatcherFn", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { searchChanged: "searchChanged", autocompleteOptionSelected: "autocompleteOptionSelected", autocompleteOptionDeselected: "autocompleteOptionDeselected" }, host: { properties: { "attr.watt-field-disabled": "isDisabled()" } }, providers: [
127
127
  {
128
128
  provide: NG_VALUE_ACCESSOR,
129
129
  useExisting: forwardRef(() => WattTextFieldComponent),
130
130
  multi: true,
131
131
  },
132
- ], viewQueries: [{ propertyName: "autocompleteRef", first: true, predicate: MatAutocomplete, descendants: true }, { propertyName: "inputField", first: true, predicate: ["inputField"], descendants: true }], ngImport: i0, template: `<watt-field
133
- #wattField
134
- [control]="formControl"
135
- [label]="label"
136
- [tooltip]="tooltip"
137
- matAutocompleteOrigin
138
- >
139
- @if (prefix) {
140
- <watt-icon [name]="prefix" />
141
- }
132
+ ], viewQueries: [{ propertyName: "autocompleteRef", first: true, predicate: MatAutocomplete, descendants: true, isSignal: true }, { propertyName: "inputField", first: true, predicate: ["inputField"], descendants: true, isSignal: true }], ngImport: i0, template: `
133
+ <watt-field
134
+ #wattField
135
+ [control]="formControl()"
136
+ [label]="label()"
137
+ [tooltip]="tooltip()"
138
+ matAutocompleteOrigin
139
+ >
140
+ @if (prefix()) {
141
+ <watt-icon [name]="prefix()" />
142
+ }
142
143
 
143
- @if (!autocompleteOptions) {
144
- <input
145
- [attr.aria-label]="label"
146
- [attr.type]="type"
147
- [attr.placeholder]="placeholder"
148
- [value]="value"
149
- [formControl]="formControl"
150
- (blur)="onTouched()"
151
- (input)="onChanged($event)"
152
- [maxlength]="maxLength"
153
- #inputField
154
- />
155
- } @else {
156
144
  <input
157
- [attr.aria-label]="label"
158
- [attr.type]="type"
159
- [attr.placeholder]="placeholder"
160
- [value]="value"
161
- [formControl]="formControl"
145
+ [attr.aria-label]="label()"
146
+ [attr.type]="type()"
147
+ [attr.placeholder]="placeholder()"
148
+ [value]="model()"
149
+ [formControl]="formControl()"
162
150
  (blur)="onTouched()"
163
151
  (input)="onChanged($event)"
164
- [maxlength]="maxLength"
152
+ [maxlength]="maxLength()"
165
153
  [matAutocomplete]="auto"
154
+ [matAutocompleteDisabled]="!autocompleteOptions()"
166
155
  [matAutocompleteConnectedTo]="{ elementRef: wattField.wrapper() ?? wattField.elementRef }"
167
156
  #inputField
168
157
  />
@@ -172,62 +161,53 @@ export class WattTextFieldComponent {
172
161
  class="watt-autocomplete-panel"
173
162
  (optionSelected)="autocompleteOptionSelected.emit($event.option.value)"
174
163
  >
175
- @for (option of autocompleteOptions; track option) {
164
+ @for (option of autocompleteOptions(); track option) {
176
165
  <mat-option [value]="option">
177
166
  {{ option }}
178
167
  </mat-option>
179
168
  }
180
169
  </mat-autocomplete>
181
- }
182
170
 
183
- <ng-content />
184
- <ng-content ngProjectAs="watt-field-descriptor" select=".descriptor" />
185
- <ng-content ngProjectAs="watt-field-hint" select="watt-field-hint" />
186
- <ng-content ngProjectAs="watt-field-error" select="watt-field-error" />
187
- </watt-field>`, isInline: true, styles: ["watt-text-field{display:block;width:100%}watt-text-field input{border:none;width:100%;outline:none;background-color:transparent}watt-text-field input::placeholder{color:var(--watt-on-light-low-emphasis)}\n"], dependencies: [{ kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i1.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i1.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i1.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i1.MatAutocompleteOrigin, selector: "[matAutocompleteOrigin]", exportAs: ["matAutocompleteOrigin"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattIconComponent, selector: "watt-icon", inputs: ["name", "label", "size", "state"] }], encapsulation: i0.ViewEncapsulation.None });
171
+ <ng-content />
172
+ <ng-content ngProjectAs="watt-field-descriptor" select=".descriptor" />
173
+ <ng-content ngProjectAs="watt-field-hint" select="watt-field-hint" />
174
+ <ng-content ngProjectAs="watt-field-error" select="watt-field-error" />
175
+ </watt-field>
176
+ `, isInline: true, styles: ["watt-text-field{display:block;width:100%}watt-text-field input{border:none;width:100%;outline:none;background-color:transparent}watt-text-field input::placeholder{color:var(--watt-on-light-low-emphasis)}\n"], dependencies: [{ kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i1.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i1.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i1.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i1.MatAutocompleteOrigin, selector: "[matAutocompleteOrigin]", exportAs: ["matAutocompleteOrigin"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattIconComponent, selector: "watt-icon", inputs: ["name", "label", "size", "state"] }], encapsulation: i0.ViewEncapsulation.None });
188
177
  }
189
178
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattTextFieldComponent, decorators: [{
190
179
  type: Component,
191
- args: [{ imports: [MatAutocompleteModule, ReactiveFormsModule, WattFieldComponent, WattIconComponent], selector: 'watt-text-field', encapsulation: ViewEncapsulation.None, providers: [
180
+ args: [{ imports: [MatAutocompleteModule, ReactiveFormsModule, WattFieldComponent, WattIconComponent], selector: 'watt-text-field', encapsulation: ViewEncapsulation.None, host: {
181
+ '[attr.watt-field-disabled]': 'isDisabled()',
182
+ }, providers: [
192
183
  {
193
184
  provide: NG_VALUE_ACCESSOR,
194
185
  useExisting: forwardRef(() => WattTextFieldComponent),
195
186
  multi: true,
196
187
  },
197
- ], template: `<watt-field
198
- #wattField
199
- [control]="formControl"
200
- [label]="label"
201
- [tooltip]="tooltip"
202
- matAutocompleteOrigin
203
- >
204
- @if (prefix) {
205
- <watt-icon [name]="prefix" />
206
- }
188
+ ], template: `
189
+ <watt-field
190
+ #wattField
191
+ [control]="formControl()"
192
+ [label]="label()"
193
+ [tooltip]="tooltip()"
194
+ matAutocompleteOrigin
195
+ >
196
+ @if (prefix()) {
197
+ <watt-icon [name]="prefix()" />
198
+ }
207
199
 
208
- @if (!autocompleteOptions) {
209
- <input
210
- [attr.aria-label]="label"
211
- [attr.type]="type"
212
- [attr.placeholder]="placeholder"
213
- [value]="value"
214
- [formControl]="formControl"
215
- (blur)="onTouched()"
216
- (input)="onChanged($event)"
217
- [maxlength]="maxLength"
218
- #inputField
219
- />
220
- } @else {
221
200
  <input
222
- [attr.aria-label]="label"
223
- [attr.type]="type"
224
- [attr.placeholder]="placeholder"
225
- [value]="value"
226
- [formControl]="formControl"
201
+ [attr.aria-label]="label()"
202
+ [attr.type]="type()"
203
+ [attr.placeholder]="placeholder()"
204
+ [value]="model()"
205
+ [formControl]="formControl()"
227
206
  (blur)="onTouched()"
228
207
  (input)="onChanged($event)"
229
- [maxlength]="maxLength"
208
+ [maxlength]="maxLength()"
230
209
  [matAutocomplete]="auto"
210
+ [matAutocompleteDisabled]="!autocompleteOptions()"
231
211
  [matAutocompleteConnectedTo]="{ elementRef: wattField.wrapper() ?? wattField.elementRef }"
232
212
  #inputField
233
213
  />
@@ -237,53 +217,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
237
217
  class="watt-autocomplete-panel"
238
218
  (optionSelected)="autocompleteOptionSelected.emit($event.option.value)"
239
219
  >
240
- @for (option of autocompleteOptions; track option) {
220
+ @for (option of autocompleteOptions(); track option) {
241
221
  <mat-option [value]="option">
242
222
  {{ option }}
243
223
  </mat-option>
244
224
  }
245
225
  </mat-autocomplete>
246
- }
247
226
 
248
- <ng-content />
249
- <ng-content ngProjectAs="watt-field-descriptor" select=".descriptor" />
250
- <ng-content ngProjectAs="watt-field-hint" select="watt-field-hint" />
251
- <ng-content ngProjectAs="watt-field-error" select="watt-field-error" />
252
- </watt-field>`, styles: ["watt-text-field{display:block;width:100%}watt-text-field input{border:none;width:100%;outline:none;background-color:transparent}watt-text-field input::placeholder{color:var(--watt-on-light-low-emphasis)}\n"] }]
253
- }], propDecorators: { value: [{
254
- type: Input
255
- }], type: [{
256
- type: Input
257
- }], placeholder: [{
258
- type: Input
259
- }], label: [{
260
- type: Input
261
- }], tooltip: [{
262
- type: Input
263
- }], prefix: [{
264
- type: Input
265
- }], maxLength: [{
266
- type: Input
267
- }], formControl: [{
268
- type: Input
269
- }], autocompleteOptions: [{
270
- type: Input
271
- }], autocompleteMatcherFn: [{
272
- type: Input
273
- }], autocompleteRef: [{
274
- type: ViewChild,
275
- args: [MatAutocomplete]
276
- }], searchChanged: [{
277
- type: Output
278
- }], autocompleteOptionSelected: [{
279
- type: Output
280
- }], autocompleteOptionDeselected: [{
281
- type: Output
282
- }], inputField: [{
283
- type: ViewChild,
284
- args: ['inputField']
285
- }], isDisabled: [{
286
- type: HostBinding,
287
- args: ['attr.watt-field-disabled']
288
- }] } });
289
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-text-field.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/text-field/watt-text-field.component.ts"],"names":[],"mappings":"AAAA,iBAAiB;AACjB;;;;;;;;;;;;;;;GAeG;AACH,YAAY;AACZ,OAAO,EACL,SAAS,EACT,KAAK,EACL,iBAAiB,EACjB,WAAW,EACX,UAAU,EACV,SAAS,EACT,UAAU,EAEV,MAAM,EACN,YAAY,EACZ,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,WAAW,EACX,iBAAiB,EACjB,mBAAmB,GACpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AAExF,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAY,MAAM,sBAAsB,CAAC;;;;AAyEnE,MAAM,OAAO,sBAAsB;IACxB,KAAK,CAAU;IACf,IAAI,GAAmB,MAAM,CAAC;IAC9B,WAAW,CAAU;IACrB,KAAK,GAAG,EAAE,CAAC;IACX,OAAO,CAAU;IACjB,MAAM,CAAY;IAClB,SAAS,GAA2B,IAAI,CAAC;IACzC,WAAW,CAAe;IAC1B,mBAAmB,CAAY;IAC/B,qBAAqB,CAA8C;IAE5E,cAAc;IACc,eAAe,CAAmB;IAE9D;;OAEG;IACO,aAAa,GAAG,IAAI,YAAY,EAAU,CAAC;IAErD;;OAEG;IACO,0BAA0B,GAAG,IAAI,YAAY,EAAU,CAAC;IAElE;;OAEG;IACO,4BAA4B,GAAG,IAAI,YAAY,EAAQ,CAAC;IAElE,cAAc;IACN,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAErC,cAAc;IACW,UAAU,CAAgC;IACnE,KAAK,CAAU;IAEf,cAAc;IAEd,UAAU,GAAG,KAAK,CAAC;IAEnB,cAAc;IACd,kBAAkB,GAAmB,EAAE,CAAC;IAExC,cAAc;IACd,eAAe;QACb,MAAM,QAAQ,GAAG,aAAa,CAAC;QAC/B,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC1E,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;QACtE,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC1B,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAChE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,GAAG,YAAY,CAAC;YACnD,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc;IACd,SAAS,CAAC,KAAY;QACpB,MAAM,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QAEvD,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,kHAAkH;YAClH,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC9C,MAAM,gBAAgB,GAAG,IAAI,CAAC,qBAAqB;oBACjD,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC;oBACjD,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,KAAK,CAAC;gBAE3B,IAAI,gBAAgB,EAAE,CAAC;oBACrB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBACrB,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACrD,CAAC;qBAAM,CAAC;oBACN,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACvB,IAAI,CAAC,4BAA4B,CAAC,IAAI,EAAE,CAAC;gBAC3C,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,cAAc;IACd,QAAQ,GAA4B,GAAG,EAAE;QACvC,mBAAmB;IACrB,CAAC,CAAC;IAEF,cAAc;IACd,SAAS,GAAe,GAAG,EAAE;QAC3B,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC/C,QAAQ,EAAE,CAAC;QACb,CAAC;IACH,CAAC,CAAC;IAEF,cAAc;IACd,UAAU,CAAC,KAAa;QACtB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,cAAc;IACd,gBAAgB,CAAC,EAA2B;QAC1C,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,cAAc;IACd,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACnC,CAAC;IAED,cAAc;IACd,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED,cAAc;IACd,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACxC,CAAC;uGArHU,sBAAsB;2FAAtB,sBAAsB,wjBAhEtB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACZ;SACF,2EAuEU,eAAe,2IAtEhB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAuDI,sRAlEJ,qBAAqB,y9BAAE,mBAAmB,6uBAAE,kBAAkB,+IAAE,iBAAiB;;2FAoEhF,sBAAsB;kBArElC,SAAS;8BACC,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,iBAAiB,CAAC,YAClF,iBAAiB,iBAEZ,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ;qBACF,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAuDI;8BAGL,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBAGsB,eAAe;sBAA1C,SAAS;uBAAC,eAAe;gBAKhB,aAAa;sBAAtB,MAAM;gBAKG,0BAA0B;sBAAnC,MAAM;gBAKG,4BAA4B;sBAArC,MAAM;gBAMkB,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBAKvB,UAAU;sBADT,WAAW;uBAAC,0BAA0B","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport {\n  Component,\n  Input,\n  ViewEncapsulation,\n  HostBinding,\n  ElementRef,\n  ViewChild,\n  forwardRef,\n  AfterViewInit,\n  inject,\n  EventEmitter,\n  Output,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormControl,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteModule } from '@angular/material/autocomplete';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattIconComponent, WattIcon } from '@energinet/watt/icon';\n\nexport type WattInputTypes = 'text' | 'password' | 'email' | 'number' | 'tel' | 'url';\n\n@Component({\n  imports: [MatAutocompleteModule, ReactiveFormsModule, WattFieldComponent, WattIconComponent],\n  selector: 'watt-text-field',\n  styleUrls: ['./watt-text-field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattTextFieldComponent),\n      multi: true,\n    },\n  ],\n  template: `<watt-field\n    #wattField\n    [control]=\"formControl\"\n    [label]=\"label\"\n    [tooltip]=\"tooltip\"\n    matAutocompleteOrigin\n  >\n    @if (prefix) {\n      <watt-icon [name]=\"prefix\" />\n    }\n\n    @if (!autocompleteOptions) {\n      <input\n        [attr.aria-label]=\"label\"\n        [attr.type]=\"type\"\n        [attr.placeholder]=\"placeholder\"\n        [value]=\"value\"\n        [formControl]=\"formControl\"\n        (blur)=\"onTouched()\"\n        (input)=\"onChanged($event)\"\n        [maxlength]=\"maxLength\"\n        #inputField\n      />\n    } @else {\n      <input\n        [attr.aria-label]=\"label\"\n        [attr.type]=\"type\"\n        [attr.placeholder]=\"placeholder\"\n        [value]=\"value\"\n        [formControl]=\"formControl\"\n        (blur)=\"onTouched()\"\n        (input)=\"onChanged($event)\"\n        [maxlength]=\"maxLength\"\n        [matAutocomplete]=\"auto\"\n        [matAutocompleteConnectedTo]=\"{ elementRef: wattField.wrapper() ?? wattField.elementRef }\"\n        #inputField\n      />\n\n      <mat-autocomplete\n        #auto=\"matAutocomplete\"\n        class=\"watt-autocomplete-panel\"\n        (optionSelected)=\"autocompleteOptionSelected.emit($event.option.value)\"\n      >\n        @for (option of autocompleteOptions; track option) {\n          <mat-option [value]=\"option\">\n            {{ option }}\n          </mat-option>\n        }\n      </mat-autocomplete>\n    }\n\n    <ng-content />\n    <ng-content ngProjectAs=\"watt-field-descriptor\" select=\".descriptor\" />\n    <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n    <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n  </watt-field>`,\n})\nexport class WattTextFieldComponent implements ControlValueAccessor, AfterViewInit {\n  @Input() value!: string;\n  @Input() type: WattInputTypes = 'text';\n  @Input() placeholder?: string;\n  @Input() label = '';\n  @Input() tooltip?: string;\n  @Input() prefix?: WattIcon;\n  @Input() maxLength: string | number | null = null;\n  @Input() formControl!: FormControl;\n  @Input() autocompleteOptions!: string[];\n  @Input() autocompleteMatcherFn!: (value: string, option: string) => boolean;\n\n  /** @ignore */\n  @ViewChild(MatAutocomplete) autocompleteRef!: MatAutocomplete;\n\n  /**\n   * Emits the value of the input field when it changes.\n   */\n  @Output() searchChanged = new EventEmitter<string>();\n\n  /**\n   * Emits the value of the input field when an autocomplete option is selected.\n   */\n  @Output() autocompleteOptionSelected = new EventEmitter<string>();\n\n  /**\n   * Emits the value of the input field when an autocomplete option is selected.\n   */\n  @Output() autocompleteOptionDeselected = new EventEmitter<void>();\n\n  /** @ignore */\n  private element = inject(ElementRef);\n\n  /** @ignore */\n  @ViewChild('inputField') inputField!: ElementRef<HTMLInputElement>;\n  model!: string;\n\n  /** @ignore */\n  @HostBinding('attr.watt-field-disabled')\n  isDisabled = false;\n\n  /** @ignore */\n  onTouchedCallbacks: (() => void)[] = [];\n\n  /** @ignore */\n  ngAfterViewInit(): void {\n    const attrName = 'data-testid';\n    const testIdAttribute = this.element.nativeElement.getAttribute(attrName);\n    this.element.nativeElement.removeAttribute(attrName);\n    this.inputField.nativeElement.setAttribute(attrName, testIdAttribute);\n    this.registerOnTouched(() => {\n      const trimmedValue = this.inputField.nativeElement.value.trim();\n      this.inputField.nativeElement.value = trimmedValue;\n      this.formControl.setValue(trimmedValue);\n    });\n  }\n\n  /** @ignore */\n  onChanged(event: Event): void {\n    const value = (event.target as HTMLInputElement).value;\n\n    if (this.autocompleteRef) {\n      // Reset the autocomplete selection if the value is not matching anymore, and auto-select if the value has a match\n      this.autocompleteRef.options.forEach((option) => {\n        const isMatchingOption = this.autocompleteMatcherFn\n          ? this.autocompleteMatcherFn(value, option.value)\n          : option.value === value;\n\n        if (isMatchingOption) {\n          option.select(false);\n          this.autocompleteOptionSelected.emit(option.value);\n        } else {\n          option.deselect(false);\n          this.autocompleteOptionDeselected.emit();\n        }\n      });\n    }\n\n    this.searchChanged.emit(value);\n    this.onChange(value);\n  }\n\n  /** @ignore */\n  onChange: (value: string) => void = () => {\n    /* noop function */\n  };\n\n  /** @ignore */\n  onTouched: () => void = () => {\n    for (const callback of this.onTouchedCallbacks) {\n      callback();\n    }\n  };\n\n  /** @ignore */\n  writeValue(value: string): void {\n    this.model = value;\n  }\n\n  /** @ignore */\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  /** @ignore */\n  registerOnTouched(fn: () => void): void {\n    this.onTouchedCallbacks.push(fn);\n  }\n\n  /** @ignore */\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  /** @ignore */\n  setFocus(): void {\n    this.inputField.nativeElement.focus();\n  }\n}\n"]}
227
+ <ng-content />
228
+ <ng-content ngProjectAs="watt-field-descriptor" select=".descriptor" />
229
+ <ng-content ngProjectAs="watt-field-hint" select="watt-field-hint" />
230
+ <ng-content ngProjectAs="watt-field-error" select="watt-field-error" />
231
+ </watt-field>
232
+ `, styles: ["watt-text-field{display:block;width:100%}watt-text-field input{border:none;width:100%;outline:none;background-color:transparent}watt-text-field input::placeholder{color:var(--watt-on-light-low-emphasis)}\n"] }]
233
+ }] });
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-text-field.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/text-field/watt-text-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport {\n  Component,\n  ViewEncapsulation,\n  ElementRef,\n  forwardRef,\n  AfterViewInit,\n  inject,\n  input,\n  output,\n  viewChild,\n  signal,\n  linkedSignal,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormControl,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteModule } from '@angular/material/autocomplete';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattIconComponent, WattIcon } from '@energinet/watt/icon';\n\nexport type WattInputTypes = 'text' | 'password' | 'email' | 'number' | 'tel' | 'url';\n\n@Component({\n  imports: [MatAutocompleteModule, ReactiveFormsModule, WattFieldComponent, WattIconComponent],\n  selector: 'watt-text-field',\n  styleUrls: ['./watt-text-field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[attr.watt-field-disabled]': 'isDisabled()',\n  },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattTextFieldComponent),\n      multi: true,\n    },\n  ],\n  template: `\n    <watt-field\n      #wattField\n      [control]=\"formControl()\"\n      [label]=\"label()\"\n      [tooltip]=\"tooltip()\"\n      matAutocompleteOrigin\n    >\n      @if (prefix()) {\n        <watt-icon [name]=\"prefix()\" />\n      }\n\n      <input\n        [attr.aria-label]=\"label()\"\n        [attr.type]=\"type()\"\n        [attr.placeholder]=\"placeholder()\"\n        [value]=\"model()\"\n        [formControl]=\"formControl()\"\n        (blur)=\"onTouched()\"\n        (input)=\"onChanged($event)\"\n        [maxlength]=\"maxLength()\"\n        [matAutocomplete]=\"auto\"\n        [matAutocompleteDisabled]=\"!autocompleteOptions()\"\n        [matAutocompleteConnectedTo]=\"{ elementRef: wattField.wrapper() ?? wattField.elementRef }\"\n        #inputField\n      />\n\n      <mat-autocomplete\n        #auto=\"matAutocomplete\"\n        class=\"watt-autocomplete-panel\"\n        (optionSelected)=\"autocompleteOptionSelected.emit($event.option.value)\"\n      >\n        @for (option of autocompleteOptions(); track option) {\n          <mat-option [value]=\"option\">\n            {{ option }}\n          </mat-option>\n        }\n      </mat-autocomplete>\n\n      <ng-content />\n      <ng-content ngProjectAs=\"watt-field-descriptor\" select=\".descriptor\" />\n      <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n      <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n    </watt-field>\n  `,\n})\nexport class WattTextFieldComponent implements ControlValueAccessor, AfterViewInit {\n  value = input('');\n  type = input<WattInputTypes>('text');\n  placeholder = input('');\n  label = input('');\n  tooltip = input('');\n  prefix = input<WattIcon>();\n  maxLength = input<string | number | null>(null);\n  formControl = input.required<FormControl>();\n  autocompleteOptions = input<string[]>([]);\n  autocompleteMatcherFn = input<(value: string, option: string) => boolean>();\n\n  /** @ignore */\n  autocompleteRef = viewChild.required(MatAutocomplete);\n\n  /**\n   * Emits the value of the input field when it changes.\n   */\n  searchChanged = output<string>();\n\n  /**\n   * Emits the value of the input field when an autocomplete option is selected.\n   */\n  autocompleteOptionSelected = output<string>();\n\n  /**\n   * Emits the value of the input field when an autocomplete option is selected.\n   */\n  autocompleteOptionDeselected = output<void>();\n\n  /** @ignore */\n  private element = inject(ElementRef);\n\n  /** @ignore */\n  inputField = viewChild.required<ElementRef<HTMLInputElement>>('inputField');\n  model = linkedSignal(this.value);\n\n  /** @ignore */\n  isDisabled = signal(false);\n\n  /** @ignore */\n  onTouchedCallbacks: (() => void)[] = [];\n\n  /** @ignore */\n  ngAfterViewInit(): void {\n    const attrName = 'data-testid';\n    const testIdAttribute = this.element.nativeElement.getAttribute(attrName);\n    this.element.nativeElement.removeAttribute(attrName);\n\n    this.inputField().nativeElement.setAttribute(attrName, testIdAttribute);\n    this.registerOnTouched(() => {\n      const trimmedValue = this.inputField().nativeElement.value.trim();\n      this.inputField().nativeElement.value = trimmedValue;\n      this.formControl().setValue(trimmedValue);\n    });\n  }\n\n  /** @ignore */\n  onChanged(event: Event): void {\n    const value = (event.target as HTMLInputElement).value;\n\n    // Reset the autocomplete selection if the value is not matching anymore, and auto-select if the value has a match\n    this.autocompleteRef().options.forEach((option) => {\n      const matcherFn = this.autocompleteMatcherFn();\n      const isMatchingOption = matcherFn ? matcherFn(value, option.value) : option.value === value;\n\n      if (isMatchingOption) {\n        option.select(false);\n        this.autocompleteOptionSelected.emit(option.value);\n      } else {\n        option.deselect(false);\n        this.autocompleteOptionDeselected.emit();\n      }\n    });\n\n    this.searchChanged.emit(value);\n    this.onChange(value);\n  }\n\n  /** @ignore */\n  onChange: (value: string) => void = () => {\n    /* noop function */\n  };\n\n  /** @ignore */\n  onTouched: () => void = () => {\n    for (const callback of this.onTouchedCallbacks) {\n      callback();\n    }\n  };\n\n  /** @ignore */\n  writeValue(value: string): void {\n    this.model.set(value);\n  }\n\n  /** @ignore */\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  /** @ignore */\n  registerOnTouched(fn: () => void): void {\n    this.onTouchedCallbacks.push(fn);\n  }\n\n  /** @ignore */\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled.set(isDisabled);\n  }\n\n  /** @ignore */\n  setFocus(): void {\n    const inputField = this.inputField();\n    if (inputField) {\n      inputField.nativeElement.focus();\n    }\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "type": "module",
3
3
  "name": "@energinet/watt",
4
- "version": "4.0.6",
4
+ "version": "4.0.7",
5
5
  "license": "Apache-2.0",
6
6
  "exports": {
7
7
  ".": {
@@ -14,44 +14,43 @@
14
14
  * See the License for the specific language governing permissions and
15
15
  * limitations under the License.
16
16
  */
17
- import { ElementRef, AfterViewInit, EventEmitter } from '@angular/core';
17
+ import { ElementRef, AfterViewInit } from '@angular/core';
18
18
  import { ControlValueAccessor, FormControl } from '@angular/forms';
19
19
  import { MatAutocomplete } from '@angular/material/autocomplete';
20
- import { WattIcon } from '@energinet/watt/icon';
21
20
  import * as i0 from "@angular/core";
22
21
  export type WattInputTypes = 'text' | 'password' | 'email' | 'number' | 'tel' | 'url';
23
22
  export declare class WattTextFieldComponent implements ControlValueAccessor, AfterViewInit {
24
- value: string;
25
- type: WattInputTypes;
26
- placeholder?: string;
27
- label: string;
28
- tooltip?: string;
29
- prefix?: WattIcon;
30
- maxLength: string | number | null;
31
- formControl: FormControl;
32
- autocompleteOptions: string[];
33
- autocompleteMatcherFn: (value: string, option: string) => boolean;
23
+ value: import("@angular/core").InputSignal<string>;
24
+ type: import("@angular/core").InputSignal<WattInputTypes>;
25
+ placeholder: import("@angular/core").InputSignal<string>;
26
+ label: import("@angular/core").InputSignal<string>;
27
+ tooltip: import("@angular/core").InputSignal<string>;
28
+ prefix: import("@angular/core").InputSignal<"email" | "filter" | "search" | "plus" | "minus" | "edit" | "redo" | "undo" | "remove" | "removeForever" | "close" | "cancel" | "checkmark" | "user" | "settings" | "contentCopy" | "date" | "time" | "markEmailUnread" | "link" | "openInNew" | "monetization" | "payments" | "forwardMessage" | "menu" | "moreVertical" | "logout" | "login" | "help" | "alternateEmail" | "refresh" | "language" | "pendingActions" | "toggleOn" | "toggleOff" | "personCheck" | "left" | "right" | "up" | "down" | "arrowDropDown" | "arrowRightAlt" | "arrowLeftAlt" | "danger" | "warning" | "success" | "info" | "feedback" | "save" | "upload" | "download" | "fileDownload" | "fileUpload" | "print" | "preview" | "power" | "location" | "smartDisplay" | "windmill" | "solarPower" | "priorityHigh" | "notifications" | "notificationsUnread" | "horizontalRule" | "wrongLocation" | "heatPump" | "inventory" | "globe" | "calculate" | "bar_chart_4_bars" | "view_list" | "view_stream" | "construction" | "factory" | "nest_eco_leaf" | "flash_on" | undefined>;
29
+ maxLength: import("@angular/core").InputSignal<string | number | null>;
30
+ formControl: import("@angular/core").InputSignal<FormControl<any>>;
31
+ autocompleteOptions: import("@angular/core").InputSignal<string[]>;
32
+ autocompleteMatcherFn: import("@angular/core").InputSignal<((value: string, option: string) => boolean) | undefined>;
34
33
  /** @ignore */
35
- autocompleteRef: MatAutocomplete;
34
+ autocompleteRef: import("@angular/core").Signal<MatAutocomplete>;
36
35
  /**
37
36
  * Emits the value of the input field when it changes.
38
37
  */
39
- searchChanged: EventEmitter<string>;
38
+ searchChanged: import("@angular/core").OutputEmitterRef<string>;
40
39
  /**
41
40
  * Emits the value of the input field when an autocomplete option is selected.
42
41
  */
43
- autocompleteOptionSelected: EventEmitter<string>;
42
+ autocompleteOptionSelected: import("@angular/core").OutputEmitterRef<string>;
44
43
  /**
45
44
  * Emits the value of the input field when an autocomplete option is selected.
46
45
  */
47
- autocompleteOptionDeselected: EventEmitter<void>;
46
+ autocompleteOptionDeselected: import("@angular/core").OutputEmitterRef<void>;
48
47
  /** @ignore */
49
48
  private element;
50
49
  /** @ignore */
51
- inputField: ElementRef<HTMLInputElement>;
52
- model: string;
50
+ inputField: import("@angular/core").Signal<ElementRef<HTMLInputElement>>;
51
+ model: import("@angular/core").WritableSignal<string>;
53
52
  /** @ignore */
54
- isDisabled: boolean;
53
+ isDisabled: import("@angular/core").WritableSignal<boolean>;
55
54
  /** @ignore */
56
55
  onTouchedCallbacks: (() => void)[];
57
56
  /** @ignore */
@@ -73,5 +72,5 @@ export declare class WattTextFieldComponent implements ControlValueAccessor, Aft
73
72
  /** @ignore */
74
73
  setFocus(): void;
75
74
  static ɵfac: i0.ɵɵFactoryDeclaration<WattTextFieldComponent, never>;
76
- static ɵcmp: i0.ɵɵComponentDeclaration<WattTextFieldComponent, "watt-text-field", never, { "value": { "alias": "value"; "required": false; }; "type": { "alias": "type"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "label": { "alias": "label"; "required": false; }; "tooltip": { "alias": "tooltip"; "required": false; }; "prefix": { "alias": "prefix"; "required": false; }; "maxLength": { "alias": "maxLength"; "required": false; }; "formControl": { "alias": "formControl"; "required": false; }; "autocompleteOptions": { "alias": "autocompleteOptions"; "required": false; }; "autocompleteMatcherFn": { "alias": "autocompleteMatcherFn"; "required": false; }; }, { "searchChanged": "searchChanged"; "autocompleteOptionSelected": "autocompleteOptionSelected"; "autocompleteOptionDeselected": "autocompleteOptionDeselected"; }, never, ["*", ".descriptor", "watt-field-hint", "watt-field-error"], true, never>;
75
+ static ɵcmp: i0.ɵɵComponentDeclaration<WattTextFieldComponent, "watt-text-field", never, { "value": { "alias": "value"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "tooltip": { "alias": "tooltip"; "required": false; "isSignal": true; }; "prefix": { "alias": "prefix"; "required": false; "isSignal": true; }; "maxLength": { "alias": "maxLength"; "required": false; "isSignal": true; }; "formControl": { "alias": "formControl"; "required": true; "isSignal": true; }; "autocompleteOptions": { "alias": "autocompleteOptions"; "required": false; "isSignal": true; }; "autocompleteMatcherFn": { "alias": "autocompleteMatcherFn"; "required": false; "isSignal": true; }; }, { "searchChanged": "searchChanged"; "autocompleteOptionSelected": "autocompleteOptionSelected"; "autocompleteOptionDeselected": "autocompleteOptionDeselected"; }, never, ["*", ".descriptor", "watt-field-hint", "watt-field-error"], true, never>;
77
76
  }