@acpaas-ui/ngx-forms 6.1.5 → 6.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,6 +3,7 @@ import { Subject } from 'rxjs';
3
3
  import { takeUntil } from 'rxjs/operators';
4
4
  import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
5
5
  import { DateHelper } from '@acpaas-ui/ngx-utils';
6
+ import { TZDate } from '@date-fns/tz';
6
7
  import { FlyoutDirective } from '@acpaas-ui/ngx-flyout';
7
8
  import { CALENDAR_DEFAULT_MONTH_LABELS, CALENDAR_DEFAULT_WEEKDAY_LABELS, CALENDAR_MONTH_LABELS, CALENDAR_WEEKDAY_LABELS, } from '@acpaas-ui/ngx-calendar';
8
9
  import { DATEPICKER_SEPARATOR_CHAR, DATEPICKER_DEFAULT_ERROR_LABELS, DATEPICKER_ERROR_LABELS, } from '../../datepicker.conf';
@@ -87,10 +88,13 @@ export class DatepickerComponent {
87
88
  const date = DateHelper.parseDate(format, 'yyyy-MM-dd');
88
89
  if (date) {
89
90
  this.selectedDate = date;
90
- this.onChange(date.toISOString());
91
+ const brusselsDate = new TZDate(date, 'Europe/Brussels');
92
+ const year = brusselsDate.getFullYear();
93
+ const month = brusselsDate.getMonth();
94
+ const day = brusselsDate.getDate();
95
+ this.onChange(DateHelper.toUtcMidnightInBrussels(year, month, day));
91
96
  }
92
97
  else {
93
- // Change value with original value (and not null or '') so we can add an error in the validate function
94
98
  this.onChange(value);
95
99
  }
96
100
  }
@@ -119,12 +123,20 @@ export class DatepickerComponent {
119
123
  .build();
120
124
  }
121
125
  writeValue(value) {
122
- this.selectedDate =
123
- typeof value === 'string'
124
- ? this.isISODateFormat(value)
125
- ? new Date(value)
126
- : DateHelper.parseDate(value, 'dd/MM/yyyy')
127
- : value;
126
+ if (typeof value === 'string') {
127
+ if (this.isISODateFormat(value)) {
128
+ this.selectedDate = DateHelper.parseDate(value);
129
+ }
130
+ else {
131
+ this.selectedDate = DateHelper.parseDate(value, 'dd/MM/yyyy');
132
+ }
133
+ }
134
+ else if (value instanceof Date) {
135
+ this.selectedDate = value;
136
+ }
137
+ else {
138
+ this.selectedDate = null;
139
+ }
128
140
  const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';
129
141
  this.formControl.setValue(dateString);
130
142
  }
@@ -293,4 +305,4 @@ export class DatepickerComponent {
293
305
  }], blur: [{
294
306
  type: Output
295
307
  }] }); })();
296
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.ts","../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { DateHelper, DateRange } from '@acpaas-ui/ngx-utils';\nimport { FlyoutDirective } from '@acpaas-ui/ngx-flyout';\nimport {\n  CALENDAR_DEFAULT_MONTH_LABELS,\n  CALENDAR_DEFAULT_WEEKDAY_LABELS,\n  CALENDAR_MONTH_LABELS,\n  CALENDAR_WEEKDAY_LABELS,\n  CalendarService,\n  DatepickerResult,\n  WeekdayLabelsConfig,\n  MonthLabelsConfig,\n} from '@acpaas-ui/ngx-calendar';\n\nimport {\n  DATEPICKER_SEPARATOR_CHAR,\n  DATEPICKER_DEFAULT_ERROR_LABELS,\n  DATEPICKER_ERROR_LABELS,\n} from '../../datepicker.conf';\nimport { DatepickerValidationErrors } from '../../types/datepicker.types';\nimport { Interval, IntervalBuilder } from '@acpaas-ui/ngx-utils';\n\n@Component({\n  selector: 'aui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  @ViewChild(FlyoutDirective, { static: true }) flyout: FlyoutDirective;\n  @Input() id: string;\n  @Input() name: string;\n  @Input() placeholder = 'dd/mm/yyyy';\n  @Input() label: string;\n  @Input() description: string;\n  @Input() range: DateRange;\n  @Input()\n  min: Date | null;\n  @Input()\n  max: Date | null;\n  @Input() autocomplete: 'off';\n  @Input() weekdayLabels: WeekdayLabelsConfig;\n  @Input() monthLabels: MonthLabelsConfig;\n  @Input() ariaOpenDatepickerLabel = 'Open kalender';\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() blur = new EventEmitter<Event>();\n\n  public formControl: UntypedFormControl;\n  public selectedDate: Date;\n  public isDisabled = false;\n  public interval: Interval.IInterval<Date>;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(\n    @Inject(CALENDAR_MONTH_LABELS) private moduleMonthLabels = CALENDAR_DEFAULT_MONTH_LABELS,\n    @Inject(CALENDAR_WEEKDAY_LABELS) private moduleWeekdayLabels = CALENDAR_DEFAULT_WEEKDAY_LABELS,\n    @Inject(DATEPICKER_ERROR_LABELS) private errorLabels = DATEPICKER_DEFAULT_ERROR_LABELS,\n    public calendarService: CalendarService,\n    private formBuilder: UntypedFormBuilder,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  public ngOnInit(): void {\n    this.weekdayLabels = this.weekdayLabels || this.moduleWeekdayLabels;\n    this.monthLabels = this.monthLabels || this.moduleMonthLabels;\n    this.createInterval();\n    this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });\n    this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {\n      if (value) {\n        const format = value.split(DATEPICKER_SEPARATOR_CHAR).reverse().join('-');\n        const date = DateHelper.parseDate(format, 'yyyy-MM-dd');\n        if (date) {\n          this.selectedDate = date;\n          this.onChange(date.toISOString());\n        } else {\n          // Change value with original value (and not null or '') so we can add an error in the validate function\n          this.onChange(value);\n        }\n      } else {\n        this.selectedDate = null;\n        this.onChange('');\n      }\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.min || changes.max) {\n      this.createInterval();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  private createInterval() {\n    if (!this.min && !this.max) {\n      return;\n    }\n    // Create an interval if min/max is filled in\n    this.interval = IntervalBuilder.dateInterval(\n      this.min ? new Date(this.min) : null,\n      this.max ? new Date(this.max) : null\n    )\n      .not()\n      .build();\n  }\n\n  public writeValue(value: string | Date): void {\n    this.selectedDate =\n      typeof value === 'string'\n        ? this.isISODateFormat(value)\n          ? new Date(value)\n          : DateHelper.parseDate(value, 'dd/MM/yyyy')\n        : value;\n    const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';\n    this.formControl.setValue(dateString);\n  }\n\n  public registerOnChange(onChange: (res: any) => void): void {\n    this.onChange = onChange;\n  }\n\n  public registerOnTouched(onTouched: (_: any) => void): void {\n    this.onTouched = onTouched;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n\n    if (this.formControl) {\n      if (isDisabled && this.formControl.enabled) {\n        this.formControl.disable();\n      } else if (!isDisabled && this.formControl.disabled) {\n        this.formControl.enable();\n      }\n    }\n\n    this.ref.markForCheck();\n  }\n\n  public selectDateFromCalendar(result: DatepickerResult): void {\n    if (result.complete) {\n      this.formControl.setValue(this.formatDate(result.date));\n      this.flyout.close();\n    }\n  }\n\n  public formatDate(date: Date): string {\n    return DateHelper.formatDate(date, 'DD/MM/YYYY', {\n      leadingZero: true,\n      monthLabels: this.monthLabels,\n      weekdayLabels: this.weekdayLabels,\n    });\n  }\n\n  public validate(ctrl: UntypedFormControl): DatepickerValidationErrors {\n    // no error on empty value (add required validator in app)\n    if (ctrl.value === '' || ctrl.value === null) {\n      return null;\n    }\n\n    // throw format error if no valid date was provided\n    const date = DateHelper.parseDate(ctrl.value);\n    if (!date) {\n      return {\n        format: this.errorLabels.ERRORS_INVALID_DATE,\n      };\n    }\n\n    // no error if valid date an no range provided\n    if (!this.range || !this.range.length) {\n      return null;\n    }\n\n    // throw error when out of range\n    const range = this.calendarService.getRangeForDate(date, this.range);\n\n    return range.indexOf(date.getDate()) >= 0\n      ? {\n          range: this.errorLabels.ERRORS_INVALID_RANGE,\n        }\n      : null;\n  }\n\n  public handleBlur(e: Event): void {\n    this.blur.emit(e);\n    this.onTouched(e);\n  }\n\n  private onChange: (res: any) => void = () => undefined;\n\n  private onTouched: (_: any) => void = () => undefined;\n\n  private isISODateFormat(value: string) {\n    if (typeof value !== 'string') {\n      return false;\n    }\n    return value.match(/\\d{4}-\\d{2}-\\d{2}T.*/);\n  }\n}\n","<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n  <label class=\"a-input__label\" for=\"{{ id }}\" *ngIf=\"label\">{{ label }}</label>\n  <small class=\"a-input__description\" *ngIf=\"description\"> {{ description }}</small>\n  <div class=\"a-input__wrapper\">\n    <input\n      (blur)=\"handleBlur($event)\"\n      [attr.disabled]=\"isDisabled ? true : null\"\n      [autocomplete]=\"autocomplete\"\n      [formControl]=\"formControl\"\n      id=\"{{ id }}\"\n      label=\"Pick date\"\n      description=\"Description\"\n      name=\"{{ name }}\"\n      placeholder=\"{{ placeholder }}\"\n      type=\"text\"\n    />\n    <ng-container *ngIf=\"isDisabled\">\n      <aui-icon\n        name=\"ai-calendar\"\n      />\n    </ng-container>\n    <ng-container *ngIf=\"!isDisabled\">\n      <aui-icon\n        auiFlyoutAction\n        [openOnFocus]=\"false\"\n        name=\"ai-calendar\"\n        className=\"is-clickable\"\n        role=\"button\"\n        [attr.aria-label]=\"ariaOpenDatepickerLabel\"\n        tabindex=\"0\"\n      />\n    </ng-container>\n\n    <ng-container *ngIf=\"!isDisabled\">\n      <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n        <aui-calendar\n          (selectDate)=\"selectDateFromCalendar($event)\"\n          [range]=\"range\"\n          [selectedDate]=\"selectedDate\"\n          [interval]=\"interval\"\n          [weekdayLabels]=\"weekdayLabels\"\n          [monthLabels]=\"monthLabels\"\n        ></aui-calendar>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
308
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.ts","../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { DateHelper, DateRange } from '@acpaas-ui/ngx-utils';\nimport { TZDate } from '@date-fns/tz';\nimport { FlyoutDirective } from '@acpaas-ui/ngx-flyout';\nimport {\n  CALENDAR_DEFAULT_MONTH_LABELS,\n  CALENDAR_DEFAULT_WEEKDAY_LABELS,\n  CALENDAR_MONTH_LABELS,\n  CALENDAR_WEEKDAY_LABELS,\n  CalendarService,\n  DatepickerResult,\n  WeekdayLabelsConfig,\n  MonthLabelsConfig,\n} from '@acpaas-ui/ngx-calendar';\n\nimport {\n  DATEPICKER_SEPARATOR_CHAR,\n  DATEPICKER_DEFAULT_ERROR_LABELS,\n  DATEPICKER_ERROR_LABELS,\n} from '../../datepicker.conf';\nimport { DatepickerValidationErrors } from '../../types/datepicker.types';\nimport { Interval, IntervalBuilder } from '@acpaas-ui/ngx-utils';\n\n@Component({\n  selector: 'aui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  @ViewChild(FlyoutDirective, { static: true }) flyout: FlyoutDirective;\n  @Input() id: string;\n  @Input() name: string;\n  @Input() placeholder = 'dd/mm/yyyy';\n  @Input() label: string;\n  @Input() description: string;\n  @Input() range: DateRange;\n  @Input()\n  min: Date | null;\n  @Input()\n  max: Date | null;\n  @Input() autocomplete: 'off';\n  @Input() weekdayLabels: WeekdayLabelsConfig;\n  @Input() monthLabels: MonthLabelsConfig;\n  @Input() ariaOpenDatepickerLabel = 'Open kalender';\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() blur = new EventEmitter<Event>();\n\n  public formControl: UntypedFormControl;\n  public selectedDate: Date;\n  public isDisabled = false;\n  public interval: Interval.IInterval<Date>;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(\n    @Inject(CALENDAR_MONTH_LABELS) private moduleMonthLabels = CALENDAR_DEFAULT_MONTH_LABELS,\n    @Inject(CALENDAR_WEEKDAY_LABELS) private moduleWeekdayLabels = CALENDAR_DEFAULT_WEEKDAY_LABELS,\n    @Inject(DATEPICKER_ERROR_LABELS) private errorLabels = DATEPICKER_DEFAULT_ERROR_LABELS,\n    public calendarService: CalendarService,\n    private formBuilder: UntypedFormBuilder,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  public ngOnInit(): void {\n    this.weekdayLabels = this.weekdayLabels || this.moduleWeekdayLabels;\n    this.monthLabels = this.monthLabels || this.moduleMonthLabels;\n    this.createInterval();\n    this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });\n    this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {\n      if (value) {\n        const format = value.split(DATEPICKER_SEPARATOR_CHAR).reverse().join('-');\n        const date = DateHelper.parseDate(format, 'yyyy-MM-dd');\n        if (date) {\n          this.selectedDate = date;\n          const brusselsDate = new TZDate(date, 'Europe/Brussels');\n          const year = brusselsDate.getFullYear();\n          const month = brusselsDate.getMonth();\n          const day = brusselsDate.getDate();\n          this.onChange(DateHelper.toUtcMidnightInBrussels(year, month, day));\n        } else {\n          this.onChange(value);\n        }\n      } else {\n        this.selectedDate = null;\n        this.onChange('');\n      }\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.min || changes.max) {\n      this.createInterval();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  private createInterval() {\n    if (!this.min && !this.max) {\n      return;\n    }\n    // Create an interval if min/max is filled in\n    this.interval = IntervalBuilder.dateInterval(\n      this.min ? new Date(this.min) : null,\n      this.max ? new Date(this.max) : null\n    )\n      .not()\n      .build();\n  }\n\n  public writeValue(value: string | Date): void {\n    if (typeof value === 'string') {\n      if (this.isISODateFormat(value)) {\n        this.selectedDate = DateHelper.parseDate(value);\n      } else {\n        this.selectedDate = DateHelper.parseDate(value, 'dd/MM/yyyy');\n      }\n    } else if (value instanceof Date) {\n      this.selectedDate = value;\n    } else {\n      this.selectedDate = null;\n    }\n\n    const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';\n    this.formControl.setValue(dateString);\n  }\n\n  public registerOnChange(onChange: (res: any) => void): void {\n    this.onChange = onChange;\n  }\n\n  public registerOnTouched(onTouched: (_: any) => void): void {\n    this.onTouched = onTouched;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n\n    if (this.formControl) {\n      if (isDisabled && this.formControl.enabled) {\n        this.formControl.disable();\n      } else if (!isDisabled && this.formControl.disabled) {\n        this.formControl.enable();\n      }\n    }\n\n    this.ref.markForCheck();\n  }\n\n  public selectDateFromCalendar(result: DatepickerResult): void {\n    if (result.complete) {\n      this.formControl.setValue(this.formatDate(result.date));\n      this.flyout.close();\n    }\n  }\n\n  public formatDate(date: Date): string {\n    return DateHelper.formatDate(date, 'DD/MM/YYYY', {\n      leadingZero: true,\n      monthLabels: this.monthLabels,\n      weekdayLabels: this.weekdayLabels,\n    });\n  }\n\n  public validate(ctrl: UntypedFormControl): DatepickerValidationErrors {\n    // no error on empty value (add required validator in app)\n    if (ctrl.value === '' || ctrl.value === null) {\n      return null;\n    }\n\n    // throw format error if no valid date was provided\n    const date = DateHelper.parseDate(ctrl.value);\n    if (!date) {\n      return {\n        format: this.errorLabels.ERRORS_INVALID_DATE,\n      };\n    }\n\n    // no error if valid date an no range provided\n    if (!this.range || !this.range.length) {\n      return null;\n    }\n\n    // throw error when out of range\n    const range = this.calendarService.getRangeForDate(date, this.range);\n\n    return range.indexOf(date.getDate()) >= 0\n      ? {\n          range: this.errorLabels.ERRORS_INVALID_RANGE,\n        }\n      : null;\n  }\n\n  public handleBlur(e: Event): void {\n    this.blur.emit(e);\n    this.onTouched(e);\n  }\n\n  private onChange: (res: any) => void = () => undefined;\n\n  private onTouched: (_: any) => void = () => undefined;\n\n  private isISODateFormat(value: string) {\n    if (typeof value !== 'string') {\n      return false;\n    }\n    return value.match(/\\d{4}-\\d{2}-\\d{2}T.*/);\n  }\n}\n","<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n  <label class=\"a-input__label\" for=\"{{ id }}\" *ngIf=\"label\">{{ label }}</label>\n  <small class=\"a-input__description\" *ngIf=\"description\"> {{ description }}</small>\n  <div class=\"a-input__wrapper\">\n    <input\n      (blur)=\"handleBlur($event)\"\n      [attr.disabled]=\"isDisabled ? true : null\"\n      [autocomplete]=\"autocomplete\"\n      [formControl]=\"formControl\"\n      id=\"{{ id }}\"\n      label=\"Pick date\"\n      description=\"Description\"\n      name=\"{{ name }}\"\n      placeholder=\"{{ placeholder }}\"\n      type=\"text\"\n    />\n    <ng-container *ngIf=\"isDisabled\">\n      <aui-icon\n        name=\"ai-calendar\"\n      />\n    </ng-container>\n    <ng-container *ngIf=\"!isDisabled\">\n      <aui-icon\n        auiFlyoutAction\n        [openOnFocus]=\"false\"\n        name=\"ai-calendar\"\n        className=\"is-clickable\"\n        role=\"button\"\n        [attr.aria-label]=\"ariaOpenDatepickerLabel\"\n        tabindex=\"0\"\n      />\n    </ng-container>\n\n    <ng-container *ngIf=\"!isDisabled\">\n      <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n        <aui-calendar\n          (selectDate)=\"selectDateFromCalendar($event)\"\n          [range]=\"range\"\n          [selectedDate]=\"selectedDate\"\n          [interval]=\"interval\"\n          [weekdayLabels]=\"weekdayLabels\"\n          [monthLabels]=\"monthLabels\"\n        ></aui-calendar>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
@@ -12,6 +12,7 @@ import { get, isEqual, debounce } from 'lodash-es';
12
12
  import { Subject, Observable } from 'rxjs';
13
13
  import { takeUntil } from 'rxjs/operators';
14
14
  import { DateHelper, IntervalBuilder } from '@acpaas-ui/ngx-utils';
15
+ import { TZDate } from '@date-fns/tz';
15
16
  import * as i1$2 from '@acpaas-ui/ngx-calendar';
16
17
  import { CALENDAR_DEFAULT_MONTH_LABELS, CALENDAR_DEFAULT_WEEKDAY_LABELS, CALENDAR_MONTH_LABELS, CALENDAR_WEEKDAY_LABELS, CalendarModule } from '@acpaas-ui/ngx-calendar';
17
18
  import * as i4$1 from '@acpaas-ui/ngx-icon';
@@ -527,10 +528,13 @@ class DatepickerComponent {
527
528
  const date = DateHelper.parseDate(format, 'yyyy-MM-dd');
528
529
  if (date) {
529
530
  this.selectedDate = date;
530
- this.onChange(date.toISOString());
531
+ const brusselsDate = new TZDate(date, 'Europe/Brussels');
532
+ const year = brusselsDate.getFullYear();
533
+ const month = brusselsDate.getMonth();
534
+ const day = brusselsDate.getDate();
535
+ this.onChange(DateHelper.toUtcMidnightInBrussels(year, month, day));
531
536
  }
532
537
  else {
533
- // Change value with original value (and not null or '') so we can add an error in the validate function
534
538
  this.onChange(value);
535
539
  }
536
540
  }
@@ -559,12 +563,20 @@ class DatepickerComponent {
559
563
  .build();
560
564
  }
561
565
  writeValue(value) {
562
- this.selectedDate =
563
- typeof value === 'string'
564
- ? this.isISODateFormat(value)
565
- ? new Date(value)
566
- : DateHelper.parseDate(value, 'dd/MM/yyyy')
567
- : value;
566
+ if (typeof value === 'string') {
567
+ if (this.isISODateFormat(value)) {
568
+ this.selectedDate = DateHelper.parseDate(value);
569
+ }
570
+ else {
571
+ this.selectedDate = DateHelper.parseDate(value, 'dd/MM/yyyy');
572
+ }
573
+ }
574
+ else if (value instanceof Date) {
575
+ this.selectedDate = value;
576
+ }
577
+ else {
578
+ this.selectedDate = null;
579
+ }
568
580
  const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';
569
581
  this.formControl.setValue(dateString);
570
582
  }