@energinet/watt 4.1.24 → 4.1.26

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,7 +16,7 @@
16
16
  * limitations under the License.
17
17
  */
18
18
  //#endregion
19
- import { Component, ElementRef, HostBinding, ViewChild, ViewEncapsulation, forwardRef, inject, input, signal, untracked, } from '@angular/core';
19
+ import { Component, ViewEncapsulation, forwardRef, inject, input, signal, untracked, viewChild, } from '@angular/core';
20
20
  import { NG_VALUE_ACCESSOR, ReactiveFormsModule, } from '@angular/forms';
21
21
  import { MaskitoDirective } from '@maskito/angular';
22
22
  import { MatSelectModule } from '@angular/material/select';
@@ -60,11 +60,11 @@ export class WattPhoneFieldComponent {
60
60
  /** @ignore */
61
61
  intl = inject(WattPhoneFieldIntlService);
62
62
  /** @ignore */
63
- isDisabled = false;
63
+ isDisabled = signal(false, ...(ngDevMode ? [{ debugName: "isDisabled" }] : []));
64
64
  /** @ignore */
65
65
  value = null;
66
66
  /** @ignore */
67
- phoneNumberInput;
67
+ phoneNumberInput = viewChild.required('phoneNumberInput');
68
68
  /** @ignore */
69
69
  ngOnInit() {
70
70
  this.setup();
@@ -105,7 +105,7 @@ export class WattPhoneFieldComponent {
105
105
  }
106
106
  /** @ignore */
107
107
  setDisabledState(isDisabled) {
108
- this.isDisabled = isDisabled;
108
+ this.isDisabled.set(isDisabled);
109
109
  }
110
110
  /** @ignore */
111
111
  selectedContry({ value }) {
@@ -116,7 +116,7 @@ export class WattPhoneFieldComponent {
116
116
  this.setCountry(country);
117
117
  this.formControl().reset();
118
118
  setTimeout(() => {
119
- this.phoneNumberInput.nativeElement.focus();
119
+ this.phoneNumberInput().nativeElement.focus();
120
120
  }, 100);
121
121
  }
122
122
  /** @ignore */
@@ -131,12 +131,11 @@ export class WattPhoneFieldComponent {
131
131
  }
132
132
  /** @ignore */
133
133
  generatePhoneOptions() {
134
- const phoneOptions = maskitoPhoneOptionsGenerator({
134
+ this.mask = maskitoPhoneOptionsGenerator({
135
135
  countryIsoCode: this.chosenCountry().countryIsoCode,
136
136
  metadata: phoneMetadata,
137
137
  separator: ' ',
138
138
  });
139
- this.mask = phoneOptions;
140
139
  }
141
140
  /** @ignore */
142
141
  setup() {
@@ -153,13 +152,13 @@ export class WattPhoneFieldComponent {
153
152
  return this.intl[countryIsoCode];
154
153
  }
155
154
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattPhoneFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
156
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.6", type: WattPhoneFieldComponent, isStandalone: true, selector: "watt-phone-field", inputs: { formControl: { classPropertyName: "formControl", publicName: "formControl", isSignal: true, isRequired: true, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.watt-field-disabled": "this.isDisabled" } }, providers: [
155
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.6", type: WattPhoneFieldComponent, isStandalone: true, selector: "watt-phone-field", inputs: { formControl: { classPropertyName: "formControl", publicName: "formControl", isSignal: true, isRequired: true, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.watt-field-disabled": "isDisabled()" } }, providers: [
157
156
  {
158
157
  provide: NG_VALUE_ACCESSOR,
159
158
  useExisting: forwardRef(() => WattPhoneFieldComponent),
160
159
  multi: true,
161
160
  },
162
- ], viewQueries: [{ propertyName: "phoneNumberInput", first: true, predicate: ["phoneNumberInput"], descendants: true }], ngImport: i0, template: `
161
+ ], viewQueries: [{ propertyName: "phoneNumberInput", first: true, predicate: ["phoneNumberInput"], descendants: true, isSignal: true }], ngImport: i0, template: `
163
162
  <watt-field [label]="label()" [control]="formControl()">
164
163
  <div class="watt-phone-field__prefix-container">
165
164
  <mat-select
@@ -172,7 +171,7 @@ export class WattPhoneFieldComponent {
172
171
  <mat-select-trigger>
173
172
  <watt-flag [country]="chosenCountry().countryIsoCode" />
174
173
  </mat-select-trigger>
175
- @for (contry of countries; track contry; let index = $index) {
174
+ @for (contry of countries; track contry) {
176
175
  <mat-option value="{{ contry.countryIsoCode }}">
177
176
  <watt-flag [country]="contry.countryIsoCode" />
178
177
  <div>{{ getCountryName(contry.countryIsoCode) }}</div>
@@ -227,7 +226,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
227
226
  <mat-select-trigger>
228
227
  <watt-flag [country]="chosenCountry().countryIsoCode" />
229
228
  </mat-select-trigger>
230
- @for (contry of countries; track contry; let index = $index) {
229
+ @for (contry of countries; track contry) {
231
230
  <mat-option value="{{ contry.countryIsoCode }}">
232
231
  <watt-flag [country]="contry.countryIsoCode" />
233
232
  <div>{{ getCountryName(contry.countryIsoCode) }}</div>
@@ -252,12 +251,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
252
251
  <watt-field-error> {{ intl.invalidPhoneNumber }} </watt-field-error>
253
252
  }
254
253
  </watt-field>
255
- `, styles: [".watt-phone-field__select.mat-mdc-select-panel{--mat-option-label-text-size: 14px;overflow-y:scroll}.watt-phone-field__select.mat-mdc-select-panel watt-icon{margin-right:var(--watt-space-s)}.watt-phone-field__select.mat-mdc-select-panel watt-icon .mat-icon{margin-right:0}.watt-phone-field__select.mat-mdc-select-panel .mat-mdc-option.mdc-list-item .mdc-list-item__primary-text{display:flex;width:100%;align-items:center;gap:var(--watt-space-xs)}watt-phone-field{display:block}watt-phone-field .watt-phone-field__prefix-container{width:100%;display:flex;align-items:center;gap:var(--watt-space-xs)}watt-phone-field input{width:100%;border:none}watt-phone-field input:focus-visible,watt-phone-field input:focus-within{border:none;outline:none}watt-phone-field .mat-mdc-select{width:auto;height:24px}watt-phone-field .mat-mdc-select .mat-mdc-select-arrow-wrapper{width:24px;justify-content:center}\n"] }]
256
- }], propDecorators: { formControl: [{ type: i0.Input, args: [{ isSignal: true, alias: "formControl", required: true }] }], label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], isDisabled: [{
257
- type: HostBinding,
258
- args: ['attr.watt-field-disabled']
259
- }], phoneNumberInput: [{
260
- type: ViewChild,
261
- args: ['phoneNumberInput']
262
- }] } });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-phone-field.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/phone-field/watt-phone-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  ElementRef,\n  HostBinding,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n  inject,\n  input,\n  signal,\n  untracked,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n} from '@angular/forms';\nimport { MaskitoDirective } from '@maskito/angular';\nimport { MatSelectChange, MatSelectModule } from '@angular/material/select';\nimport { MASKITO_DEFAULT_OPTIONS, maskitoTransform } from '@maskito/core';\nimport { maskitoPhoneOptionsGenerator } from '@maskito/phone';\nimport { isValidPhoneNumber, type CountryCode } from 'libphonenumber-js';\nimport phoneMetadata from 'libphonenumber-js/min/metadata';\n\nimport { WattFlagComponent } from '@energinet/watt/icon/flags';\nimport { WattFieldComponent, WattFieldErrorComponent } from '@energinet/watt/field';\n\nimport { WattPhoneFieldIntlService } from './watt-phone-field-intl.service';\n\ntype Contry = {\n  countryIsoCode: CountryCode;\n  phoneExtension: string;\n};\n\nfunction phoneValidator(countryCode: CountryCode): ValidatorFn {\n  return (control: AbstractControl): ValidationErrors | null => {\n    if (!control.value) return null;\n    const valid = isValidPhoneNumber(control.value, countryCode);\n\n    return valid ? null : { invalidPhone: true };\n  };\n}\n\n@Component({\n  selector: 'watt-phone-field',\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    ReactiveFormsModule,\n    MatSelectModule,\n    MaskitoDirective,\n    WattFieldComponent,\n    WattFieldErrorComponent,\n    WattFlagComponent,\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattPhoneFieldComponent),\n      multi: true,\n    },\n  ],\n  template: `\n    <watt-field [label]=\"label()\" [control]=\"formControl()\">\n      <div class=\"watt-phone-field__prefix-container\">\n        <mat-select\n          panelWidth=\"\"\n          panelClass=\"watt-phone-field__select\"\n          [hideSingleSelectionIndicator]=\"true\"\n          [value]=\"chosenCountry().countryIsoCode\"\n          (selectionChange)=\"selectedContry($event)\"\n        >\n          <mat-select-trigger>\n            <watt-flag [country]=\"chosenCountry().countryIsoCode\" />\n          </mat-select-trigger>\n          @for (contry of countries; track contry; let index = $index) {\n            <mat-option value=\"{{ contry.countryIsoCode }}\">\n              <watt-flag [country]=\"contry.countryIsoCode\" />\n              <div>{{ getCountryName(contry.countryIsoCode) }}</div>\n            </mat-option>\n          }\n        </mat-select>\n        <input\n          [attr.aria-label]=\"label()\"\n          autocomplete=\"tel\"\n          inputmode=\"tel\"\n          [value]=\"value\"\n          [formControl]=\"formControl()\"\n          (blur)=\"onTouched()\"\n          (input)=\"onChanged($event)\"\n          [maskito]=\"mask\"\n          #phoneNumberInput\n        />\n      </div>\n      <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n      <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n      @if (formControl().hasError('invalidPhone')) {\n        <watt-field-error> {{ intl.invalidPhoneNumber }} </watt-field-error>\n      }\n    </watt-field>\n  `,\n  styleUrl: './watt-phone-field.component.scss',\n})\nexport class WattPhoneFieldComponent implements ControlValueAccessor, OnInit {\n  /** @ignore */\n  readonly countries: Contry[] = [\n    { countryIsoCode: 'DK', phoneExtension: '+45' },\n    { countryIsoCode: 'SE', phoneExtension: '+46' },\n    { countryIsoCode: 'NO', phoneExtension: '+47' },\n    { countryIsoCode: 'GB', phoneExtension: '+44' },\n    { countryIsoCode: 'DE', phoneExtension: '+49' },\n    { countryIsoCode: 'FI', phoneExtension: '+358' },\n    { countryIsoCode: 'PL', phoneExtension: '+48' },\n    { countryIsoCode: 'NL', phoneExtension: '+31' },\n    { countryIsoCode: 'CH', phoneExtension: '+41' },\n  ];\n\n  formControl = input.required<FormControl>();\n  label = input<string>();\n\n  /** @ignore */\n  chosenCountry = signal<Contry>(this.countries[0]);\n\n  /** @ignore */\n  mask = MASKITO_DEFAULT_OPTIONS;\n\n  /** @ignore */\n  intl = inject(WattPhoneFieldIntlService);\n\n  /** @ignore */\n  @HostBinding('attr.watt-field-disabled')\n  isDisabled = false;\n\n  /** @ignore */\n  value: string | null = null;\n\n  /** @ignore */\n  @ViewChild('phoneNumberInput') phoneNumberInput!: ElementRef<HTMLInputElement>;\n\n  /** @ignore */\n  ngOnInit(): void {\n    this.setup();\n  }\n\n  /** @ignore */\n  writeValue(value: string): void {\n    if (value) {\n      const country = this.countries.find((country) => value.startsWith(country.phoneExtension));\n\n      if (country) {\n        // Exclude Signal from being tracked\n        // in case the parent component sets the value inside an `effect`.\n        // Without this, updating the Signal internaly triggers the parrent `effect` to re-run.\n        // Note: Revisit once v19 is released because the `effect` API has changed\n        // significantly and this might not be necessary anymore\n        untracked(() => {\n          this.setCountry(country);\n        });\n\n        value = maskitoTransform(value, this.mask);\n      }\n    }\n\n    this.value = value;\n  }\n\n  /** @ignore */\n  onChange: (value: string) => void = () => {\n    /* noop function */\n  };\n\n  /** @ignore */\n  onTouched: () => void = () => {\n    /* noop function */\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.onTouched = fn;\n  }\n\n  /** @ignore */\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  /** @ignore */\n  selectedContry({ value }: MatSelectChange) {\n    const country = this.countries.find((contry) => contry.countryIsoCode === value);\n\n    if (!country) {\n      throw new Error('Prefix not found');\n    }\n\n    this.setCountry(country);\n    this.formControl().reset();\n\n    setTimeout(() => {\n      this.phoneNumberInput.nativeElement.focus();\n    }, 100);\n  }\n\n  /** @ignore */\n  setCountry(country: Contry) {\n    this.chosenCountry.set(country);\n    this.setup();\n  }\n\n  /** @ignore */\n  onChanged(event: Event): void {\n    const value = (event.target as HTMLSelectElement)?.value;\n    this.onChange(value);\n  }\n\n  /** @ignore */\n  private generatePhoneOptions(): void {\n    const phoneOptions = maskitoPhoneOptionsGenerator({\n      countryIsoCode: this.chosenCountry().countryIsoCode,\n      metadata: phoneMetadata,\n      separator: ' ',\n    });\n\n    this.mask = phoneOptions;\n  }\n\n  /** @ignore */\n  private setup(): void {\n    this.generatePhoneOptions();\n    this.setValidator();\n  }\n\n  /** @ignore */\n  private setValidator() {\n    const countryCode = this.chosenCountry().countryIsoCode;\n    this.formControl().addValidators(phoneValidator(countryCode));\n  }\n\n  /** @ignore */\n  getCountryName(countryIsoCode: CountryCode) {\n    return this.intl[countryIsoCode as keyof WattPhoneFieldIntlService];\n  }\n}\n"]}
254
+ `, host: {
255
+ '[attr.watt-field-disabled]': 'isDisabled()',
256
+ }, styles: [".watt-phone-field__select.mat-mdc-select-panel{--mat-option-label-text-size: 14px;overflow-y:scroll}.watt-phone-field__select.mat-mdc-select-panel watt-icon{margin-right:var(--watt-space-s)}.watt-phone-field__select.mat-mdc-select-panel watt-icon .mat-icon{margin-right:0}.watt-phone-field__select.mat-mdc-select-panel .mat-mdc-option.mdc-list-item .mdc-list-item__primary-text{display:flex;width:100%;align-items:center;gap:var(--watt-space-xs)}watt-phone-field{display:block}watt-phone-field .watt-phone-field__prefix-container{width:100%;display:flex;align-items:center;gap:var(--watt-space-xs)}watt-phone-field input{width:100%;border:none}watt-phone-field input:focus-visible,watt-phone-field input:focus-within{border:none;outline:none}watt-phone-field .mat-mdc-select{width:auto;height:24px}watt-phone-field .mat-mdc-select .mat-mdc-select-arrow-wrapper{width:24px;justify-content:center}\n"] }]
257
+ }], propDecorators: { formControl: [{ type: i0.Input, args: [{ isSignal: true, alias: "formControl", required: true }] }], label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], phoneNumberInput: [{ type: i0.ViewChild, args: ['phoneNumberInput', { isSignal: true }] }] } });
258
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-phone-field.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/phone-field/watt-phone-field.component.ts"],"names":[],"mappings":"AAAA,iBAAiB;AACjB;;;;;;;;;;;;;;;GAeG;AACH,YAAY;AACZ,OAAO,EACL,SAAS,EAET,iBAAiB,EACjB,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EACN,SAAS,EACT,SAAS,GAEV,MAAM,eAAe,CAAC;AACvB,OAAO,EAIL,iBAAiB,EACjB,mBAAmB,GAGpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAmB,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,4BAA4B,EAAE,MAAM,gBAAgB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAoB,MAAM,mBAAmB,CAAC;AACzE,OAAO,aAAa,MAAM,gCAAgC,CAAC;AAE3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AAEpF,OAAO,EAAE,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;;;;AAO5E,SAAS,cAAc,CAAC,WAAwB;IAC9C,OAAO,CAAC,OAAwB,EAA2B,EAAE;QAC3D,IAAI,CAAC,OAAO,CAAC,KAAK;YAAE,OAAO,IAAI,CAAC;QAChC,MAAM,KAAK,GAAG,kBAAkB,CAAC,OAAO,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAC7D,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC;IAC/C,CAAC,CAAC;AACJ,CAAC;AAgED,MAAM,OAAO,uBAAuB;IAClC,cAAc;IACL,SAAS,GAAa;QAC7B,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE;QAChD,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;QAC/C,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;KAChD,CAAC;IAEF,WAAW,GAAG,KAAK,CAAC,QAAQ,sDAAe,CAAC;IAC5C,KAAK,GAAG,KAAK,2DAAU,CAAC;IAExB,cAAc;IACd,aAAa,GAAG,MAAM,CAAS,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,yDAAC,CAAC;IAElD,cAAc;IACd,IAAI,GAAG,uBAAuB,CAAC;IAE/B,cAAc;IACd,IAAI,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC;IAEzC,cAAc;IACd,UAAU,GAAG,MAAM,CAAC,KAAK,sDAAC,CAAC;IAE3B,cAAc;IACd,KAAK,GAAkB,IAAI,CAAC;IAE5B,cAAc;IACd,gBAAgB,GAAG,SAAS,CAAC,QAAQ,CAA+B,kBAAkB,CAAC,CAAC;IAExF,cAAc;IACd,QAAQ;QACN,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,cAAc;IACd,UAAU,CAAC,KAAa;QACtB,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC;YAC3F,IAAI,OAAO,EAAE,CAAC;gBACZ,oCAAoC;gBACpC,kEAAkE;gBAClE,uFAAuF;gBACvF,0EAA0E;gBAC1E,wDAAwD;gBACxD,SAAS,CAAC,GAAG,EAAE;oBACb,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;gBAC3B,CAAC,CAAC,CAAC;gBAEH,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC;QAED,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,cAAc;IACd,QAAQ,GAA4B,GAAG,EAAE;QACvC,mBAAmB;IACrB,CAAC,CAAC;IAEF,cAAc;IACd,SAAS,GAAe,GAAG,EAAE;QAC3B,mBAAmB;IACrB,CAAC,CAAC;IAEF,cAAc;IACd,gBAAgB,CAAC,EAA2B;QAC1C,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,cAAc;IACd,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,cAAc;IACd,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAED,cAAc;IACd,cAAc,CAAC,EAAE,KAAK,EAAmB;QACvC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,cAAc,KAAK,KAAK,CAAC,CAAC;QACjF,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QACzB,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,CAAC;QAC3B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,gBAAgB,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAChD,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,cAAc;IACd,UAAU,CAAC,OAAe;QACxB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAChC,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,cAAc;IACd,SAAS,CAAC,KAAY;QACpB,MAAM,KAAK,GAAI,KAAK,CAAC,MAA4B,EAAE,KAAK,CAAC;QACzD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,cAAc;IACN,oBAAoB;QAC1B,IAAI,CAAC,IAAI,GAAG,4BAA4B,CAAC;YACvC,cAAc,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,cAAc;YACnD,QAAQ,EAAE,aAAa;YACvB,SAAS,EAAE,GAAG;SACf,CAAC,CAAC;IACL,CAAC;IAED,cAAc;IACN,KAAK;QACX,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,cAAc;IACN,YAAY;QAClB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,cAAc,CAAC;QACxD,IAAI,CAAC,WAAW,EAAE,CAAC,aAAa,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC;IAChE,CAAC;IAED,cAAc;IACd,cAAc,CAAC,cAA2B;QACxC,OAAO,IAAI,CAAC,IAAI,CAAC,cAAiD,CAAC,CAAC;IACtE,CAAC;uGAvIU,uBAAuB;2FAAvB,uBAAuB,kZAnDvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACZ;SACF,gKACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCT,08BApDC,mBAAmB,ykBACnB,eAAe,kyBACf,gBAAgB,6FAChB,kBAAkB,yLAClB,uBAAuB,6DACvB,iBAAiB;;2FAqDR,uBAAuB;kBA9DnC,SAAS;+BACE,kBAAkB,iBACb,iBAAiB,CAAC,IAAI,WAC5B;wBACP,mBAAmB;wBACnB,eAAe;wBACf,gBAAgB;wBAChB,kBAAkB;wBAClB,uBAAuB;wBACvB,iBAAiB;qBAClB,aACU;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACZ;qBACF,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCT,QAEK;wBACJ,4BAA4B,EAAE,cAAc;qBAC7C;6QAmCmE,kBAAkB","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  OnInit,\n  ViewEncapsulation,\n  forwardRef,\n  inject,\n  input,\n  signal,\n  untracked,\n  viewChild,\n  ElementRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n} from '@angular/forms';\nimport { MaskitoDirective } from '@maskito/angular';\nimport { MatSelectChange, MatSelectModule } from '@angular/material/select';\nimport { MASKITO_DEFAULT_OPTIONS, maskitoTransform } from '@maskito/core';\nimport { maskitoPhoneOptionsGenerator } from '@maskito/phone';\nimport { isValidPhoneNumber, type CountryCode } from 'libphonenumber-js';\nimport phoneMetadata from 'libphonenumber-js/min/metadata';\n\nimport { WattFlagComponent } from '@energinet/watt/icon/flags';\nimport { WattFieldComponent, WattFieldErrorComponent } from '@energinet/watt/field';\n\nimport { WattPhoneFieldIntlService } from './watt-phone-field-intl.service';\n\ntype Contry = {\n  countryIsoCode: CountryCode;\n  phoneExtension: string;\n};\n\nfunction phoneValidator(countryCode: CountryCode): ValidatorFn {\n  return (control: AbstractControl): ValidationErrors | null => {\n    if (!control.value) return null;\n    const valid = isValidPhoneNumber(control.value, countryCode);\n    return valid ? null : { invalidPhone: true };\n  };\n}\n\n@Component({\n  selector: 'watt-phone-field',\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    ReactiveFormsModule,\n    MatSelectModule,\n    MaskitoDirective,\n    WattFieldComponent,\n    WattFieldErrorComponent,\n    WattFlagComponent,\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattPhoneFieldComponent),\n      multi: true,\n    },\n  ],\n  template: `\n    <watt-field [label]=\"label()\" [control]=\"formControl()\">\n      <div class=\"watt-phone-field__prefix-container\">\n        <mat-select\n          panelWidth=\"\"\n          panelClass=\"watt-phone-field__select\"\n          [hideSingleSelectionIndicator]=\"true\"\n          [value]=\"chosenCountry().countryIsoCode\"\n          (selectionChange)=\"selectedContry($event)\"\n        >\n          <mat-select-trigger>\n            <watt-flag [country]=\"chosenCountry().countryIsoCode\" />\n          </mat-select-trigger>\n          @for (contry of countries; track contry) {\n            <mat-option value=\"{{ contry.countryIsoCode }}\">\n              <watt-flag [country]=\"contry.countryIsoCode\" />\n              <div>{{ getCountryName(contry.countryIsoCode) }}</div>\n            </mat-option>\n          }\n        </mat-select>\n        <input\n          [attr.aria-label]=\"label()\"\n          autocomplete=\"tel\"\n          inputmode=\"tel\"\n          [value]=\"value\"\n          [formControl]=\"formControl()\"\n          (blur)=\"onTouched()\"\n          (input)=\"onChanged($event)\"\n          [maskito]=\"mask\"\n          #phoneNumberInput\n        />\n      </div>\n      <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n      <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n      @if (formControl().hasError('invalidPhone')) {\n        <watt-field-error> {{ intl.invalidPhoneNumber }} </watt-field-error>\n      }\n    </watt-field>\n  `,\n  styleUrl: './watt-phone-field.component.scss',\n  host: {\n    '[attr.watt-field-disabled]': 'isDisabled()',\n  },\n})\nexport class WattPhoneFieldComponent implements ControlValueAccessor, OnInit {\n  /** @ignore */\n  readonly countries: Contry[] = [\n    { countryIsoCode: 'DK', phoneExtension: '+45' },\n    { countryIsoCode: 'SE', phoneExtension: '+46' },\n    { countryIsoCode: 'NO', phoneExtension: '+47' },\n    { countryIsoCode: 'GB', phoneExtension: '+44' },\n    { countryIsoCode: 'DE', phoneExtension: '+49' },\n    { countryIsoCode: 'FI', phoneExtension: '+358' },\n    { countryIsoCode: 'PL', phoneExtension: '+48' },\n    { countryIsoCode: 'NL', phoneExtension: '+31' },\n    { countryIsoCode: 'CH', phoneExtension: '+41' },\n  ];\n\n  formControl = input.required<FormControl>();\n  label = input<string>();\n\n  /** @ignore */\n  chosenCountry = signal<Contry>(this.countries[0]);\n\n  /** @ignore */\n  mask = MASKITO_DEFAULT_OPTIONS;\n\n  /** @ignore */\n  intl = inject(WattPhoneFieldIntlService);\n\n  /** @ignore */\n  isDisabled = signal(false);\n\n  /** @ignore */\n  value: string | null = null;\n\n  /** @ignore */\n  phoneNumberInput = viewChild.required<ElementRef<HTMLInputElement>>('phoneNumberInput');\n\n  /** @ignore */\n  ngOnInit(): void {\n    this.setup();\n  }\n\n  /** @ignore */\n  writeValue(value: string): void {\n    if (value) {\n      const country = this.countries.find((country) => value.startsWith(country.phoneExtension));\n      if (country) {\n        // Exclude Signal from being tracked\n        // in case the parent component sets the value inside an `effect`.\n        // Without this, updating the Signal internaly triggers the parrent `effect` to re-run.\n        // Note: Revisit once v19 is released because the `effect` API has changed\n        // significantly and this might not be necessary anymore\n        untracked(() => {\n          this.setCountry(country);\n        });\n\n        value = maskitoTransform(value, this.mask);\n      }\n    }\n\n    this.value = value;\n  }\n\n  /** @ignore */\n  onChange: (value: string) => void = () => {\n    /* noop function */\n  };\n\n  /** @ignore */\n  onTouched: () => void = () => {\n    /* noop function */\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.onTouched = fn;\n  }\n\n  /** @ignore */\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled.set(isDisabled);\n  }\n\n  /** @ignore */\n  selectedContry({ value }: MatSelectChange) {\n    const country = this.countries.find((contry) => contry.countryIsoCode === value);\n    if (!country) {\n      throw new Error('Prefix not found');\n    }\n    this.setCountry(country);\n    this.formControl().reset();\n    setTimeout(() => {\n      this.phoneNumberInput().nativeElement.focus();\n    }, 100);\n  }\n\n  /** @ignore */\n  setCountry(country: Contry) {\n    this.chosenCountry.set(country);\n    this.setup();\n  }\n\n  /** @ignore */\n  onChanged(event: Event): void {\n    const value = (event.target as HTMLSelectElement)?.value;\n    this.onChange(value);\n  }\n\n  /** @ignore */\n  private generatePhoneOptions(): void {\n    this.mask = maskitoPhoneOptionsGenerator({\n      countryIsoCode: this.chosenCountry().countryIsoCode,\n      metadata: phoneMetadata,\n      separator: ' ',\n    });\n  }\n\n  /** @ignore */\n  private setup(): void {\n    this.generatePhoneOptions();\n    this.setValidator();\n  }\n\n  /** @ignore */\n  private setValidator() {\n    const countryCode = this.chosenCountry().countryIsoCode;\n    this.formControl().addValidators(phoneValidator(countryCode));\n  }\n\n  /** @ignore */\n  getCountryName(countryIsoCode: CountryCode) {\n    return this.intl[countryIsoCode as keyof WattPhoneFieldIntlService];\n  }\n}\n"]}
@@ -16,13 +16,13 @@
16
16
  * limitations under the License.
17
17
  */
18
18
  //#endregion
19
- import { Component, input, output, ViewChild } from '@angular/core';
19
+ import { Component, input, output, viewChild } from '@angular/core';
20
20
  import { MatStep } from '@angular/material/stepper';
21
21
  import { CdkStep } from '@angular/cdk/stepper';
22
22
  import * as i0 from "@angular/core";
23
23
  export { CdkStep as WattStep };
24
24
  export class WattStepperStepComponent extends MatStep {
25
- templateRef = null;
25
+ templateRef = viewChild('templateRef', ...(ngDevMode ? [{ debugName: "templateRef" }] : []));
26
26
  nextButtonLabel = input(...(ngDevMode ? [undefined, { debugName: "nextButtonLabel" }] : []));
27
27
  disableNextButton = input(false, ...(ngDevMode ? [{ debugName: "disableNextButton" }] : []));
28
28
  loadingNextButton = input(false, ...(ngDevMode ? [{ debugName: "loadingNextButton" }] : []));
@@ -33,7 +33,7 @@ export class WattStepperStepComponent extends MatStep {
33
33
  leaving = output();
34
34
  next = output();
35
35
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattStepperStepComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
36
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.3.6", type: WattStepperStepComponent, isStandalone: true, selector: "watt-stepper-step", inputs: { nextButtonLabel: { classPropertyName: "nextButtonLabel", publicName: "nextButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, disableNextButton: { classPropertyName: "disableNextButton", publicName: "disableNextButton", isSignal: true, isRequired: false, transformFunction: null }, loadingNextButton: { classPropertyName: "loadingNextButton", publicName: "loadingNextButton", isSignal: true, isRequired: false, transformFunction: null }, previousButtonLabel: { classPropertyName: "previousButtonLabel", publicName: "previousButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, enabled: { classPropertyName: "enabled", publicName: "enabled", isSignal: true, isRequired: false, transformFunction: null }, disablePreviousButton: { classPropertyName: "disablePreviousButton", publicName: "disablePreviousButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { entering: "entering", leaving: "leaving", next: "next" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: ` <ng-template #templateRef>
36
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.3.6", type: WattStepperStepComponent, isStandalone: true, selector: "watt-stepper-step", inputs: { nextButtonLabel: { classPropertyName: "nextButtonLabel", publicName: "nextButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, disableNextButton: { classPropertyName: "disableNextButton", publicName: "disableNextButton", isSignal: true, isRequired: false, transformFunction: null }, loadingNextButton: { classPropertyName: "loadingNextButton", publicName: "loadingNextButton", isSignal: true, isRequired: false, transformFunction: null }, previousButtonLabel: { classPropertyName: "previousButtonLabel", publicName: "previousButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, enabled: { classPropertyName: "enabled", publicName: "enabled", isSignal: true, isRequired: false, transformFunction: null }, disablePreviousButton: { classPropertyName: "disablePreviousButton", publicName: "disablePreviousButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { entering: "entering", leaving: "leaving", next: "next" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: ` <ng-template #templateRef>
37
37
  <ng-content />
38
38
  </ng-template>`, isInline: true });
39
39
  }
@@ -45,8 +45,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
45
45
  <ng-content />
46
46
  </ng-template>`,
47
47
  }]
48
- }], propDecorators: { templateRef: [{
49
- type: ViewChild,
50
- args: ['templateRef']
51
- }], nextButtonLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "nextButtonLabel", required: false }] }], disableNextButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "disableNextButton", required: false }] }], loadingNextButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingNextButton", required: false }] }], previousButtonLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "previousButtonLabel", required: false }] }], enabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "enabled", required: false }] }], disablePreviousButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "disablePreviousButton", required: false }] }], entering: [{ type: i0.Output, args: ["entering"] }], leaving: [{ type: i0.Output, args: ["leaving"] }], next: [{ type: i0.Output, args: ["next"] }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1zdGVwcGVyLXN0ZXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy93YXR0L3BhY2thZ2Uvc3RlcHBlci93YXR0LXN0ZXBwZXItc3RlcC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsaUJBQWlCO0FBQ2pCOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILFlBQVk7QUFDWixPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQWUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBRS9DLE9BQU8sRUFBRSxPQUFPLElBQUksUUFBUSxFQUFFLENBQUM7QUFRL0IsTUFBTSxPQUFPLHdCQUF5QixTQUFRLE9BQU87SUFDbEIsV0FBVyxHQUFnQyxJQUFJLENBQUM7SUFFakYsZUFBZSxHQUFHLEtBQUsscUVBQVUsQ0FBQztJQUNsQyxpQkFBaUIsR0FBRyxLQUFLLENBQVUsS0FBSyw2REFBQyxDQUFDO0lBQzFDLGlCQUFpQixHQUFHLEtBQUssQ0FBVSxLQUFLLDZEQUFDLENBQUM7SUFDMUMsbUJBQW1CLEdBQUcsS0FBSyx5RUFBVSxDQUFDO0lBQ3RDLE9BQU8sR0FBRyxLQUFLLENBQVUsSUFBSSxtREFBQyxDQUFDO0lBQy9CLHFCQUFxQixHQUFHLEtBQUssQ0FBVSxLQUFLLGlFQUFDLENBQUM7SUFFOUMsUUFBUSxHQUFHLE1BQU0sRUFBVyxDQUFDO0lBQzdCLE9BQU8sR0FBRyxNQUFNLEVBQVcsQ0FBQztJQUM1QixJQUFJLEdBQUcsTUFBTSxFQUFRLENBQUM7dUdBWlgsd0JBQXdCOzJGQUF4Qix3QkFBd0IsdXJDQUp6Qjs7aUJBRUs7OzJGQUVKLHdCQUF3QjtrQkFOcEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixRQUFRLEVBQUU7O2lCQUVLO2lCQUNoQjs7c0JBRUUsU0FBUzt1QkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiLy8jcmVnaW9uIExpY2Vuc2Vcbi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCAyMDIwIEVuZXJnaW5ldCBEYXRhSHViIEEvU1xuICpcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2UyXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cbi8vI2VuZHJlZ2lvblxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgb3V0cHV0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRTdGVwIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc3RlcHBlcic7XG5pbXBvcnQgeyBDZGtTdGVwIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3N0ZXBwZXInO1xuXG5leHBvcnQgeyBDZGtTdGVwIGFzIFdhdHRTdGVwIH07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3dhdHQtc3RlcHBlci1zdGVwJyxcbiAgdGVtcGxhdGU6IGAgPG5nLXRlbXBsYXRlICN0ZW1wbGF0ZVJlZj5cbiAgICA8bmctY29udGVudCAvPlxuICA8L25nLXRlbXBsYXRlPmAsXG59KVxuZXhwb3J0IGNsYXNzIFdhdHRTdGVwcGVyU3RlcENvbXBvbmVudCBleHRlbmRzIE1hdFN0ZXAge1xuICBAVmlld0NoaWxkKCd0ZW1wbGF0ZVJlZicpIHB1YmxpYyB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8dW5rbm93bj4gfCBudWxsID0gbnVsbDtcblxuICBuZXh0QnV0dG9uTGFiZWwgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIGRpc2FibGVOZXh0QnV0dG9uID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBsb2FkaW5nTmV4dEJ1dHRvbiA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcHJldmlvdXNCdXR0b25MYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcbiAgZW5hYmxlZCA9IGlucHV0PGJvb2xlYW4+KHRydWUpO1xuICBkaXNhYmxlUHJldmlvdXNCdXR0b24gPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG5cbiAgZW50ZXJpbmcgPSBvdXRwdXQ8Q2RrU3RlcD4oKTtcbiAgbGVhdmluZyA9IG91dHB1dDxDZGtTdGVwPigpO1xuICBuZXh0ID0gb3V0cHV0PHZvaWQ+KCk7XG59XG4iXX0=
48
+ }], propDecorators: { templateRef: [{ type: i0.ViewChild, args: ['templateRef', { isSignal: true }] }], nextButtonLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "nextButtonLabel", required: false }] }], disableNextButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "disableNextButton", required: false }] }], loadingNextButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingNextButton", required: false }] }], previousButtonLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "previousButtonLabel", required: false }] }], enabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "enabled", required: false }] }], disablePreviousButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "disablePreviousButton", required: false }] }], entering: [{ type: i0.Output, args: ["entering"] }], leaving: [{ type: i0.Output, args: ["leaving"] }], next: [{ type: i0.Output, args: ["next"] }] } });
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1zdGVwcGVyLXN0ZXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy93YXR0L3BhY2thZ2Uvc3RlcHBlci93YXR0LXN0ZXBwZXItc3RlcC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsaUJBQWlCO0FBQ2pCOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILFlBQVk7QUFDWixPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQWUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBRS9DLE9BQU8sRUFBRSxPQUFPLElBQUksUUFBUSxFQUFFLENBQUM7QUFRL0IsTUFBTSxPQUFPLHdCQUF5QixTQUFRLE9BQU87SUFDbkMsV0FBVyxHQUFHLFNBQVMsQ0FBdUIsYUFBYSx1REFBQyxDQUFDO0lBRTdFLGVBQWUsR0FBRyxLQUFLLHFFQUFVLENBQUM7SUFDbEMsaUJBQWlCLEdBQUcsS0FBSyxDQUFVLEtBQUssNkRBQUMsQ0FBQztJQUMxQyxpQkFBaUIsR0FBRyxLQUFLLENBQVUsS0FBSyw2REFBQyxDQUFDO0lBQzFDLG1CQUFtQixHQUFHLEtBQUsseUVBQVUsQ0FBQztJQUN0QyxPQUFPLEdBQUcsS0FBSyxDQUFVLElBQUksbURBQUMsQ0FBQztJQUMvQixxQkFBcUIsR0FBRyxLQUFLLENBQVUsS0FBSyxpRUFBQyxDQUFDO0lBRTlDLFFBQVEsR0FBRyxNQUFNLEVBQVcsQ0FBQztJQUM3QixPQUFPLEdBQUcsTUFBTSxFQUFXLENBQUM7SUFDNUIsSUFBSSxHQUFHLE1BQU0sRUFBUSxDQUFDO3VHQVpYLHdCQUF3QjsyRkFBeEIsd0JBQXdCLHVzQ0FKekI7O2lCQUVLOzsyRkFFSix3QkFBd0I7a0JBTnBDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsUUFBUSxFQUFFOztpQkFFSztpQkFDaEI7eUVBRStELGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyIvLyNyZWdpb24gTGljZW5zZVxuLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IDIwMjAgRW5lcmdpbmV0IERhdGFIdWIgQS9TXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZTJcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuLy8jZW5kcmVnaW9uXG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQsIFRlbXBsYXRlUmVmLCB2aWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdFN0ZXAgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zdGVwcGVyJztcbmltcG9ydCB7IENka1N0ZXAgfSBmcm9tICdAYW5ndWxhci9jZGsvc3RlcHBlcic7XG5cbmV4cG9ydCB7IENka1N0ZXAgYXMgV2F0dFN0ZXAgfTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnd2F0dC1zdGVwcGVyLXN0ZXAnLFxuICB0ZW1wbGF0ZTogYCA8bmctdGVtcGxhdGUgI3RlbXBsYXRlUmVmPlxuICAgIDxuZy1jb250ZW50IC8+XG4gIDwvbmctdGVtcGxhdGU+YCxcbn0pXG5leHBvcnQgY2xhc3MgV2F0dFN0ZXBwZXJTdGVwQ29tcG9uZW50IGV4dGVuZHMgTWF0U3RlcCB7XG4gIHB1YmxpYyByZWFkb25seSB0ZW1wbGF0ZVJlZiA9IHZpZXdDaGlsZDxUZW1wbGF0ZVJlZjx1bmtub3duPj4oJ3RlbXBsYXRlUmVmJyk7XG5cbiAgbmV4dEJ1dHRvbkxhYmVsID0gaW5wdXQ8c3RyaW5nPigpO1xuICBkaXNhYmxlTmV4dEJ1dHRvbiA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgbG9hZGluZ05leHRCdXR0b24gPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG4gIHByZXZpb3VzQnV0dG9uTGFiZWwgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIGVuYWJsZWQgPSBpbnB1dDxib29sZWFuPih0cnVlKTtcbiAgZGlzYWJsZVByZXZpb3VzQnV0dG9uID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIGVudGVyaW5nID0gb3V0cHV0PENka1N0ZXA+KCk7XG4gIGxlYXZpbmcgPSBvdXRwdXQ8Q2RrU3RlcD4oKTtcbiAgbmV4dCA9IG91dHB1dDx2b2lkPigpO1xufVxuIl19
@@ -70,7 +70,7 @@ export class WattStepperComponent extends MatStepper {
70
70
  },
71
71
  { provide: CdkStepper, useExisting: WattStepperComponent },
72
72
  { provide: MatStepper, useExisting: WattStepperComponent },
73
- ], queries: [{ propertyName: "_steps", predicate: WattStepperStepComponent, descendants: true }], viewQueries: [{ propertyName: "stepper", first: true, predicate: MatStepper, descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<mat-stepper\n #stepper\n [disableRipple]=\"disableRipple\"\n [linear]=\"true\"\n animationDuration=\"0\"\n class=\"watt-stepper\"\n>\n <ng-template let-index=\"index\" matStepperIcon=\"edit\">\n {{ index + 1 }}\n </ng-template>\n <ng-template matStepperIcon=\"done\">\n <watt-icon name=\"checkmark\" />\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"number\">\n @if (\n stepper.steps.get(index)?.completed &&\n stepper.steps.get(index)?.interacted &&\n index !== stepper.selectedIndex\n ) {\n <watt-icon name=\"checkmark\" />\n } @else {\n {{ index + 1 }}\n }\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"error\">\n {{ index + 1 }}\n </ng-template>\n @for (step of _steps; track step) {\n @if (step.enabled()) {\n <mat-step [editable]=\"step.editable\" [stepControl]=\"step.stepControl\">\n <ng-template matStepLabel>{{ step.label }}</ng-template>\n <div class=\"watt-stepper-content-wrapper\">\n <ng-container *ngTemplateOutlet=\"step.templateRef\" />\n </div>\n <div class=\"watt-stepper-button-wrapper\">\n @if (!(onFirstStep$ | push)) {\n <watt-button\n [disabled]=\"step.disablePreviousButton()\"\n variant=\"secondary\"\n (click)=\"previousStep()\"\n >\n <watt-icon name=\"left\" />\n {{ step.previousButtonLabel() }}\n </watt-button>\n }\n\n @if (!(onLastStep$ | push)) {\n <watt-button\n variant=\"secondary\"\n (click)=\"nextStep(step)\"\n [loading]=\"step.loadingNextButton()\"\n [disabled]=\"step.disableNextButton()\"\n >\n {{ step.nextButtonLabel() }}\n <watt-icon name=\"right\" />\n </watt-button>\n }\n\n @if (onLastStep$ | push) {\n <watt-button\n variant=\"primary\"\n [loading]=\"isCompleting\"\n (click)=\"complete()\"\n [disabled]=\"step.disableNextButton()\"\n >{{ step.nextButtonLabel() }}\n </watt-button>\n }\n </div>\n </mat-step>\n }\n }\n</mat-stepper>\n", styles: [".watt-stepper .mat-horizontal-stepper-header-container{padding-bottom:var(--watt-space-ml)}.watt-stepper .mat-step-label.mat-step-label-selected{color:var(--watt-color-primary)}.watt-stepper .mat-form-field-suffix{padding-right:var(--watt-space-s);color:var(--watt-color-neutral-grey-600)}.watt-stepper .mat-step-label{color:var(--watt-typography-label-color);font-size:1rem;line-height:1.5rem;font-weight:600;text-transform:none}.watt-stepper .mat-step-header .mat-step-icon-selected{border:solid 1px var(--watt-color-primary);background-color:var(--watt-color-neutral-white);color:var(--watt-color-primary)}.watt-stepper .mat-stepper-horizontal-line{margin:0 5px}.watt-stepper .watt-stepper-button-wrapper{display:flex;justify-content:flex-end;gap:var(--watt-space-m);width:100%;padding-top:var(--watt-space-ml)}.watt-stepper .mat-step-icon-state-error{color:var(--watt-color-state-danger);border:solid 1px var(--watt-color-state-danger)}@media(max-width:719.98px){.watt-stepper .mat-horizontal-stepper-header{padding:0}.watt-stepper .mat-step-label:not(.mat-step-label-selected){display:none}.watt-stepper .mat-horizontal-content-container{padding:0 0 24px}}.watt-modal--medium watt-stepper,.watt-modal--medium .watt-stepper,.watt-modal--large watt-stepper,.watt-modal--large .watt-stepper{height:100%}.watt-modal--medium .mat-horizontal-stepper-content,.watt-modal--large .mat-horizontal-stepper-content{display:grid;align-items:center;grid-template-rows:1fr auto;grid-template-areas:\"content\" \"actions\"}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-content-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-content-wrapper{align-self:stretch;grid-area:content;overflow:auto}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-button-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-button-wrapper{grid-area:actions}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatStepperModule }, { kind: "component", type: i1.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i1.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i1.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "directive", type: i1.MatStepperIcon, selector: "ng-template[matStepperIcon]", inputs: ["matStepperIcon"] }, { kind: "component", type: WattIconComponent, selector: "watt-icon", inputs: ["name", "label", "size", "state"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "pipe", type: RxPush, name: "push" }], encapsulation: i0.ViewEncapsulation.None });
73
+ ], queries: [{ propertyName: "_steps", predicate: WattStepperStepComponent, descendants: true }], viewQueries: [{ propertyName: "stepper", first: true, predicate: MatStepper, descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<mat-stepper\n #stepper\n [disableRipple]=\"disableRipple\"\n [linear]=\"true\"\n animationDuration=\"0\"\n class=\"watt-stepper\"\n>\n <ng-template let-index=\"index\" matStepperIcon=\"edit\">\n {{ index + 1 }}\n </ng-template>\n <ng-template matStepperIcon=\"done\">\n <watt-icon name=\"checkmark\" />\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"number\">\n @if (\n stepper.steps.get(index)?.completed &&\n stepper.steps.get(index)?.interacted &&\n index !== stepper.selectedIndex\n ) {\n <watt-icon name=\"checkmark\" />\n } @else {\n {{ index + 1 }}\n }\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"error\">\n {{ index + 1 }}\n </ng-template>\n @for (step of _steps; track step) {\n @if (step.enabled()) {\n <mat-step [editable]=\"step.editable\" [stepControl]=\"step.stepControl\">\n <ng-template matStepLabel>{{ step.label }}</ng-template>\n <div class=\"watt-stepper-content-wrapper\">\n <ng-container *ngTemplateOutlet=\"step.templateRef()\" />\n </div>\n <div class=\"watt-stepper-button-wrapper\">\n @if (!(onFirstStep$ | push)) {\n <watt-button\n [disabled]=\"step.disablePreviousButton()\"\n variant=\"secondary\"\n (click)=\"previousStep()\"\n >\n <watt-icon name=\"left\" />\n {{ step.previousButtonLabel() }}\n </watt-button>\n }\n\n @if (!(onLastStep$ | push)) {\n <watt-button\n variant=\"secondary\"\n (click)=\"nextStep(step)\"\n [loading]=\"step.loadingNextButton()\"\n [disabled]=\"step.disableNextButton()\"\n >\n {{ step.nextButtonLabel() }}\n <watt-icon name=\"right\" />\n </watt-button>\n }\n\n @if (onLastStep$ | push) {\n <watt-button\n variant=\"primary\"\n [loading]=\"isCompleting\"\n (click)=\"complete()\"\n [disabled]=\"step.disableNextButton()\"\n >{{ step.nextButtonLabel() }}\n </watt-button>\n }\n </div>\n </mat-step>\n }\n }\n</mat-stepper>\n", styles: [".watt-stepper .mat-horizontal-stepper-header-container{padding-bottom:var(--watt-space-ml)}.watt-stepper .mat-step-label.mat-step-label-selected{color:var(--watt-color-primary)}.watt-stepper .mat-form-field-suffix{padding-right:var(--watt-space-s);color:var(--watt-color-neutral-grey-600)}.watt-stepper .mat-step-label{color:var(--watt-typography-label-color);font-size:1rem;line-height:1.5rem;font-weight:600;text-transform:none}.watt-stepper .mat-step-header .mat-step-icon-selected{border:solid 1px var(--watt-color-primary);background-color:var(--watt-color-neutral-white);color:var(--watt-color-primary)}.watt-stepper .mat-stepper-horizontal-line{margin:0 5px}.watt-stepper .watt-stepper-button-wrapper{display:flex;justify-content:flex-end;gap:var(--watt-space-m);width:100%;padding-top:var(--watt-space-ml)}.watt-stepper .mat-step-icon-state-error{color:var(--watt-color-state-danger);border:solid 1px var(--watt-color-state-danger)}@media(max-width:719.98px){.watt-stepper .mat-horizontal-stepper-header{padding:0}.watt-stepper .mat-step-label:not(.mat-step-label-selected){display:none}.watt-stepper .mat-horizontal-content-container{padding:0 0 24px}}.watt-modal--medium watt-stepper,.watt-modal--medium .watt-stepper,.watt-modal--large watt-stepper,.watt-modal--large .watt-stepper{height:100%}.watt-modal--medium .mat-horizontal-stepper-content,.watt-modal--large .mat-horizontal-stepper-content{display:grid;align-items:center;grid-template-rows:1fr auto;grid-template-areas:\"content\" \"actions\"}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-content-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-content-wrapper{align-self:stretch;grid-area:content;overflow:auto}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-button-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-button-wrapper{grid-area:actions}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatStepperModule }, { kind: "component", type: i1.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i1.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i1.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "directive", type: i1.MatStepperIcon, selector: "ng-template[matStepperIcon]", inputs: ["matStepperIcon"] }, { kind: "component", type: WattIconComponent, selector: "watt-icon", inputs: ["name", "label", "size", "state"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "pipe", type: RxPush, name: "push" }], encapsulation: i0.ViewEncapsulation.None });
74
74
  }
75
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattStepperComponent, decorators: [{
76
76
  type: Component,
@@ -81,7 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
81
81
  },
82
82
  { provide: CdkStepper, useExisting: WattStepperComponent },
83
83
  { provide: MatStepper, useExisting: WattStepperComponent },
84
- ], template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<mat-stepper\n #stepper\n [disableRipple]=\"disableRipple\"\n [linear]=\"true\"\n animationDuration=\"0\"\n class=\"watt-stepper\"\n>\n <ng-template let-index=\"index\" matStepperIcon=\"edit\">\n {{ index + 1 }}\n </ng-template>\n <ng-template matStepperIcon=\"done\">\n <watt-icon name=\"checkmark\" />\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"number\">\n @if (\n stepper.steps.get(index)?.completed &&\n stepper.steps.get(index)?.interacted &&\n index !== stepper.selectedIndex\n ) {\n <watt-icon name=\"checkmark\" />\n } @else {\n {{ index + 1 }}\n }\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"error\">\n {{ index + 1 }}\n </ng-template>\n @for (step of _steps; track step) {\n @if (step.enabled()) {\n <mat-step [editable]=\"step.editable\" [stepControl]=\"step.stepControl\">\n <ng-template matStepLabel>{{ step.label }}</ng-template>\n <div class=\"watt-stepper-content-wrapper\">\n <ng-container *ngTemplateOutlet=\"step.templateRef\" />\n </div>\n <div class=\"watt-stepper-button-wrapper\">\n @if (!(onFirstStep$ | push)) {\n <watt-button\n [disabled]=\"step.disablePreviousButton()\"\n variant=\"secondary\"\n (click)=\"previousStep()\"\n >\n <watt-icon name=\"left\" />\n {{ step.previousButtonLabel() }}\n </watt-button>\n }\n\n @if (!(onLastStep$ | push)) {\n <watt-button\n variant=\"secondary\"\n (click)=\"nextStep(step)\"\n [loading]=\"step.loadingNextButton()\"\n [disabled]=\"step.disableNextButton()\"\n >\n {{ step.nextButtonLabel() }}\n <watt-icon name=\"right\" />\n </watt-button>\n }\n\n @if (onLastStep$ | push) {\n <watt-button\n variant=\"primary\"\n [loading]=\"isCompleting\"\n (click)=\"complete()\"\n [disabled]=\"step.disableNextButton()\"\n >{{ step.nextButtonLabel() }}\n </watt-button>\n }\n </div>\n </mat-step>\n }\n }\n</mat-stepper>\n", styles: [".watt-stepper .mat-horizontal-stepper-header-container{padding-bottom:var(--watt-space-ml)}.watt-stepper .mat-step-label.mat-step-label-selected{color:var(--watt-color-primary)}.watt-stepper .mat-form-field-suffix{padding-right:var(--watt-space-s);color:var(--watt-color-neutral-grey-600)}.watt-stepper .mat-step-label{color:var(--watt-typography-label-color);font-size:1rem;line-height:1.5rem;font-weight:600;text-transform:none}.watt-stepper .mat-step-header .mat-step-icon-selected{border:solid 1px var(--watt-color-primary);background-color:var(--watt-color-neutral-white);color:var(--watt-color-primary)}.watt-stepper .mat-stepper-horizontal-line{margin:0 5px}.watt-stepper .watt-stepper-button-wrapper{display:flex;justify-content:flex-end;gap:var(--watt-space-m);width:100%;padding-top:var(--watt-space-ml)}.watt-stepper .mat-step-icon-state-error{color:var(--watt-color-state-danger);border:solid 1px var(--watt-color-state-danger)}@media(max-width:719.98px){.watt-stepper .mat-horizontal-stepper-header{padding:0}.watt-stepper .mat-step-label:not(.mat-step-label-selected){display:none}.watt-stepper .mat-horizontal-content-container{padding:0 0 24px}}.watt-modal--medium watt-stepper,.watt-modal--medium .watt-stepper,.watt-modal--large watt-stepper,.watt-modal--large .watt-stepper{height:100%}.watt-modal--medium .mat-horizontal-stepper-content,.watt-modal--large .mat-horizontal-stepper-content{display:grid;align-items:center;grid-template-rows:1fr auto;grid-template-areas:\"content\" \"actions\"}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-content-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-content-wrapper{align-self:stretch;grid-area:content;overflow:auto}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-button-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-button-wrapper{grid-area:actions}\n"] }]
84
+ ], template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<mat-stepper\n #stepper\n [disableRipple]=\"disableRipple\"\n [linear]=\"true\"\n animationDuration=\"0\"\n class=\"watt-stepper\"\n>\n <ng-template let-index=\"index\" matStepperIcon=\"edit\">\n {{ index + 1 }}\n </ng-template>\n <ng-template matStepperIcon=\"done\">\n <watt-icon name=\"checkmark\" />\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"number\">\n @if (\n stepper.steps.get(index)?.completed &&\n stepper.steps.get(index)?.interacted &&\n index !== stepper.selectedIndex\n ) {\n <watt-icon name=\"checkmark\" />\n } @else {\n {{ index + 1 }}\n }\n </ng-template>\n <ng-template let-index=\"index\" matStepperIcon=\"error\">\n {{ index + 1 }}\n </ng-template>\n @for (step of _steps; track step) {\n @if (step.enabled()) {\n <mat-step [editable]=\"step.editable\" [stepControl]=\"step.stepControl\">\n <ng-template matStepLabel>{{ step.label }}</ng-template>\n <div class=\"watt-stepper-content-wrapper\">\n <ng-container *ngTemplateOutlet=\"step.templateRef()\" />\n </div>\n <div class=\"watt-stepper-button-wrapper\">\n @if (!(onFirstStep$ | push)) {\n <watt-button\n [disabled]=\"step.disablePreviousButton()\"\n variant=\"secondary\"\n (click)=\"previousStep()\"\n >\n <watt-icon name=\"left\" />\n {{ step.previousButtonLabel() }}\n </watt-button>\n }\n\n @if (!(onLastStep$ | push)) {\n <watt-button\n variant=\"secondary\"\n (click)=\"nextStep(step)\"\n [loading]=\"step.loadingNextButton()\"\n [disabled]=\"step.disableNextButton()\"\n >\n {{ step.nextButtonLabel() }}\n <watt-icon name=\"right\" />\n </watt-button>\n }\n\n @if (onLastStep$ | push) {\n <watt-button\n variant=\"primary\"\n [loading]=\"isCompleting\"\n (click)=\"complete()\"\n [disabled]=\"step.disableNextButton()\"\n >{{ step.nextButtonLabel() }}\n </watt-button>\n }\n </div>\n </mat-step>\n }\n }\n</mat-stepper>\n", styles: [".watt-stepper .mat-horizontal-stepper-header-container{padding-bottom:var(--watt-space-ml)}.watt-stepper .mat-step-label.mat-step-label-selected{color:var(--watt-color-primary)}.watt-stepper .mat-form-field-suffix{padding-right:var(--watt-space-s);color:var(--watt-color-neutral-grey-600)}.watt-stepper .mat-step-label{color:var(--watt-typography-label-color);font-size:1rem;line-height:1.5rem;font-weight:600;text-transform:none}.watt-stepper .mat-step-header .mat-step-icon-selected{border:solid 1px var(--watt-color-primary);background-color:var(--watt-color-neutral-white);color:var(--watt-color-primary)}.watt-stepper .mat-stepper-horizontal-line{margin:0 5px}.watt-stepper .watt-stepper-button-wrapper{display:flex;justify-content:flex-end;gap:var(--watt-space-m);width:100%;padding-top:var(--watt-space-ml)}.watt-stepper .mat-step-icon-state-error{color:var(--watt-color-state-danger);border:solid 1px var(--watt-color-state-danger)}@media(max-width:719.98px){.watt-stepper .mat-horizontal-stepper-header{padding:0}.watt-stepper .mat-step-label:not(.mat-step-label-selected){display:none}.watt-stepper .mat-horizontal-content-container{padding:0 0 24px}}.watt-modal--medium watt-stepper,.watt-modal--medium .watt-stepper,.watt-modal--large watt-stepper,.watt-modal--large .watt-stepper{height:100%}.watt-modal--medium .mat-horizontal-stepper-content,.watt-modal--large .mat-horizontal-stepper-content{display:grid;align-items:center;grid-template-rows:1fr auto;grid-template-areas:\"content\" \"actions\"}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-content-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-content-wrapper{align-self:stretch;grid-area:content;overflow:auto}.watt-modal--medium .mat-horizontal-stepper-content .watt-stepper-button-wrapper,.watt-modal--large .mat-horizontal-stepper-content .watt-stepper-button-wrapper{grid-area:actions}\n"] }]
85
85
  }], propDecorators: { completed: [{
86
86
  type: Output
87
87
  }], isCompleting: [{
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
94
94
  args: [MatStepper]
95
95
  }] } });
96
96
  export const WATT_STEPPER = [WattStepperComponent, WattStepperStepComponent];
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-stepper.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/stepper/watt-stepper.component.ts","../../../../libs/watt/package/stepper/watt-stepper.component.html"],"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  AfterViewInit,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  EventEmitter,\n  inject,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { CdkStepper, STEPPER_GLOBAL_OPTIONS, StepperSelectionEvent } from '@angular/cdk/stepper';\nimport { MatStepper, MatStepperModule } from '@angular/material/stepper';\nimport { RxPush } from '@rx-angular/template/push';\nimport { from, map, Observable, of, startWith, withLatestFrom } from 'rxjs';\n\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattIconComponent } from '@energinet/watt/icon';\n\nimport { WattStepperStepComponent } from './watt-stepper-step.component';\n\n@Component({\n  selector: 'watt-stepper',\n  templateUrl: './watt-stepper.component.html',\n  styleUrls: ['./watt-stepper.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  imports: [NgTemplateOutlet, RxPush, MatStepperModule, WattIconComponent, WattButtonComponent],\n  providers: [\n    {\n      provide: STEPPER_GLOBAL_OPTIONS,\n      useValue: { showError: true, displayDefaultIndicatorType: false },\n    },\n    { provide: CdkStepper, useExisting: WattStepperComponent },\n    { provide: MatStepper, useExisting: WattStepperComponent },\n  ],\n})\nexport class WattStepperComponent extends MatStepper implements AfterViewInit {\n  @Output() completed = new EventEmitter<void>();\n  @Input() isCompleting = false;\n\n  @ContentChildren(WattStepperStepComponent, { descendants: true })\n  declare _steps: QueryList<WattStepperStepComponent>;\n\n  @ViewChild(MatStepper) stepper!: MatStepper;\n\n  selectedIndexChanged$!: Observable<StepperSelectionEvent>;\n  onFirstStep$!: Observable<boolean>;\n  onLastStep$!: Observable<boolean>;\n\n  private destroyRef = inject(DestroyRef);\n\n  override reset() {\n    this.stepper.reset();\n  }\n\n  override ngAfterViewInit(): void {\n    this.selectedIndexChanged$ = from(this.stepper.selectionChange);\n    this.onLastStep$ = this.selectedIndexChanged$.pipe(\n      withLatestFrom(of(this._steps)),\n      map(([index, steps]) => index.selectedIndex === steps.filter((x) => x.enabled()).length - 1),\n      startWith(false)\n    );\n    this.onFirstStep$ = this.selectedIndexChanged$.pipe(\n      map((index) => index.selectedIndex === 0),\n      startWith(true)\n    );\n\n    // Emit entering and leaving events\n    this.selectedIndexChanged$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((change) => {\n      this._steps.get(change.selectedIndex)?.entering.emit(change.selectedStep);\n      this._steps.get(change.previouslySelectedIndex)?.leaving.emit(change.previouslySelectedStep);\n    });\n  }\n\n  nextStep(step: WattStepperStepComponent): void {\n    step.next.emit();\n    this.stepper.selected?.stepControl?.markAllAsTouched();\n    this.stepper.next();\n  }\n\n  previousStep(): void {\n    this.stepper.previous();\n  }\n\n  complete(): void {\n    this.stepper.selected?.stepControl?.markAllAsTouched();\n    this.completed.emit();\n  }\n}\n\nexport const WATT_STEPPER = [WattStepperComponent, WattStepperStepComponent];\n","<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<mat-stepper\n  #stepper\n  [disableRipple]=\"disableRipple\"\n  [linear]=\"true\"\n  animationDuration=\"0\"\n  class=\"watt-stepper\"\n>\n  <ng-template let-index=\"index\" matStepperIcon=\"edit\">\n    {{ index + 1 }}\n  </ng-template>\n  <ng-template matStepperIcon=\"done\">\n    <watt-icon name=\"checkmark\" />\n  </ng-template>\n  <ng-template let-index=\"index\" matStepperIcon=\"number\">\n    @if (\n      stepper.steps.get(index)?.completed &&\n      stepper.steps.get(index)?.interacted &&\n      index !== stepper.selectedIndex\n    ) {\n      <watt-icon name=\"checkmark\" />\n    } @else {\n      {{ index + 1 }}\n    }\n  </ng-template>\n  <ng-template let-index=\"index\" matStepperIcon=\"error\">\n    {{ index + 1 }}\n  </ng-template>\n  @for (step of _steps; track step) {\n    @if (step.enabled()) {\n      <mat-step [editable]=\"step.editable\" [stepControl]=\"step.stepControl\">\n        <ng-template matStepLabel>{{ step.label }}</ng-template>\n        <div class=\"watt-stepper-content-wrapper\">\n          <ng-container *ngTemplateOutlet=\"step.templateRef\" />\n        </div>\n        <div class=\"watt-stepper-button-wrapper\">\n          @if (!(onFirstStep$ | push)) {\n            <watt-button\n              [disabled]=\"step.disablePreviousButton()\"\n              variant=\"secondary\"\n              (click)=\"previousStep()\"\n            >\n              <watt-icon name=\"left\" />\n              {{ step.previousButtonLabel() }}\n            </watt-button>\n          }\n\n          @if (!(onLastStep$ | push)) {\n            <watt-button\n              variant=\"secondary\"\n              (click)=\"nextStep(step)\"\n              [loading]=\"step.loadingNextButton()\"\n              [disabled]=\"step.disableNextButton()\"\n            >\n              {{ step.nextButtonLabel() }}\n              <watt-icon name=\"right\" />\n            </watt-button>\n          }\n\n          @if (onLastStep$ | push) {\n            <watt-button\n              variant=\"primary\"\n              [loading]=\"isCompleting\"\n              (click)=\"complete()\"\n              [disabled]=\"step.disableNextButton()\"\n              >{{ step.nextButtonLabel() }}\n            </watt-button>\n          }\n        </div>\n      </mat-step>\n    }\n  }\n</mat-stepper>\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-stepper.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/stepper/watt-stepper.component.ts","../../../../libs/watt/package/stepper/watt-stepper.component.html"],"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  AfterViewInit,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  EventEmitter,\n  inject,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { CdkStepper, STEPPER_GLOBAL_OPTIONS, StepperSelectionEvent } from '@angular/cdk/stepper';\nimport { MatStepper, MatStepperModule } from '@angular/material/stepper';\nimport { RxPush } from '@rx-angular/template/push';\nimport { from, map, Observable, of, startWith, withLatestFrom } from 'rxjs';\n\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattIconComponent } from '@energinet/watt/icon';\n\nimport { WattStepperStepComponent } from './watt-stepper-step.component';\n\n@Component({\n  selector: 'watt-stepper',\n  templateUrl: './watt-stepper.component.html',\n  styleUrls: ['./watt-stepper.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  imports: [NgTemplateOutlet, RxPush, MatStepperModule, WattIconComponent, WattButtonComponent],\n  providers: [\n    {\n      provide: STEPPER_GLOBAL_OPTIONS,\n      useValue: { showError: true, displayDefaultIndicatorType: false },\n    },\n    { provide: CdkStepper, useExisting: WattStepperComponent },\n    { provide: MatStepper, useExisting: WattStepperComponent },\n  ],\n})\nexport class WattStepperComponent extends MatStepper implements AfterViewInit {\n  @Output() completed = new EventEmitter<void>();\n  @Input() isCompleting = false;\n\n  @ContentChildren(WattStepperStepComponent, { descendants: true })\n  declare _steps: QueryList<WattStepperStepComponent>;\n\n  @ViewChild(MatStepper) stepper!: MatStepper;\n\n  selectedIndexChanged$!: Observable<StepperSelectionEvent>;\n  onFirstStep$!: Observable<boolean>;\n  onLastStep$!: Observable<boolean>;\n\n  private destroyRef = inject(DestroyRef);\n\n  override reset() {\n    this.stepper.reset();\n  }\n\n  override ngAfterViewInit(): void {\n    this.selectedIndexChanged$ = from(this.stepper.selectionChange);\n    this.onLastStep$ = this.selectedIndexChanged$.pipe(\n      withLatestFrom(of(this._steps)),\n      map(([index, steps]) => index.selectedIndex === steps.filter((x) => x.enabled()).length - 1),\n      startWith(false)\n    );\n    this.onFirstStep$ = this.selectedIndexChanged$.pipe(\n      map((index) => index.selectedIndex === 0),\n      startWith(true)\n    );\n\n    // Emit entering and leaving events\n    this.selectedIndexChanged$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((change) => {\n      this._steps.get(change.selectedIndex)?.entering.emit(change.selectedStep);\n      this._steps.get(change.previouslySelectedIndex)?.leaving.emit(change.previouslySelectedStep);\n    });\n  }\n\n  nextStep(step: WattStepperStepComponent): void {\n    step.next.emit();\n    this.stepper.selected?.stepControl?.markAllAsTouched();\n    this.stepper.next();\n  }\n\n  previousStep(): void {\n    this.stepper.previous();\n  }\n\n  complete(): void {\n    this.stepper.selected?.stepControl?.markAllAsTouched();\n    this.completed.emit();\n  }\n}\n\nexport const WATT_STEPPER = [WattStepperComponent, WattStepperStepComponent];\n","<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<mat-stepper\n  #stepper\n  [disableRipple]=\"disableRipple\"\n  [linear]=\"true\"\n  animationDuration=\"0\"\n  class=\"watt-stepper\"\n>\n  <ng-template let-index=\"index\" matStepperIcon=\"edit\">\n    {{ index + 1 }}\n  </ng-template>\n  <ng-template matStepperIcon=\"done\">\n    <watt-icon name=\"checkmark\" />\n  </ng-template>\n  <ng-template let-index=\"index\" matStepperIcon=\"number\">\n    @if (\n      stepper.steps.get(index)?.completed &&\n      stepper.steps.get(index)?.interacted &&\n      index !== stepper.selectedIndex\n    ) {\n      <watt-icon name=\"checkmark\" />\n    } @else {\n      {{ index + 1 }}\n    }\n  </ng-template>\n  <ng-template let-index=\"index\" matStepperIcon=\"error\">\n    {{ index + 1 }}\n  </ng-template>\n  @for (step of _steps; track step) {\n    @if (step.enabled()) {\n      <mat-step [editable]=\"step.editable\" [stepControl]=\"step.stepControl\">\n        <ng-template matStepLabel>{{ step.label }}</ng-template>\n        <div class=\"watt-stepper-content-wrapper\">\n          <ng-container *ngTemplateOutlet=\"step.templateRef()\" />\n        </div>\n        <div class=\"watt-stepper-button-wrapper\">\n          @if (!(onFirstStep$ | push)) {\n            <watt-button\n              [disabled]=\"step.disablePreviousButton()\"\n              variant=\"secondary\"\n              (click)=\"previousStep()\"\n            >\n              <watt-icon name=\"left\" />\n              {{ step.previousButtonLabel() }}\n            </watt-button>\n          }\n\n          @if (!(onLastStep$ | push)) {\n            <watt-button\n              variant=\"secondary\"\n              (click)=\"nextStep(step)\"\n              [loading]=\"step.loadingNextButton()\"\n              [disabled]=\"step.disableNextButton()\"\n            >\n              {{ step.nextButtonLabel() }}\n              <watt-icon name=\"right\" />\n            </watt-button>\n          }\n\n          @if (onLastStep$ | push) {\n            <watt-button\n              variant=\"primary\"\n              [loading]=\"isCompleting\"\n              (click)=\"complete()\"\n              [disabled]=\"step.disableNextButton()\"\n              >{{ step.nextButtonLabel() }}\n            </watt-button>\n          }\n        </div>\n      </mat-step>\n    }\n  }\n</mat-stepper>\n"]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "type": "module",
3
3
  "name": "@energinet/watt",
4
- "version": "4.1.24",
4
+ "version": "4.1.26",
5
5
  "license": "Apache-2.0",
6
6
  "exports": {
7
7
  ".": {
@@ -14,7 +14,7 @@
14
14
  * See the License for the specific language governing permissions and
15
15
  * limitations under the License.
16
16
  */
17
- import { ElementRef, OnInit } from '@angular/core';
17
+ import { OnInit, ElementRef } from '@angular/core';
18
18
  import { ControlValueAccessor, FormControl } from '@angular/forms';
19
19
  import { MatSelectChange } from '@angular/material/select';
20
20
  import { type CountryCode } from 'libphonenumber-js';
@@ -36,11 +36,11 @@ export declare class WattPhoneFieldComponent implements ControlValueAccessor, On
36
36
  /** @ignore */
37
37
  intl: WattPhoneFieldIntlService;
38
38
  /** @ignore */
39
- isDisabled: boolean;
39
+ isDisabled: import("@angular/core").WritableSignal<boolean>;
40
40
  /** @ignore */
41
41
  value: string | null;
42
42
  /** @ignore */
43
- phoneNumberInput: ElementRef<HTMLInputElement>;
43
+ phoneNumberInput: import("@angular/core").Signal<ElementRef<HTMLInputElement>>;
44
44
  /** @ignore */
45
45
  ngOnInit(): void;
46
46
  /** @ignore */
@@ -20,7 +20,7 @@ import { CdkStep } from '@angular/cdk/stepper';
20
20
  import * as i0 from "@angular/core";
21
21
  export { CdkStep as WattStep };
22
22
  export declare class WattStepperStepComponent extends MatStep {
23
- templateRef: TemplateRef<unknown> | null;
23
+ readonly templateRef: import("@angular/core").Signal<TemplateRef<unknown> | undefined>;
24
24
  nextButtonLabel: import("@angular/core").InputSignal<string | undefined>;
25
25
  disableNextButton: import("@angular/core").InputSignal<boolean>;
26
26
  loadingNextButton: import("@angular/core").InputSignal<boolean>;