@energinet/watt 4.0.2 → 4.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -89,7 +89,9 @@ export class WattDataTableComponent {
89
89
  <vater-flex [autoSize]="autoSize()" fill="vertical">
90
90
  <ng-content select="watt-table" />
91
91
  @if (
92
- enableEmptyState() && !table().loading && table().dataSource().filteredData.length === 0
92
+ enableEmptyState() &&
93
+ !table().loading() &&
94
+ table().dataSource().filteredData.length === 0
93
95
  ) {
94
96
  <vater-flex [autoSize]="autoSize()" fill="vertical">
95
97
  <vater-stack scrollable justify="center">
@@ -167,7 +169,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
167
169
  <vater-flex [autoSize]="autoSize()" fill="vertical">
168
170
  <ng-content select="watt-table" />
169
171
  @if (
170
- enableEmptyState() && !table().loading && table().dataSource().filteredData.length === 0
172
+ enableEmptyState() &&
173
+ !table().loading() &&
174
+ table().dataSource().filteredData.length === 0
171
175
  ) {
172
176
  <vater-flex [autoSize]="autoSize()" fill="vertical">
173
177
  <vater-stack scrollable justify="center">
@@ -199,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
199
203
  </watt-card>
200
204
  `, styles: ["watt-data-table h3,watt-data-table h4{line-height:44px;min-height:44px;margin:0}watt-data-table watt-paginator{display:block;margin:calc(-1 * var(--watt-space-m)) -24px -24px}watt-data-table watt-table .mat-mdc-table tr.mdc-data-table__row:last-child .mat-mdc-cell{border-bottom:none}watt-data-table watt-empty-state{margin:var(--watt-space-xl) 0}\n"] }]
201
205
  }] });
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-data-table.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/data/watt-data-table.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  contentChild,\n  inject,\n  input,\n  output,\n  viewChild,\n} from '@angular/core';\nimport { PageEvent } from '@angular/material/paginator';\n\nimport {\n  VaterFlexComponent,\n  VaterSpacerComponent,\n  VaterStackComponent,\n  VaterUtilityDirective,\n} from '@energinet/watt/vater';\nimport { WATT_CARD_VARIANT, WattCardComponent } from '@energinet/watt/card';\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattEmptyStateComponent } from '@energinet/watt/empty-state';\nimport { WattPaginatorComponent } from '@energinet/watt/paginator';\nimport { WattSearchComponent } from '@energinet/watt/search';\nimport { WattTableComponent } from '@energinet/watt/table';\nimport { WattIcon } from '@energinet/watt/icon';\n\nimport { WattDataIntlService } from './watt-data-intl.service';\n\n@Component({\n  selector: 'watt-data-table',\n  imports: [\n    VaterFlexComponent,\n    VaterSpacerComponent,\n    VaterStackComponent,\n    VaterUtilityDirective,\n    WattCardComponent,\n    WattEmptyStateComponent,\n    WattPaginatorComponent,\n    WattSearchComponent,\n    WattButtonComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  styles: [\n    `\n      watt-data-table h3,\n      watt-data-table h4 {\n        line-height: 44px;\n        min-height: 44px;\n        margin: 0;\n      }\n\n      watt-data-table watt-paginator {\n        display: block;\n        margin: calc(-1 * var(--watt-space-m)) -24px -24px;\n      }\n\n      watt-data-table watt-table .mat-mdc-table tr.mdc-data-table__row:last-child .mat-mdc-cell {\n        border-bottom: none;\n      }\n\n      watt-data-table watt-empty-state {\n        margin: var(--watt-space-xl) 0;\n      }\n    `,\n  ],\n  template: `\n    <watt-card vater fill=\"vertical\" [variant]=\"variant()\">\n      <vater-flex autoSize fill=\"vertical\" gap=\"m\">\n        @if (header()) {\n          <vater-stack direction=\"row\" gap=\"m\">\n            <vater-stack direction=\"row\" gap=\"s\">\n              <ng-content select=\"h3\" />\n              <ng-content select=\"h4\" />\n              @if (enableCount()) {\n                <span class=\"watt-chip-label\">\n                  {{ count() ?? table().dataSource().totalCount }}\n                </span>\n              }\n              @if (queryTime()) {\n                <span class=\"watt-label\">in {{ queryTime() }} ms</span>\n              }\n            </vater-stack>\n            <ng-content />\n            <vater-spacer />\n            @if (enableSearch()) {\n              <watt-search\n                [label]=\"searchLabel() ?? intl.search\"\n                [trim]=\"trimSearch()\"\n                (search)=\"onSearch($event)\"\n              />\n            }\n            <ng-content select=\"watt-data-actions\" />\n            <ng-content select=\"watt-button\" />\n          </vater-stack>\n        }\n        <ng-content select=\"watt-data-filters\" />\n        <vater-flex [autoSize]=\"autoSize()\" fill=\"vertical\">\n          <ng-content select=\"watt-table\" />\n          @if (\n            enableEmptyState() && !table().loading && table().dataSource().filteredData.length === 0\n          ) {\n            <vater-flex [autoSize]=\"autoSize()\" fill=\"vertical\">\n              <vater-stack scrollable justify=\"center\">\n                <watt-empty-state\n                  [icon]=\"error() ? 'custom-power' : ready() ? emptyStateIcon() : 'custom-explore'\"\n                  [title]=\"\n                    error() ? intl.errorTitle : ready() ? intl.emptyTitle : intl.defaultTitle\n                  \"\n                  [message]=\"error() ? intl.errorText : ready() ? intl.emptyText : intl.defaultText\"\n                >\n                  @if (enableRetry()) {\n                    <watt-button variant=\"secondary\" (click)=\"retry.emit()\">{{\n                      intl.emptyRetry\n                    }}</watt-button>\n                  }\n                </watt-empty-state>\n              </vater-stack>\n            </vater-flex>\n          }\n        </vater-flex>\n        @if (enablePaginator()) {\n          <watt-paginator\n            [for]=\"table().dataSource()\"\n            [length]=\"count() ?? 0\"\n            (changed)=\"pageChanged.emit($event)\"\n          />\n        }\n      </vater-flex>\n    </watt-card>\n  `,\n})\nexport class WattDataTableComponent {\n  intl = inject(WattDataIntlService);\n\n  error = input<unknown>();\n  ready = input(true);\n  enableSearch = input(true);\n  trimSearch = input(true);\n  header = input(true);\n  enableRetry = input(false);\n  enableCount = input(true);\n  enableEmptyState = input(true);\n  queryTime = input<number>();\n  searchLabel = input<string>();\n  enablePaginator = input(true);\n  count = input<number>();\n  autoSize = input(false);\n  variant = input<WATT_CARD_VARIANT>('elevation');\n  emptyStateIcon = input<WattIcon | 'custom-power' | 'custom-explore' | 'custom-no-results'>(\n    'cancel'\n  );\n\n  clear = output();\n  pageChanged = output<PageEvent>();\n  retry = output();\n\n  table = contentChild.required(WattTableComponent<unknown>, { descendants: true });\n\n  search = viewChild(WattSearchComponent);\n  reset = () => this.search()?.clear();\n\n  onSearch(value: string) {\n    this.table().dataSource().filter = value;\n    if (!value) this.clear.emit();\n  }\n}\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-data-table.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/data/watt-data-table.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  contentChild,\n  inject,\n  input,\n  output,\n  viewChild,\n} from '@angular/core';\nimport { PageEvent } from '@angular/material/paginator';\n\nimport {\n  VaterFlexComponent,\n  VaterSpacerComponent,\n  VaterStackComponent,\n  VaterUtilityDirective,\n} from '@energinet/watt/vater';\nimport { WATT_CARD_VARIANT, WattCardComponent } from '@energinet/watt/card';\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattEmptyStateComponent } from '@energinet/watt/empty-state';\nimport { WattPaginatorComponent } from '@energinet/watt/paginator';\nimport { WattSearchComponent } from '@energinet/watt/search';\nimport { WattTableComponent } from '@energinet/watt/table';\nimport { WattIcon } from '@energinet/watt/icon';\n\nimport { WattDataIntlService } from './watt-data-intl.service';\n\n@Component({\n  selector: 'watt-data-table',\n  imports: [\n    VaterFlexComponent,\n    VaterSpacerComponent,\n    VaterStackComponent,\n    VaterUtilityDirective,\n    WattCardComponent,\n    WattEmptyStateComponent,\n    WattPaginatorComponent,\n    WattSearchComponent,\n    WattButtonComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  styles: [\n    `\n      watt-data-table h3,\n      watt-data-table h4 {\n        line-height: 44px;\n        min-height: 44px;\n        margin: 0;\n      }\n\n      watt-data-table watt-paginator {\n        display: block;\n        margin: calc(-1 * var(--watt-space-m)) -24px -24px;\n      }\n\n      watt-data-table watt-table .mat-mdc-table tr.mdc-data-table__row:last-child .mat-mdc-cell {\n        border-bottom: none;\n      }\n\n      watt-data-table watt-empty-state {\n        margin: var(--watt-space-xl) 0;\n      }\n    `,\n  ],\n  template: `\n    <watt-card vater fill=\"vertical\" [variant]=\"variant()\">\n      <vater-flex autoSize fill=\"vertical\" gap=\"m\">\n        @if (header()) {\n          <vater-stack direction=\"row\" gap=\"m\">\n            <vater-stack direction=\"row\" gap=\"s\">\n              <ng-content select=\"h3\" />\n              <ng-content select=\"h4\" />\n              @if (enableCount()) {\n                <span class=\"watt-chip-label\">\n                  {{ count() ?? table().dataSource().totalCount }}\n                </span>\n              }\n              @if (queryTime()) {\n                <span class=\"watt-label\">in {{ queryTime() }} ms</span>\n              }\n            </vater-stack>\n            <ng-content />\n            <vater-spacer />\n            @if (enableSearch()) {\n              <watt-search\n                [label]=\"searchLabel() ?? intl.search\"\n                [trim]=\"trimSearch()\"\n                (search)=\"onSearch($event)\"\n              />\n            }\n            <ng-content select=\"watt-data-actions\" />\n            <ng-content select=\"watt-button\" />\n          </vater-stack>\n        }\n        <ng-content select=\"watt-data-filters\" />\n        <vater-flex [autoSize]=\"autoSize()\" fill=\"vertical\">\n          <ng-content select=\"watt-table\" />\n          @if (\n            enableEmptyState() &&\n            !table().loading() &&\n            table().dataSource().filteredData.length === 0\n          ) {\n            <vater-flex [autoSize]=\"autoSize()\" fill=\"vertical\">\n              <vater-stack scrollable justify=\"center\">\n                <watt-empty-state\n                  [icon]=\"error() ? 'custom-power' : ready() ? emptyStateIcon() : 'custom-explore'\"\n                  [title]=\"\n                    error() ? intl.errorTitle : ready() ? intl.emptyTitle : intl.defaultTitle\n                  \"\n                  [message]=\"error() ? intl.errorText : ready() ? intl.emptyText : intl.defaultText\"\n                >\n                  @if (enableRetry()) {\n                    <watt-button variant=\"secondary\" (click)=\"retry.emit()\">{{\n                      intl.emptyRetry\n                    }}</watt-button>\n                  }\n                </watt-empty-state>\n              </vater-stack>\n            </vater-flex>\n          }\n        </vater-flex>\n        @if (enablePaginator()) {\n          <watt-paginator\n            [for]=\"table().dataSource()\"\n            [length]=\"count() ?? 0\"\n            (changed)=\"pageChanged.emit($event)\"\n          />\n        }\n      </vater-flex>\n    </watt-card>\n  `,\n})\nexport class WattDataTableComponent {\n  intl = inject(WattDataIntlService);\n\n  error = input<unknown>();\n  ready = input(true);\n  enableSearch = input(true);\n  trimSearch = input(true);\n  header = input(true);\n  enableRetry = input(false);\n  enableCount = input(true);\n  enableEmptyState = input(true);\n  queryTime = input<number>();\n  searchLabel = input<string>();\n  enablePaginator = input(true);\n  count = input<number>();\n  autoSize = input(false);\n  variant = input<WATT_CARD_VARIANT>('elevation');\n  emptyStateIcon = input<WattIcon | 'custom-power' | 'custom-explore' | 'custom-no-results'>(\n    'cancel'\n  );\n\n  clear = output();\n  pageChanged = output<PageEvent>();\n  retry = output();\n\n  table = contentChild.required(WattTableComponent<unknown>, { descendants: true });\n\n  search = viewChild(WattSearchComponent);\n  reset = () => this.search()?.clear();\n\n  onSearch(value: string) {\n    this.table().dataSource().filter = value;\n    if (!value) this.clear.emit();\n  }\n}\n"]}
@@ -16,22 +16,24 @@
16
16
  * limitations under the License.
17
17
  */
18
18
  //#endregion
19
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
20
- import { ChangeDetectorRef, DestroyRef, Directive, ElementRef, HostBinding, Input, inject, } from '@angular/core';
19
+ import { Input, inject, Directive, ElementRef, DestroyRef, HostBinding, ChangeDetectorRef, input, } from '@angular/core';
21
20
  import { NgControl } from '@angular/forms';
21
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
22
22
  import { Subject } from 'rxjs';
23
23
  import * as i0 from "@angular/core";
24
24
  export class WattPickerBase {
25
- elementRef = inject(ElementRef);
25
+ destroyRef = inject(DestroyRef);
26
26
  changeDetectionRef = inject(ChangeDetectorRef);
27
27
  ngControl = inject(NgControl, { optional: true });
28
+ elementRef = inject(ElementRef);
28
29
  static nextId = 0;
29
30
  id;
30
31
  initialValue = null;
31
32
  focused = false;
32
33
  controlType = 'mat-date-range-input'; // We keep the controlType of Material Date Range Input as is, to keep some styling.
33
34
  stateChanges = new Subject();
34
- _destroyRef = inject(DestroyRef);
35
+ // eslint-disable-next-line @angular-eslint/no-input-rename
36
+ userAriaDescribedBy = input(undefined, ...(ngDevMode ? [{ debugName: "userAriaDescribedBy", alias: 'aria-describedby' }] : [{ alias: 'aria-describedby' }]));
35
37
  get placeholder() {
36
38
  return this._placeholder;
37
39
  }
@@ -47,20 +49,22 @@ export class WattPickerBase {
47
49
  return null;
48
50
  }
49
51
  set value(value) {
50
- const inputNotToBeInTheDocument = !this.range ? !this.input() : !this.startInput();
52
+ const input = this.input();
53
+ const startInput = this.startInput();
54
+ const endInput = this.endInput();
55
+ const inputNotToBeInTheDocument = !this.range ? !input : !startInput;
51
56
  if (inputNotToBeInTheDocument) {
52
57
  this.initialValue = value;
53
58
  return;
54
59
  }
55
- const startInput = this.startInput();
56
- const endInput = this.endInput();
57
- const input = this.input();
58
- if (!startInput || !endInput || !input)
59
- return;
60
60
  if (this.range) {
61
+ if (!startInput || !endInput)
62
+ return;
61
63
  this.setRangeValue(value, startInput.nativeElement, endInput.nativeElement);
62
64
  }
63
65
  else {
66
+ if (!input)
67
+ return;
64
68
  this.setSingleValue(value, input.nativeElement);
65
69
  }
66
70
  this.stateChanges.next();
@@ -174,7 +178,7 @@ export class WattPickerBase {
174
178
  // Intentionally left empty
175
179
  };
176
180
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattPickerBase, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
177
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.1.3", type: WattPickerBase, isStandalone: true, inputs: { value: "value", range: "range", required: "required", disabled: "disabled" }, host: { properties: { "attr.watt-field-disabled": "this.disabled" } }, ngImport: i0 });
181
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "20.1.3", type: WattPickerBase, isStandalone: true, inputs: { userAriaDescribedBy: { classPropertyName: "userAriaDescribedBy", publicName: "aria-describedby", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null }, range: { classPropertyName: "range", publicName: "range", isSignal: false, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null } }, host: { properties: { "attr.watt-field-disabled": "this.disabled" } }, ngImport: i0 });
178
182
  }
179
183
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattPickerBase, decorators: [{
180
184
  type: Directive
@@ -190,4 +194,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
190
194
  }, {
191
195
  type: Input
192
196
  }] } });
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-picker-base.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/__shared/watt-picker-base.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 { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  DestroyRef,\n  Directive,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  Signal,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\nimport { Subject } from 'rxjs';\n\nimport { WattDateRange } from '@energinet/watt/core/date';\nimport { WattPickerValue } from './watt-picker-value';\n\n@Directive()\nexport abstract class WattPickerBase\n  implements OnInit, AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  protected elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected changeDetectionRef = inject(ChangeDetectorRef);\n  protected ngControl = inject(NgControl, { optional: true });\n\n  protected abstract input: Signal<ElementRef<HTMLInputElement> | undefined>;\n\n  protected abstract startInput: Signal<ElementRef<HTMLInputElement> | undefined>;\n\n  protected abstract endInput: Signal<ElementRef<HTMLInputElement> | undefined>;\n\n  static nextId = 0;\n\n  id: string;\n\n  initialValue: WattPickerValue = null;\n\n  focused = false;\n\n  controlType = 'mat-date-range-input'; // We keep the controlType of Material Date Range Input as is, to keep some styling.\n\n  stateChanges = new Subject<void>();\n\n  protected _destroyRef = inject(DestroyRef);\n\n  get placeholder(): string {\n    return this._placeholder;\n  }\n\n  set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n\n  protected abstract _placeholder: string;\n\n  @Input()\n  get value(): WattDateRange | null {\n    if (this.ngControl?.valid) {\n      const {\n        value: { start, end },\n      } = this.ngControl;\n\n      return { start, end };\n    }\n\n    return null;\n  }\n\n  set value(value: WattPickerValue) {\n    const inputNotToBeInTheDocument = !this.range ? !this.input() : !this.startInput();\n\n    if (inputNotToBeInTheDocument) {\n      this.initialValue = value;\n      return;\n    }\n\n    const startInput = this.startInput();\n    const endInput = this.endInput();\n    const input = this.input();\n\n    if (!startInput || !endInput || !input) return;\n\n    if (this.range) {\n      this.setRangeValue(value as WattDateRange, startInput.nativeElement, endInput.nativeElement);\n    } else {\n      this.setSingleValue(value as Exclude<WattPickerValue, WattDateRange>, input.nativeElement);\n    }\n\n    this.stateChanges.next();\n  }\n\n  @Input()\n  set range(range: boolean) {\n    this._range = coerceBooleanProperty(range);\n  }\n  get range(): boolean {\n    return this._range;\n  }\n\n  private _range = false;\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n\n  set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n\n  private _required = false;\n\n  @HostBinding('attr.watt-field-disabled')\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n\n  private _disabled = false;\n\n  get empty() {\n    if (this.range) {\n      return !this.ngControl?.value?.start && !this.ngControl?.value?.end;\n    } else {\n      return this.ngControl?.value?.length === 0;\n    }\n  }\n\n  get errorState(): boolean {\n    return !!this.ngControl?.invalid && !!this.ngControl?.touched;\n  }\n\n  get shouldLabelFloat() {\n    return this.focused || !this.empty;\n  }\n\n  /**\n   *\n   * @ignore\n   */\n  control: FormControl | null = null;\n\n  constructor(id: string) {\n    this.id = id;\n    this.elementRef.nativeElement.setAttribute('id', id);\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.control = this.ngControl?.control as FormControl;\n  }\n\n  ngAfterViewInit() {\n    if (this.initialValue) {\n      this.writeValue(this.initialValue);\n    }\n\n    if (this.range) {\n      this.initRangeInput();\n    } else {\n      this.initSingleInput();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  protected abstract initRangeInput(): void;\n\n  protected abstract initSingleInput(): void;\n\n  protected abstract setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ): void;\n\n  protected abstract setRangeValue(\n    value: WattDateRange,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ): void;\n\n  setDescribedByIds(ids: string[]) {\n    this.elementRef.nativeElement.setAttribute('aria-describedby', ids.join(' '));\n  }\n\n  onContainerClick() {\n    // Intentionally left empty\n  }\n\n  writeValue(value: WattPickerValue): void {\n    this.value = value;\n  }\n\n  registerOnChange(onChangeFn: (value: string | WattDateRange) => void): void {\n    this.changeParentValue = onChangeFn;\n  }\n\n  registerOnTouched(onTouchFn: () => void) {\n    this.markParentControlAsTouched = onTouchFn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.changeDetectionRef.detectChanges();\n  }\n\n  onFocusIn() {\n    if (!this.focused) {\n      this.focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  onFocusOut(event: FocusEvent) {\n    const id = this.elementRef.nativeElement.attributes.getNamedItem('aria-owns');\n    const overlay = id ? document.getElementById(id.value) : null;\n    const isChild = overlay?.contains(event.relatedTarget as Element);\n\n    if (!this.elementRef.nativeElement.contains(event.relatedTarget as Element) && !isChild) {\n      this.focused = false;\n      this.markParentControlAsTouched();\n      this.stateChanges.next();\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected changeParentValue = (value: string | WattDateRange): void => {\n    // Intentionally left empty\n  };\n\n  protected markParentControlAsTouched = (): void => {\n    // Intentionally left empty\n  };\n}\n"]}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-picker-base.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/__shared/watt-picker-base.ts"],"names":[],"mappings":"AAAA,iBAAiB;AACjB;;;;;;;;;;;;;;;GAeG;AACH,YAAY;AACZ,OAAO,EACL,KAAK,EAGL,MAAM,EACN,SAAS,EAET,UAAU,EACV,UAAU,EACV,WAAW,EAEX,iBAAiB,EACjB,KAAK,GACN,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAqC,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAgB,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAE5E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;AAM/B,MAAM,OAAgB,cAAc;IAGxB,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAChC,kBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC/C,SAAS,GAAG,MAAM,CAAC,SAAS,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;IAClD,UAAU,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;IAMnE,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;IAElB,EAAE,CAAS;IAEX,YAAY,GAAoB,IAAI,CAAC;IAErC,OAAO,GAAG,KAAK,CAAC;IAEhB,WAAW,GAAG,sBAAsB,CAAC,CAAC,oFAAoF;IAE1H,YAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;IAEnC,2DAA2D;IAC3D,mBAAmB,GAAG,KAAK,CAAS,SAAS,uDAAI,KAAK,EAAE,kBAAkB,OAA3B,EAAE,KAAK,EAAE,kBAAkB,EAAE,GAAC,CAAC;IAE9E,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,IAAI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAID,IACI,KAAK;QACP,IAAI,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;YAC1B,MAAM,EACJ,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,GACtB,GAAG,IAAI,CAAC,SAAS,CAAC;YAEnB,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;QACxB,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,KAAK,CAAC,KAAsB;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC3B,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEjC,MAAM,yBAAyB,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;QAErE,IAAI,yBAAyB,EAAE,CAAC;YAC9B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,UAAU,IAAI,CAAC,QAAQ;gBAAE,OAAO;YACrC,IAAI,CAAC,aAAa,CAAC,KAAsB,EAAE,UAAU,CAAC,aAAa,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC/F,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK;gBAAE,OAAO;YACnB,IAAI,CAAC,cAAc,CAAC,KAAgD,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;QAC7F,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,IACI,KAAK,CAAC,KAAc;QACtB,IAAI,CAAC,MAAM,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAEO,MAAM,GAAG,KAAK,CAAC;IAEvB,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAmB;QAC9B,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAEO,SAAS,GAAG,KAAK,CAAC;IAE1B,IAEI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAmB;QAC9B,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAEO,SAAS,GAAG,KAAK,CAAC;IAE1B,IAAI,KAAK;QACP,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,GAAG,CAAC;QACtE,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,MAAM,KAAK,CAAC,CAAC;QAC7C,CAAC;IACH,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;IAChE,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,OAAO,GAAuB,IAAI,CAAC;IAEnC,YAAY,EAAU;QACpB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAErD,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,OAAsB,CAAC;IACxD,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACrC,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAiBD,iBAAiB,CAAC,GAAa;QAC7B,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IAChF,CAAC;IAED,gBAAgB;QACd,2BAA2B;IAC7B,CAAC;IAED,UAAU,CAAC,KAAsB;QAC/B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,UAAmD;QAClE,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC;IACtC,CAAC;IAED,iBAAiB,CAAC,SAAqB;QACrC,IAAI,CAAC,0BAA0B,GAAG,SAAS,CAAC;IAC9C,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;IAC1C,CAAC;IAED,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAiB;QAC1B,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAC9E,MAAM,OAAO,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9D,MAAM,OAAO,GAAG,OAAO,EAAE,QAAQ,CAAC,KAAK,CAAC,aAAwB,CAAC,CAAC;QAElE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAwB,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACxF,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,0BAA0B,EAAE,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,6DAA6D;IACnD,iBAAiB,GAAG,CAAC,KAA6B,EAAQ,EAAE;QACpE,2BAA2B;IAC7B,CAAC,CAAC;IAEQ,0BAA0B,GAAG,GAAS,EAAE;QAChD,2BAA2B;IAC7B,CAAC,CAAC;uGAlOkB,cAAc;2FAAd,cAAc;;2FAAd,cAAc;kBADnC,SAAS;2EAwCJ,KAAK;sBADR,KAAK;gBAqCF,KAAK;sBADR,KAAK;gBAWF,QAAQ;sBADX,KAAK;gBAcF,QAAQ;sBAFX,WAAW;uBAAC,0BAA0B;;sBACtC,KAAK","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  Input,\n  OnInit,\n  Signal,\n  inject,\n  Directive,\n  OnDestroy,\n  ElementRef,\n  DestroyRef,\n  HostBinding,\n  AfterViewInit,\n  ChangeDetectorRef,\n  input,\n} from '@angular/core';\n\nimport { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\n\nimport { Subject } from 'rxjs';\n\nimport { WattDateRange } from '@energinet/watt/core/date';\n\nimport { WattPickerValue } from './watt-picker-value';\n@Directive()\nexport abstract class WattPickerBase\n  implements OnInit, AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  protected destroyRef = inject(DestroyRef);\n  protected changeDetectionRef = inject(ChangeDetectorRef);\n  protected ngControl = inject(NgControl, { optional: true });\n  protected elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  abstract input: Signal<ElementRef<HTMLInputElement> | undefined>;\n  abstract endInput: Signal<ElementRef<HTMLInputElement> | undefined>;\n  abstract startInput: Signal<ElementRef<HTMLInputElement> | undefined>;\n\n  static nextId = 0;\n\n  id: string;\n\n  initialValue: WattPickerValue = null;\n\n  focused = false;\n\n  controlType = 'mat-date-range-input'; // We keep the controlType of Material Date Range Input as is, to keep some styling.\n\n  stateChanges = new Subject<void>();\n\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  userAriaDescribedBy = input<string>(undefined, { alias: 'aria-describedby' });\n\n  get placeholder(): string {\n    return this._placeholder;\n  }\n\n  set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n\n  protected abstract _placeholder: string;\n\n  @Input()\n  get value(): WattDateRange | null {\n    if (this.ngControl?.valid) {\n      const {\n        value: { start, end },\n      } = this.ngControl;\n\n      return { start, end };\n    }\n\n    return null;\n  }\n\n  set value(value: WattPickerValue) {\n    const input = this.input();\n    const startInput = this.startInput();\n    const endInput = this.endInput();\n\n    const inputNotToBeInTheDocument = !this.range ? !input : !startInput;\n\n    if (inputNotToBeInTheDocument) {\n      this.initialValue = value;\n      return;\n    }\n\n    if (this.range) {\n      if (!startInput || !endInput) return;\n      this.setRangeValue(value as WattDateRange, startInput.nativeElement, endInput.nativeElement);\n    } else {\n      if (!input) return;\n      this.setSingleValue(value as Exclude<WattPickerValue, WattDateRange>, input.nativeElement);\n    }\n\n    this.stateChanges.next();\n  }\n\n  @Input()\n  set range(range: boolean) {\n    this._range = coerceBooleanProperty(range);\n  }\n  get range(): boolean {\n    return this._range;\n  }\n\n  private _range = false;\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n\n  set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n\n  private _required = false;\n\n  @HostBinding('attr.watt-field-disabled')\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n\n  private _disabled = false;\n\n  get empty() {\n    if (this.range) {\n      return !this.ngControl?.value?.start && !this.ngControl?.value?.end;\n    } else {\n      return this.ngControl?.value?.length === 0;\n    }\n  }\n\n  get errorState(): boolean {\n    return !!this.ngControl?.invalid && !!this.ngControl?.touched;\n  }\n\n  get shouldLabelFloat() {\n    return this.focused || !this.empty;\n  }\n\n  /**\n   *\n   * @ignore\n   */\n  control: FormControl | null = null;\n\n  constructor(id: string) {\n    this.id = id;\n    this.elementRef.nativeElement.setAttribute('id', id);\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.control = this.ngControl?.control as FormControl;\n  }\n\n  ngAfterViewInit() {\n    if (this.initialValue) {\n      this.writeValue(this.initialValue);\n    }\n\n    if (this.range) {\n      this.initRangeInput();\n    } else {\n      this.initSingleInput();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  protected abstract initRangeInput(): void;\n\n  protected abstract initSingleInput(): void;\n\n  protected abstract setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ): void;\n\n  protected abstract setRangeValue(\n    value: WattDateRange,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ): void;\n\n  setDescribedByIds(ids: string[]) {\n    this.elementRef.nativeElement.setAttribute('aria-describedby', ids.join(' '));\n  }\n\n  onContainerClick() {\n    // Intentionally left empty\n  }\n\n  writeValue(value: WattPickerValue): void {\n    this.value = value;\n  }\n\n  registerOnChange(onChangeFn: (value: string | WattDateRange) => void): void {\n    this.changeParentValue = onChangeFn;\n  }\n\n  registerOnTouched(onTouchFn: () => void) {\n    this.markParentControlAsTouched = onTouchFn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.changeDetectionRef.detectChanges();\n  }\n\n  onFocusIn() {\n    if (!this.focused) {\n      this.focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  onFocusOut(event: FocusEvent) {\n    const id = this.elementRef.nativeElement.attributes.getNamedItem('aria-owns');\n    const overlay = id ? document.getElementById(id.value) : null;\n    const isChild = overlay?.contains(event.relatedTarget as Element);\n\n    if (!this.elementRef.nativeElement.contains(event.relatedTarget as Element) && !isChild) {\n      this.focused = false;\n      this.markParentControlAsTouched();\n      this.stateChanges.next();\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected changeParentValue = (value: string | WattDateRange): void => {\n    // Intentionally left empty\n  };\n\n  protected markParentControlAsTouched = (): void => {\n    // Intentionally left empty\n  };\n}\n"]}