@energinet/watt 4.0.2 → 4.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/picker/__shared/watt-picker-base.js +16 -12
- package/esm2022/picker/datepicker/watt-datepicker.component.js +55 -38
- package/esm2022/picker/timepicker/watt-timepicker.component.js +1 -1
- package/package.json +1 -1
- package/picker/__shared/watt-picker-base.d.ts +9 -8
- package/picker/datepicker/watt-datepicker.component.d.ts +15 -15
- package/picker/timepicker/watt-timepicker.component.d.ts +3 -3
|
@@ -16,22 +16,24 @@
|
|
|
16
16
|
* limitations under the License.
|
|
17
17
|
*/
|
|
18
18
|
//#endregion
|
|
19
|
-
import {
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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: "
|
|
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":"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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  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"]}
|
|
@@ -16,19 +16,19 @@
|
|
|
16
16
|
* limitations under the License.
|
|
17
17
|
*/
|
|
18
18
|
//#endregion
|
|
19
|
-
import {
|
|
20
|
-
import { NgControl } from '@angular/forms';
|
|
21
|
-
import { MatDateRangeInput, MatDateRangePicker, MatDatepickerInput, MatDatepickerModule, MatEndDate, MatStartDate, } from '@angular/material/datepicker';
|
|
22
|
-
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
19
|
+
import { input, effect, inject, computed, Component, LOCALE_ID, viewChild, ElementRef, linkedSignal, booleanAttribute, ChangeDetectorRef, ViewEncapsulation, } from '@angular/core';
|
|
23
20
|
import { MatInputModule } from '@angular/material/input';
|
|
21
|
+
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
22
|
+
import { NgControl } from '@angular/forms';
|
|
23
|
+
import { MatEndDate, MatStartDate, MatDateRangeInput, MatDateRangePicker, MatDatepickerInput, MatDatepickerModule, } from '@angular/material/datepicker';
|
|
24
24
|
import { maskitoDateOptionsGenerator, maskitoDateRangeOptionsGenerator } from '@maskito/kit';
|
|
25
|
+
import { dayjs, WattLocaleService, } from '@energinet/watt/core/date';
|
|
25
26
|
import { WattFieldComponent } from '@energinet/watt/field';
|
|
26
|
-
import { WattLocaleService, dayjs, } from '@energinet/watt/core/date';
|
|
27
27
|
import { WattButtonComponent } from '@energinet/watt/button';
|
|
28
28
|
import { WattPickerBase, WattPlaceholderMaskComponent, } from '@energinet/watt/picker/__shared';
|
|
29
29
|
import * as i0 from "@angular/core";
|
|
30
|
-
import * as i1 from "@angular/material/
|
|
31
|
-
import * as i2 from "@angular/material/
|
|
30
|
+
import * as i1 from "@angular/material/input";
|
|
31
|
+
import * as i2 from "@angular/material/datepicker";
|
|
32
32
|
const dateShortFormat = 'DD-MM-YYYY';
|
|
33
33
|
export const danishTimeZoneIdentifier = 'Europe/Copenhagen';
|
|
34
34
|
/**
|
|
@@ -46,20 +46,20 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
46
46
|
locale = inject(LOCALE_ID);
|
|
47
47
|
max = input(...(ngDevMode ? [undefined, { debugName: "max" }] : []));
|
|
48
48
|
min = input(...(ngDevMode ? [undefined, { debugName: "min" }] : []));
|
|
49
|
+
label = input('', ...(ngDevMode ? [{ debugName: "label" }] : []));
|
|
49
50
|
rangeMonthOnlyMode = input(false, ...(ngDevMode ? [{ debugName: "rangeMonthOnlyMode" }] : []));
|
|
50
51
|
startAt = input(null, ...(ngDevMode ? [{ debugName: "startAt" }] : []));
|
|
51
|
-
label = input('', ...(ngDevMode ? [{ debugName: "label" }] : []));
|
|
52
52
|
dateClass = input(() => '', ...(ngDevMode ? [{ debugName: "dateClass" }] : []));
|
|
53
53
|
canStepThroughDays = input(false, ...(ngDevMode ? [{ debugName: "canStepThroughDays", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
matDateRangeInput = viewChild
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
actualInput = viewChild
|
|
54
|
+
matEndDate = viewChild(MatEndDate, ...(ngDevMode ? [{ debugName: "matEndDate" }] : []));
|
|
55
|
+
matStartDate = viewChild(MatStartDate, ...(ngDevMode ? [{ debugName: "matStartDate" }] : []));
|
|
56
|
+
matDateRangeInput = viewChild(MatDateRangeInput, ...(ngDevMode ? [{ debugName: "matDateRangeInput" }] : []));
|
|
57
|
+
matDatepickerInput = viewChild(MatDatepickerInput, ...(ngDevMode ? [{ debugName: "matDatepickerInput" }] : []));
|
|
58
|
+
matDateRangePicker = viewChild(MatDateRangePicker, ...(ngDevMode ? [{ debugName: "matDateRangePicker" }] : []));
|
|
59
|
+
actualInput = viewChild('actualInput', ...(ngDevMode ? [{ debugName: "actualInput" }] : []));
|
|
60
60
|
input = viewChild('dateInput', ...(ngDevMode ? [{ debugName: "input" }] : []));
|
|
61
|
-
startInput = viewChild('startDateInput', ...(ngDevMode ? [{ debugName: "startInput" }] : []));
|
|
62
61
|
endInput = viewChild('endDateInput', ...(ngDevMode ? [{ debugName: "endInput" }] : []));
|
|
62
|
+
startInput = viewChild('startDateInput', ...(ngDevMode ? [{ debugName: "startInput" }] : []));
|
|
63
63
|
_placeholder = this.getPlaceholderByLocale(this.locale);
|
|
64
64
|
rangeSeparator = ' - ';
|
|
65
65
|
rangePlaceholder = this.getRangePlaceholder();
|
|
@@ -97,9 +97,9 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
97
97
|
}
|
|
98
98
|
ngAfterViewInit() {
|
|
99
99
|
super.ngAfterViewInit();
|
|
100
|
-
this.ngControl?.control?.addValidators(this.validate
|
|
100
|
+
this.ngControl?.control?.addValidators(this.validate);
|
|
101
101
|
}
|
|
102
|
-
validate({ value }) {
|
|
102
|
+
validate = ({ value }) => {
|
|
103
103
|
if (!value?.end || !value?.start)
|
|
104
104
|
return null;
|
|
105
105
|
if (!this.rangeMonthOnlyMode())
|
|
@@ -109,10 +109,11 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
109
109
|
return start.isSame(start.startOf('month')) && end.isSame(start.endOf('month'))
|
|
110
110
|
? null
|
|
111
111
|
: { monthOnly: true };
|
|
112
|
-
}
|
|
112
|
+
};
|
|
113
113
|
initSingleInput() {
|
|
114
|
-
|
|
115
|
-
|
|
114
|
+
const matDatepickerInput = this.matDatepickerInput();
|
|
115
|
+
if (this.initialValue && matDatepickerInput) {
|
|
116
|
+
matDatepickerInput.value = this.initialValue;
|
|
116
117
|
this.datepickerClosed();
|
|
117
118
|
}
|
|
118
119
|
}
|
|
@@ -131,7 +132,9 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
131
132
|
datepickerClosed() {
|
|
132
133
|
const matDatepickerInput = this.matDatepickerInput();
|
|
133
134
|
const actualInput = this.actualInput();
|
|
134
|
-
if (
|
|
135
|
+
if (!actualInput)
|
|
136
|
+
return;
|
|
137
|
+
if (matDatepickerInput && matDatepickerInput.value) {
|
|
135
138
|
this.control?.setValue(matDatepickerInput.value);
|
|
136
139
|
actualInput.nativeElement.value = this.formatDateTimeFromModelToView(this.formatDateFromViewToModel(matDatepickerInput.value));
|
|
137
140
|
}
|
|
@@ -144,22 +147,27 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
144
147
|
actualInput.nativeElement.dispatchEvent(new InputEvent('input'));
|
|
145
148
|
}
|
|
146
149
|
onMonthSelected(date) {
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
150
|
+
const matDateRangePicker = this.matDateRangePicker();
|
|
151
|
+
if (matDateRangePicker && this.rangeMonthOnlyMode() && date) {
|
|
152
|
+
matDateRangePicker.select(dayjs(date).startOf('month').toDate());
|
|
153
|
+
matDateRangePicker.select(dayjs(date).endOf('month').toDate());
|
|
154
|
+
matDateRangePicker.close();
|
|
151
155
|
}
|
|
152
156
|
}
|
|
153
157
|
initRangeInput() {
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
158
|
+
const matStartDate = this.matStartDate();
|
|
159
|
+
const matEndDate = this.matEndDate();
|
|
160
|
+
if (this.initialValue && matStartDate && matEndDate) {
|
|
161
|
+
matStartDate.value = this.initialValue.start;
|
|
162
|
+
matEndDate.value = this.initialValue.end;
|
|
157
163
|
this.rangePickerClosed();
|
|
158
164
|
}
|
|
159
165
|
}
|
|
160
166
|
clearRangePicker() {
|
|
161
|
-
this.control?.setValue(null);
|
|
162
167
|
const actualInput = this.actualInput();
|
|
168
|
+
if (!actualInput)
|
|
169
|
+
return;
|
|
170
|
+
this.control?.setValue(null);
|
|
163
171
|
actualInput.nativeElement.value = '';
|
|
164
172
|
actualInput.nativeElement.dispatchEvent(new InputEvent('input'));
|
|
165
173
|
}
|
|
@@ -183,7 +191,9 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
183
191
|
rangePickerClosed() {
|
|
184
192
|
const matDateRangeInput = this.matDateRangeInput();
|
|
185
193
|
const actualInput = this.actualInput();
|
|
186
|
-
if (
|
|
194
|
+
if (!actualInput)
|
|
195
|
+
return;
|
|
196
|
+
if (matDateRangeInput?.value?.start && matDateRangeInput?.value?.end) {
|
|
187
197
|
actualInput.nativeElement.value =
|
|
188
198
|
this.formatDateTimeFromModelToView(this.formatDateFromViewToModel(matDateRangeInput.value?.start)) +
|
|
189
199
|
'-' +
|
|
@@ -200,12 +210,19 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
200
210
|
actualInput.nativeElement.dispatchEvent(new InputEvent('input'));
|
|
201
211
|
}
|
|
202
212
|
setSingleValue(value, input) {
|
|
203
|
-
|
|
213
|
+
const matDatepickerInput = this.matDatepickerInput();
|
|
214
|
+
if (matDatepickerInput) {
|
|
215
|
+
this.setValueToInput(value, input, matDatepickerInput);
|
|
216
|
+
}
|
|
204
217
|
}
|
|
205
218
|
setRangeValue(value, startInput, endInput) {
|
|
206
219
|
const { start, end } = value ?? {};
|
|
207
|
-
|
|
208
|
-
|
|
220
|
+
const matStartDate = this.matStartDate();
|
|
221
|
+
const matEndDate = this.matEndDate();
|
|
222
|
+
if (!matStartDate || !matEndDate)
|
|
223
|
+
return;
|
|
224
|
+
this.setValueToInput(start, startInput, matStartDate);
|
|
225
|
+
this.setValueToInput(end, endInput, matEndDate);
|
|
209
226
|
}
|
|
210
227
|
prevDay() {
|
|
211
228
|
this.changeDay(-1);
|
|
@@ -214,7 +231,7 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
214
231
|
this.changeDay(1);
|
|
215
232
|
}
|
|
216
233
|
changeDay(value) {
|
|
217
|
-
const currentDate = this.matDatepickerInput()
|
|
234
|
+
const currentDate = this.matDatepickerInput()?.value;
|
|
218
235
|
if (currentDate) {
|
|
219
236
|
const newDate = dayjs(currentDate).add(value, 'day').toISOString();
|
|
220
237
|
const newDateFormatted = this.formatDateTimeFromModelToView(newDate);
|
|
@@ -272,16 +289,16 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
272
289
|
return maybeDateInDanishTimeZone;
|
|
273
290
|
}
|
|
274
291
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattDatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
275
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattDatepickerComponent, isStandalone: true, selector: "watt-datepicker", inputs: { max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, rangeMonthOnlyMode: { classPropertyName: "rangeMonthOnlyMode", publicName: "rangeMonthOnlyMode", isSignal: true, isRequired: false, transformFunction: null }, startAt: { classPropertyName: "startAt", publicName: "startAt", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, dateClass: { classPropertyName: "dateClass", publicName: "dateClass", isSignal: true, isRequired: false, transformFunction: null }, canStepThroughDays: { classPropertyName: "canStepThroughDays", publicName: "canStepThroughDays", isSignal: true, isRequired: false, transformFunction: null } }, providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }], viewQueries: [{ propertyName: "matDatepickerInput", first: true, predicate: MatDatepickerInput, descendants: true, isSignal: true }, { propertyName: "matDateRangePicker", first: true, predicate: MatDateRangePicker, descendants: true, isSignal: true }, { propertyName: "matDateRangeInput", first: true, predicate: MatDateRangeInput, descendants: true, isSignal: true }, { propertyName: "matStartDate", first: true, predicate: MatStartDate, descendants: true, isSignal: true }, { propertyName: "matEndDate", first: true, predicate: MatEndDate, descendants: true, isSignal: true }, { propertyName: "actualInput", first: true, predicate: ["actualInput"], descendants: true, isSignal: true }, { propertyName: "input", first: true, predicate: ["dateInput"], descendants: true, isSignal: true }, { propertyName: "startInput", first: true, predicate: ["startDateInput"], descendants: true, isSignal: true }, { propertyName: "endInput", first: true, predicate: ["endDateInput"], descendants: true, isSignal: 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<watt-field [control]=\"control\" [label]=\"label()\">\n @if (range) {\n <mat-date-range-input\n [disabled]=\"disabled\"\n [rangePicker]=\"rangeDatepicker\"\n [min]=\"min() ?? null\"\n [max]=\"max() ?? null\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n >\n <input\n inert\n aria-label=\"start-date-input\"\n matStartDate\n #startDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n\n <input\n inert\n aria-label=\"end-date-input\"\n matEndDate\n #endDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n </mat-date-range-input>\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"rangeInputMask()\"\n [placeholder]=\"rangePlaceholder\"\n (maskApplied)=\"rangeInputChanged($event)\"\n />\n\n <watt-button\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n [attr.aria-pressed]=\"false\"\n (click)=\"rangeDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-date-range-picker\n [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n [startAt]=\"startAt()\"\n (monthSelected)=\"onMonthSelected($event)\"\n (closed)=\"rangePickerClosed()\"\n #rangeDatepicker\n />\n } @else {\n <input\n inert\n matInput\n tabindex=\"-1\"\n aria-label=\"date-input\"\n #dateInput\n autocomplete=\"off\"\n spellcheck=\"false\"\n [disabled]=\"disabled\"\n [min]=\"min()\"\n [max]=\"max()\"\n [matDatepicker]=\"singleDatepicker\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"inputMask()\"\n [placeholder]=\"placeholder\"\n (maskApplied)=\"inputChanged($event)\"\n />\n\n <watt-button\n wattSuffix\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n (click)=\"singleDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-datepicker\n #singleDatepicker\n panelClass=\"watt-datepicker-single__panel\"\n [dateClass]=\"dateClass()\"\n [startAt]=\"startAt()\"\n (closed)=\"datepickerClosed()\"\n />\n }\n\n <ng-content />\n <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n <span\n class=\"watt-datepicker-single__step-through\"\n [class.watt-datepicker-single__has-label]=\"!!label()\"\n >\n <watt-button\n variant=\"icon\"\n icon=\"left\"\n (click)=\"prevDay()\"\n [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n />\n <watt-button\n variant=\"icon\"\n icon=\"right\"\n (click)=\"nextDay()\"\n [disabled]=\"disabled || isNextDayButtonDisabled()\"\n />\n </span>\n}\n", styles: ["watt-datepicker{display:flex;align-items:center;width:100%}watt-datepicker watt-button[variant=icon]{margin-left:auto}watt-datepicker watt-button[variant=icon] .watt-button--icon{height:42px}watt-datepicker mat-datepicker,watt-datepicker mat-date-range-picker{display:none}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker .mat-date-range-input-mirror,watt-datepicker input.mask-input{font-family:Droid Sans Mono,monospace}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker input.mask-input{border:none;caret-color:var(--watt-color-neutral-black);letter-spacing:-.03em;-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;color:transparent}watt-datepicker input.mask-input{color:#000}watt-datepicker input.mask-input{position:absolute;min-width:100%;padding:2px 1px}watt-datepicker input.mask-input:focus-visible{outline:none}watt-datepicker .mat-date-range-input-container{align-items:initial}watt-datepicker .mat-date-range-input-start-wrapper,watt-datepicker .mat-date-range-input-end-wrapper{max-width:calc(50% - var(--watt-space-s));overflow:visible;position:relative}watt-datepicker .mat-date-range-input-separator{display:flex;align-items:center}watt-datepicker .mat-date-range-input-separator-hidden,watt-datepicker .mat-date-range-input-separator{opacity:0!important}watt-datepicker .mat-date-range-input-inner::-webkit-input-placeholder{color:var(--watt-color-neutral-grey-500)!important;-webkit-text-fill-color:var(--watt-color-neutral-grey-500)}watt-datepicker watt-button .mat-button{background:transparent}watt-datepicker:has(.watt-datepicker-single__step-through){align-items:flex-start}watt-datepicker:has(.watt-datepicker-single__step-through) .watt-datepicker-single__step-through{display:flex;margin-top:1px}watt-datepicker:has(.watt-datepicker-single__has-label) .watt-datepicker-single__step-through{margin-top:28px}.watt-datepicker-range__panel--month-only .mat-calendar-period-button{pointer-events:none}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i1.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i1.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattPlaceholderMaskComponent, selector: "watt-placeholder-mask", inputs: ["primaryInputElement", "secondaryInputElement", "mask", "placeholder"], outputs: ["maskApplied"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
292
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattDatepickerComponent, isStandalone: true, selector: "watt-datepicker", inputs: { max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, rangeMonthOnlyMode: { classPropertyName: "rangeMonthOnlyMode", publicName: "rangeMonthOnlyMode", isSignal: true, isRequired: false, transformFunction: null }, startAt: { classPropertyName: "startAt", publicName: "startAt", isSignal: true, isRequired: false, transformFunction: null }, dateClass: { classPropertyName: "dateClass", publicName: "dateClass", isSignal: true, isRequired: false, transformFunction: null }, canStepThroughDays: { classPropertyName: "canStepThroughDays", publicName: "canStepThroughDays", isSignal: true, isRequired: false, transformFunction: null } }, providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }], viewQueries: [{ propertyName: "matEndDate", first: true, predicate: MatEndDate, descendants: true, isSignal: true }, { propertyName: "matStartDate", first: true, predicate: MatStartDate, descendants: true, isSignal: true }, { propertyName: "matDateRangeInput", first: true, predicate: MatDateRangeInput, descendants: true, isSignal: true }, { propertyName: "matDatepickerInput", first: true, predicate: MatDatepickerInput, descendants: true, isSignal: true }, { propertyName: "matDateRangePicker", first: true, predicate: MatDateRangePicker, descendants: true, isSignal: true }, { propertyName: "actualInput", first: true, predicate: ["actualInput"], descendants: true, isSignal: true }, { propertyName: "input", first: true, predicate: ["dateInput"], descendants: true, isSignal: true }, { propertyName: "endInput", first: true, predicate: ["endDateInput"], descendants: true, isSignal: true }, { propertyName: "startInput", first: true, predicate: ["startDateInput"], descendants: true, isSignal: 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<watt-field [control]=\"control\" [label]=\"label()\">\n @if (range) {\n <mat-date-range-input\n [disabled]=\"disabled\"\n [rangePicker]=\"rangeDatepicker\"\n [min]=\"min() ?? null\"\n [max]=\"max() ?? null\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n >\n <input\n inert\n aria-label=\"start-date-input\"\n matStartDate\n #startDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n\n <input\n inert\n aria-label=\"end-date-input\"\n matEndDate\n #endDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n </mat-date-range-input>\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"rangeInputMask()\"\n [placeholder]=\"rangePlaceholder\"\n (maskApplied)=\"rangeInputChanged($event)\"\n />\n\n <watt-button\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n [attr.aria-pressed]=\"false\"\n (click)=\"rangeDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-date-range-picker\n [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n [startAt]=\"startAt()\"\n (monthSelected)=\"onMonthSelected($event)\"\n (closed)=\"rangePickerClosed()\"\n #rangeDatepicker\n />\n } @else {\n <input\n inert\n matInput\n tabindex=\"-1\"\n aria-label=\"date-input\"\n #dateInput\n autocomplete=\"off\"\n spellcheck=\"false\"\n [disabled]=\"disabled\"\n [min]=\"min()\"\n [max]=\"max()\"\n [matDatepicker]=\"singleDatepicker\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"inputMask()\"\n [placeholder]=\"placeholder\"\n (maskApplied)=\"inputChanged($event)\"\n />\n\n <watt-button\n wattSuffix\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n (click)=\"singleDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-datepicker\n #singleDatepicker\n panelClass=\"watt-datepicker-single__panel\"\n [dateClass]=\"dateClass()\"\n [startAt]=\"startAt()\"\n (closed)=\"datepickerClosed()\"\n />\n }\n\n <ng-content />\n <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n <span\n class=\"watt-datepicker-single__step-through\"\n [class.watt-datepicker-single__has-label]=\"!!label()\"\n >\n <watt-button\n variant=\"icon\"\n icon=\"left\"\n (click)=\"prevDay()\"\n [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n />\n <watt-button\n variant=\"icon\"\n icon=\"right\"\n (click)=\"nextDay()\"\n [disabled]=\"disabled || isNextDayButtonDisabled()\"\n />\n </span>\n}\n", styles: ["watt-datepicker{display:flex;align-items:center;width:100%}watt-datepicker watt-button[variant=icon]{margin-left:auto}watt-datepicker watt-button[variant=icon] .watt-button--icon{height:42px}watt-datepicker mat-datepicker,watt-datepicker mat-date-range-picker{display:none}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker .mat-date-range-input-mirror,watt-datepicker input.mask-input{font-family:Droid Sans Mono,monospace}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker input.mask-input{border:none;caret-color:var(--watt-color-neutral-black);letter-spacing:-.03em;-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;color:transparent}watt-datepicker input.mask-input{color:#000}watt-datepicker input.mask-input{position:absolute;min-width:100%;padding:2px 1px}watt-datepicker input.mask-input:focus-visible{outline:none}watt-datepicker .mat-date-range-input-container{align-items:initial}watt-datepicker .mat-date-range-input-start-wrapper,watt-datepicker .mat-date-range-input-end-wrapper{max-width:calc(50% - var(--watt-space-s));overflow:visible;position:relative}watt-datepicker .mat-date-range-input-separator{display:flex;align-items:center}watt-datepicker .mat-date-range-input-separator-hidden,watt-datepicker .mat-date-range-input-separator{opacity:0!important}watt-datepicker .mat-date-range-input-inner::-webkit-input-placeholder{color:var(--watt-color-neutral-grey-500)!important;-webkit-text-fill-color:var(--watt-color-neutral-grey-500)}watt-datepicker watt-button .mat-button{background:transparent}watt-datepicker:has(.watt-datepicker-single__step-through){align-items:flex-start}watt-datepicker:has(.watt-datepicker-single__step-through) .watt-datepicker-single__step-through{display:flex;margin-top:1px}watt-datepicker:has(.watt-datepicker-single__has-label) .watt-datepicker-single__step-through{margin-top:28px}.watt-datepicker-range__panel--month-only .mat-calendar-period-button{pointer-events:none}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i2.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i2.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i2.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i2.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i2.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "component", type: WattPlaceholderMaskComponent, selector: "watt-placeholder-mask", inputs: ["primaryInputElement", "secondaryInputElement", "mask", "placeholder"], outputs: ["maskApplied"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
276
293
|
}
|
|
277
294
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattDatepickerComponent, decorators: [{
|
|
278
295
|
type: Component,
|
|
279
296
|
args: [{ selector: 'watt-datepicker', providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }], encapsulation: ViewEncapsulation.None, imports: [
|
|
280
|
-
MatDatepickerModule,
|
|
281
297
|
MatInputModule,
|
|
282
|
-
|
|
298
|
+
MatDatepickerModule,
|
|
283
299
|
WattFieldComponent,
|
|
300
|
+
WattButtonComponent,
|
|
284
301
|
WattPlaceholderMaskComponent,
|
|
285
302
|
], 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<watt-field [control]=\"control\" [label]=\"label()\">\n @if (range) {\n <mat-date-range-input\n [disabled]=\"disabled\"\n [rangePicker]=\"rangeDatepicker\"\n [min]=\"min() ?? null\"\n [max]=\"max() ?? null\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n >\n <input\n inert\n aria-label=\"start-date-input\"\n matStartDate\n #startDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n\n <input\n inert\n aria-label=\"end-date-input\"\n matEndDate\n #endDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n </mat-date-range-input>\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"rangeInputMask()\"\n [placeholder]=\"rangePlaceholder\"\n (maskApplied)=\"rangeInputChanged($event)\"\n />\n\n <watt-button\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n [attr.aria-pressed]=\"false\"\n (click)=\"rangeDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-date-range-picker\n [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n [startAt]=\"startAt()\"\n (monthSelected)=\"onMonthSelected($event)\"\n (closed)=\"rangePickerClosed()\"\n #rangeDatepicker\n />\n } @else {\n <input\n inert\n matInput\n tabindex=\"-1\"\n aria-label=\"date-input\"\n #dateInput\n autocomplete=\"off\"\n spellcheck=\"false\"\n [disabled]=\"disabled\"\n [min]=\"min()\"\n [max]=\"max()\"\n [matDatepicker]=\"singleDatepicker\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"inputMask()\"\n [placeholder]=\"placeholder\"\n (maskApplied)=\"inputChanged($event)\"\n />\n\n <watt-button\n wattSuffix\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n (click)=\"singleDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-datepicker\n #singleDatepicker\n panelClass=\"watt-datepicker-single__panel\"\n [dateClass]=\"dateClass()\"\n [startAt]=\"startAt()\"\n (closed)=\"datepickerClosed()\"\n />\n }\n\n <ng-content />\n <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n <span\n class=\"watt-datepicker-single__step-through\"\n [class.watt-datepicker-single__has-label]=\"!!label()\"\n >\n <watt-button\n variant=\"icon\"\n icon=\"left\"\n (click)=\"prevDay()\"\n [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n />\n <watt-button\n variant=\"icon\"\n icon=\"right\"\n (click)=\"nextDay()\"\n [disabled]=\"disabled || isNextDayButtonDisabled()\"\n />\n </span>\n}\n", styles: ["watt-datepicker{display:flex;align-items:center;width:100%}watt-datepicker watt-button[variant=icon]{margin-left:auto}watt-datepicker watt-button[variant=icon] .watt-button--icon{height:42px}watt-datepicker mat-datepicker,watt-datepicker mat-date-range-picker{display:none}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker .mat-date-range-input-mirror,watt-datepicker input.mask-input{font-family:Droid Sans Mono,monospace}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker input.mask-input{border:none;caret-color:var(--watt-color-neutral-black);letter-spacing:-.03em;-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;color:transparent}watt-datepicker input.mask-input{color:#000}watt-datepicker input.mask-input{position:absolute;min-width:100%;padding:2px 1px}watt-datepicker input.mask-input:focus-visible{outline:none}watt-datepicker .mat-date-range-input-container{align-items:initial}watt-datepicker .mat-date-range-input-start-wrapper,watt-datepicker .mat-date-range-input-end-wrapper{max-width:calc(50% - var(--watt-space-s));overflow:visible;position:relative}watt-datepicker .mat-date-range-input-separator{display:flex;align-items:center}watt-datepicker .mat-date-range-input-separator-hidden,watt-datepicker .mat-date-range-input-separator{opacity:0!important}watt-datepicker .mat-date-range-input-inner::-webkit-input-placeholder{color:var(--watt-color-neutral-grey-500)!important;-webkit-text-fill-color:var(--watt-color-neutral-grey-500)}watt-datepicker watt-button .mat-button{background:transparent}watt-datepicker:has(.watt-datepicker-single__step-through){align-items:flex-start}watt-datepicker:has(.watt-datepicker-single__step-through) .watt-datepicker-single__step-through{display:flex;margin-top:1px}watt-datepicker:has(.watt-datepicker-single__has-label) .watt-datepicker-single__step-through{margin-top:28px}.watt-datepicker-range__panel--month-only .mat-calendar-period-button{pointer-events:none}\n"] }]
|
|
286
303
|
}], ctorParameters: () => [] });
|
|
287
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-datepicker.component.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/datepicker/watt-datepicker.component.ts","../../../../../libs/watt/package/picker/datepicker/watt-datepicker.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  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  LOCALE_ID,\n  ViewEncapsulation,\n  computed,\n  inject,\n  input,\n  AfterViewInit,\n  effect,\n  linkedSignal,\n  booleanAttribute,\n  viewChild,\n} from '@angular/core';\nimport { AbstractControl, NgControl, Validator } from '@angular/forms';\nimport {\n  MatCalendarCellClassFunction,\n  MatDateRangeInput,\n  MatDateRangePicker,\n  MatDatepickerInput,\n  MatDatepickerModule,\n  MatEndDate,\n  MatStartDate,\n} from '@angular/material/datepicker';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { maskitoDateOptionsGenerator, maskitoDateRangeOptionsGenerator } from '@maskito/kit';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport {\n  WattDateRange,\n  WattLocaleService,\n  WattRange,\n  WattSupportedLocales,\n  dayjs,\n} from '@energinet/watt/core/date';\nimport { WattButtonComponent } from '@energinet/watt/button';\n\nimport {\n  WattPickerBase,\n  WattPickerValue,\n  WattPlaceholderMaskComponent,\n} from '@energinet/watt/picker/__shared';\n\nconst dateShortFormat = 'DD-MM-YYYY';\nexport const danishTimeZoneIdentifier = 'Europe/Copenhagen';\n\n/**\n * Usage:\n * `import { WattDatepickerComponent } from '@energinet-datahub/watt/datepicker';`\n *\n * IMPORTANT:\n * The styling is calculated based on our monospaced font.\n */\n@Component({\n  selector: 'watt-datepicker',\n  templateUrl: './watt-datepicker.component.html',\n  styleUrls: ['./watt-datepicker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }],\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    MatDatepickerModule,\n    MatInputModule,\n    WattButtonComponent,\n    WattFieldComponent,\n    WattPlaceholderMaskComponent,\n  ],\n})\nexport class WattDatepickerComponent extends WattPickerBase implements Validator, AfterViewInit {\n  protected override elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected override changeDetectionRef = inject(ChangeDetectorRef);\n  protected override ngControl = inject(NgControl, { optional: true, self: true });\n  private localeService = inject(WattLocaleService);\n  private locale = inject<WattSupportedLocales>(LOCALE_ID);\n\n  max = input<Date>();\n  min = input<Date>();\n  rangeMonthOnlyMode = input(false);\n  startAt = input<Date | null>(null);\n  label = input<string>('');\n  dateClass = input<MatCalendarCellClassFunction<Date>>(() => '');\n  canStepThroughDays = input(false, { transform: booleanAttribute });\n\n  protected matDatepickerInput =\n    viewChild.required<MatDatepickerInput<Date | null>>(MatDatepickerInput);\n  protected matDateRangePicker =\n    viewChild.required<MatDateRangePicker<Date | null>>(MatDateRangePicker);\n  protected matDateRangeInput =\n    viewChild.required<MatDateRangeInput<Date | null>>(MatDateRangeInput);\n\n  protected matStartDate = viewChild.required<MatStartDate<Date | null>>(MatStartDate);\n  protected matEndDate = viewChild.required<MatEndDate<Date | null>>(MatEndDate);\n  protected actualInput = viewChild.required<ElementRef<HTMLInputElement>>('actualInput');\n  protected override input = viewChild<ElementRef<HTMLInputElement>>('dateInput');\n  protected override startInput = viewChild<ElementRef<HTMLInputElement>>('startDateInput');\n  protected override endInput = viewChild<ElementRef<HTMLInputElement>>('endDateInput');\n\n  protected override _placeholder = this.getPlaceholderByLocale(this.locale);\n\n  rangeSeparator = ' - ';\n\n  rangePlaceholder = this.getRangePlaceholder();\n\n  inputMask = computed(() =>\n    maskitoDateOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      separator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  rangeInputMask = computed(() =>\n    maskitoDateRangeOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      dateSeparator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  getPlaceholderByLocale(locale: WattSupportedLocales): string {\n    return locale === 'da' ? 'dd-mm-åååå' : 'dd-mm-yyyy';\n  }\n\n  getRangePlaceholder(): string {\n    return this.placeholder + this.rangeSeparator + this.placeholder;\n  }\n\n  isPrevDayButtonDisabled = linkedSignal(() => this.isPrevDayBeforeOrEqualToMinDate());\n  isNextDayButtonDisabled = linkedSignal(() => this.isNextDayAfterOrEqualToMaxDate());\n\n  constructor() {\n    super(`watt-datepicker-${WattDatepickerComponent.nextId++}`);\n\n    effect(() => {\n      const locale = this.localeService.locale();\n      this.placeholder = this.getPlaceholderByLocale(locale);\n      this.rangePlaceholder = this.getRangePlaceholder();\n    });\n\n    effect(() => {\n      this.rangeMonthOnlyMode();\n      this.ngControl?.control?.updateValueAndValidity();\n    });\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n\n    this.ngControl?.control?.addValidators(this.validate.bind(this));\n  }\n\n  validate({ value }: AbstractControl<WattRange<string>>) {\n    if (!value?.end || !value?.start) return null;\n    if (!this.rangeMonthOnlyMode()) return null;\n    const start = dayjs(value.start);\n    const end = dayjs(value.end);\n    return start.isSame(start.startOf('month')) && end.isSame(start.endOf('month'))\n      ? null\n      : { monthOnly: true };\n  }\n\n  protected initSingleInput() {\n    if (this.initialValue) {\n      this.matDatepickerInput().value = this.initialValue;\n      this.datepickerClosed();\n    }\n  }\n\n  inputChanged(value: string) {\n    const dateString = value.slice(0, this.placeholder.length);\n\n    if (dateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (dateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const date = this.parseDateShortFormat(dateString);\n    this.control?.setValue(this.formatDateFromViewToModel(date));\n  }\n\n  datepickerClosed() {\n    const matDatepickerInput = this.matDatepickerInput();\n    const actualInput = this.actualInput();\n    if (matDatepickerInput.value) {\n      this.control?.setValue(matDatepickerInput.value);\n\n      actualInput.nativeElement.value = this.formatDateTimeFromModelToView(\n        this.formatDateFromViewToModel(matDatepickerInput.value)\n      );\n    } else {\n      actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    this.isPrevDayButtonDisabled.set(this.isPrevDayBeforeOrEqualToMinDate());\n    this.isNextDayButtonDisabled.set(this.isNextDayAfterOrEqualToMaxDate());\n\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  onMonthSelected(date: Date) {\n    if (this.rangeMonthOnlyMode() && date) {\n      this.matDateRangePicker().select(dayjs(date).startOf('month').toDate());\n      this.matDateRangePicker().select(dayjs(date).endOf('month').toDate());\n      this.matDateRangePicker().close();\n    }\n  }\n\n  protected initRangeInput() {\n    if (this.initialValue) {\n      this.matStartDate().value = (this.initialValue as WattDateRange).start;\n      this.matEndDate().value = (this.initialValue as WattDateRange).end;\n      this.rangePickerClosed();\n    }\n  }\n\n  clearRangePicker() {\n    this.control?.setValue(null);\n    const actualInput = this.actualInput();\n    actualInput.nativeElement.value = '';\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  rangeInputChanged(value: string) {\n    const startDateString = value.slice(0, this.placeholder.length);\n\n    if (startDateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (startDateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const start = this.parseDateShortFormat(startDateString);\n    const endDateString = value.slice(this.placeholder.length + this.rangeSeparator.length);\n    let end = this.setEndDateToDanishTimeZone(endDateString);\n\n    if (end !== null) {\n      end = this.setToEndOfDay(end);\n      this.control?.setValue({ start, end });\n    }\n  }\n\n  rangePickerClosed() {\n    const matDateRangeInput = this.matDateRangeInput();\n    const actualInput = this.actualInput();\n    if (matDateRangeInput.value?.start && matDateRangeInput.value.end) {\n      actualInput.nativeElement.value =\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(matDateRangeInput.value?.start)\n        ) +\n        '-' +\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(matDateRangeInput.value.end)\n        );\n\n      this.control?.setValue({\n        start: this.formatDateFromViewToModel(matDateRangeInput.value.start),\n        end: this.formatDateFromViewToModel(matDateRangeInput.value.end),\n      });\n    } else {\n      actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  protected setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ) {\n    this.setValueToInput(value, input, this.matDatepickerInput());\n  }\n\n  protected setRangeValue(\n    value: WattDateRange | null,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ) {\n    const { start, end } = value ?? {};\n\n    this.setValueToInput(start, startInput, this.matStartDate());\n    this.setValueToInput(end, endInput, this.matEndDate());\n  }\n  prevDay(): void {\n    this.changeDay(-1);\n  }\n  nextDay(): void {\n    this.changeDay(1);\n  }\n\n  private changeDay(value: number): void {\n    const currentDate = this.matDatepickerInput().value;\n\n    if (currentDate) {\n      const newDate = dayjs(currentDate).add(value, 'day').toISOString();\n      const newDateFormatted = this.formatDateTimeFromModelToView(newDate);\n\n      this.inputChanged(newDateFormatted);\n      this.datepickerClosed();\n    }\n  }\n\n  private isPrevDayBeforeOrEqualToMinDate() {\n    const min = this.min();\n    const selectedDate = this.matDatepickerInput()?.value;\n\n    if (!min || !selectedDate) return false;\n\n    const isBefore = dayjs(selectedDate).isBefore(min, 'day');\n    const isSame = dayjs(selectedDate).isSame(min, 'day');\n\n    return isSame || isBefore;\n  }\n\n  private isNextDayAfterOrEqualToMaxDate() {\n    const max = this.max();\n    const selectedDate = this.matDatepickerInput()?.value;\n\n    if (!max || !selectedDate) return false;\n\n    const isAfter = dayjs(selectedDate).isAfter(max, 'day');\n    const isSame = dayjs(selectedDate).isSame(max, 'day');\n\n    return isSame || isAfter;\n  }\n\n  private parseDateShortFormat(value: string): Date {\n    return dayjs(value, dateShortFormat).toDate();\n  }\n\n  private setValueToInput<D extends { value: Date | null }>(\n    value: string | null | undefined,\n    nativeInput: HTMLInputElement,\n    matDateInput: D\n  ): void {\n    nativeInput.value = value ? this.formatDateTimeFromModelToView(value) : '';\n    matDateInput.value = value ? dayjs(value).utc().toDate() : null;\n  }\n\n  /**\n   * @ignore\n   * Formats Date to full ISO 8601 format (e.g. `2022-08-31T22:00:00.000Z`)\n   */\n  private formatDateFromViewToModel(value: Date): string {\n    return dayjs(value).utc().toISOString();\n  }\n\n  private formatDateTimeFromModelToView(value: string): string {\n    return dayjs(value).tz(danishTimeZoneIdentifier).format(dateShortFormat);\n  }\n\n  private toDanishTimeZone(value: Date): Date {\n    return dayjs(value.toISOString()).tz(danishTimeZoneIdentifier).toDate();\n  }\n\n  private setToEndOfDay(value: Date): Date {\n    return dayjs(value).endOf('day').toDate();\n  }\n\n  private setEndDateToDanishTimeZone(value: string): Date | null {\n    const dateBasedOnShortFormat = this.parseDateShortFormat(value);\n\n    let maybeDateInDanishTimeZone: Date | null = null;\n\n    if (dayjs(dateBasedOnShortFormat).isValid()) {\n      maybeDateInDanishTimeZone = this.toDanishTimeZone(dateBasedOnShortFormat);\n    }\n\n    return maybeDateInDanishTimeZone;\n  }\n}\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<watt-field [control]=\"control\" [label]=\"label()\">\n  @if (range) {\n    <mat-date-range-input\n      [disabled]=\"disabled\"\n      [rangePicker]=\"rangeDatepicker\"\n      [min]=\"min() ?? null\"\n      [max]=\"max() ?? null\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    >\n      <input\n        inert\n        aria-label=\"start-date-input\"\n        matStartDate\n        #startDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n\n      <input\n        inert\n        aria-label=\"end-date-input\"\n        matEndDate\n        #endDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n    </mat-date-range-input>\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"rangeInputMask()\"\n      [placeholder]=\"rangePlaceholder\"\n      (maskApplied)=\"rangeInputChanged($event)\"\n    />\n\n    <watt-button\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      [attr.aria-pressed]=\"false\"\n      (click)=\"rangeDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-date-range-picker\n      [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n      [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n      [startAt]=\"startAt()\"\n      (monthSelected)=\"onMonthSelected($event)\"\n      (closed)=\"rangePickerClosed()\"\n      #rangeDatepicker\n    />\n  } @else {\n    <input\n      inert\n      matInput\n      tabindex=\"-1\"\n      aria-label=\"date-input\"\n      #dateInput\n      autocomplete=\"off\"\n      spellcheck=\"false\"\n      [disabled]=\"disabled\"\n      [min]=\"min()\"\n      [max]=\"max()\"\n      [matDatepicker]=\"singleDatepicker\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"inputMask()\"\n      [placeholder]=\"placeholder\"\n      (maskApplied)=\"inputChanged($event)\"\n    />\n\n    <watt-button\n      wattSuffix\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      (click)=\"singleDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-datepicker\n      #singleDatepicker\n      panelClass=\"watt-datepicker-single__panel\"\n      [dateClass]=\"dateClass()\"\n      [startAt]=\"startAt()\"\n      (closed)=\"datepickerClosed()\"\n    />\n  }\n\n  <ng-content />\n  <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n  <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n  <span\n    class=\"watt-datepicker-single__step-through\"\n    [class.watt-datepicker-single__has-label]=\"!!label()\"\n  >\n    <watt-button\n      variant=\"icon\"\n      icon=\"left\"\n      (click)=\"prevDay()\"\n      [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n    />\n    <watt-button\n      variant=\"icon\"\n      icon=\"right\"\n      (click)=\"nextDay()\"\n      [disabled]=\"disabled || isNextDayButtonDisabled()\"\n    />\n  </span>\n}\n"]}
|
|
304
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-datepicker.component.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/datepicker/watt-datepicker.component.ts","../../../../../libs/watt/package/picker/datepicker/watt-datepicker.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  input,\n  effect,\n  inject,\n  computed,\n  Component,\n  LOCALE_ID,\n  viewChild,\n  ElementRef,\n  linkedSignal,\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectorRef,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { MatInputModule } from '@angular/material/input';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { AbstractControl, NgControl, Validator } from '@angular/forms';\n\nimport {\n  MatEndDate,\n  MatStartDate,\n  MatDateRangeInput,\n  MatDateRangePicker,\n  MatDatepickerInput,\n  MatDatepickerModule,\n  MatCalendarCellClassFunction,\n} from '@angular/material/datepicker';\n\nimport { maskitoDateOptionsGenerator, maskitoDateRangeOptionsGenerator } from '@maskito/kit';\n\nimport {\n  dayjs,\n  WattRange,\n  WattDateRange,\n  WattLocaleService,\n  WattSupportedLocales,\n} from '@energinet/watt/core/date';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattButtonComponent } from '@energinet/watt/button';\n\nimport {\n  WattPickerBase,\n  WattPickerValue,\n  WattPlaceholderMaskComponent,\n} from '@energinet/watt/picker/__shared';\n\nconst dateShortFormat = 'DD-MM-YYYY';\nexport const danishTimeZoneIdentifier = 'Europe/Copenhagen';\n\n/**\n * Usage:\n * `import { WattDatepickerComponent } from '@energinet-datahub/watt/datepicker';`\n *\n * IMPORTANT:\n * The styling is calculated based on our monospaced font.\n */\n@Component({\n  selector: 'watt-datepicker',\n  templateUrl: './watt-datepicker.component.html',\n  styleUrls: ['./watt-datepicker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }],\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    MatInputModule,\n    MatDatepickerModule,\n\n    WattFieldComponent,\n    WattButtonComponent,\n    WattPlaceholderMaskComponent,\n  ],\n})\nexport class WattDatepickerComponent extends WattPickerBase implements Validator, AfterViewInit {\n  protected override elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected override changeDetectionRef = inject(ChangeDetectorRef);\n  protected override ngControl = inject(NgControl, { optional: true, self: true });\n  private localeService = inject(WattLocaleService);\n  private locale = inject<WattSupportedLocales>(LOCALE_ID);\n\n  max = input<Date>();\n  min = input<Date>();\n  label = input<string>('');\n  rangeMonthOnlyMode = input(false);\n  startAt = input<Date | null>(null);\n  dateClass = input<MatCalendarCellClassFunction<Date>>(() => '');\n  canStepThroughDays = input(false, { transform: booleanAttribute });\n\n  matEndDate = viewChild<MatEndDate<Date | null>>(MatEndDate);\n  matStartDate = viewChild<MatStartDate<Date | null>>(MatStartDate);\n  matDateRangeInput = viewChild<MatDateRangeInput<Date | null>>(MatDateRangeInput);\n  matDatepickerInput = viewChild<MatDatepickerInput<Date | null>>(MatDatepickerInput);\n  matDateRangePicker = viewChild<MatDateRangePicker<Date | null>>(MatDateRangePicker);\n\n  actualInput = viewChild<ElementRef<HTMLInputElement>>('actualInput');\n  override input = viewChild<ElementRef<HTMLInputElement>>('dateInput');\n  override endInput = viewChild<ElementRef<HTMLInputElement>>('endDateInput');\n  override startInput = viewChild<ElementRef<HTMLInputElement>>('startDateInput');\n\n  protected _placeholder = this.getPlaceholderByLocale(this.locale);\n\n  rangeSeparator = ' - ';\n\n  rangePlaceholder = this.getRangePlaceholder();\n\n  inputMask = computed(() =>\n    maskitoDateOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      separator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  rangeInputMask = computed(() =>\n    maskitoDateRangeOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      dateSeparator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  getPlaceholderByLocale(locale: WattSupportedLocales): string {\n    return locale === 'da' ? 'dd-mm-åååå' : 'dd-mm-yyyy';\n  }\n\n  getRangePlaceholder(): string {\n    return this.placeholder + this.rangeSeparator + this.placeholder;\n  }\n\n  isPrevDayButtonDisabled = linkedSignal(() => this.isPrevDayBeforeOrEqualToMinDate());\n  isNextDayButtonDisabled = linkedSignal(() => this.isNextDayAfterOrEqualToMaxDate());\n\n  constructor() {\n    super(`watt-datepicker-${WattDatepickerComponent.nextId++}`);\n\n    effect(() => {\n      const locale = this.localeService.locale();\n      this.placeholder = this.getPlaceholderByLocale(locale);\n      this.rangePlaceholder = this.getRangePlaceholder();\n    });\n\n    effect(() => {\n      this.rangeMonthOnlyMode();\n      this.ngControl?.control?.updateValueAndValidity();\n    });\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n\n    this.ngControl?.control?.addValidators(this.validate);\n  }\n\n  validate = ({ value }: AbstractControl<WattRange<string>>) => {\n    if (!value?.end || !value?.start) return null;\n    if (!this.rangeMonthOnlyMode()) return null;\n    const start = dayjs(value.start);\n    const end = dayjs(value.end);\n    return start.isSame(start.startOf('month')) && end.isSame(start.endOf('month'))\n      ? null\n      : { monthOnly: true };\n  };\n\n  protected initSingleInput() {\n    const matDatepickerInput = this.matDatepickerInput();\n    if (this.initialValue && matDatepickerInput) {\n      matDatepickerInput.value = this.initialValue;\n      this.datepickerClosed();\n    }\n  }\n\n  inputChanged(value: string) {\n    const dateString = value.slice(0, this.placeholder.length);\n\n    if (dateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (dateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const date = this.parseDateShortFormat(dateString);\n    this.control?.setValue(this.formatDateFromViewToModel(date));\n  }\n\n  datepickerClosed() {\n    const matDatepickerInput = this.matDatepickerInput();\n    const actualInput = this.actualInput();\n\n    if (!actualInput) return;\n\n    if (matDatepickerInput && matDatepickerInput.value) {\n      this.control?.setValue(matDatepickerInput.value);\n\n      actualInput.nativeElement.value = this.formatDateTimeFromModelToView(\n        this.formatDateFromViewToModel(matDatepickerInput.value)\n      );\n    } else {\n      actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    this.isPrevDayButtonDisabled.set(this.isPrevDayBeforeOrEqualToMinDate());\n    this.isNextDayButtonDisabled.set(this.isNextDayAfterOrEqualToMaxDate());\n\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  onMonthSelected(date: Date) {\n    const matDateRangePicker = this.matDateRangePicker();\n    if (matDateRangePicker && this.rangeMonthOnlyMode() && date) {\n      matDateRangePicker.select(dayjs(date).startOf('month').toDate());\n      matDateRangePicker.select(dayjs(date).endOf('month').toDate());\n      matDateRangePicker.close();\n    }\n  }\n\n  protected initRangeInput() {\n    const matStartDate = this.matStartDate();\n    const matEndDate = this.matEndDate();\n\n    if (this.initialValue && matStartDate && matEndDate) {\n      matStartDate.value = (this.initialValue as WattDateRange).start;\n      matEndDate.value = (this.initialValue as WattDateRange).end;\n      this.rangePickerClosed();\n    }\n  }\n\n  clearRangePicker() {\n    const actualInput = this.actualInput();\n\n    if (!actualInput) return;\n\n    this.control?.setValue(null);\n    actualInput.nativeElement.value = '';\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  rangeInputChanged(value: string) {\n    const startDateString = value.slice(0, this.placeholder.length);\n\n    if (startDateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (startDateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const start = this.parseDateShortFormat(startDateString);\n    const endDateString = value.slice(this.placeholder.length + this.rangeSeparator.length);\n    let end = this.setEndDateToDanishTimeZone(endDateString);\n\n    if (end !== null) {\n      end = this.setToEndOfDay(end);\n      this.control?.setValue({ start, end });\n    }\n  }\n\n  rangePickerClosed() {\n    const matDateRangeInput = this.matDateRangeInput();\n    const actualInput = this.actualInput();\n\n    if (!actualInput) return;\n\n    if (matDateRangeInput?.value?.start && matDateRangeInput?.value?.end) {\n      actualInput.nativeElement.value =\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(matDateRangeInput.value?.start)\n        ) +\n        '-' +\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(matDateRangeInput.value.end)\n        );\n\n      this.control?.setValue({\n        start: this.formatDateFromViewToModel(matDateRangeInput.value.start),\n        end: this.formatDateFromViewToModel(matDateRangeInput.value.end),\n      });\n    } else {\n      actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  protected setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ) {\n    const matDatepickerInput = this.matDatepickerInput();\n    if (matDatepickerInput) {\n      this.setValueToInput(value, input, matDatepickerInput);\n    }\n  }\n\n  protected setRangeValue(\n    value: WattDateRange | null,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ) {\n    const { start, end } = value ?? {};\n\n    const matStartDate = this.matStartDate();\n    const matEndDate = this.matEndDate();\n\n    if (!matStartDate || !matEndDate) return;\n\n    this.setValueToInput(start, startInput, matStartDate);\n    this.setValueToInput(end, endInput, matEndDate);\n  }\n\n  prevDay() {\n    this.changeDay(-1);\n  }\n\n  nextDay() {\n    this.changeDay(1);\n  }\n\n  private changeDay(value: number) {\n    const currentDate = this.matDatepickerInput()?.value;\n\n    if (currentDate) {\n      const newDate = dayjs(currentDate).add(value, 'day').toISOString();\n      const newDateFormatted = this.formatDateTimeFromModelToView(newDate);\n\n      this.inputChanged(newDateFormatted);\n      this.datepickerClosed();\n    }\n  }\n\n  private isPrevDayBeforeOrEqualToMinDate() {\n    const min = this.min();\n    const selectedDate = this.matDatepickerInput()?.value;\n\n    if (!min || !selectedDate) return false;\n\n    const isBefore = dayjs(selectedDate).isBefore(min, 'day');\n    const isSame = dayjs(selectedDate).isSame(min, 'day');\n\n    return isSame || isBefore;\n  }\n\n  private isNextDayAfterOrEqualToMaxDate() {\n    const max = this.max();\n    const selectedDate = this.matDatepickerInput()?.value;\n\n    if (!max || !selectedDate) return false;\n\n    const isAfter = dayjs(selectedDate).isAfter(max, 'day');\n    const isSame = dayjs(selectedDate).isSame(max, 'day');\n\n    return isSame || isAfter;\n  }\n\n  private parseDateShortFormat(value: string): Date {\n    return dayjs(value, dateShortFormat).toDate();\n  }\n\n  private setValueToInput<D extends { value: Date | null }>(\n    value: string | null | undefined,\n    nativeInput: HTMLInputElement,\n    matDateInput: D\n  ): void {\n    nativeInput.value = value ? this.formatDateTimeFromModelToView(value) : '';\n    matDateInput.value = value ? dayjs(value).utc().toDate() : null;\n  }\n\n  /**\n   * @ignore\n   * Formats Date to full ISO 8601 format (e.g. `2022-08-31T22:00:00.000Z`)\n   */\n  private formatDateFromViewToModel(value: Date): string {\n    return dayjs(value).utc().toISOString();\n  }\n\n  private formatDateTimeFromModelToView(value: string): string {\n    return dayjs(value).tz(danishTimeZoneIdentifier).format(dateShortFormat);\n  }\n\n  private toDanishTimeZone(value: Date): Date {\n    return dayjs(value.toISOString()).tz(danishTimeZoneIdentifier).toDate();\n  }\n\n  private setToEndOfDay(value: Date): Date {\n    return dayjs(value).endOf('day').toDate();\n  }\n\n  private setEndDateToDanishTimeZone(value: string): Date | null {\n    const dateBasedOnShortFormat = this.parseDateShortFormat(value);\n\n    let maybeDateInDanishTimeZone: Date | null = null;\n\n    if (dayjs(dateBasedOnShortFormat).isValid()) {\n      maybeDateInDanishTimeZone = this.toDanishTimeZone(dateBasedOnShortFormat);\n    }\n\n    return maybeDateInDanishTimeZone;\n  }\n}\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<watt-field [control]=\"control\" [label]=\"label()\">\n  @if (range) {\n    <mat-date-range-input\n      [disabled]=\"disabled\"\n      [rangePicker]=\"rangeDatepicker\"\n      [min]=\"min() ?? null\"\n      [max]=\"max() ?? null\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    >\n      <input\n        inert\n        aria-label=\"start-date-input\"\n        matStartDate\n        #startDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n\n      <input\n        inert\n        aria-label=\"end-date-input\"\n        matEndDate\n        #endDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n    </mat-date-range-input>\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"rangeInputMask()\"\n      [placeholder]=\"rangePlaceholder\"\n      (maskApplied)=\"rangeInputChanged($event)\"\n    />\n\n    <watt-button\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      [attr.aria-pressed]=\"false\"\n      (click)=\"rangeDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-date-range-picker\n      [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n      [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n      [startAt]=\"startAt()\"\n      (monthSelected)=\"onMonthSelected($event)\"\n      (closed)=\"rangePickerClosed()\"\n      #rangeDatepicker\n    />\n  } @else {\n    <input\n      inert\n      matInput\n      tabindex=\"-1\"\n      aria-label=\"date-input\"\n      #dateInput\n      autocomplete=\"off\"\n      spellcheck=\"false\"\n      [disabled]=\"disabled\"\n      [min]=\"min()\"\n      [max]=\"max()\"\n      [matDatepicker]=\"singleDatepicker\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"inputMask()\"\n      [placeholder]=\"placeholder\"\n      (maskApplied)=\"inputChanged($event)\"\n    />\n\n    <watt-button\n      wattSuffix\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      (click)=\"singleDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-datepicker\n      #singleDatepicker\n      panelClass=\"watt-datepicker-single__panel\"\n      [dateClass]=\"dateClass()\"\n      [startAt]=\"startAt()\"\n      (closed)=\"datepickerClosed()\"\n    />\n  }\n\n  <ng-content />\n  <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n  <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n  <span\n    class=\"watt-datepicker-single__step-through\"\n    [class.watt-datepicker-single__has-label]=\"!!label()\"\n  >\n    <watt-button\n      variant=\"icon\"\n      icon=\"left\"\n      (click)=\"prevDay()\"\n      [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n    />\n    <watt-button\n      variant=\"icon\"\n      icon=\"right\"\n      (click)=\"nextDay()\"\n      [disabled]=\"disabled || isNextDayButtonDisabled()\"\n    />\n  </span>\n}\n"]}
|
|
@@ -213,4 +213,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
|
|
|
213
213
|
type: HostBinding,
|
|
214
214
|
args: ['attr.aria-owns']
|
|
215
215
|
}] } });
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-timepicker.component.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/timepicker/watt-timepicker.component.ts","../../../../../libs/watt/package/picker/timepicker/watt-timepicker.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 { OverlayModule } from '@angular/cdk/overlay';\nimport {\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  ElementRef,\n  HostBinding,\n  ViewEncapsulation,\n  inject,\n  input,\n  viewChild,\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { Subject } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { maskitoTimeOptionsGenerator } from '@maskito/kit';\n\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattDateRange } from '@energinet/watt/core/date';\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattSliderComponent, WattSliderValue } from '@energinet/watt/slider';\n\nimport { maskitoTimeRangeOptionsGenerator } from './maskito-time-range-mask';\nimport {\n  WattPickerBase,\n  WattPickerValue,\n  WattPlaceholderMaskComponent,\n} from '@energinet/watt/picker/__shared';\n\n// Constants for working with time intervals\nconst minutesInADay = 24 * 60;\nconst quartersInADay = minutesInADay / 15;\n\n// Show slider initially as \"00:00 - 23:59\"\nconst initialSliderValue: WattSliderValue = { min: 0, max: minutesInADay - 1 };\n\n/** Converts string time format (HH:MM) to number of minutes. */\nfunction timeToMinutes(value: string): number {\n  const [hours, minutes] = value.split(':');\n  return Number(hours) * 60 + Number(minutes);\n}\n\n/** Converts number of minutes to string time format (HH:MM). */\nfunction minutesToTime(value: number): string {\n  const hours = `${Math.floor(value / 60)}`;\n  const minutes = `${value % 60}`;\n  return `${hours.padStart(2, '0')}:${minutes.padStart(2, '0')}`;\n}\n/**\n * Usage:\n * `import { WattTimepickerComponent } from '@energinet-datahub/watt/timepicker';`\n *\n * IMPORTANT:\n * The styling is calculated based on our monospaced font.\n */\n@Component({\n  selector: 'watt-timepicker',\n  templateUrl: './watt-timepicker.component.html',\n  styleUrls: ['./watt-timepicker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: WattTimepickerComponent }],\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    MatDatepickerModule,\n    MatInputModule,\n    OverlayModule,\n\n    WattButtonComponent,\n    WattSliderComponent,\n    WattFieldComponent,\n    WattPlaceholderMaskComponent,\n  ],\n})\nexport class WattTimepickerComponent extends WattPickerBase {\n  protected override elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected override changeDetectionRef = inject(ChangeDetectorRef);\n  protected override ngControl = inject(NgControl, { optional: true, self: true });\n  label = input('');\n  /**\n   * Text to display on label for time range slider.\n   */\n  sliderLabel = input('');\n\n  protected override input = viewChild<ElementRef<HTMLInputElement>>('timeInput');\n  protected override startInput = viewChild<ElementRef<HTMLInputElement>>('startTimeInput');\n  protected override endInput = viewChild<ElementRef<HTMLInputElement>>('endTimeInput');\n\n  sliderId = `${this.id}-slider`;\n\n  /**\n   * Used for defining a relationship between the time picker and\n   * the slider overlay (since the DOM hierarchy cannot be used).\n   * @ignore\n   */\n  @HostBinding('attr.aria-owns')\n  get ariaOwns() {\n    // Only range input has slider\n    return this.range && this.sliderOpen ? this.sliderId : undefined;\n  }\n  hoursMinutesPlaceholder = 'HH:MM';\n  rangeSeparator = ' - ';\n  rangePlaceholder =\n    this.hoursMinutesPlaceholder + this.rangeSeparator + this.hoursMinutesPlaceholder;\n  protected _placeholder = this.hoursMinutesPlaceholder;\n\n  /**\n   * Whether the slider is open.\n   * @ignore\n   */\n  sliderOpen = false;\n\n  sliderSteps = [...Array(quartersInADay).keys()].map((x) => x * 15).concat(minutesInADay - 1);\n\n  sliderChange$ = new Subject<WattSliderValue>();\n\n  get sliderValue(): WattSliderValue {\n    if (this.value?.start && this.value?.end) {\n      return {\n        min: timeToMinutes(this.value.start),\n        max: timeToMinutes(this.value.end),\n      };\n    }\n\n    // Retain last slider value if input value is incomplete\n    return initialSliderValue;\n  }\n\n  /**\n   * Toggles the visibility of the slider overlay.\n   * @ignore\n   */\n  toggleSlider() {\n    this.sliderOpen = !this.sliderOpen;\n  }\n\n  /**\n   * Override to automatically close the slider overlay on blur.\n   * @ignore\n   */\n  override onFocusOut(event: FocusEvent) {\n    super.onFocusOut(event);\n    if (!this.focused) this.sliderOpen = false;\n  }\n\n  inputMask = maskitoTimeOptionsGenerator({ mode: 'HH:MM' });\n  rangeInputMask = maskitoTimeRangeOptionsGenerator();\n  destroyRef = inject(DestroyRef);\n\n  constructor() {\n    super(`watt-timepicker-${WattTimepickerComponent.nextId++}`);\n  }\n\n  protected initSingleInput() {\n    const input = this.input();\n    if (this.initialValue && input) {\n      (input.nativeElement as HTMLInputElement).value = this.initialValue as string;\n      input.nativeElement.dispatchEvent(new InputEvent('input'));\n    }\n  }\n\n  inputChanged(value: string) {\n    const time = value.slice(0, this.hoursMinutesPlaceholder.length);\n    if (time.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n    if (time.length !== this.hoursMinutesPlaceholder.length) {\n      return;\n    }\n    this.control?.setValue(time);\n  }\n\n  rangeInputChanged(value: string) {\n    const start = value.slice(0, this.hoursMinutesPlaceholder.length);\n    if (start.length !== this.hoursMinutesPlaceholder.length) {\n      this.control?.setValue({ start: '', end: '' });\n      return;\n    }\n    if (value.length < this.rangePlaceholder.length) {\n      this.control?.setValue({ start, end: '' });\n      return;\n    }\n    let end = value.slice(this.hoursMinutesPlaceholder.length + this.rangeSeparator.length);\n    if (timeToMinutes(end) > timeToMinutes(start)) {\n      this.control?.setValue({ start, end });\n    } else {\n      end = minutesToTime(timeToMinutes(start) + 1);\n      this.setRangeValueAndNotify(start, end);\n    }\n  }\n\n  protected initRangeInput() {\n    if (this.initialValue) {\n      const { start, end } = this.initialValue as WattDateRange;\n      this.setRangeValueAndNotify(start, end);\n    } else {\n      this.control?.setValue({ start: '', end: '' });\n    }\n    this.sliderChange$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((sliderValue) => {\n      const start = minutesToTime(sliderValue.min);\n      const end = minutesToTime(sliderValue.max);\n      if (end > start) {\n        this.setRangeValueAndNotify(start, end);\n      }\n    });\n  }\n\n  setRangeValueAndNotify(start: string, end: string | null) {\n    this.control?.setValue({ start, end });\n    const input = this.input();\n    if (!input) return;\n    (input.nativeElement as HTMLInputElement).value = start + this.rangeSeparator + end;\n    input.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  protected setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ) {\n    input.value = value ?? '';\n  }\n\n  protected setRangeValue(\n    value: WattDateRange,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ) {\n    const { start, end } = value;\n\n    if (start) {\n      startInput.value = start;\n    }\n\n    if (end) {\n      endInput.value = end;\n    }\n  }\n}\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<watt-field [id]=\"id\" [control]=\"control\" [label]=\"label()\">\n  @if (!range) {\n    <input\n      inert\n      matInput\n      aria-label=\"time-input\"\n      autocomplete=\"off\"\n      spellcheck=\"false\"\n      [disabled]=\"disabled\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n    <input #timeInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"timeInput\"\n      [mask]=\"inputMask\"\n      [placeholder]=\"hoursMinutesPlaceholder\"\n      (maskApplied)=\"inputChanged($event)\"\n    />\n  } @else {\n    <mat-date-range-input\n      cdkOverlayOrigin\n      #trigger=\"cdkOverlayOrigin\"\n      [disabled]=\"disabled\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    >\n      <input\n        inert\n        aria-label=\"start-time-input\"\n        matStartDate\n        #startTimeInput\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n      />\n      <input\n        inert\n        aria-label=\"end-time-input\"\n        matEndDate\n        #endTimeInput\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n      />\n    </mat-date-range-input>\n    <input #timeInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"timeInput\"\n      [mask]=\"rangeInputMask\"\n      [placeholder]=\"rangePlaceholder\"\n      (maskApplied)=\"rangeInputChanged($event)\"\n    />\n\n    <watt-button\n      variant=\"icon\"\n      icon=\"time\"\n      [disabled]=\"disabled\"\n      [attr.aria-pressed]=\"sliderOpen\"\n      (click)=\"toggleSlider()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <ng-template\n      cdkConnectedOverlay\n      [cdkConnectedOverlayOrigin]=\"trigger\"\n      [cdkConnectedOverlayOpen]=\"sliderOpen\"\n      [cdkConnectedOverlayOffsetY]=\"12\"\n    >\n      <div\n        [id]=\"sliderId\"\n        role=\"dialog\"\n        class=\"watt-timepicker-slider\"\n        tabindex=\"-1\"\n        (focusin)=\"onFocusIn()\"\n        (focusout)=\"onFocusOut($event)\"\n      >\n        <span class=\"watt-label\">{{ sliderLabel() }}</span>\n        <watt-slider\n          [min]=\"sliderSteps[0]\"\n          [max]=\"sliderSteps[sliderSteps.length - 1]\"\n          [step]=\"1\"\n          [value]=\"sliderValue\"\n          (valueChange)=\"sliderChange$.next($event)\"\n        />\n      </div>\n    </ng-template>\n  }\n\n  <ng-content />\n  <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n  <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n"]}
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-timepicker.component.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/timepicker/watt-timepicker.component.ts","../../../../../libs/watt/package/picker/timepicker/watt-timepicker.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 { OverlayModule } from '@angular/cdk/overlay';\nimport {\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  ElementRef,\n  HostBinding,\n  ViewEncapsulation,\n  inject,\n  input,\n  viewChild,\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { Subject } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { maskitoTimeOptionsGenerator } from '@maskito/kit';\n\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattDateRange } from '@energinet/watt/core/date';\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattSliderComponent, WattSliderValue } from '@energinet/watt/slider';\n\nimport { maskitoTimeRangeOptionsGenerator } from './maskito-time-range-mask';\nimport {\n  WattPickerBase,\n  WattPickerValue,\n  WattPlaceholderMaskComponent,\n} from '@energinet/watt/picker/__shared';\n\n// Constants for working with time intervals\nconst minutesInADay = 24 * 60;\nconst quartersInADay = minutesInADay / 15;\n\n// Show slider initially as \"00:00 - 23:59\"\nconst initialSliderValue: WattSliderValue = { min: 0, max: minutesInADay - 1 };\n\n/** Converts string time format (HH:MM) to number of minutes. */\nfunction timeToMinutes(value: string): number {\n  const [hours, minutes] = value.split(':');\n  return Number(hours) * 60 + Number(minutes);\n}\n\n/** Converts number of minutes to string time format (HH:MM). */\nfunction minutesToTime(value: number): string {\n  const hours = `${Math.floor(value / 60)}`;\n  const minutes = `${value % 60}`;\n  return `${hours.padStart(2, '0')}:${minutes.padStart(2, '0')}`;\n}\n/**\n * Usage:\n * `import { WattTimepickerComponent } from '@energinet-datahub/watt/timepicker';`\n *\n * IMPORTANT:\n * The styling is calculated based on our monospaced font.\n */\n@Component({\n  selector: 'watt-timepicker',\n  templateUrl: './watt-timepicker.component.html',\n  styleUrls: ['./watt-timepicker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: WattTimepickerComponent }],\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    MatDatepickerModule,\n    MatInputModule,\n    OverlayModule,\n\n    WattButtonComponent,\n    WattSliderComponent,\n    WattFieldComponent,\n    WattPlaceholderMaskComponent,\n  ],\n})\nexport class WattTimepickerComponent extends WattPickerBase {\n  protected override elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected override changeDetectionRef = inject(ChangeDetectorRef);\n  protected override ngControl = inject(NgControl, { optional: true, self: true });\n  label = input('');\n  /**\n   * Text to display on label for time range slider.\n   */\n  sliderLabel = input('');\n\n  override input = viewChild<ElementRef<HTMLInputElement>>('timeInput');\n  override startInput = viewChild<ElementRef<HTMLInputElement>>('startTimeInput');\n  override endInput = viewChild<ElementRef<HTMLInputElement>>('endTimeInput');\n\n  sliderId = `${this.id}-slider`;\n\n  /**\n   * Used for defining a relationship between the time picker and\n   * the slider overlay (since the DOM hierarchy cannot be used).\n   * @ignore\n   */\n  @HostBinding('attr.aria-owns')\n  get ariaOwns() {\n    // Only range input has slider\n    return this.range && this.sliderOpen ? this.sliderId : undefined;\n  }\n  hoursMinutesPlaceholder = 'HH:MM';\n  rangeSeparator = ' - ';\n  rangePlaceholder =\n    this.hoursMinutesPlaceholder + this.rangeSeparator + this.hoursMinutesPlaceholder;\n  protected _placeholder = this.hoursMinutesPlaceholder;\n\n  /**\n   * Whether the slider is open.\n   * @ignore\n   */\n  sliderOpen = false;\n\n  sliderSteps = [...Array(quartersInADay).keys()].map((x) => x * 15).concat(minutesInADay - 1);\n\n  sliderChange$ = new Subject<WattSliderValue>();\n\n  get sliderValue(): WattSliderValue {\n    if (this.value?.start && this.value?.end) {\n      return {\n        min: timeToMinutes(this.value.start),\n        max: timeToMinutes(this.value.end),\n      };\n    }\n\n    // Retain last slider value if input value is incomplete\n    return initialSliderValue;\n  }\n\n  /**\n   * Toggles the visibility of the slider overlay.\n   * @ignore\n   */\n  toggleSlider() {\n    this.sliderOpen = !this.sliderOpen;\n  }\n\n  /**\n   * Override to automatically close the slider overlay on blur.\n   * @ignore\n   */\n  override onFocusOut(event: FocusEvent) {\n    super.onFocusOut(event);\n    if (!this.focused) this.sliderOpen = false;\n  }\n\n  inputMask = maskitoTimeOptionsGenerator({ mode: 'HH:MM' });\n  rangeInputMask = maskitoTimeRangeOptionsGenerator();\n  override destroyRef = inject(DestroyRef);\n\n  constructor() {\n    super(`watt-timepicker-${WattTimepickerComponent.nextId++}`);\n  }\n\n  protected initSingleInput() {\n    const input = this.input();\n    if (this.initialValue && input) {\n      (input.nativeElement as HTMLInputElement).value = this.initialValue as string;\n      input.nativeElement.dispatchEvent(new InputEvent('input'));\n    }\n  }\n\n  inputChanged(value: string) {\n    const time = value.slice(0, this.hoursMinutesPlaceholder.length);\n    if (time.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n    if (time.length !== this.hoursMinutesPlaceholder.length) {\n      return;\n    }\n    this.control?.setValue(time);\n  }\n\n  rangeInputChanged(value: string) {\n    const start = value.slice(0, this.hoursMinutesPlaceholder.length);\n    if (start.length !== this.hoursMinutesPlaceholder.length) {\n      this.control?.setValue({ start: '', end: '' });\n      return;\n    }\n    if (value.length < this.rangePlaceholder.length) {\n      this.control?.setValue({ start, end: '' });\n      return;\n    }\n    let end = value.slice(this.hoursMinutesPlaceholder.length + this.rangeSeparator.length);\n    if (timeToMinutes(end) > timeToMinutes(start)) {\n      this.control?.setValue({ start, end });\n    } else {\n      end = minutesToTime(timeToMinutes(start) + 1);\n      this.setRangeValueAndNotify(start, end);\n    }\n  }\n\n  protected initRangeInput() {\n    if (this.initialValue) {\n      const { start, end } = this.initialValue as WattDateRange;\n      this.setRangeValueAndNotify(start, end);\n    } else {\n      this.control?.setValue({ start: '', end: '' });\n    }\n    this.sliderChange$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((sliderValue) => {\n      const start = minutesToTime(sliderValue.min);\n      const end = minutesToTime(sliderValue.max);\n      if (end > start) {\n        this.setRangeValueAndNotify(start, end);\n      }\n    });\n  }\n\n  setRangeValueAndNotify(start: string, end: string | null) {\n    this.control?.setValue({ start, end });\n    const input = this.input();\n    if (!input) return;\n    (input.nativeElement as HTMLInputElement).value = start + this.rangeSeparator + end;\n    input.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  protected setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ) {\n    input.value = value ?? '';\n  }\n\n  protected setRangeValue(\n    value: WattDateRange,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ) {\n    const { start, end } = value;\n\n    if (start) {\n      startInput.value = start;\n    }\n\n    if (end) {\n      endInput.value = end;\n    }\n  }\n}\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<watt-field [id]=\"id\" [control]=\"control\" [label]=\"label()\">\n  @if (!range) {\n    <input\n      inert\n      matInput\n      aria-label=\"time-input\"\n      autocomplete=\"off\"\n      spellcheck=\"false\"\n      [disabled]=\"disabled\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n    <input #timeInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"timeInput\"\n      [mask]=\"inputMask\"\n      [placeholder]=\"hoursMinutesPlaceholder\"\n      (maskApplied)=\"inputChanged($event)\"\n    />\n  } @else {\n    <mat-date-range-input\n      cdkOverlayOrigin\n      #trigger=\"cdkOverlayOrigin\"\n      [disabled]=\"disabled\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    >\n      <input\n        inert\n        aria-label=\"start-time-input\"\n        matStartDate\n        #startTimeInput\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n      />\n      <input\n        inert\n        aria-label=\"end-time-input\"\n        matEndDate\n        #endTimeInput\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n      />\n    </mat-date-range-input>\n    <input #timeInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"timeInput\"\n      [mask]=\"rangeInputMask\"\n      [placeholder]=\"rangePlaceholder\"\n      (maskApplied)=\"rangeInputChanged($event)\"\n    />\n\n    <watt-button\n      variant=\"icon\"\n      icon=\"time\"\n      [disabled]=\"disabled\"\n      [attr.aria-pressed]=\"sliderOpen\"\n      (click)=\"toggleSlider()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <ng-template\n      cdkConnectedOverlay\n      [cdkConnectedOverlayOrigin]=\"trigger\"\n      [cdkConnectedOverlayOpen]=\"sliderOpen\"\n      [cdkConnectedOverlayOffsetY]=\"12\"\n    >\n      <div\n        [id]=\"sliderId\"\n        role=\"dialog\"\n        class=\"watt-timepicker-slider\"\n        tabindex=\"-1\"\n        (focusin)=\"onFocusIn()\"\n        (focusout)=\"onFocusOut($event)\"\n      >\n        <span class=\"watt-label\">{{ sliderLabel() }}</span>\n        <watt-slider\n          [min]=\"sliderSteps[0]\"\n          [max]=\"sliderSteps[sliderSteps.length - 1]\"\n          [step]=\"1\"\n          [value]=\"sliderValue\"\n          (valueChange)=\"sliderChange$.next($event)\"\n        />\n      </div>\n    </ng-template>\n  }\n\n  <ng-content />\n  <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n  <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n"]}
|
package/package.json
CHANGED
|
@@ -14,27 +14,28 @@
|
|
|
14
14
|
* See the License for the specific language governing permissions and
|
|
15
15
|
* limitations under the License.
|
|
16
16
|
*/
|
|
17
|
-
import {
|
|
18
|
-
import { AfterViewInit, ChangeDetectorRef, DestroyRef, ElementRef, OnDestroy, OnInit, Signal } from '@angular/core';
|
|
17
|
+
import { OnInit, Signal, OnDestroy, ElementRef, DestroyRef, AfterViewInit, ChangeDetectorRef } from '@angular/core';
|
|
19
18
|
import { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';
|
|
19
|
+
import { BooleanInput } from '@angular/cdk/coercion';
|
|
20
20
|
import { Subject } from 'rxjs';
|
|
21
21
|
import { WattDateRange } from '@energinet/watt/core/date';
|
|
22
22
|
import { WattPickerValue } from './watt-picker-value';
|
|
23
23
|
import * as i0 from "@angular/core";
|
|
24
24
|
export declare abstract class WattPickerBase implements OnInit, AfterViewInit, OnDestroy, ControlValueAccessor {
|
|
25
|
-
protected
|
|
25
|
+
protected destroyRef: DestroyRef;
|
|
26
26
|
protected changeDetectionRef: ChangeDetectorRef;
|
|
27
27
|
protected ngControl: NgControl | null;
|
|
28
|
-
protected
|
|
29
|
-
|
|
30
|
-
|
|
28
|
+
protected elementRef: ElementRef<HTMLElement>;
|
|
29
|
+
abstract input: Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
30
|
+
abstract endInput: Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
31
|
+
abstract startInput: Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
31
32
|
static nextId: number;
|
|
32
33
|
id: string;
|
|
33
34
|
initialValue: WattPickerValue;
|
|
34
35
|
focused: boolean;
|
|
35
36
|
controlType: string;
|
|
36
37
|
stateChanges: Subject<void>;
|
|
37
|
-
|
|
38
|
+
userAriaDescribedBy: import("@angular/core").InputSignal<string | undefined>;
|
|
38
39
|
get placeholder(): string;
|
|
39
40
|
set placeholder(value: string);
|
|
40
41
|
protected abstract _placeholder: string;
|
|
@@ -76,5 +77,5 @@ export declare abstract class WattPickerBase implements OnInit, AfterViewInit, O
|
|
|
76
77
|
protected changeParentValue: (value: string | WattDateRange) => void;
|
|
77
78
|
protected markParentControlAsTouched: () => void;
|
|
78
79
|
static ɵfac: i0.ɵɵFactoryDeclaration<WattPickerBase, never>;
|
|
79
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<WattPickerBase, never, never, { "value": { "alias": "value"; "required": false; }; "range": { "alias": "range"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, never, true, never>;
|
|
80
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<WattPickerBase, never, never, { "userAriaDescribedBy": { "alias": "aria-describedby"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; }; "range": { "alias": "range"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, never, true, never>;
|
|
80
81
|
}
|
|
@@ -14,10 +14,10 @@
|
|
|
14
14
|
* See the License for the specific language governing permissions and
|
|
15
15
|
* limitations under the License.
|
|
16
16
|
*/
|
|
17
|
-
import {
|
|
17
|
+
import { ElementRef, AfterViewInit, ChangeDetectorRef } from '@angular/core';
|
|
18
18
|
import { AbstractControl, NgControl, Validator } from '@angular/forms';
|
|
19
|
-
import {
|
|
20
|
-
import {
|
|
19
|
+
import { MatEndDate, MatStartDate, MatDateRangeInput, MatDateRangePicker, MatDatepickerInput, MatCalendarCellClassFunction } from '@angular/material/datepicker';
|
|
20
|
+
import { WattRange, WattDateRange, WattSupportedLocales } from '@energinet/watt/core/date';
|
|
21
21
|
import { WattPickerBase, WattPickerValue } from '@energinet/watt/picker/__shared';
|
|
22
22
|
import * as i0 from "@angular/core";
|
|
23
23
|
export declare const danishTimeZoneIdentifier = "Europe/Copenhagen";
|
|
@@ -36,20 +36,20 @@ export declare class WattDatepickerComponent extends WattPickerBase implements V
|
|
|
36
36
|
private locale;
|
|
37
37
|
max: import("@angular/core").InputSignal<Date | undefined>;
|
|
38
38
|
min: import("@angular/core").InputSignal<Date | undefined>;
|
|
39
|
+
label: import("@angular/core").InputSignal<string>;
|
|
39
40
|
rangeMonthOnlyMode: import("@angular/core").InputSignal<boolean>;
|
|
40
41
|
startAt: import("@angular/core").InputSignal<Date | null>;
|
|
41
|
-
label: import("@angular/core").InputSignal<string>;
|
|
42
42
|
dateClass: import("@angular/core").InputSignal<MatCalendarCellClassFunction<Date>>;
|
|
43
43
|
canStepThroughDays: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
44
|
+
matEndDate: import("@angular/core").Signal<MatEndDate<Date | null> | undefined>;
|
|
45
|
+
matStartDate: import("@angular/core").Signal<MatStartDate<Date | null> | undefined>;
|
|
46
|
+
matDateRangeInput: import("@angular/core").Signal<MatDateRangeInput<Date | null> | undefined>;
|
|
47
|
+
matDatepickerInput: import("@angular/core").Signal<MatDatepickerInput<Date | null> | undefined>;
|
|
48
|
+
matDateRangePicker: import("@angular/core").Signal<MatDateRangePicker<Date | null> | undefined>;
|
|
49
|
+
actualInput: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
50
|
+
input: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
51
|
+
endInput: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
52
|
+
startInput: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
53
53
|
protected _placeholder: string;
|
|
54
54
|
rangeSeparator: string;
|
|
55
55
|
rangePlaceholder: string;
|
|
@@ -61,7 +61,7 @@ export declare class WattDatepickerComponent extends WattPickerBase implements V
|
|
|
61
61
|
isNextDayButtonDisabled: import("@angular/core").WritableSignal<boolean>;
|
|
62
62
|
constructor();
|
|
63
63
|
ngAfterViewInit(): void;
|
|
64
|
-
validate({ value }: AbstractControl<WattRange<string>>)
|
|
64
|
+
validate: ({ value }: AbstractControl<WattRange<string>>) => {
|
|
65
65
|
monthOnly: boolean;
|
|
66
66
|
} | null;
|
|
67
67
|
protected initSingleInput(): void;
|
|
@@ -91,5 +91,5 @@ export declare class WattDatepickerComponent extends WattPickerBase implements V
|
|
|
91
91
|
private setToEndOfDay;
|
|
92
92
|
private setEndDateToDanishTimeZone;
|
|
93
93
|
static ɵfac: i0.ɵɵFactoryDeclaration<WattDatepickerComponent, never>;
|
|
94
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<WattDatepickerComponent, "watt-datepicker", never, { "max": { "alias": "max"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "
|
|
94
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<WattDatepickerComponent, "watt-datepicker", never, { "max": { "alias": "max"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "rangeMonthOnlyMode": { "alias": "rangeMonthOnlyMode"; "required": false; "isSignal": true; }; "startAt": { "alias": "startAt"; "required": false; "isSignal": true; }; "dateClass": { "alias": "dateClass"; "required": false; "isSignal": true; }; "canStepThroughDays": { "alias": "canStepThroughDays"; "required": false; "isSignal": true; }; }, {}, never, ["*", "watt-field-hint", "watt-field-error"], true, never>;
|
|
95
95
|
}
|
|
@@ -21,9 +21,9 @@ export declare class WattTimepickerComponent extends WattPickerBase {
|
|
|
21
21
|
* Text to display on label for time range slider.
|
|
22
22
|
*/
|
|
23
23
|
sliderLabel: import("@angular/core").InputSignal<string>;
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
input: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
25
|
+
startInput: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
26
|
+
endInput: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
|
|
27
27
|
sliderId: string;
|
|
28
28
|
/**
|
|
29
29
|
* Used for defining a relationship between the time picker and
|