UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

258 lines 47.1 kB
import { ChangeDetectorRef, Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core'; import { FormControl, FormGroup, NG_VALIDATORS, NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule } from '@angular/forms'; import { first, takeUntil } from 'rxjs/operators'; import { Subject } from 'rxjs'; import { gettext } from '../i18n'; import { BsDatepickerDirective, BsDatepickerModule } from 'ngx-bootstrap/datepicker'; import { NgSwitch, NgSwitchCase } from '@angular/common'; import { CloseDatePickerDirective } from './close-date-picker.directive'; import { TimepickerModule } from 'ngx-bootstrap/timepicker'; import { DatePickerComponent } from '../date-picker/date-picker.component'; import { C8yTranslatePipe } from '../i18n/c8y-translate.pipe'; import * as i0 from "@angular/core"; import * as i1 from "ngx-bootstrap/datepicker"; import * as i2 from "@angular/forms"; import * as i3 from "ngx-bootstrap/timepicker"; export class DateTimePickerComponent { set _minDate(value) { this.minDate = value ? new Date(value) : undefined; } set _maxDate(value) { this.maxDate = value ? new Date(value) : undefined; } constructor(cd) { this.cd = cd; this.dateInputFormat = 'YYYY-MM-DD'; this.adaptivePosition = false; /** * Specifies the type of date input. * * @param DateAndTime - Display both date and time. * @param Date - Display only the date without the time. * @param DateRange - Specify a range of dates. * @param SingleDateRequired - Require the selection of a single date. * @param Time - Display only the time without the date. * * @defaultValue 'DateAndTime' */ this.dateType = 'DateAndTime'; this.config = { showMeridian: false, showMinutes: true, showSeconds: false, showSpinners: false }; this.onDateSelected = new EventEmitter(); this.defaultPlaceholder = gettext('Select a date'); this.previousTimePickerValues = {}; this.destroy$ = new Subject(); // eslint-disable-next-line @typescript-eslint/no-empty-function this.onChange = () => { }; // eslint-disable-next-line @typescript-eslint/no-empty-function this.onTouched = () => { }; this.form = new FormGroup({}); this.form.addControl('date', new FormControl(null)); this.form.addControl('time', new FormControl(null)); this.form.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => { this.setDatetime(value); this.previousValue = value; }); this.form.statusChanges .pipe(first()) .pipe(takeUntil(this.destroy$)) .subscribe(() => { this.onTouched(); }); } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } ngAfterViewInit() { this.cd.detectChanges(); } /** * Control Value Accessor - If form value changes by external factor, update date property and internal form with new value. */ writeValue(value) { if (typeof value === 'string' && value.length) { this.date = new Date(value); this.form.setValue({ date: new Date(value), time: this.date }, { emitEvent: false }); } else { this.form.setValue({ date: null, time: null }, { emitEvent: false }); } this.previousValue = this.form.value; } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(onTouched) { this.onTouched = onTouched; } setDisabledState(disabled) { if (disabled === this.form?.disabled) { return; } disabled ? this.form.disable() : this.form.enable(); } validate(_control) { if (this.date?.getTime() < new Date(this.minDate).getTime()) { return { dateBeforeRangeMin: true }; } else if (this.date?.getTime() > new Date(this.maxDate).getTime()) { return { dateAfterRangeMax: true }; } else if (this.form.invalid) { return { invalidDateTime: true }; } else { return null; } } previousDay() { const isOpen = this.datepicker.isOpen; this.date.setDate(this.date.getDate() - 1); this.setDatetime({ date: this.date, time: this.form.get('time').value }); if (isOpen) { this.datepicker.show(); } } nextDay() { const isOpen = this.datepicker.isOpen; this.date.setDate(this.date.getDate() + 1); this.setDatetime({ date: this.date, time: this.form.get('time').value }); if (isOpen) { this.datepicker.show(); } } hide() { this.datepicker.hide(); } handleMouseWheel(event) { const hours = this.form.get('time').value.getHours(); const minutes = this.form.get('time').value.getMinutes(); // down event.preventDefault(); if (event.deltaY > 0) { if (Number(hours) === 23 && this.previousTimePickerValues.hours !== 23) { this.previousDay(); } } // up if (event.deltaY < 0) { if (this.previousTimePickerValues.hours === undefined) { // scrolling up on empty form should not result in increasing day. } else if (Number(hours) === 0 && this.previousTimePickerValues.hours !== 0) { this.nextDay(); } } this.previousTimePickerValues = { hours, minutes }; } /** * If internal form changes its value, then combine date and time into one Date and pass its ISO string value to onChange method * @param dateTime * @private */ setDatetime(dateTime) { // if date input is cleared from a previous correct value, clear form value: if (this.isInputCleared(dateTime)) { this.form.get('date').setValue(undefined, { emitEvent: false }); this.form.get('time').setValue(undefined, { emitEvent: false }); this.onChange(null); return; } // if both date and time is invalid, do set form value to null and stop: if (!this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) { this.onChange(null); return; } // If only time is provided, set Date to today: if (!this.verifyDate(dateTime.date) && this.verifyDate(dateTime.time)) { dateTime.date = new Date(dateTime.time); } // If only date is provided, set time to 00:00: if (this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) { dateTime.time = new Date(dateTime.date.getFullYear(), dateTime.date.getMonth(), dateTime.date.getDate(), 0, 0, 0); this.form.get('time').setValue(dateTime.time, { emitEvent: false }); } // Merge date and time, and emit as new form value: this.date = new Date(dateTime.date); this.date.setHours(dateTime.time.getHours(), dateTime.time.getMinutes()); this.form.get('date').setValue(dateTime.date, { emitEvent: false }); this.onChange(this.date.toISOString()); } verifyDate(value) { const date = value; return date instanceof Date && !isNaN(date.getTime()); } isInputCleared(value) { return this.previousValue?.date && value.date === undefined; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "c8y-date-time-picker", inputs: { _minDate: ["minDate", "_minDate"], _maxDate: ["maxDate", "_maxDate"], placeholder: "placeholder", dateInputFormat: "dateInputFormat", adaptivePosition: "adaptivePosition", size: "size", dateType: "dateType", config: "config" }, outputs: { onDateSelected: "onDateSelected" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateTimePickerComponent), multi: true }, { provide: NG_VALIDATORS, useExisting: forwardRef(() => DateTimePickerComponent), multi: true } ], viewQueries: [{ propertyName: "datepicker", first: true, predicate: BsDatepickerDirective, descendants: true }], ngImport: i0, template: "<div\n class=\"datetime-picker\"\n [ngSwitch]=\"dateType\"\n>\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateAndTime'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n style=\"min-width: 120px\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Date'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateRange'\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n placeholder=\"{{ 'Select a date range' | translate }}\"\n [formControl]=\"form.get('date')\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n adaptivePosition: true,\n rangeInputFormat: dateInputFormat\n }\"\n bsDaterangepicker\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Time'\"\n >\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div *ngSwitchCase=\"'SingleDateRequired'\">\n <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: CloseDatePickerDirective, selector: "[closeDatepicker]", inputs: ["closeDatepicker"] }, { kind: "ngmodule", type: BsDatepickerModule }, { kind: "directive", type: i1.BsDatepickerDirective, selector: "[bsDatepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isDisabled", "minDate", "maxDate", "minMode", "daysDisabled", "datesDisabled", "datesEnabled", "dateCustomClasses", "dateTooltipTexts", "isOpen", "bsValue", "bsConfig"], outputs: ["onShown", "onHidden", "bsValueChange"], exportAs: ["bsDatepicker"] }, { kind: "directive", type: i1.BsDatepickerInputDirective, selector: "input[bsDatepicker]" }, { kind: "directive", type: i1.BsDaterangepickerDirective, selector: "[bsDaterangepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isOpen", "bsValue", "bsConfig", "isDisabled", "minDate", "maxDate", "dateCustomClasses", "daysDisabled", "datesDisabled", "datesEnabled"], outputs: ["onShown", "onHidden", "bsValueChange"], exportAs: ["bsDaterangepicker"] }, { kind: "directive", type: i1.BsDaterangepickerInputDirective, selector: "input[bsDaterangepicker]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TimepickerModule }, { kind: "component", type: i3.TimepickerComponent, selector: "timepicker", inputs: ["hourStep", "minuteStep", "secondsStep", "readonlyInput", "disabled", "mousewheel", "arrowkeys", "showSpinners", "showMeridian", "showMinutes", "showSeconds", "meridians", "min", "max", "hoursPlaceholder", "minutesPlaceholder", "secondsPlaceholder"], outputs: ["isValid", "meridianChange"] }, { kind: "component", type: DatePickerComponent, selector: "c8y-date-picker", inputs: ["placeholder"], outputs: ["onDateSelected"] }, { kind: "pipe", type: C8yTranslatePipe, name: "translate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-date-time-picker', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateTimePickerComponent), multi: true }, { provide: NG_VALIDATORS, useExisting: forwardRef(() => DateTimePickerComponent), multi: true } ], standalone: true, imports: [ NgSwitch, NgSwitchCase, CloseDatePickerDirective, BsDatepickerModule, FormsModule, ReactiveFormsModule, TimepickerModule, DatePickerComponent, C8yTranslatePipe ], template: "<div\n class=\"datetime-picker\"\n [ngSwitch]=\"dateType\"\n>\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateAndTime'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n style=\"min-width: 120px\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Date'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateRange'\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n placeholder=\"{{ 'Select a date range' | translate }}\"\n [formControl]=\"form.get('date')\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n adaptivePosition: true,\n rangeInputFormat: dateInputFormat\n }\"\n bsDaterangepicker\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Time'\"\n >\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div *ngSwitchCase=\"'SingleDateRequired'\">\n <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n </div>\n </div>\n</div>\n" }] }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { _minDate: [{ type: Input, args: ['minDate'] }], _maxDate: [{ type: Input, args: ['maxDate'] }], placeholder: [{ type: Input }], dateInputFormat: [{ type: Input }], adaptivePosition: [{ type: Input }], size: [{ type: Input }], dateType: [{ type: Input }], config: [{ type: Input }], onDateSelected: [{ type: Output }], datepicker: [{ type: ViewChild, args: [BsDatepickerDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../core/date-time-picker/date-time-picker.component.ts","../../../../core/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  FormGroup,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  FormsModule,\n  ReactiveFormsModule\n} from '@angular/forms';\nimport { first, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { gettext } from '../i18n';\nimport { BsDatepickerDirective, BsDatepickerModule } from 'ngx-bootstrap/datepicker';\nimport { PickedDates } from '../date-picker';\nimport { NgSwitch, NgSwitchCase } from '@angular/common';\nimport { CloseDatePickerDirective } from './close-date-picker.directive';\nimport { TimepickerModule } from 'ngx-bootstrap/timepicker';\nimport { DatePickerComponent } from '../date-picker/date-picker.component';\nimport { C8yTranslatePipe } from '../i18n/c8y-translate.pipe';\n\ninterface DateAndTime {\n  date: Date;\n  time: Date;\n}\n\ninterface DateAndTimeOptions {\n  showSpinners?: boolean;\n  showMeridian?: boolean;\n  showMinutes?: boolean;\n  showSeconds?: boolean;\n}\n\nexport type DateType = 'DateAndTime' | 'Date' | 'DateRange' | 'SingleDateRequired' | 'Time';\n\n@Component({\n  selector: 'c8y-date-time-picker',\n  templateUrl: './date-time-picker.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateTimePickerComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DateTimePickerComponent),\n      multi: true\n    }\n  ],\n  standalone: true,\n  imports: [\n    NgSwitch,\n    NgSwitchCase,\n    CloseDatePickerDirective,\n    BsDatepickerModule,\n    FormsModule,\n    ReactiveFormsModule,\n    TimepickerModule,\n    DatePickerComponent,\n    C8yTranslatePipe\n  ]\n})\nexport class DateTimePickerComponent implements ControlValueAccessor, Validator, OnDestroy {\n  minDate: Date;\n\n  @Input('minDate')\n  set _minDate(value: string) {\n    this.minDate = value ? new Date(value) : undefined;\n  }\n\n  maxDate: Date;\n\n  @Input('maxDate')\n  set _maxDate(value: string) {\n    this.maxDate = value ? new Date(value) : undefined;\n  }\n\n  @Input()\n  placeholder: string;\n\n  @Input()\n  dateInputFormat = 'YYYY-MM-DD';\n\n  @Input()\n  adaptivePosition = false;\n\n  @Input()\n  size: string;\n\n  /**\n   * Specifies the type of date input.\n   *\n   * @param DateAndTime - Display both date and time.\n   * @param Date - Display only the date without the time.\n   * @param DateRange - Specify a range of dates.\n   * @param SingleDateRequired - Require the selection of a single date.\n   * @param Time - Display only the time without the date.\n   *\n   * @defaultValue 'DateAndTime'\n   */\n  @Input()\n  dateType: DateType = 'DateAndTime';\n\n  @Input()\n  config: DateAndTimeOptions = {\n    showMeridian: false,\n    showMinutes: true,\n    showSeconds: false,\n    showSpinners: false\n  };\n\n  @Output()\n  onDateSelected: EventEmitter<PickedDates> = new EventEmitter();\n\n  date: Date;\n  form: FormGroup;\n\n  defaultPlaceholder = gettext('Select a date…');\n\n  @ViewChild(BsDatepickerDirective) datepicker: BsDatepickerDirective;\n\n  private previousValue: DateAndTime;\n  private previousTimePickerValues: { hours?: number; minutes?: number } = {};\n  private destroy$: Subject<void> = new Subject();\n\n  constructor(private cd: ChangeDetectorRef) {\n    this.form = new FormGroup({});\n    this.form.addControl('date', new FormControl(null));\n    this.form.addControl('time', new FormControl(null));\n    this.form.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value: DateAndTime) => {\n      this.setDatetime(value);\n      this.previousValue = value;\n    });\n    this.form.statusChanges\n      .pipe(first())\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        this.onTouched();\n      });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange: (value: string) => void = () => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched: () => void = () => {};\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  ngAfterViewInit() {\n    this.cd.detectChanges();\n  }\n\n  /**\n   * Control Value Accessor - If form value changes by external factor, update date property and internal form with new value.\n   */\n  writeValue(value: string): void {\n    if (typeof value === 'string' && value.length) {\n      this.date = new Date(value);\n      this.form.setValue(\n        {\n          date: new Date(value),\n          time: this.date\n        },\n        { emitEvent: false }\n      );\n    } else {\n      this.form.setValue({ date: null, time: null }, { emitEvent: false });\n    }\n    this.previousValue = this.form.value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(onTouched: any) {\n    this.onTouched = onTouched;\n  }\n\n  setDisabledState(disabled: boolean) {\n    if (disabled === this.form?.disabled) {\n      return;\n    }\n    disabled ? this.form.disable() : this.form.enable();\n  }\n\n  validate(_control: AbstractControl): ValidationErrors | null {\n    if (this.date?.getTime() < new Date(this.minDate).getTime()) {\n      return { dateBeforeRangeMin: true };\n    } else if (this.date?.getTime() > new Date(this.maxDate).getTime()) {\n      return { dateAfterRangeMax: true };\n    } else if (this.form.invalid) {\n      return { invalidDateTime: true };\n    } else {\n      return null;\n    }\n  }\n\n  previousDay() {\n    const isOpen = this.datepicker.isOpen;\n    this.date.setDate(this.date.getDate() - 1);\n    this.setDatetime({ date: this.date, time: this.form.get('time').value });\n    if (isOpen) {\n      this.datepicker.show();\n    }\n  }\n\n  nextDay() {\n    const isOpen = this.datepicker.isOpen;\n    this.date.setDate(this.date.getDate() + 1);\n    this.setDatetime({ date: this.date, time: this.form.get('time').value });\n    if (isOpen) {\n      this.datepicker.show();\n    }\n  }\n\n  hide(): void {\n    this.datepicker.hide();\n  }\n\n  handleMouseWheel(event: WheelEvent): void {\n    const hours = this.form.get('time').value.getHours();\n    const minutes = this.form.get('time').value.getMinutes();\n    // down\n    event.preventDefault();\n    if (event.deltaY > 0) {\n      if (Number(hours) === 23 && this.previousTimePickerValues.hours !== 23) {\n        this.previousDay();\n      }\n    }\n\n    // up\n    if (event.deltaY < 0) {\n      if (this.previousTimePickerValues.hours === undefined) {\n        // scrolling up on empty form should not result in increasing day.\n      } else if (Number(hours) === 0 && this.previousTimePickerValues.hours !== 0) {\n        this.nextDay();\n      }\n    }\n    this.previousTimePickerValues = { hours, minutes };\n  }\n\n  /**\n   * If internal form changes its value, then combine date and time into one Date and pass its ISO string value to onChange method\n   * @param dateTime\n   * @private\n   */\n  private setDatetime(dateTime: DateAndTime) {\n    // if date input is cleared from a previous correct value, clear form value:\n    if (this.isInputCleared(dateTime)) {\n      this.form.get('date').setValue(undefined, { emitEvent: false });\n      this.form.get('time').setValue(undefined, { emitEvent: false });\n      this.onChange(null);\n      return;\n    }\n\n    // if both date and time is invalid, do set form value to null and stop:\n    if (!this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) {\n      this.onChange(null);\n      return;\n    }\n    // If only time is provided, set Date to today:\n    if (!this.verifyDate(dateTime.date) && this.verifyDate(dateTime.time)) {\n      dateTime.date = new Date(dateTime.time);\n    }\n\n    // If only date is provided, set time to 00:00:\n    if (this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) {\n      dateTime.time = new Date(\n        dateTime.date.getFullYear(),\n        dateTime.date.getMonth(),\n        dateTime.date.getDate(),\n        0,\n        0,\n        0\n      );\n      this.form.get('time').setValue(dateTime.time, { emitEvent: false });\n    }\n\n    // Merge date and time, and emit as new form value:\n    this.date = new Date(dateTime.date);\n    this.date.setHours(dateTime.time.getHours(), dateTime.time.getMinutes());\n    this.form.get('date').setValue(dateTime.date, { emitEvent: false });\n    this.onChange(this.date.toISOString());\n  }\n\n  private verifyDate(value: Date): boolean {\n    const date = value;\n    return date instanceof Date && !isNaN(date.getTime());\n  }\n\n  private isInputCleared(value: DateAndTime): boolean {\n    return this.previousValue?.date && value.date === undefined;\n  }\n}\n","<div\n  class=\"datetime-picker\"\n  [ngSwitch]=\"dateType\"\n>\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'DateAndTime'\"\n    [closeDatepicker]=\"datepicker\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        style=\"min-width: 120px\"\n        [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n        bsDatepicker\n        [outsideClick]=\"false\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          dateInputFormat: dateInputFormat,\n          adaptivePosition: adaptivePosition\n        }\"\n        [formControl]=\"form.get('date')\"\n        (blur)=\"onTouched()\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n      />\n    </div>\n    <timepicker\n      class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n      [formControl]=\"form.get('time')\"\n      [showSeconds]=\"config.showSeconds\"\n      [showSpinners]=\"config.showSpinners\"\n      [showMeridian]=\"config.showMeridian\"\n      (wheel)=\"handleMouseWheel($event)\"\n    ></timepicker>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'Date'\"\n    [closeDatepicker]=\"datepicker\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n        bsDatepicker\n        [outsideClick]=\"false\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          dateInputFormat: dateInputFormat,\n          adaptivePosition: adaptivePosition\n        }\"\n        [formControl]=\"form.get('date')\"\n        (blur)=\"onTouched()\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n      />\n    </div>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'DateRange'\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        placeholder=\"{{ 'Select a date range' | translate }}\"\n        [formControl]=\"form.get('date')\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          adaptivePosition: true,\n          rangeInputFormat: dateInputFormat\n        }\"\n        bsDaterangepicker\n      />\n    </div>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'Time'\"\n  >\n    <timepicker\n      class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n      [formControl]=\"form.get('time')\"\n      [showSeconds]=\"config.showSeconds\"\n      [showSpinners]=\"config.showSpinners\"\n      [showMeridian]=\"config.showMeridian\"\n      [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n      [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n      [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n      (wheel)=\"handleMouseWheel($event)\"\n    ></timepicker>\n  </div>\n\n  <div *ngSwitchCase=\"'SingleDateRequired'\">\n    <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n      <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n    </div>\n  </div>\n</div>\n"]}