@festo-ui/angular 6.0.0-dev.199 → 6.0.0-dev.205

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.
@@ -48,23 +48,26 @@ export class FngTimePickerDropdownComponent {
48
48
  const min = +event.target.min;
49
49
  const hour = +event.target.value;
50
50
  this.date?.setHours(hour > max ? max : hour < min ? min : hour);
51
+ this.onDateChange(false, false);
51
52
  }
52
53
  onMinuteChange(event) {
53
54
  const max = +event.target.max;
54
55
  const min = +event.target.min;
55
56
  const minute = +event.target.value;
56
57
  this.date?.setMinutes(minute > max ? max : minute < min ? min : minute);
58
+ this.onDateChange(false, false);
57
59
  }
58
60
  onSecondChange(event) {
59
61
  const max = +event.target.max;
60
62
  const min = +event.target.min;
61
63
  const seconds = +event.target.value;
62
64
  this.date?.setSeconds(seconds > max ? max : seconds < min ? min : seconds);
65
+ this.onDateChange(false, false);
63
66
  }
64
67
  onDateChange(close, reset) {
65
68
  if (this.date != null) {
66
69
  this.date = new Date(this.date);
67
- this.dateChange.emit({ date: !reset ? new Date(this.date) : null, close });
70
+ this.dateChange.emit({ reset, date: new Date(this.date), close });
68
71
  }
69
72
  }
70
73
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngTimePickerDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -88,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
88
91
  type: HostListener,
89
92
  args: ['document:keydown', ['$event']]
90
93
  }] } });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.ts","../../../../../../../projects/angular/src/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'fng-time-picker-dropdown',\n  templateUrl: './time-picker-dropdown.component.html',\n  styleUrls: ['./time-picker-dropdown.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FngTimePickerDropdownComponent implements AfterViewInit {\n  @Input() date: Date = new Date();\n  @Input() showSeconds = false;\n  @Input() timeFormat: '12' | '24' = '24';\n  @Output() dateChange = new EventEmitter<{ date: Date | null; close: boolean }>();\n\n  @ViewChild('hoursInput') hoursInput: ElementRef | undefined;\n\n  @HostListener('document:keydown', ['$event'])\n  hide(event: KeyboardEvent) {\n    if (event.key === 'Escape' || event.key === 'Enter') {\n      this.onDateChange(true, event.key === 'Escape');\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.hoursInput != null && this.hoursInput.nativeElement != null) {\n      (this.hoursInput.nativeElement as HTMLElement).focus();\n    }\n  }\n\n  onHourUp() {\n    this.date?.setHours(this.date.getHours() + 1);\n    this.onDateChange(false, false);\n  }\n\n  onHourDown() {\n    this.date?.setHours(this.date.getHours() - 1);\n    this.onDateChange(false, false);\n  }\n\n  onMinuteUp() {\n    this.date?.setMinutes(this.date.getMinutes() + 1);\n    this.onDateChange(false, false);\n  }\n\n  onMinuteDown() {\n    this.date?.setMinutes(this.date.getMinutes() - 1);\n    this.onDateChange(false, false);\n  }\n\n  onSecondUp() {\n    this.date?.setSeconds(this.date.getSeconds() + 1);\n    this.onDateChange(false, false);\n  }\n\n  onSecondDown() {\n    this.date?.setSeconds(this.date.getSeconds() - 1);\n    this.onDateChange(false, false);\n  }\n\n  onHourChange(event: Event) {\n    const max = +(event.target as HTMLInputElement).max;\n    const min = +(event.target as HTMLInputElement).min;\n    const hour = +(event.target as HTMLInputElement).value;\n    this.date?.setHours(hour > max ? max : hour < min ? min : hour);\n  }\n\n  onMinuteChange(event: Event) {\n    const max = +(event.target as HTMLInputElement).max;\n    const min = +(event.target as HTMLInputElement).min;\n    const minute = +(event.target as HTMLInputElement).value;\n    this.date?.setMinutes(minute > max ? max : minute < min ? min : minute);\n  }\n\n  onSecondChange(event: Event) {\n    const max = +(event.target as HTMLInputElement).max;\n    const min = +(event.target as HTMLInputElement).min;\n    const seconds = +(event.target as HTMLInputElement).value;\n    this.date?.setSeconds(seconds > max ? max : seconds < min ? min : seconds);\n  }\n\n  onDateChange(close: boolean, reset: boolean) {\n    if (this.date != null) {\n      this.date = new Date(this.date);\n      this.dateChange.emit({ date: !reset ? new Date(this.date) : null, close });\n    }\n  }\n}\n","<div class=\"fwe-timepicker\" [class.fwe-timepicker-am-pm]=\"timeFormat === '12'\">\n  <div class=\"fwe-timepicker-spinners\">\n    <div class=\"fwe-timepicker-spinners-hours\">\n      <button type=\"button\" aria-label=\"hour up\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onHourUp()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-expand\"></i>\n      </button>\n      <input\n        #hoursInput\n        aria-label=\"hours value\"\n        class=\"fwe-timepicker-hide-spinners\"\n        type=\"number\"\n        min=\"0\"\n        tabindex=\"1\"\n        step=\"1\"\n        [value]=\"date | date : (timeFormat === '12' ? 'hh' : 'HH')\"\n        [attr.max]=\"timeFormat === '12' ? 12 : 23\"\n        (input)=\"onHourChange($event)\"\n      />\n      <button type=\"button\" aria-label=\"hour down\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onHourDown()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-collapse\"></i>\n      </button>\n    </div>\n    <div class=\"fwe-timepicker-spinners-minutes\">\n      <button type=\"button\" aria-label=\"minute up\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onMinuteUp()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-expand\"></i>\n      </button>\n      <input\n        aria-label=\"minutes value\"\n        class=\"fwe-timepicker-hide-spinners\"\n        type=\"number\"\n        min=\"0\"\n        max=\"59\"\n        step=\"1\"\n        tabindex=\"2\"\n        [value]=\"date | date : 'mm'\"\n        (input)=\"onMinuteChange($event)\"\n      />\n      <button type=\"button\" aria-label=\"minute down\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onMinuteDown()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-collapse\"></i>\n      </button>\n    </div>\n    <div *ngIf=\"showSeconds\" class=\"fwe-timepicker-spinners-seconds\">\n      <button type=\"button\" aria-label=\"seconds up\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onSecondUp()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-expand\"></i>\n      </button>\n      <input\n        aria-label=\"seconds value\"\n        class=\"fwe-timepicker-hide-spinners\"\n        type=\"number\"\n        min=\"0\"\n        max=\"59\"\n        step=\"1\"\n        tabindex=\"3\"\n        [value]=\"date | date : 'ss'\"\n        (input)=\"onSecondChange($event)\"\n      />\n      <button type=\"button\" aria-label=\"seconds down\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onSecondDown()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-collapse\"></i>\n      </button>\n    </div>\n  </div>\n  <span *ngIf=\"timeFormat === '12'\" class=\"fwe-badge fwe-badge-control\">\n    {{ date | date : 'a' }}\n  </span>\n</div>\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.ts","../../../../../../../projects/angular/src/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'fng-time-picker-dropdown',\n  templateUrl: './time-picker-dropdown.component.html',\n  styleUrls: ['./time-picker-dropdown.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FngTimePickerDropdownComponent implements AfterViewInit {\n  @Input() date: Date = new Date();\n  @Input() showSeconds = false;\n  @Input() timeFormat: '12' | '24' = '24';\n  @Output() dateChange = new EventEmitter<{ reset: boolean; date: Date; close: boolean }>();\n\n  @ViewChild('hoursInput') hoursInput: ElementRef | undefined;\n\n  @HostListener('document:keydown', ['$event'])\n  hide(event: KeyboardEvent) {\n    if (event.key === 'Escape' || event.key === 'Enter') {\n      this.onDateChange(true, event.key === 'Escape');\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.hoursInput != null && this.hoursInput.nativeElement != null) {\n      (this.hoursInput.nativeElement as HTMLElement).focus();\n    }\n  }\n\n  onHourUp() {\n    this.date?.setHours(this.date.getHours() + 1);\n    this.onDateChange(false, false);\n  }\n\n  onHourDown() {\n    this.date?.setHours(this.date.getHours() - 1);\n    this.onDateChange(false, false);\n  }\n\n  onMinuteUp() {\n    this.date?.setMinutes(this.date.getMinutes() + 1);\n    this.onDateChange(false, false);\n  }\n\n  onMinuteDown() {\n    this.date?.setMinutes(this.date.getMinutes() - 1);\n    this.onDateChange(false, false);\n  }\n\n  onSecondUp() {\n    this.date?.setSeconds(this.date.getSeconds() + 1);\n    this.onDateChange(false, false);\n  }\n\n  onSecondDown() {\n    this.date?.setSeconds(this.date.getSeconds() - 1);\n    this.onDateChange(false, false);\n  }\n\n  onHourChange(event: Event) {\n    const max = +(event.target as HTMLInputElement).max;\n    const min = +(event.target as HTMLInputElement).min;\n    const hour = +(event.target as HTMLInputElement).value;\n    this.date?.setHours(hour > max ? max : hour < min ? min : hour);\n    this.onDateChange(false, false);\n  }\n\n  onMinuteChange(event: Event) {\n    const max = +(event.target as HTMLInputElement).max;\n    const min = +(event.target as HTMLInputElement).min;\n    const minute = +(event.target as HTMLInputElement).value;\n    this.date?.setMinutes(minute > max ? max : minute < min ? min : minute);\n    this.onDateChange(false, false);\n  }\n\n  onSecondChange(event: Event) {\n    const max = +(event.target as HTMLInputElement).max;\n    const min = +(event.target as HTMLInputElement).min;\n    const seconds = +(event.target as HTMLInputElement).value;\n    this.date?.setSeconds(seconds > max ? max : seconds < min ? min : seconds);\n    this.onDateChange(false, false);\n  }\n\n  onDateChange(close: boolean, reset: boolean) {\n    if (this.date != null) {\n      this.date = new Date(this.date);\n      this.dateChange.emit({ reset, date: new Date(this.date), close });\n    }\n  }\n}\n","<div class=\"fwe-timepicker\" [class.fwe-timepicker-am-pm]=\"timeFormat === '12'\">\n  <div class=\"fwe-timepicker-spinners\">\n    <div class=\"fwe-timepicker-spinners-hours\">\n      <button type=\"button\" aria-label=\"hour up\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onHourUp()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-expand\"></i>\n      </button>\n      <input\n        #hoursInput\n        aria-label=\"hours value\"\n        class=\"fwe-timepicker-hide-spinners\"\n        type=\"number\"\n        min=\"0\"\n        tabindex=\"1\"\n        step=\"1\"\n        [value]=\"date | date : (timeFormat === '12' ? 'hh' : 'HH')\"\n        [attr.max]=\"timeFormat === '12' ? 12 : 23\"\n        (input)=\"onHourChange($event)\"\n      />\n      <button type=\"button\" aria-label=\"hour down\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onHourDown()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-collapse\"></i>\n      </button>\n    </div>\n    <div class=\"fwe-timepicker-spinners-minutes\">\n      <button type=\"button\" aria-label=\"minute up\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onMinuteUp()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-expand\"></i>\n      </button>\n      <input\n        aria-label=\"minutes value\"\n        class=\"fwe-timepicker-hide-spinners\"\n        type=\"number\"\n        min=\"0\"\n        max=\"59\"\n        step=\"1\"\n        tabindex=\"2\"\n        [value]=\"date | date : 'mm'\"\n        (input)=\"onMinuteChange($event)\"\n      />\n      <button type=\"button\" aria-label=\"minute down\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onMinuteDown()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-collapse\"></i>\n      </button>\n    </div>\n    <div *ngIf=\"showSeconds\" class=\"fwe-timepicker-spinners-seconds\">\n      <button type=\"button\" aria-label=\"seconds up\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onSecondUp()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-expand\"></i>\n      </button>\n      <input\n        aria-label=\"seconds value\"\n        class=\"fwe-timepicker-hide-spinners\"\n        type=\"number\"\n        min=\"0\"\n        max=\"59\"\n        step=\"1\"\n        tabindex=\"3\"\n        [value]=\"date | date : 'ss'\"\n        (input)=\"onSecondChange($event)\"\n      />\n      <button type=\"button\" aria-label=\"seconds down\" class=\"fwe-btn fwe-btn-link fwe-dark\" (click)=\"onSecondDown()\">\n        <i aria-hidden=\"true\" class=\"fwe-icon fwe-icon-arrows-collapse\"></i>\n      </button>\n    </div>\n  </div>\n  <span *ngIf=\"timeFormat === '12'\" class=\"fwe-badge fwe-badge-control\">\n    {{ date | date : 'a' }}\n  </span>\n</div>\n"]}
@@ -1,5 +1,5 @@
1
1
  import { ComponentPortal } from '@angular/cdk/portal';
2
- import { Component, forwardRef, HostBinding, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { Component, forwardRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core';
3
3
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
4
  import { Subject } from 'rxjs';
5
5
  import { takeUntil } from 'rxjs/operators';
@@ -58,11 +58,6 @@ export class FngTimePickerComponent {
58
58
  this.innerDisabled = false;
59
59
  this.complete = new Subject();
60
60
  }
61
- hide(event) {
62
- if (event.key === 'Escape') {
63
- this.dispose();
64
- }
65
- }
66
61
  writeValue(date) {
67
62
  this.innerValue = date;
68
63
  }
@@ -76,6 +71,7 @@ export class FngTimePickerComponent {
76
71
  this.disabled = isDisabled;
77
72
  }
78
73
  toggle(event) {
74
+ const resetValue = this.value;
79
75
  event.preventDefault();
80
76
  event.stopPropagation();
81
77
  if (!this.disabled) {
@@ -115,24 +111,27 @@ export class FngTimePickerComponent {
115
111
  this.timePicker.instance.showSeconds = this.options != null && this.options.showSeconds != null ? this.options.showSeconds : false;
116
112
  this.timePicker.instance.date = new Date(this.value);
117
113
  this.timePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe(ev => {
118
- if (ev.date != null) {
114
+ if (ev.reset) {
115
+ this.value = resetValue;
116
+ }
117
+ else {
119
118
  this.value = ev.date;
120
119
  }
121
120
  if (ev.close) {
122
- this.dispose();
121
+ this.disposeDropdown();
123
122
  }
124
123
  });
125
124
  this.timePickerRef
126
125
  .backdropClick()
127
126
  .pipe(takeUntil(this.complete))
128
- .subscribe(() => this.dispose());
127
+ .subscribe(() => this.disposeDropdown());
129
128
  }
130
129
  else {
131
- this.dispose();
130
+ this.disposeDropdown();
132
131
  }
133
132
  }
134
133
  }
135
- dispose() {
134
+ disposeDropdown() {
136
135
  if (this.timePickerRef != null) {
137
136
  this.timePickerRef.detach();
138
137
  this.timePickerRef.dispose();
@@ -144,7 +143,7 @@ export class FngTimePickerComponent {
144
143
  }
145
144
  }
146
145
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngTimePickerComponent, deps: [{ token: i1.Overlay }], target: i0.ɵɵFactoryTarget.Component }); }
147
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngTimePickerComponent, isStandalone: true, selector: "fng-time-picker", inputs: { value: "value", disabled: "disabled", required: "required", hint: "hint", error: "error", options: "options", width: "width" }, host: { listeners: { "document:keydown": "hide($event)" }, properties: { "style.width": "this.width", "style.display": "this.display" } }, providers: [
146
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngTimePickerComponent, isStandalone: true, selector: "fng-time-picker", inputs: { value: "value", disabled: "disabled", required: "required", hint: "hint", error: "error", options: "options", width: "width" }, host: { properties: { "style.width": "this.width", "style.display": "this.display" } }, providers: [
148
147
  {
149
148
  provide: NG_VALUE_ACCESSOR,
150
149
  useExisting: forwardRef(() => FngTimePickerComponent),
@@ -184,8 +183,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
184
183
  }], connector: [{
185
184
  type: ViewChild,
186
185
  args: ['connector', { static: true }]
187
- }], hide: [{
188
- type: HostListener,
189
- args: ['document:keydown', ['$event']]
190
186
  }] } });
191
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/time-picker/time-picker.component.ts","../../../../../../projects/angular/src/lib/forms/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport {\n  Component,\n  ComponentRef,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngTimePickerDropdownComponent } from './time-picker-dropdown/time-picker-dropdown.component';\nimport { CommonModule } from '@angular/common';\n\nexport interface FngTimePickerOptions {\n  timeFormat?: '12' | '24';\n  showSeconds?: boolean;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'fng-time-picker',\n  templateUrl: './time-picker.component.html',\n  styleUrls: ['./time-picker.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngTimePickerComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FngTimePickerComponent implements ControlValueAccessor {\n  get value(): Date {\n    return this.innerValue;\n  }\n  @Input()\n  set value(date: Date) {\n    if (!this.disabled) {\n      this.innerValue = date;\n      if (this.onChange != null) {\n        this.onChange(date);\n      }\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n    }\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this.innerRequired;\n  }\n  set required(value: boolean) {\n    this.innerRequired = coerceBooleanProperty(value);\n  }\n  protected innerRequired = false;\n\n  @Input() hint: string | undefined;\n  @Input() error: string | undefined;\n  @Input() options: FngTimePickerOptions | undefined;\n\n  @Input()\n  @HostBinding('style.width')\n  width: string = 'none';\n  @HostBinding('style.display') display: string = 'block';\n\n  @ViewChild('connector', { static: true }) connector: ElementRef | undefined;\n\n  get timeFormat(): string {\n    let timeFormat = 'H:mm';\n    if (this.options != null) {\n      if (this.options.showSeconds) {\n        timeFormat += ':ss';\n      }\n      if (this.options.timeFormat === '12') {\n        timeFormat = timeFormat.toLowerCase() + ' a';\n      }\n    }\n    return timeFormat;\n  }\n\n  timePickerRef: OverlayRef | null = null;\n\n  protected innerValue: Date = new Date();\n  protected innerDisabled = false;\n\n  private complete = new Subject<boolean>();\n  private timePicker: ComponentRef<FngTimePickerDropdownComponent> | undefined;\n\n  constructor(private overlay: Overlay) {}\n\n  onTouched: (() => void) | undefined;\n  onChange: ((date: Date) => void) | undefined;\n\n  @HostListener('document:keydown', ['$event'])\n  hide(event: KeyboardEvent) {\n    if (event.key === 'Escape') {\n      this.dispose();\n    }\n  }\n\n  writeValue(date: Date): void {\n    this.innerValue = date;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  toggle(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n    if (!this.disabled) {\n      if (this.timePickerRef == null && this.connector != null && this.connector.nativeElement != null) {\n        const labelWidth = (this.connector.nativeElement as HTMLElement).clientWidth;\n        this.timePickerRef = this.overlay.create({\n          width: `${labelWidth}px`,\n          panelClass: 'fng-first-child-fullwidth',\n          hasBackdrop: true,\n          backdropClass: 'fng-date-picker-backdrop',\n          scrollStrategy: this.overlay.scrollStrategies.block(),\n          positionStrategy: this.overlay\n            .position()\n            .flexibleConnectedTo(this.connector.nativeElement)\n            .withPositions([\n              {\n                originX: 'center',\n                originY: 'bottom',\n                overlayX: 'center',\n                overlayY: 'top',\n                offsetY: -12\n              },\n              {\n                originX: 'center',\n                originY: 'top',\n                overlayX: 'center',\n                overlayY: 'bottom',\n                offsetY: 4\n              }\n            ])\n            .withFlexibleDimensions(false)\n            .withPush(false)\n        });\n        const timePickerPortal = new ComponentPortal(FngTimePickerDropdownComponent);\n        this.timePicker = this.timePickerRef.attach(timePickerPortal);\n        this.timePicker.instance.timeFormat = this.options != null && this.options.timeFormat != null ? this.options.timeFormat : '24';\n        this.timePicker.instance.showSeconds = this.options != null && this.options.showSeconds != null ? this.options.showSeconds : false;\n        this.timePicker.instance.date = new Date(this.value);\n        this.timePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe(ev => {\n          if (ev.date != null) {\n            this.value = ev.date;\n          }\n          if (ev.close) {\n            this.dispose();\n          }\n        });\n        this.timePickerRef\n          .backdropClick()\n          .pipe(takeUntil(this.complete))\n          .subscribe(() => this.dispose());\n      } else {\n        this.dispose();\n      }\n    }\n  }\n\n  private dispose() {\n    if (this.timePickerRef != null) {\n      this.timePickerRef.detach();\n      this.timePickerRef.dispose();\n      this.timePickerRef = null;\n    }\n    if (this.complete != null) {\n      this.complete.next(true);\n      this.complete.complete();\n    }\n  }\n}\n","<label #connector class=\"fng-time-picker fwe-input-text fwe-input-text-icon\" (click)=\"toggle($event)\">\n  <i class=\"fwe-icon fwe-icon-time-time\" [class.fwe-color-hero]=\"timePickerRef != null\" [class.fwe-color-control-disabled]=\"disabled\"></i>\n  <input\n    aria-label=\"picked time\"\n    type=\"text\"\n    readonly\n    [required]=\"required === true || null\"\n    [class.fwe-border-hero]=\"timePickerRef != null\"\n    [value]=\"value | date: timeFormat\"\n    [disabled]=\"disabled\"\n  />\n  <span class=\"fwe-input-text-label\"><ng-content></ng-content></span>\n  <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n  <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n</label>\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/time-picker/time-picker.component.ts","../../../../../../projects/angular/src/lib/forms/time-picker/time-picker.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,SAAS,EAA4B,UAAU,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAClI,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,8BAA8B,EAAE,MAAM,uDAAuD,CAAC;AACvG,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;AAsB/C,MAAM,OAAO,sBAAsB;IACjC,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IACI,KAAK,CAAC,IAAU;QAClB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;gBACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;aACrB;YACD,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE;gBAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;aAClB;SACF;IACH,CAAC;IAED,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,aAAa,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IAED,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,aAAa,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IAcD,IAAI,UAAU;QACZ,IAAI,UAAU,GAAG,MAAM,CAAC;QACxB,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,EAAE;YACxB,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;gBAC5B,UAAU,IAAI,KAAK,CAAC;aACrB;YACD,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,IAAI,EAAE;gBACpC,UAAU,GAAG,UAAU,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC;aAC9C;SACF;QACD,OAAO,UAAU,CAAC;IACpB,CAAC;IAUD,YAAoB,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;QAlC1B,kBAAa,GAAG,KAAK,CAAC;QAQhC,UAAK,GAAW,MAAM,CAAC;QACO,YAAO,GAAW,OAAO,CAAC;QAiBxD,kBAAa,GAAsB,IAAI,CAAC;QAE9B,eAAU,GAAS,IAAI,IAAI,EAAE,CAAC;QAC9B,kBAAa,GAAG,KAAK,CAAC;QAExB,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;IAGH,CAAC;IAKxC,UAAU,CAAC,IAAU;QACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,MAAM,CAAC,KAAY;QACjB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC;QAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,IAAI,IAAI,EAAE;gBAChG,MAAM,UAAU,GAAI,IAAI,CAAC,SAAS,CAAC,aAA6B,CAAC,WAAW,CAAC;gBAC7E,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;oBACvC,KAAK,EAAE,GAAG,UAAU,IAAI;oBACxB,UAAU,EAAE,2BAA2B;oBACvC,WAAW,EAAE,IAAI;oBACjB,aAAa,EAAE,0BAA0B;oBACzC,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE;oBACrD,gBAAgB,EAAE,IAAI,CAAC,OAAO;yBAC3B,QAAQ,EAAE;yBACV,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;yBACjD,aAAa,CAAC;wBACb;4BACE,OAAO,EAAE,QAAQ;4BACjB,OAAO,EAAE,QAAQ;4BACjB,QAAQ,EAAE,QAAQ;4BAClB,QAAQ,EAAE,KAAK;4BACf,OAAO,EAAE,CAAC,EAAE;yBACb;wBACD;4BACE,OAAO,EAAE,QAAQ;4BACjB,OAAO,EAAE,KAAK;4BACd,QAAQ,EAAE,QAAQ;4BAClB,QAAQ,EAAE,QAAQ;4BAClB,OAAO,EAAE,CAAC;yBACX;qBACF,CAAC;yBACD,sBAAsB,CAAC,KAAK,CAAC;yBAC7B,QAAQ,CAAC,KAAK,CAAC;iBACnB,CAAC,CAAC;gBACH,MAAM,gBAAgB,GAAG,IAAI,eAAe,CAAC,8BAA8B,CAAC,CAAC;gBAC7E,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;gBAC9D,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;gBAC/H,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC;gBACnI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACrD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE;oBAChF,IAAI,EAAE,CAAC,KAAK,EAAE;wBACZ,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC;qBACzB;yBAAM;wBACL,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,IAAI,CAAC;qBACtB;oBACD,IAAI,EAAE,CAAC,KAAK,EAAE;wBACZ,IAAI,CAAC,eAAe,EAAE,CAAC;qBACxB;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,aAAa;qBACf,aAAa,EAAE;qBACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;qBAC9B,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;aAC5C;iBAAM;gBACL,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;SACF;IACH,CAAC;IAEM,eAAe;QACpB,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,EAAE;YAC9B,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;YAC5B,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;QACD,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;SAC1B;IACH,CAAC;8GA7JU,sBAAsB;kGAAtB,sBAAsB,gSATtB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACZ;SACF,gJC3BH,quBAeA,0HDEY,YAAY;;2FAaX,sBAAsB;kBAflC,SAAS;iCACI,IAAI,WACP,CAAC,YAAY,CAAC,YACb,iBAAiB,aAGhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ;qBACF,iBACc,iBAAiB,CAAC,IAAI;4EAOjC,KAAK;sBADR,KAAK;gBAcF,QAAQ;sBADX,KAAK;gBASF,QAAQ;sBADX,KAAK;gBASG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAIN,KAAK;sBAFJ,KAAK;;sBACL,WAAW;uBAAC,aAAa;gBAEI,OAAO;sBAApC,WAAW;uBAAC,eAAe;gBAEc,SAAS;sBAAlD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { Component, ComponentRef, ElementRef, forwardRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngTimePickerDropdownComponent } from './time-picker-dropdown/time-picker-dropdown.component';\nimport { CommonModule } from '@angular/common';\n\nexport interface FngTimePickerOptions {\n  timeFormat?: '12' | '24';\n  showSeconds?: boolean;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'fng-time-picker',\n  templateUrl: './time-picker.component.html',\n  styleUrls: ['./time-picker.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngTimePickerComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FngTimePickerComponent implements ControlValueAccessor {\n  get value(): Date {\n    return this.innerValue;\n  }\n  @Input()\n  set value(date: Date) {\n    if (!this.disabled) {\n      this.innerValue = date;\n      if (this.onChange != null) {\n        this.onChange(date);\n      }\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n    }\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this.innerRequired;\n  }\n  set required(value: boolean) {\n    this.innerRequired = coerceBooleanProperty(value);\n  }\n  protected innerRequired = false;\n\n  @Input() hint: string | undefined;\n  @Input() error: string | undefined;\n  @Input() options: FngTimePickerOptions | undefined;\n\n  @Input()\n  @HostBinding('style.width')\n  width: string = 'none';\n  @HostBinding('style.display') display: string = 'block';\n\n  @ViewChild('connector', { static: true }) connector: ElementRef | undefined;\n\n  get timeFormat(): string {\n    let timeFormat = 'H:mm';\n    if (this.options != null) {\n      if (this.options.showSeconds) {\n        timeFormat += ':ss';\n      }\n      if (this.options.timeFormat === '12') {\n        timeFormat = timeFormat.toLowerCase() + ' a';\n      }\n    }\n    return timeFormat;\n  }\n\n  timePickerRef: OverlayRef | null = null;\n\n  protected innerValue: Date = new Date();\n  protected innerDisabled = false;\n\n  private complete = new Subject<boolean>();\n  private timePicker: ComponentRef<FngTimePickerDropdownComponent> | undefined;\n\n  constructor(private overlay: Overlay) {}\n\n  onTouched: (() => void) | undefined;\n  onChange: ((date: Date) => void) | undefined;\n\n  writeValue(date: Date): void {\n    this.innerValue = date;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  toggle(event: Event) {\n    const resetValue = this.value;\n    event.preventDefault();\n    event.stopPropagation();\n    if (!this.disabled) {\n      if (this.timePickerRef == null && this.connector != null && this.connector.nativeElement != null) {\n        const labelWidth = (this.connector.nativeElement as HTMLElement).clientWidth;\n        this.timePickerRef = this.overlay.create({\n          width: `${labelWidth}px`,\n          panelClass: 'fng-first-child-fullwidth',\n          hasBackdrop: true,\n          backdropClass: 'fng-date-picker-backdrop',\n          scrollStrategy: this.overlay.scrollStrategies.block(),\n          positionStrategy: this.overlay\n            .position()\n            .flexibleConnectedTo(this.connector.nativeElement)\n            .withPositions([\n              {\n                originX: 'center',\n                originY: 'bottom',\n                overlayX: 'center',\n                overlayY: 'top',\n                offsetY: -12\n              },\n              {\n                originX: 'center',\n                originY: 'top',\n                overlayX: 'center',\n                overlayY: 'bottom',\n                offsetY: 4\n              }\n            ])\n            .withFlexibleDimensions(false)\n            .withPush(false)\n        });\n        const timePickerPortal = new ComponentPortal(FngTimePickerDropdownComponent);\n        this.timePicker = this.timePickerRef.attach(timePickerPortal);\n        this.timePicker.instance.timeFormat = this.options != null && this.options.timeFormat != null ? this.options.timeFormat : '24';\n        this.timePicker.instance.showSeconds = this.options != null && this.options.showSeconds != null ? this.options.showSeconds : false;\n        this.timePicker.instance.date = new Date(this.value);\n        this.timePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe(ev => {\n          if (ev.reset) {\n            this.value = resetValue;\n          } else {\n            this.value = ev.date;\n          }\n          if (ev.close) {\n            this.disposeDropdown();\n          }\n        });\n        this.timePickerRef\n          .backdropClick()\n          .pipe(takeUntil(this.complete))\n          .subscribe(() => this.disposeDropdown());\n      } else {\n        this.disposeDropdown();\n      }\n    }\n  }\n\n  public disposeDropdown() {\n    if (this.timePickerRef != null) {\n      this.timePickerRef.detach();\n      this.timePickerRef.dispose();\n      this.timePickerRef = null;\n    }\n    if (this.complete != null) {\n      this.complete.next(true);\n      this.complete.complete();\n    }\n  }\n}\n","<label #connector class=\"fng-time-picker fwe-input-text fwe-input-text-icon\" (click)=\"toggle($event)\">\n  <i class=\"fwe-icon fwe-icon-time-time\" [class.fwe-color-hero]=\"timePickerRef != null\" [class.fwe-color-control-disabled]=\"disabled\"></i>\n  <input\n    aria-label=\"picked time\"\n    type=\"text\"\n    readonly\n    [required]=\"required === true || null\"\n    [class.fwe-border-hero]=\"timePickerRef != null\"\n    [value]=\"value | date: timeFormat\"\n    [disabled]=\"disabled\"\n  />\n  <span class=\"fwe-input-text-label\"><ng-content></ng-content></span>\n  <span *ngIf=\"hint\" class=\"fwe-input-text-info\">{{ hint }}</span>\n  <span *ngIf=\"error\" class=\"fwe-input-text-invalid\">{{ error }}</span>\n</label>\n"]}
@@ -3987,23 +3987,26 @@ class FngTimePickerDropdownComponent {
3987
3987
  const min = +event.target.min;
3988
3988
  const hour = +event.target.value;
3989
3989
  this.date?.setHours(hour > max ? max : hour < min ? min : hour);
3990
+ this.onDateChange(false, false);
3990
3991
  }
3991
3992
  onMinuteChange(event) {
3992
3993
  const max = +event.target.max;
3993
3994
  const min = +event.target.min;
3994
3995
  const minute = +event.target.value;
3995
3996
  this.date?.setMinutes(minute > max ? max : minute < min ? min : minute);
3997
+ this.onDateChange(false, false);
3996
3998
  }
3997
3999
  onSecondChange(event) {
3998
4000
  const max = +event.target.max;
3999
4001
  const min = +event.target.min;
4000
4002
  const seconds = +event.target.value;
4001
4003
  this.date?.setSeconds(seconds > max ? max : seconds < min ? min : seconds);
4004
+ this.onDateChange(false, false);
4002
4005
  }
4003
4006
  onDateChange(close, reset) {
4004
4007
  if (this.date != null) {
4005
4008
  this.date = new Date(this.date);
4006
- this.dateChange.emit({ date: !reset ? new Date(this.date) : null, close });
4009
+ this.dateChange.emit({ reset, date: new Date(this.date), close });
4007
4010
  }
4008
4011
  }
4009
4012
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngTimePickerDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -4077,11 +4080,6 @@ class FngTimePickerComponent {
4077
4080
  this.innerDisabled = false;
4078
4081
  this.complete = new Subject();
4079
4082
  }
4080
- hide(event) {
4081
- if (event.key === 'Escape') {
4082
- this.dispose();
4083
- }
4084
- }
4085
4083
  writeValue(date) {
4086
4084
  this.innerValue = date;
4087
4085
  }
@@ -4095,6 +4093,7 @@ class FngTimePickerComponent {
4095
4093
  this.disabled = isDisabled;
4096
4094
  }
4097
4095
  toggle(event) {
4096
+ const resetValue = this.value;
4098
4097
  event.preventDefault();
4099
4098
  event.stopPropagation();
4100
4099
  if (!this.disabled) {
@@ -4134,24 +4133,27 @@ class FngTimePickerComponent {
4134
4133
  this.timePicker.instance.showSeconds = this.options != null && this.options.showSeconds != null ? this.options.showSeconds : false;
4135
4134
  this.timePicker.instance.date = new Date(this.value);
4136
4135
  this.timePicker.instance.dateChange.pipe(takeUntil(this.complete)).subscribe(ev => {
4137
- if (ev.date != null) {
4136
+ if (ev.reset) {
4137
+ this.value = resetValue;
4138
+ }
4139
+ else {
4138
4140
  this.value = ev.date;
4139
4141
  }
4140
4142
  if (ev.close) {
4141
- this.dispose();
4143
+ this.disposeDropdown();
4142
4144
  }
4143
4145
  });
4144
4146
  this.timePickerRef
4145
4147
  .backdropClick()
4146
4148
  .pipe(takeUntil(this.complete))
4147
- .subscribe(() => this.dispose());
4149
+ .subscribe(() => this.disposeDropdown());
4148
4150
  }
4149
4151
  else {
4150
- this.dispose();
4152
+ this.disposeDropdown();
4151
4153
  }
4152
4154
  }
4153
4155
  }
4154
- dispose() {
4156
+ disposeDropdown() {
4155
4157
  if (this.timePickerRef != null) {
4156
4158
  this.timePickerRef.detach();
4157
4159
  this.timePickerRef.dispose();
@@ -4163,7 +4165,7 @@ class FngTimePickerComponent {
4163
4165
  }
4164
4166
  }
4165
4167
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngTimePickerComponent, deps: [{ token: i1$3.Overlay }], target: i0.ɵɵFactoryTarget.Component }); }
4166
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngTimePickerComponent, isStandalone: true, selector: "fng-time-picker", inputs: { value: "value", disabled: "disabled", required: "required", hint: "hint", error: "error", options: "options", width: "width" }, host: { listeners: { "document:keydown": "hide($event)" }, properties: { "style.width": "this.width", "style.display": "this.display" } }, providers: [
4168
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngTimePickerComponent, isStandalone: true, selector: "fng-time-picker", inputs: { value: "value", disabled: "disabled", required: "required", hint: "hint", error: "error", options: "options", width: "width" }, host: { properties: { "style.width": "this.width", "style.display": "this.display" } }, providers: [
4167
4169
  {
4168
4170
  provide: NG_VALUE_ACCESSOR,
4169
4171
  useExisting: forwardRef(() => FngTimePickerComponent),
@@ -4203,9 +4205,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
4203
4205
  }], connector: [{
4204
4206
  type: ViewChild,
4205
4207
  args: ['connector', { static: true }]
4206
- }], hide: [{
4207
- type: HostListener,
4208
- args: ['document:keydown', ['$event']]
4209
4208
  }] } });
4210
4209
 
4211
4210
  class FngFlatpickrComponent {