@dhutaryan/ngx-mat-timepicker 17.5.1 → 17.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/clock-dials.mjs +11 -13
- package/esm2022/lib/time-input-base.mjs +3 -14
- package/esm2022/lib/time-inputs.mjs +7 -9
- package/esm2022/lib/timepicker-base.mjs +66 -17
- package/esm2022/lib/timepicker-content.mjs +40 -9
- package/esm2022/lib/timepicker-input-base.mjs +35 -4
- package/esm2022/lib/timepicker-toggle.mjs +31 -6
- package/fesm2022/dhutaryan-ngx-mat-timepicker.mjs +180 -62
- package/fesm2022/dhutaryan-ngx-mat-timepicker.mjs.map +1 -1
- package/lib/timepicker-base.d.ts +23 -1
- package/lib/timepicker-content.d.ts +7 -1
- package/lib/timepicker-input-base.d.ts +12 -2
- package/lib/timepicker-toggle.d.ts +9 -3
- package/package.json +9 -8
|
@@ -39,18 +39,16 @@ export class MatClockDials extends MatTimeFaceBase {
|
|
|
39
39
|
focusActiveCell() {
|
|
40
40
|
this._ngZone.runOutsideAngular(() => {
|
|
41
41
|
this._ngZone.onStable.pipe(take(1)).subscribe(() => {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
if
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
}
|
|
53
|
-
}, 50);
|
|
42
|
+
const activeCell = this._elementRef.nativeElement.querySelector('.mat-timepicker-content .mat-clock-dial-cell-active');
|
|
43
|
+
if (activeCell) {
|
|
44
|
+
activeCell.focus();
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
const activePoint = this._elementRef.nativeElement.querySelector('.mat-timepicker-content .mat-clock-dial-hand-point');
|
|
48
|
+
if (activePoint) {
|
|
49
|
+
// if no active cell we need to focus a small dot
|
|
50
|
+
activePoint.focus();
|
|
51
|
+
}
|
|
54
52
|
});
|
|
55
53
|
});
|
|
56
54
|
}
|
|
@@ -94,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
94
92
|
}], touchUi: [{
|
|
95
93
|
type: Input
|
|
96
94
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clock-dials.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/clock-dials.ts","../../../../projects/mat-timepicker/src/lib/clock-dials.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  OnInit,\n  OnDestroy,\n  Optional,\n  NgZone,\n  ElementRef,\n  Input,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { BehaviorSubject, Subscription, take } from 'rxjs';\n\nimport { TimeAdapter } from './adapter';\nimport { MatTimeFaceBase } from './time-face-base';\nimport { withZeroPrefixMeridiem } from './time-input-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport { TimepickerOrientation } from './orientation';\nimport { enterLeaveAnimation } from './clock-dial-adnimation';\nimport { MatTimepickerContentLayout } from './timepicker-content-layout';\nimport { MatHoursClockDial } from './hours-clock-dial';\nimport { MatMinutesClockDial } from './minutes-clock-dial';\nimport { MatTimePeriod } from './time-period';\n\nexport type MatDialView = 'hours' | 'minutes';\n\n@Component({\n  selector: 'mat-clock-dials',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatTimepickerContentLayout,\n    MatHoursClockDial,\n    MatMinutesClockDial,\n    MatTimePeriod,\n  ],\n  templateUrl: './clock-dials.html',\n  styleUrls: ['./clock-dials.scss'],\n  exportAs: 'matClockDials',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    role: 'dial',\n    class: 'mat-clock-dials',\n  },\n  animations: [enterLeaveAnimation],\n})\nexport class MatClockDials<T>\n  extends MatTimeFaceBase<T>\n  implements OnInit, OnDestroy\n{\n  /** Layout orientation. */\n  @Input() orientation: TimepickerOrientation;\n\n  /** Whether the timepicker UI is in touch mode. */\n  @Input() touchUi: boolean;\n\n  isHoursView = true;\n\n  /** Specifies the view of clock dial. */\n  private readonly _view = new BehaviorSubject<MatDialView>('hours');\n  private _viewSubscription: Subscription | null = Subscription.EMPTY;\n\n  constructor(\n    public _intl: MatTimepickerIntl,\n    @Optional() _timeAdapter: TimeAdapter<T>,\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef,\n    private _cdr: ChangeDetectorRef,\n  ) {\n    super(_timeAdapter);\n  }\n\n  ngOnInit(): void {\n    this._viewSubscription = this._view.subscribe(\n      (view) => (this.isHoursView = view === 'hours'),\n    );\n  }\n\n  ngOnDestroy(): void {\n    this._viewSubscription?.unsubscribe();\n    this._viewSubscription = null;\n  }\n\n  /** Changes clock dial view. */\n  onViewChange(event: Event, view: MatDialView): void {\n    event.preventDefault();\n    this._view.next(view);\n  }\n\n  focusActiveCell(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n        setTimeout(() => {\n          const activeCell: HTMLElement | null =\n            this._elementRef.nativeElement.querySelector(\n              '.mat-timepicker-content .mat-clock-dial-cell-active', // to avoid focus for inline mode\n            );\n\n          if (activeCell) {\n            activeCell.focus();\n            return;\n          }\n\n          const activePoint: HTMLElement | null =\n            this._elementRef.nativeElement.querySelector(\n              '.mat-timepicker-content .mat-clock-dial-hand-point', // to avoid focus for inline mode\n            );\n\n          if (activePoint) {\n            // if no active cell we need to focus a small dot\n            activePoint.focus();\n          }\n        }, 50);\n      });\n    });\n  }\n\n  _withZeroPrefix(value: number): string {\n    if (value === 0) {\n      return '00';\n    }\n\n    return withZeroPrefixMeridiem(value, this.isMeridiem);\n  }\n\n  override _onMinuteSelected(minute: number): void {\n    super._onMinuteSelected(minute);\n    this._cdr.detectChanges();\n  }\n\n  /** Handles hour selection. */\n  _onHourChanged({\n    hour,\n    changeView = false,\n  }: {\n    hour: number;\n    changeView?: boolean;\n  }): void {\n    if (changeView) {\n      this._view.next('minutes');\n    }\n    this._onHourSelected(hour);\n    this._cdr.detectChanges();\n  }\n}\n","<mat-timepicker-content-layout [title]=\"_intl.dialsTitle\" [orientation]=\"orientation\">\n  <div\n    tabindex=\"0\"\n    class=\"mat-clock-dial-value\"\n    hours\n    [class.mat-clock-dial-value-active]=\"isHoursView\"\n    (click)=\"onViewChange($event, 'hours')\"\n    (keydown.space)=\"onViewChange($event, 'hours')\"\n  >\n    {{ _withZeroPrefix(selectedHour) }}\n  </div>\n  <div\n    tabindex=\"0\"\n    class=\"mat-clock-dial-value\"\n    minutes\n    [class.mat-clock-dial-value-active]=\"!isHoursView\"\n    (click)=\"onViewChange($event, 'minutes')\"\n    (keydown.space)=\"onViewChange($event, 'minutes')\"\n  >\n    {{ _withZeroPrefix(selectedMinute) }}\n  </div>\n\n  <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n    <mat-time-period\n      [period]=\"period\"\n      [disabledPeriod]=\"disabledPeriod\"\n      [vertical]=\"orientation === 'vertical'\"\n      (periodChanged)=\"_onPeriodChanged($event)\"\n    ></mat-time-period>\n  </ng-template>\n\n  <div\n    class=\"mat-clock-dial-faces\"\n    [class.mat-clock-dial-faces-horizontal]=\"orientation === 'horizontal'\"\n  >\n    @if (isHoursView) {\n      <mat-hours-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedHour]=\"selectedHour\"\n        [isMeridiem]=\"isMeridiem\"\n        [availableHours]=\"_getAvailableHours()\"\n        [touchUi]=\"touchUi\"\n        (selectedChange)=\"_onHourChanged($event)\"\n        (keydown)=\"_onKeydown($event, 'hour')\"\n      ></mat-hours-clock-dial>\n    }\n\n    @if (!isHoursView) {\n      <mat-minutes-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedMinute]=\"selectedMinute\"\n        [interval]=\"minuteInterval\"\n        [availableMinutes]=\"availableMinutes\"\n        [touchUi]=\"touchUi\"\n        (selectedChange)=\"_onMinuteSelected($event)\"\n        (keydown)=\"_onKeydown($event, 'minute')\"\n      ></mat-minutes-clock-dial>\n    }\n  </div>\n</mat-timepicker-content-layout>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clock-dials.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/clock-dials.ts","../../../../projects/mat-timepicker/src/lib/clock-dials.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  OnInit,\n  OnDestroy,\n  Optional,\n  NgZone,\n  ElementRef,\n  Input,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { BehaviorSubject, Subscription, take } from 'rxjs';\n\nimport { TimeAdapter } from './adapter';\nimport { MatTimeFaceBase } from './time-face-base';\nimport { withZeroPrefixMeridiem } from './time-input-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport { TimepickerOrientation } from './orientation';\nimport { enterLeaveAnimation } from './clock-dial-adnimation';\nimport { MatTimepickerContentLayout } from './timepicker-content-layout';\nimport { MatHoursClockDial } from './hours-clock-dial';\nimport { MatMinutesClockDial } from './minutes-clock-dial';\nimport { MatTimePeriod } from './time-period';\n\nexport type MatDialView = 'hours' | 'minutes';\n\n@Component({\n  selector: 'mat-clock-dials',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatTimepickerContentLayout,\n    MatHoursClockDial,\n    MatMinutesClockDial,\n    MatTimePeriod,\n  ],\n  templateUrl: './clock-dials.html',\n  styleUrls: ['./clock-dials.scss'],\n  exportAs: 'matClockDials',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    role: 'dial',\n    class: 'mat-clock-dials',\n  },\n  animations: [enterLeaveAnimation],\n})\nexport class MatClockDials<T>\n  extends MatTimeFaceBase<T>\n  implements OnInit, OnDestroy\n{\n  /** Layout orientation. */\n  @Input() orientation: TimepickerOrientation;\n\n  /** Whether the timepicker UI is in touch mode. */\n  @Input() touchUi: boolean;\n\n  isHoursView = true;\n\n  /** Specifies the view of clock dial. */\n  private readonly _view = new BehaviorSubject<MatDialView>('hours');\n  private _viewSubscription: Subscription | null = Subscription.EMPTY;\n\n  constructor(\n    public _intl: MatTimepickerIntl,\n    @Optional() _timeAdapter: TimeAdapter<T>,\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef,\n    private _cdr: ChangeDetectorRef,\n  ) {\n    super(_timeAdapter);\n  }\n\n  ngOnInit(): void {\n    this._viewSubscription = this._view.subscribe(\n      (view) => (this.isHoursView = view === 'hours'),\n    );\n  }\n\n  ngOnDestroy(): void {\n    this._viewSubscription?.unsubscribe();\n    this._viewSubscription = null;\n  }\n\n  /** Changes clock dial view. */\n  onViewChange(event: Event, view: MatDialView): void {\n    event.preventDefault();\n    this._view.next(view);\n  }\n\n  focusActiveCell(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n        const activeCell: HTMLElement | null =\n          this._elementRef.nativeElement.querySelector(\n            '.mat-timepicker-content .mat-clock-dial-cell-active', // to avoid focus for inline mode\n          );\n\n        if (activeCell) {\n          activeCell.focus();\n          return;\n        }\n\n        const activePoint: HTMLElement | null =\n          this._elementRef.nativeElement.querySelector(\n            '.mat-timepicker-content .mat-clock-dial-hand-point', // to avoid focus for inline mode\n          );\n\n        if (activePoint) {\n          // if no active cell we need to focus a small dot\n          activePoint.focus();\n        }\n      });\n    });\n  }\n\n  _withZeroPrefix(value: number): string {\n    if (value === 0) {\n      return '00';\n    }\n\n    return withZeroPrefixMeridiem(value, this.isMeridiem);\n  }\n\n  override _onMinuteSelected(minute: number): void {\n    super._onMinuteSelected(minute);\n    this._cdr.detectChanges();\n  }\n\n  /** Handles hour selection. */\n  _onHourChanged({\n    hour,\n    changeView = false,\n  }: {\n    hour: number;\n    changeView?: boolean;\n  }): void {\n    if (changeView) {\n      this._view.next('minutes');\n    }\n    this._onHourSelected(hour);\n    this._cdr.detectChanges();\n  }\n}\n","<mat-timepicker-content-layout [title]=\"_intl.dialsTitle\" [orientation]=\"orientation\">\n  <div\n    tabindex=\"0\"\n    class=\"mat-clock-dial-value\"\n    hours\n    [class.mat-clock-dial-value-active]=\"isHoursView\"\n    (click)=\"onViewChange($event, 'hours')\"\n    (keydown.space)=\"onViewChange($event, 'hours')\"\n  >\n    {{ _withZeroPrefix(selectedHour) }}\n  </div>\n  <div\n    tabindex=\"0\"\n    class=\"mat-clock-dial-value\"\n    minutes\n    [class.mat-clock-dial-value-active]=\"!isHoursView\"\n    (click)=\"onViewChange($event, 'minutes')\"\n    (keydown.space)=\"onViewChange($event, 'minutes')\"\n  >\n    {{ _withZeroPrefix(selectedMinute) }}\n  </div>\n\n  <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n    <mat-time-period\n      [period]=\"period\"\n      [disabledPeriod]=\"disabledPeriod\"\n      [vertical]=\"orientation === 'vertical'\"\n      (periodChanged)=\"_onPeriodChanged($event)\"\n    ></mat-time-period>\n  </ng-template>\n\n  <div\n    class=\"mat-clock-dial-faces\"\n    [class.mat-clock-dial-faces-horizontal]=\"orientation === 'horizontal'\"\n  >\n    @if (isHoursView) {\n      <mat-hours-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedHour]=\"selectedHour\"\n        [isMeridiem]=\"isMeridiem\"\n        [availableHours]=\"_getAvailableHours()\"\n        [touchUi]=\"touchUi\"\n        (selectedChange)=\"_onHourChanged($event)\"\n        (keydown)=\"_onKeydown($event, 'hour')\"\n      ></mat-hours-clock-dial>\n    }\n\n    @if (!isHoursView) {\n      <mat-minutes-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedMinute]=\"selectedMinute\"\n        [interval]=\"minuteInterval\"\n        [availableMinutes]=\"availableMinutes\"\n        [touchUi]=\"touchUi\"\n        (selectedChange)=\"_onMinuteSelected($event)\"\n        (keydown)=\"_onKeydown($event, 'minute')\"\n      ></mat-minutes-clock-dial>\n    }\n  </div>\n</mat-timepicker-content-layout>\n"]}
|
|
@@ -8,18 +8,7 @@ export function withZeroPrefixMeridiem(value, isMeridiem) {
|
|
|
8
8
|
const newValue = isMeridiem && value === 0 ? 12 : value;
|
|
9
9
|
return withZeroPrefix(newValue);
|
|
10
10
|
}
|
|
11
|
-
const DIGIT_KEYS =
|
|
12
|
-
'Digit0',
|
|
13
|
-
'Digit1',
|
|
14
|
-
'Digit2',
|
|
15
|
-
'Digit3',
|
|
16
|
-
'Digit4',
|
|
17
|
-
'Digit5',
|
|
18
|
-
'Digit6',
|
|
19
|
-
'Digit7',
|
|
20
|
-
'Digit8',
|
|
21
|
-
'Digit9',
|
|
22
|
-
];
|
|
11
|
+
const DIGIT_KEYS = Array.from({ length: 10 }, (_, i) => `${i}`);
|
|
23
12
|
const SPECIAL_KEYS = ['Backspace', 'Delete', 'ArrowLeft', 'ArrowRight', 'Tab'];
|
|
24
13
|
export class MatTimeInputBase {
|
|
25
14
|
get value() {
|
|
@@ -36,7 +25,7 @@ export class MatTimeInputBase {
|
|
|
36
25
|
}, 0);
|
|
37
26
|
}
|
|
38
27
|
_keydown(event) {
|
|
39
|
-
const isAllow = (DIGIT_KEYS.includes(event.
|
|
28
|
+
const isAllow = (DIGIT_KEYS.includes(event.key) && !event.shiftKey) ||
|
|
40
29
|
SPECIAL_KEYS.includes(event.code);
|
|
41
30
|
if (!isAllow) {
|
|
42
31
|
event.preventDefault();
|
|
@@ -93,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
93
82
|
type: HostListener,
|
|
94
83
|
args: ['keydown', ['$event']]
|
|
95
84
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1pbnB1dC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbWF0LXRpbWVwaWNrZXIvc3JjL2xpYi90aW1lLWlucHV0LWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFDTCxLQUFLLEVBQ0wsTUFBTSxFQUNOLFlBQVksRUFDWixTQUFTLEVBR1QsTUFBTSxFQUVOLFlBQVksR0FDYixNQUFNLGVBQWUsQ0FBQzs7QUFFdkIsTUFBTSxVQUFVLGNBQWMsQ0FBQyxLQUFhO0lBQzFDLE9BQU8sS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLEVBQUUsQ0FBQztBQUMvQyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxLQUFhLEVBQ2IsVUFBbUI7SUFFbkIsTUFBTSxRQUFRLEdBQUcsVUFBVSxJQUFJLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBRXhELE9BQU8sY0FBYyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQ2xDLENBQUM7QUFFRCxNQUFNLFVBQVUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQ2pFLE1BQU0sWUFBWSxHQUFHLENBQUMsV0FBVyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBRy9FLE1BQU0sT0FBZ0IsZ0JBQWdCO0lBQ3BDLElBQ0ksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lB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S0FBSztzQkFEUixLQUFLO2dCQWdCSSxXQUFXO3NCQUFwQixNQUFNO2dCQUU4QixRQUFRO3NCQUE1QyxZQUFZO3VCQUFDLFNBQVMsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIElucHV0LFxuICBPdXRwdXQsXG4gIEV2ZW50RW1pdHRlcixcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgSW5qZWN0LFxuICBTZWxmLFxuICBIb3N0TGlzdGVuZXIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgZnVuY3Rpb24gd2l0aFplcm9QcmVmaXgodmFsdWU6IG51bWJlcik6IHN0cmluZyB7XG4gIHJldHVybiB2YWx1ZSA8IDEwID8gYDAke3ZhbHVlfWAgOiBgJHt2YWx1ZX1gO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gd2l0aFplcm9QcmVmaXhNZXJpZGllbShcbiAgdmFsdWU6IG51bWJlcixcbiAgaXNNZXJpZGllbTogYm9vbGVhbixcbik6IHN0cmluZyB7XG4gIGNvbnN0IG5ld1ZhbHVlID0gaXNNZXJpZGllbSAmJiB2YWx1ZSA9PT0gMCA/IDEyIDogdmFsdWU7XG5cbiAgcmV0dXJuIHdpdGhaZXJvUHJlZml4KG5ld1ZhbHVlKTtcbn1cblxuY29uc3QgRElHSVRfS0VZUyA9IEFycmF5LmZyb20oeyBsZW5ndGg6IDEwIH0sICAoXywgaSkgPT4gYCR7aX1gKTtcbmNvbnN0IFNQRUNJQUxfS0VZUyA9IFsnQmFja3NwYWNlJywgJ0RlbGV0ZScsICdBcnJvd0xlZnQnLCAnQXJyb3dSaWdodCcsICdUYWInXTtcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTWF0VGltZUlucHV0QmFzZSB7XG4gIEBJbnB1dCgpXG4gIGdldCB2YWx1ZSgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLl92YWx1ZTtcbiAgfVxuICBzZXQgdmFsdWUodmFsdWU6IG51bWJlcikge1xuICAgIHRoaXMuX3ZhbHVlID0gdmFsdWU7XG4gICAgaWYgKCF0aGlzLmhhc0ZvY3VzKSB7XG4gICAgICB0aGlzLnNldElucHV0VmFsdWUodGhpcy5fdmFsdWUpO1xuICAgIH1cbiAgICAvLyB3ZSBuZWVkIHRpbWVvdXQgaGVyZSB0byBzZXQgcGxhY2Vob2xkZXIgZmlyc3QgdGltZVxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5zZXRJbnB1dFBsYWNlaG9sZGVyKHRoaXMuX3ZhbHVlKTtcbiAgICB9LCAwKTtcbiAgfVxuICBwcml2YXRlIF92YWx1ZTogbnVtYmVyO1xuXG4gIEBPdXRwdXQoKSB0aW1lQ2hhbmdlZCA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2tleWRvd24nLCBbJyRldmVudCddKSBfa2V5ZG93bihldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgIGNvbnN0IGlzQWxsb3cgPVxuICAgICAgKERJR0lUX0tFWVMuaW5jbHVkZXMoZXZlbnQua2V5KSAmJiAhZXZlbnQuc2hpZnRLZXkpIHx8XG4gICAgICBTUEVDSUFMX0tFWVMuaW5jbHVkZXMoZXZlbnQuY29kZSk7XG5cbiAgICBpZiAoIWlzQWxsb3cpIHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgfVxuICB9XG5cbiAgZ2V0IGlucHV0RWxlbWVudCgpIHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQgYXMgSFRNTElucHV0RWxlbWVudDtcbiAgfVxuXG4gIGdldCBoYXNGb2N1cygpIHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50Py5uYXRpdmVFbGVtZW50ID09PSB0aGlzLl9kb2N1bWVudC5hY3RpdmVFbGVtZW50O1xuICB9XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBlbGVtZW50OiBFbGVtZW50UmVmPEhUTUxJbnB1dEVsZW1lbnQ+LFxuICAgIHByaXZhdGUgX2NkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSBfZG9jdW1lbnQ6IERvY3VtZW50LFxuICApIHt9XG5cbiAgZm9jdXMoKSB7XG4gICAgdGhpcy5zZXRJbnB1dFZhbHVlKG51bGwpO1xuICB9XG5cbiAgYmx1cigpIHtcbiAgICBjb25zdCBpc051bWJlciA9ICFpc05hTihOdW1iZXIodGhpcy5pbnB1dEVsZW1lbnQudmFsdWUpKTtcbiAgICBjb25zdCB2YWx1ZSA9IHRoaXMuX2Zvcm1hdFZhbHVlKFxuICAgICAgaXNOdW1iZXIgPyBOdW1iZXIodGhpcy5pbnB1dEVsZW1lbnQudmFsdWUgfHwgdGhpcy5fdmFsdWUpIDogdGhpcy52YWx1ZSxcbiAgICApO1xuICAgIHRoaXMuc2V0SW5wdXRWYWx1ZSh2YWx1ZSk7XG4gICAgdGhpcy5zZXRJbnB1dFBsYWNlaG9sZGVyKHZhbHVlKTtcbiAgICB0aGlzLnRpbWVDaGFuZ2VkLmVtaXQodmFsdWUpO1xuICB9XG5cbiAgc2V0SW5wdXRWYWx1ZSh2YWx1ZTogbnVtYmVyIHwgbnVsbCkge1xuICAgIGlmICh2YWx1ZSAhPT0gbnVsbCkge1xuICAgICAgdGhpcy5pbnB1dEVsZW1lbnQudmFsdWUgPSB0aGlzLl93aXRoWmVyb1ByZWZpeCh2YWx1ZSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaW5wdXRFbGVtZW50LnZhbHVlID0gJyc7XG4gICAgfVxuXG4gICAgdGhpcy5fY2RyLm1hcmtGb3JDaGVjaygpO1xuICB9XG5cbiAgc2V0SW5wdXRQbGFjZWhvbGRlcih2YWx1ZTogbnVtYmVyKSB7XG4gICAgdGhpcy5pbnB1dEVsZW1lbnQucGxhY2Vob2xkZXIgPSB0aGlzLl93aXRoWmVyb1ByZWZpeCh2YWx1ZSk7XG4gICAgdGhpcy5fY2RyLm1hcmtGb3JDaGVjaygpO1xuICB9XG5cbiAgYWJzdHJhY3QgX3dpdGhaZXJvUHJlZml4KHZhbHVlOiBudW1iZXIpOiBzdHJpbmc7XG5cbiAgYWJzdHJhY3QgX2Zvcm1hdFZhbHVlKHZhbHVlOiBudW1iZXIpOiBudW1iZXI7XG59XG4iXX0=
|
|
@@ -5,7 +5,7 @@ import { MatFormFieldModule } from '@angular/material/form-field';
|
|
|
5
5
|
import { MatInputModule } from '@angular/material/input';
|
|
6
6
|
import { take } from 'rxjs';
|
|
7
7
|
import { MatTimeFaceBase } from './time-face-base';
|
|
8
|
-
import { MatTimeInputBase, withZeroPrefix, withZeroPrefixMeridiem } from './time-input-base';
|
|
8
|
+
import { MatTimeInputBase, withZeroPrefix, withZeroPrefixMeridiem, } from './time-input-base';
|
|
9
9
|
import { MatTimePeriod } from './time-period';
|
|
10
10
|
import { MatTimepickerContentLayout } from './timepicker-content-layout';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
@@ -149,13 +149,11 @@ export class MatTimeInputs extends MatTimeFaceBase {
|
|
|
149
149
|
focusActiveCell() {
|
|
150
150
|
this._ngZone.runOutsideAngular(() => {
|
|
151
151
|
this._ngZone.onStable.pipe(take(1)).subscribe(() => {
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
}
|
|
158
|
-
});
|
|
152
|
+
const activeCell = this._elementRef.nativeElement.querySelector('.mat-timepicker-content input');
|
|
153
|
+
if (activeCell && !this._skipNextTickFocus) {
|
|
154
|
+
activeCell.focus();
|
|
155
|
+
this._skipNextTickFocus = true;
|
|
156
|
+
}
|
|
159
157
|
});
|
|
160
158
|
});
|
|
161
159
|
}
|
|
@@ -178,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
178
176
|
}], ctorParameters: () => [{ type: i1.MatTimepickerIntl }, { type: i2.TimeAdapter, decorators: [{
|
|
179
177
|
type: Optional
|
|
180
178
|
}] }, { type: i0.NgZone }, { type: i0.ElementRef }] });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-inputs.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/time-inputs.ts","../../../../projects/mat-timepicker/src/lib/time-inputs.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  Optional,\n  Directive,\n  Input,\n  ElementRef,\n  ChangeDetectorRef,\n  Inject,\n  NgZone,\n} from '@angular/core';\nimport { coerceNumberProperty } from '@angular/cdk/coercion';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { take } from 'rxjs';\n\nimport { TimeAdapter } from './adapter';\nimport { MatTimeFaceBase } from './time-face-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport { MatTimeInputBase, withZeroPrefix, withZeroPrefixMeridiem } from './time-input-base';\nimport { MatTimePeriod } from './time-period';\nimport { MatTimepickerContentLayout } from './timepicker-content-layout';\n\n@Directive({\n  selector: 'input[matHourInput]',\n  standalone: true,\n  exportAs: 'matTimeInput',\n  host: {\n    class: 'mat-time-input',\n    '(focus)': 'focus($event)',\n    '(blur)': 'blur($event)',\n  },\n})\nexport class MatHourInput extends MatTimeInputBase {\n  @Input()\n  get availableHours(): number[] {\n    return this._availableHours;\n  }\n  set availableHours(value: number[]) {\n    this._availableHours = value;\n  }\n  private _availableHours: number[] = [];\n\n  @Input() isMeridiem: boolean;\n\n  constructor(\n    element: ElementRef<HTMLInputElement>,\n    _cdr: ChangeDetectorRef,\n    @Inject(DOCUMENT) _document: Document,\n  ) {\n    super(element, _cdr, _document);\n  }\n\n  _withZeroPrefix(value: number): string {\n    return withZeroPrefixMeridiem(value, this.isMeridiem);\n  }\n\n  _formatValue(hour: number): number {\n    const getValue = () => {\n      if (this.isMeridiem) {\n        if (hour === 0 || hour === 24) {\n          return 12;\n        }\n      }\n\n      if (hour === 24) {\n        return 0;\n      }\n\n      return this.isMeridiem && hour > 12 ? hour - 12 : hour;\n    };\n\n    const value = getValue();\n\n    if (this.isMeridiem) {\n      if (!this.availableHours.length) {\n        return this.value;\n      }\n\n      if (value === 12 && this.availableHours.includes(12)) {\n        return 12;\n      }\n\n      if (value === 12 && !this.availableHours.includes(12)) {\n        return Math.min(...this.availableHours);\n      }\n\n      if (value >= 1 && value < 12) {\n        // the last item is max becuase 12 at the beginning is kinda \"min\"\n        const maxHour = this.availableHours[this.availableHours.length - 1];\n\n        return Math.min(Math.max(value, Math.min(...this.availableHours)), maxHour);\n      }\n    }\n\n    return Math.min(\n      Math.max(value, Math.min(...this.availableHours)),\n      Math.max(...this.availableHours),\n    );\n  }\n}\n\n@Directive({\n  selector: 'input[matMinuteInput]',\n  standalone: true,\n  exportAs: 'matTimeInput',\n  host: {\n    class: 'mat-time-input',\n    '(focus)': 'focus($event)',\n    '(blur)': 'blur($event)',\n  },\n})\nexport class MatMinuteInput extends MatTimeInputBase {\n  /** Step over minutes. */\n  @Input()\n  get interval(): number {\n    return this._interval;\n  }\n  set interval(value: number) {\n    this._interval = coerceNumberProperty(value) || 1;\n  }\n  private _interval: number = 1;\n\n  @Input()\n  get availableMinutes(): number[] {\n    return this._availableMinutes;\n  }\n  set availableMinutes(value: number[]) {\n    this._availableMinutes = value;\n  }\n  private _availableMinutes: number[] = [];\n\n  constructor(\n    element: ElementRef<HTMLInputElement>,\n    _cdr: ChangeDetectorRef,\n    @Inject(DOCUMENT) _document: Document,\n  ) {\n    super(element, _cdr, _document);\n  }\n\n  _withZeroPrefix(value: number): string {\n    return withZeroPrefix(value);\n  }\n\n  _formatValue(value: number): number {\n    if (!this.availableMinutes.length) {\n      return this.value;\n    }\n\n    const roundedValue = Math.round(value / this.interval) * this.interval;\n\n    return Math.min(\n      Math.max(roundedValue, Math.min(...this.availableMinutes)),\n      Math.max(...this.availableMinutes),\n    );\n  }\n}\n\n@Component({\n  selector: 'mat-time-inputs',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatFormFieldModule,\n    MatInputModule,\n    MatTimepickerContentLayout,\n    MatHourInput,\n    MatMinuteInput,\n    MatTimePeriod,\n  ],\n  templateUrl: './time-inputs.html',\n  styleUrls: ['./time-inputs.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'mat-time-inputs',\n  },\n})\nexport class MatTimeInputs<T> extends MatTimeFaceBase<T> {\n  constructor(\n    public _intl: MatTimepickerIntl,\n    @Optional() _timeAdapter: TimeAdapter<T>,\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef,\n  ) {\n    super(_timeAdapter);\n  }\n\n  /**\n   * Using for skipping that focus shouldn't be moved to the active cell on the next tick.\n   * We need to use it to avoid focusing input for input mode.\n   */\n  private _skipNextTickFocus = false;\n\n  focusActiveCell(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n        setTimeout(() => {\n          const activeCell: HTMLElement | null = this._elementRef.nativeElement.querySelector(\n            '.mat-timepicker-content input', // to avoid focus for inline mode\n          );\n          if (activeCell && !this._skipNextTickFocus) {\n            activeCell.focus();\n            this._skipNextTickFocus = true;\n          }\n        });\n      });\n    });\n  }\n}\n","<mat-timepicker-content-layout [title]=\"_intl.inputsTitle\">\n  <mat-form-field\n    class=\"mat-time-inputs-field\"\n    appearance=\"outline\"\n    hours\n    [color]=\"color\"\n  >\n    <input\n      type=\"text\"\n      inputmode=\"numeric\"\n      maxlength=\"2\"\n      matInput\n      matHourInput\n      [isMeridiem]=\"isMeridiem\"\n      [value]=\"selectedHour\"\n      [availableHours]=\"_getAvailableHours()\"\n      (timeChanged)=\"_onHourSelected($event)\"\n      (keydown)=\"_onKeydown($event, 'hour')\"\n    />\n    <mat-hint>{{_intl.hourInputHint}}</mat-hint>\n  </mat-form-field>\n  <mat-form-field\n    class=\"mat-time-inputs-field\"\n    appearance=\"outline\"\n    minutes\n    [color]=\"color\"\n  >\n    <input\n      type=\"text\"\n      inputmode=\"numeric\"\n      maxlength=\"2\"\n      matInput\n      matMinuteInput\n      [value]=\"selectedMinute\"\n      [interval]=\"minuteInterval\"\n      [availableMinutes]=\"availableMinutes\"\n      (timeChanged)=\"_onMinuteSelected($event)\"\n      (keydown)=\"_onKeydown($event, 'minute')\"\n    />\n    <mat-hint>{{_intl.minuteInputHint}}</mat-hint>\n  </mat-form-field>\n\n  <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n    <mat-time-period\n      [period]=\"period\"\n      [disabledPeriod]=\"disabledPeriod\"\n      (periodChanged)=\"_onPeriodChanged($event)\"\n    ></mat-time-period>\n  </ng-template>\n</mat-timepicker-content-layout>\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-inputs.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/time-inputs.ts","../../../../projects/mat-timepicker/src/lib/time-inputs.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EACL,SAAS,EACT,uBAAuB,EACvB,iBAAiB,EACjB,QAAQ,EACR,SAAS,EACT,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEnD,OAAO,EACL,gBAAgB,EAChB,cAAc,EACd,sBAAsB,GACvB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;;;;;;;AAYzE,MAAM,OAAO,YAAa,SAAQ,gBAAgB;IAChD,IACI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IACD,IAAI,cAAc,CAAC,KAAe;QAChC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAKD,YACE,OAAqC,EACrC,IAAuB,EACL,SAAmB;QAErC,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;QAT1B,oBAAe,GAAa,EAAE,CAAC;IAUvC,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,OAAO,sBAAsB,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACxD,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,MAAM,QAAQ,GAAG,GAAG,EAAE;YACpB,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,EAAE,EAAE;oBAC7B,OAAO,EAAE,CAAC;iBACX;aACF;YAED,IAAI,IAAI,KAAK,EAAE,EAAE;gBACf,OAAO,CAAC,CAAC;aACV;YAED,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QACzD,CAAC,CAAC;QAEF,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;QAEzB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;gBAC/B,OAAO,IAAI,CAAC,KAAK,CAAC;aACnB;YAED,IAAI,KAAK,KAAK,EAAE,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE;gBACpD,OAAO,EAAE,CAAC;aACX;YAED,IAAI,KAAK,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE;gBACrD,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;aACzC;YAED,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,GAAG,EAAE,EAAE;gBAC5B,kEAAkE;gBAClE,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBAEpE,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,EACjD,OAAO,CACR,CAAC;aACH;SACF;QAED,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,EACjD,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CACjC,CAAC;IACJ,CAAC;8GArEU,YAAY,6EAeb,QAAQ;kGAfP,YAAY;;2FAAZ,YAAY;kBAVxB,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,cAAc;oBACxB,IAAI,EAAE;wBACJ,KAAK,EAAE,gBAAgB;wBACvB,SAAS,EAAE,eAAe;wBAC1B,QAAQ,EAAE,cAAc;qBACzB;iBACF;;0BAgBI,MAAM;2BAAC,QAAQ;yCAbd,cAAc;sBADjB,KAAK;gBASG,UAAU;sBAAlB,KAAK;;AAwER,MAAM,OAAO,cAAe,SAAQ,gBAAgB;IAClD,yBAAyB;IACzB,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAa;QACxB,IAAI,CAAC,SAAS,GAAG,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC;IAGD,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,gBAAgB,CAAC,KAAe;QAClC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAGD,YACE,OAAqC,EACrC,IAAuB,EACL,SAAmB;QAErC,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;QAhB1B,cAAS,GAAW,CAAC,CAAC;QAStB,sBAAiB,GAAa,EAAE,CAAC;IAQzC,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;YACjC,OAAO,IAAI,CAAC,KAAK,CAAC;SACnB;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;QAEvE,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,EAC1D,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CACnC,CAAC;IACJ,CAAC;8GA3CU,cAAc,6EAuBf,QAAQ;kGAvBP,cAAc;;2FAAd,cAAc;kBAV1B,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,cAAc;oBACxB,IAAI,EAAE;wBACJ,KAAK,EAAE,gBAAgB;wBACvB,SAAS,EAAE,eAAe;wBAC1B,QAAQ,EAAE,cAAc;qBACzB;iBACF;;0BAwBI,MAAM;2BAAC,QAAQ;yCApBd,QAAQ;sBADX,KAAK;gBAUF,gBAAgB;sBADnB,KAAK;;AAuDR,MAAM,OAAO,aAAiB,SAAQ,eAAkB;IACtD,YACS,KAAwB,EACnB,YAA4B,EAChC,OAAe,EACf,WAAuB;QAE/B,KAAK,CAAC,YAAY,CAAC,CAAC;QALb,UAAK,GAAL,KAAK,CAAmB;QAEvB,YAAO,GAAP,OAAO,CAAQ;QACf,gBAAW,GAAX,WAAW,CAAY;QAKjC;;;WAGG;QACK,uBAAkB,GAAG,KAAK,CAAC;IANnC,CAAC;IAQD,eAAe;QACb,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBACjD,MAAM,UAAU,GACd,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAC1C,+BAA+B,CAChC,CAAC;gBACJ,IAAI,UAAU,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;oBAC1C,UAAU,CAAC,KAAK,EAAE,CAAC;oBACnB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;iBAChC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;8GA7BU,aAAa;kGAAb,aAAa,+IC3L1B,m5CAkDA,4vCDyHI,YAAY,kIACZ,kBAAkB,iUAClB,cAAc,2WACd,0BAA0B,gJAvIjB,YAAY,sIAkFZ,cAAc,wIAwDvB,aAAa;;2FAUJ,aAAa;kBApBzB,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP;wBACP,YAAY;wBACZ,kBAAkB;wBAClB,cAAc;wBACd,0BAA0B;wBAC1B,YAAY;wBACZ,cAAc;wBACd,aAAa;qBACd,mBAGgB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,QAC/B;wBACJ,KAAK,EAAE,iBAAiB;qBACzB;;0BAKE,QAAQ","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  Optional,\n  Directive,\n  Input,\n  ElementRef,\n  ChangeDetectorRef,\n  Inject,\n  NgZone,\n} from '@angular/core';\nimport { coerceNumberProperty } from '@angular/cdk/coercion';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { take } from 'rxjs';\n\nimport { TimeAdapter } from './adapter';\nimport { MatTimeFaceBase } from './time-face-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport {\n  MatTimeInputBase,\n  withZeroPrefix,\n  withZeroPrefixMeridiem,\n} from './time-input-base';\nimport { MatTimePeriod } from './time-period';\nimport { MatTimepickerContentLayout } from './timepicker-content-layout';\n\n@Directive({\n  selector: 'input[matHourInput]',\n  standalone: true,\n  exportAs: 'matTimeInput',\n  host: {\n    class: 'mat-time-input',\n    '(focus)': 'focus($event)',\n    '(blur)': 'blur($event)',\n  },\n})\nexport class MatHourInput extends MatTimeInputBase {\n  @Input()\n  get availableHours(): number[] {\n    return this._availableHours;\n  }\n  set availableHours(value: number[]) {\n    this._availableHours = value;\n  }\n  private _availableHours: number[] = [];\n\n  @Input() isMeridiem: boolean;\n\n  constructor(\n    element: ElementRef<HTMLInputElement>,\n    _cdr: ChangeDetectorRef,\n    @Inject(DOCUMENT) _document: Document,\n  ) {\n    super(element, _cdr, _document);\n  }\n\n  _withZeroPrefix(value: number): string {\n    return withZeroPrefixMeridiem(value, this.isMeridiem);\n  }\n\n  _formatValue(hour: number): number {\n    const getValue = () => {\n      if (this.isMeridiem) {\n        if (hour === 0 || hour === 24) {\n          return 12;\n        }\n      }\n\n      if (hour === 24) {\n        return 0;\n      }\n\n      return this.isMeridiem && hour > 12 ? hour - 12 : hour;\n    };\n\n    const value = getValue();\n\n    if (this.isMeridiem) {\n      if (!this.availableHours.length) {\n        return this.value;\n      }\n\n      if (value === 12 && this.availableHours.includes(12)) {\n        return 12;\n      }\n\n      if (value === 12 && !this.availableHours.includes(12)) {\n        return Math.min(...this.availableHours);\n      }\n\n      if (value >= 1 && value < 12) {\n        // the last item is max becuase 12 at the beginning is kinda \"min\"\n        const maxHour = this.availableHours[this.availableHours.length - 1];\n\n        return Math.min(\n          Math.max(value, Math.min(...this.availableHours)),\n          maxHour,\n        );\n      }\n    }\n\n    return Math.min(\n      Math.max(value, Math.min(...this.availableHours)),\n      Math.max(...this.availableHours),\n    );\n  }\n}\n\n@Directive({\n  selector: 'input[matMinuteInput]',\n  standalone: true,\n  exportAs: 'matTimeInput',\n  host: {\n    class: 'mat-time-input',\n    '(focus)': 'focus($event)',\n    '(blur)': 'blur($event)',\n  },\n})\nexport class MatMinuteInput extends MatTimeInputBase {\n  /** Step over minutes. */\n  @Input()\n  get interval(): number {\n    return this._interval;\n  }\n  set interval(value: number) {\n    this._interval = coerceNumberProperty(value) || 1;\n  }\n  private _interval: number = 1;\n\n  @Input()\n  get availableMinutes(): number[] {\n    return this._availableMinutes;\n  }\n  set availableMinutes(value: number[]) {\n    this._availableMinutes = value;\n  }\n  private _availableMinutes: number[] = [];\n\n  constructor(\n    element: ElementRef<HTMLInputElement>,\n    _cdr: ChangeDetectorRef,\n    @Inject(DOCUMENT) _document: Document,\n  ) {\n    super(element, _cdr, _document);\n  }\n\n  _withZeroPrefix(value: number): string {\n    return withZeroPrefix(value);\n  }\n\n  _formatValue(value: number): number {\n    if (!this.availableMinutes.length) {\n      return this.value;\n    }\n\n    const roundedValue = Math.round(value / this.interval) * this.interval;\n\n    return Math.min(\n      Math.max(roundedValue, Math.min(...this.availableMinutes)),\n      Math.max(...this.availableMinutes),\n    );\n  }\n}\n\n@Component({\n  selector: 'mat-time-inputs',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatFormFieldModule,\n    MatInputModule,\n    MatTimepickerContentLayout,\n    MatHourInput,\n    MatMinuteInput,\n    MatTimePeriod,\n  ],\n  templateUrl: './time-inputs.html',\n  styleUrls: ['./time-inputs.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'mat-time-inputs',\n  },\n})\nexport class MatTimeInputs<T> extends MatTimeFaceBase<T> {\n  constructor(\n    public _intl: MatTimepickerIntl,\n    @Optional() _timeAdapter: TimeAdapter<T>,\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef,\n  ) {\n    super(_timeAdapter);\n  }\n\n  /**\n   * Using for skipping that focus shouldn't be moved to the active cell on the next tick.\n   * We need to use it to avoid focusing input for input mode.\n   */\n  private _skipNextTickFocus = false;\n\n  focusActiveCell(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n        const activeCell: HTMLElement | null =\n          this._elementRef.nativeElement.querySelector(\n            '.mat-timepicker-content input', // to avoid focus for inline mode\n          );\n        if (activeCell && !this._skipNextTickFocus) {\n          activeCell.focus();\n          this._skipNextTickFocus = true;\n        }\n      });\n    });\n  }\n}\n","<mat-timepicker-content-layout [title]=\"_intl.inputsTitle\">\n  <mat-form-field\n    class=\"mat-time-inputs-field\"\n    appearance=\"outline\"\n    hours\n    [color]=\"color\"\n  >\n    <input\n      type=\"text\"\n      inputmode=\"numeric\"\n      maxlength=\"2\"\n      matInput\n      matHourInput\n      [isMeridiem]=\"isMeridiem\"\n      [value]=\"selectedHour\"\n      [availableHours]=\"_getAvailableHours()\"\n      (timeChanged)=\"_onHourSelected($event)\"\n      (keydown)=\"_onKeydown($event, 'hour')\"\n    />\n    <mat-hint>{{_intl.hourInputHint}}</mat-hint>\n  </mat-form-field>\n  <mat-form-field\n    class=\"mat-time-inputs-field\"\n    appearance=\"outline\"\n    minutes\n    [color]=\"color\"\n  >\n    <input\n      type=\"text\"\n      inputmode=\"numeric\"\n      maxlength=\"2\"\n      matInput\n      matMinuteInput\n      [value]=\"selectedMinute\"\n      [interval]=\"minuteInterval\"\n      [availableMinutes]=\"availableMinutes\"\n      (timeChanged)=\"_onMinuteSelected($event)\"\n      (keydown)=\"_onKeydown($event, 'minute')\"\n    />\n    <mat-hint>{{_intl.minuteInputHint}}</mat-hint>\n  </mat-form-field>\n\n  <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n    <mat-time-period\n      [period]=\"period\"\n      [disabledPeriod]=\"disabledPeriod\"\n      (periodChanged)=\"_onPeriodChanged($event)\"\n    ></mat-time-period>\n  </ng-template>\n</mat-timepicker-content-layout>\n"]}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import { Input, Directive, Inject, Output, EventEmitter, InjectionToken, Optional, booleanAttribute, } from '@angular/core';
|
|
1
|
+
import { Input, Directive, Inject, Output, EventEmitter, InjectionToken, Optional, booleanAttribute, inject, } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';
|
|
2
4
|
import { coerceBooleanProperty, coerceNumberProperty, } from '@angular/cdk/coercion';
|
|
3
5
|
import { FlexibleConnectedPositionStrategy, OverlayConfig, } from '@angular/cdk/overlay';
|
|
4
6
|
import { ComponentPortal, } from '@angular/cdk/portal';
|
|
5
7
|
import { DOWN_ARROW, ESCAPE, hasModifierKey, PAGE_DOWN, PAGE_UP, UP_ARROW, } from '@angular/cdk/keycodes';
|
|
6
|
-
import { filter, first, merge } from 'rxjs';
|
|
8
|
+
import { filter, first, merge, Subject, take } from 'rxjs';
|
|
7
9
|
import { MatTimepickerContent } from './timepicker-content';
|
|
8
10
|
import { MAT_TIMEPICKER_SCROLL_STRATEGY } from './timepicker-scroll-strategy';
|
|
9
11
|
import { MAT_DEFAULT_ACITONS } from './timepicker-actions-default';
|
|
@@ -34,6 +36,7 @@ export class MatTimepickerBase {
|
|
|
34
36
|
const newValue = coerceBooleanProperty(value);
|
|
35
37
|
if (newValue !== this._disabled) {
|
|
36
38
|
this._disabled = newValue;
|
|
39
|
+
this.stateChanges.next(undefined);
|
|
37
40
|
}
|
|
38
41
|
}
|
|
39
42
|
/** Whether the timepicker is open. */
|
|
@@ -130,14 +133,27 @@ export class MatTimepickerBase {
|
|
|
130
133
|
this.xPosition = 'start';
|
|
131
134
|
/** Preferred position of the timepicker in the Y axis. */
|
|
132
135
|
this.yPosition = 'below';
|
|
136
|
+
/**
|
|
137
|
+
* Whether to restore focus to the previously-focused element when the timepicker is closed.
|
|
138
|
+
* Note that automatic focus restoration is an accessibility feature and it is recommended that
|
|
139
|
+
* you provide your own equivalent, if you decide to turn it off.
|
|
140
|
+
*/
|
|
141
|
+
this.restoreFocus = true;
|
|
142
|
+
/** Emits when the timepicker has been opened. */
|
|
143
|
+
this.openedStream = new EventEmitter();
|
|
133
144
|
/** Emits when the timepicker has been closed. */
|
|
134
145
|
this.closedStream = new EventEmitter();
|
|
135
146
|
/** The id for the timepicker. */
|
|
136
147
|
this.id = `mat-timepicker-${timepickerUid++}`;
|
|
137
148
|
/** Portal with projected action buttons. */
|
|
138
149
|
this._actionsPortal = null;
|
|
150
|
+
/** Emits when the timepicker's state changes. */
|
|
151
|
+
this.stateChanges = new Subject();
|
|
139
152
|
/** Unique class that will be added to the backdrop so that the test harnesses can look it up. */
|
|
140
153
|
this._backdropHarnessClass = `${this.id}-backdrop`;
|
|
154
|
+
/** The element that was focused before the timepicker was opened. */
|
|
155
|
+
this._focusedElementBeforeOpen = null;
|
|
156
|
+
this._document = inject(DOCUMENT);
|
|
141
157
|
this._scrollStrategy = scrollStrategy;
|
|
142
158
|
if (_defaults) {
|
|
143
159
|
this.showToggleModeButton =
|
|
@@ -157,39 +173,66 @@ export class MatTimepickerBase {
|
|
|
157
173
|
}
|
|
158
174
|
}
|
|
159
175
|
}
|
|
176
|
+
this.stateChanges.next(undefined);
|
|
160
177
|
}
|
|
161
178
|
ngOnDestroy() {
|
|
162
179
|
this._destroyOverlay();
|
|
163
180
|
this.close();
|
|
181
|
+
this.stateChanges.complete();
|
|
164
182
|
}
|
|
165
183
|
/** Opens the timepicker. */
|
|
166
184
|
open() {
|
|
167
|
-
if (this._opened ||
|
|
185
|
+
if (this._opened ||
|
|
186
|
+
this.disabled ||
|
|
187
|
+
this._componentRef?.instance._isAnimating) {
|
|
168
188
|
return;
|
|
169
189
|
}
|
|
170
190
|
if (!this.timepickerInput) {
|
|
171
191
|
throw Error('Attempted to open an MatTimepicker with no associated input.');
|
|
172
192
|
}
|
|
193
|
+
this._focusedElementBeforeOpen = _getFocusedElementPierceShadowDom();
|
|
173
194
|
this._openOverlay();
|
|
174
195
|
this._opened = true;
|
|
196
|
+
this.openedStream.emit();
|
|
175
197
|
}
|
|
176
198
|
/** Closes the timepicker. */
|
|
177
199
|
close() {
|
|
178
|
-
if (!this._opened) {
|
|
200
|
+
if (!this._opened || this._componentRef?.instance._isAnimating) {
|
|
179
201
|
return;
|
|
180
202
|
}
|
|
203
|
+
const canRestoreFocus = this.restoreFocus &&
|
|
204
|
+
this._focusedElementBeforeOpen &&
|
|
205
|
+
typeof this._focusedElementBeforeOpen.focus === 'function';
|
|
206
|
+
const completeClose = () => {
|
|
207
|
+
// The `_opened` could've been reset already if
|
|
208
|
+
// we got two events in quick succession.
|
|
209
|
+
if (this._opened) {
|
|
210
|
+
this._opened = false;
|
|
211
|
+
this.closedStream.emit();
|
|
212
|
+
}
|
|
213
|
+
};
|
|
181
214
|
if (this._componentRef) {
|
|
182
|
-
const instance = this._componentRef
|
|
183
|
-
instance.
|
|
184
|
-
instance._animationDone
|
|
185
|
-
.
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
215
|
+
const { instance, location } = this._componentRef;
|
|
216
|
+
instance._startExitAnimation();
|
|
217
|
+
instance._animationDone.pipe(take(1)).subscribe(() => {
|
|
218
|
+
const activeElement = this._document.activeElement;
|
|
219
|
+
// Since we restore focus after the exit animation, we have to check that
|
|
220
|
+
// the user didn't move focus themselves inside the `close` handler.
|
|
221
|
+
if (canRestoreFocus &&
|
|
222
|
+
(!activeElement ||
|
|
223
|
+
activeElement === this._document.activeElement ||
|
|
224
|
+
location.nativeElement.contains(activeElement))) {
|
|
225
|
+
this._focusedElementBeforeOpen.focus();
|
|
226
|
+
}
|
|
227
|
+
this._focusedElementBeforeOpen = null;
|
|
228
|
+
this._destroyOverlay();
|
|
229
|
+
});
|
|
230
|
+
if (canRestoreFocus) {
|
|
231
|
+
setTimeout(completeClose);
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
completeClose();
|
|
235
|
+
}
|
|
193
236
|
}
|
|
194
237
|
}
|
|
195
238
|
/**
|
|
@@ -362,7 +405,7 @@ export class MatTimepickerBase {
|
|
|
362
405
|
})));
|
|
363
406
|
}
|
|
364
407
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: MatTimepickerBase, deps: [{ token: i0.ViewContainerRef }, { token: i1.Overlay }, { token: i0.NgZone }, { token: MAT_TIMEPICKER_SCROLL_STRATEGY }, { token: MAT_DEFAULT_ACITONS }, { token: i2.MatTimeSelectionModel }, { token: MAT_TIMEPICKER_DEFAULT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
365
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.9", type: MatTimepickerBase, inputs: { disabled: "disabled", opened: "opened", openAs: "openAs", color: "color", mode: "mode", format: "format", showToggleModeButton: "showToggleModeButton", minuteInterval: "minuteInterval", orientation: "orientation", touchUi: ["touchUi", "touchUi", booleanAttribute], xPosition: "xPosition", yPosition: "yPosition" }, outputs: { closedStream: "closed" }, usesOnChanges: true, ngImport: i0 }); }
|
|
408
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.9", type: MatTimepickerBase, inputs: { disabled: "disabled", opened: "opened", openAs: "openAs", color: "color", mode: "mode", format: "format", showToggleModeButton: "showToggleModeButton", minuteInterval: "minuteInterval", orientation: "orientation", touchUi: ["touchUi", "touchUi", booleanAttribute], xPosition: "xPosition", yPosition: "yPosition", restoreFocus: ["restoreFocus", "restoreFocus", booleanAttribute] }, outputs: { openedStream: "opened", closedStream: "closed" }, usesOnChanges: true, ngImport: i0 }); }
|
|
366
409
|
}
|
|
367
410
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: MatTimepickerBase, decorators: [{
|
|
368
411
|
type: Directive
|
|
@@ -402,8 +445,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
402
445
|
type: Input
|
|
403
446
|
}], yPosition: [{
|
|
404
447
|
type: Input
|
|
448
|
+
}], restoreFocus: [{
|
|
449
|
+
type: Input,
|
|
450
|
+
args: [{ transform: booleanAttribute }]
|
|
451
|
+
}], openedStream: [{
|
|
452
|
+
type: Output,
|
|
453
|
+
args: ['opened']
|
|
405
454
|
}], closedStream: [{
|
|
406
455
|
type: Output,
|
|
407
456
|
args: ['closed']
|
|
408
457
|
}] } });
|
|
409
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-base.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  ComponentRef,\n  ViewContainerRef,\n  Directive,\n  NgZone,\n  Inject,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef,\n  InjectionToken,\n  Optional,\n  booleanAttribute,\n} from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport {\n  BooleanInput,\n  coerceBooleanProperty,\n  coerceNumberProperty,\n} from '@angular/cdk/coercion';\nimport {\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollStrategy,\n} from '@angular/cdk/overlay';\nimport {\n  ComponentPortal,\n  ComponentType,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  DOWN_ARROW,\n  ESCAPE,\n  hasModifierKey,\n  PAGE_DOWN,\n  PAGE_UP,\n  UP_ARROW,\n} from '@angular/cdk/keycodes';\nimport { filter, first, merge, Observable } from 'rxjs';\n\nimport { MatTimepickerContent } from './timepicker-content';\nimport { MAT_TIMEPICKER_SCROLL_STRATEGY } from './timepicker-scroll-strategy';\nimport {\n  ExtractTimeTypeFromSelection,\n  MatTimeSelectionModel,\n} from './time-selection-model';\nimport { MAT_DEFAULT_ACITONS } from './timepicker-actions-default';\nimport { TimepickerOrientation } from './orientation';\n\n/** Possible options for the timepicker to open. */\nexport type TimepickerOpenAs = 'dialog' | 'popup';\n\n/** Possible positions for the timepicker dropdown along the X axis. */\nexport type TimepickerDropdownPositionX = 'start' | 'end';\n\n/** Possible positions for the timepicker dropdown along the Y axis. */\nexport type TimepickerDropdownPositionY = 'above' | 'below';\n\n/** Possible options for the timepicker to display. */\nexport type TimepickerMode = 'input' | 'dial';\n\n/** Possible options for the timepicker period format. */\nexport type TimepickerFormat = '12h' | '24h';\n\n/** Form control that can be associated with a timepicker. */\nexport interface MatTimepickerControl<T> {\n  disabled: boolean;\n  min: T | null;\n  max: T | null;\n  getThemePalette(): ThemePalette;\n  getConnectedOverlayOrigin(): ElementRef;\n  getOverlayLabelId(): string | null;\n}\n\n/** A timepicker that can be attached to a {@link MatTimepickerControl}. */\nexport interface MatTimepickerPanel<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>\n> {\n  /** Register an input with the timeepicker. */\n  registerInput(input: C): MatTimeSelectionModel<S, T>;\n}\n\n/**\n * Represents the default options for the form field that can be configured\n * using the `MAT_TIMEPICKER_DEFAULT_OPTIONS` injection token.\n */\nexport interface MatTimepickerDefaultOptions {\n  /** Default color of the timepicker. */\n  color?: ThemePalette;\n  /** Default timepicker mode. */\n  mode: TimepickerMode;\n  /** Defines how timepicker will be appeared. */\n  openAs: TimepickerOpenAs;\n  /** Default timepicker format. */\n  format: TimepickerFormat;\n  /** Should toggle face button be visible. */\n  showToggleModeButton: boolean;\n  /** Step for minutes. */\n  minuteInterval: number;\n  /** Orientation for dial mode. */\n  orientation: TimepickerOrientation;\n}\n\n/**\n * Injection token that can be used to configure the\n * default options for all timepickers within an app.\n */\nexport const MAT_TIMEPICKER_DEFAULT_OPTIONS =\n  new InjectionToken<MatTimepickerDefaultOptions>(\n    'MAT_TIMEPICKER_DEFAULT_OPTIONS'\n  );\n\n/** Default open as used by the timepicker. */\nconst DEFAULT_OPEN_AS: TimepickerOpenAs = 'popup';\n\n/** Default mode used by the timepicker. */\nconst DEFAULT_MODE: TimepickerMode = 'dial';\n\n/** Default format used by the timepicker. */\nconst DEFAULT_FORMAT: TimepickerFormat = '12h';\n\n/** Used to generate a unique ID for each timepicker instance. */\nlet timepickerUid = 0;\n\n@Directive()\nexport abstract class MatTimepickerBase<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>\n> implements OnChanges\n{\n  /** Whether the timepicker pop-up should be disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled === undefined && this.timepickerInput\n      ? this.timepickerInput.disabled\n      : !!this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this._disabled) {\n      this._disabled = newValue;\n    }\n  }\n  private _disabled: boolean;\n\n  /** Whether the timepicker is open. */\n  @Input()\n  get opened(): boolean {\n    return this._opened;\n  }\n  set opened(value: BooleanInput) {\n    coerceBooleanProperty(value) ? this.open() : this.close();\n  }\n  private _opened = false;\n\n  /** Whether the timepicker mode which determines what the timepicker will be opened as. */\n  @Input()\n  get openAs(): TimepickerOpenAs {\n    return this._openAs || this._defaults?.openAs || DEFAULT_OPEN_AS;\n  }\n  set openAs(value: TimepickerOpenAs) {\n    this._openAs = value;\n  }\n  private _openAs: TimepickerOpenAs;\n\n  /** Color palette to use on the timepicker's content. */\n  @Input()\n  get color(): ThemePalette {\n    return (\n      this._color ||\n      this._defaults?.color ||\n      (this.timepickerInput\n        ? this.timepickerInput.getThemePalette()\n        : undefined)\n    );\n  }\n  set color(value: ThemePalette) {\n    this._color = value;\n  }\n  private _color: ThemePalette;\n\n  /** Timepicker display mode. */\n  @Input()\n  get mode(): TimepickerMode {\n    return this._mode || this._defaults?.mode || DEFAULT_MODE;\n  }\n  set mode(value: TimepickerMode) {\n    this._mode = value;\n  }\n  private _mode: TimepickerMode;\n\n  /** Timepicker period format. */\n  @Input()\n  get format(): TimepickerFormat {\n    return this._format || this._defaults?.format || DEFAULT_FORMAT;\n  }\n  set format(value: TimepickerFormat) {\n    this._format = value;\n  }\n  private _format: TimepickerFormat;\n\n  /** Show or hide toggle button between dial and input. */\n  @Input()\n  get showToggleModeButton(): boolean {\n    return this._showToggleModeButton;\n  }\n  set showToggleModeButton(value: boolean) {\n    this._showToggleModeButton = value;\n  }\n  private _showToggleModeButton: boolean = true;\n\n  /** Step for minutes. */\n  @Input()\n  get minuteInterval(): number {\n    return this._minuteInterval || this._defaults?.minuteInterval || 1;\n  }\n  set minuteInterval(value: number) {\n    this._minuteInterval = coerceNumberProperty(value);\n  }\n  private _minuteInterval: number;\n\n  /** Orientation for dial mode. */\n  @Input()\n  get orientation(): TimepickerOrientation {\n    return this._orientation || this._defaults?.orientation || 'vertical';\n  }\n  set orientation(value: TimepickerOrientation) {\n    this._orientation = value;\n  }\n  private _orientation: TimepickerOrientation;\n\n  /**\n   * Whether the timepicker UI is in touch mode. In touch mode elements are larger for bigger touch targets.\n   */\n  @Input({ transform: booleanAttribute })\n  get touchUi(): boolean {\n    return this._touchUi;\n  }\n  set touchUi(value: boolean) {\n    this._touchUi = coerceBooleanProperty(value);\n\n    if (value) {\n      this.openAs = 'dialog';\n    }\n  }\n  private _touchUi: boolean = false;\n\n  /** Preferred position of the timepicker in the X axis. */\n  @Input()\n  xPosition: TimepickerDropdownPositionX = 'start';\n\n  /** Preferred position of the timepicker in the Y axis. */\n  @Input()\n  yPosition: TimepickerDropdownPositionY = 'below';\n\n  /** Emits when the timepicker has been closed. */\n  @Output('closed') readonly closedStream = new EventEmitter<void>();\n\n  /** The id for the timepicker. */\n  id: string = `mat-timepicker-${timepickerUid++}`;\n\n  /** The input element this timepicker is associated with. */\n  timepickerInput!: C;\n\n  /** Portal with projected action buttons. */\n  _actionsPortal: TemplatePortal | null = null;\n\n  /** A reference to the overlay into which we've rendered the timepicker. */\n  private _overlayRef: OverlayRef | null;\n\n  /** Reference to the component instance rendered in the overlay. */\n  private _componentRef!: ComponentRef<MatTimepickerContent<S, T>> | null;\n\n  /** Unique class that will be added to the backdrop so that the test harnesses can look it up. */\n  private _backdropHarnessClass = `${this.id}-backdrop`;\n\n  /** Scroll strategy. */\n  private _scrollStrategy: () => ScrollStrategy;\n\n  /** The minimum selectable time. */\n  _getMinTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.min;\n  }\n\n  /** The maximum selectable time. */\n  _getMaxTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.max;\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _overlay: Overlay,\n    private _ngZone: NgZone,\n    @Inject(MAT_TIMEPICKER_SCROLL_STRATEGY) scrollStrategy: any,\n    @Inject(MAT_DEFAULT_ACITONS)\n    private _defaultActionsComponent: ComponentType<any>,\n    private _model: MatTimeSelectionModel<S, T>,\n    @Optional()\n    @Inject(MAT_TIMEPICKER_DEFAULT_OPTIONS)\n    private _defaults?: MatTimepickerDefaultOptions\n  ) {\n    this._scrollStrategy = scrollStrategy;\n\n    if (_defaults) {\n      this.showToggleModeButton =\n        _defaults.showToggleModeButton !== undefined\n          ? _defaults.showToggleModeButton\n          : true;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const positionChange = changes['xPosition'] || changes['yPosition'];\n\n    if (positionChange && !positionChange.firstChange && this._overlayRef) {\n      const positionStrategy = this._overlayRef.getConfig().positionStrategy;\n\n      if (positionStrategy instanceof FlexibleConnectedPositionStrategy) {\n        this._setConnectedPositions(positionStrategy);\n\n        if (this.opened) {\n          this._overlayRef.updatePosition();\n        }\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroyOverlay();\n    this.close();\n  }\n\n  /** Opens the timepicker. */\n  open(): void {\n    if (this._opened || this.disabled) {\n      return;\n    }\n\n    if (!this.timepickerInput) {\n      throw Error(\n        'Attempted to open an MatTimepicker with no associated input.'\n      );\n    }\n\n    this._openOverlay();\n    this._opened = true;\n  }\n\n  /** Closes the timepicker. */\n  close(): void {\n    if (!this._opened) {\n      return;\n    }\n\n    if (this._componentRef) {\n      const instance = this._componentRef.instance;\n      instance.startExitAnimation();\n      instance._animationDone\n        .pipe(first())\n        .subscribe(() => this._destroyOverlay());\n    }\n\n    // The `_opened` could've been reset already if\n    // we got two events in quick succession.\n    if (this._opened) {\n      this._opened = false;\n      this.closedStream.emit();\n    }\n  }\n\n  /**\n   * Register an input with this timepicker.\n   * @param input The timepicker input to register with this timepicker.\n   * @returns Selection model that the input should hook itself up to.\n   */\n  registerInput(input: C): MatTimeSelectionModel<S, T> {\n    if (this.timepickerInput) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single input.'\n      );\n    }\n\n    this.timepickerInput = input;\n    return this._model;\n  }\n\n  /**\n   * Registers a portal containing action buttons with the timepicker.\n   * @param portal Portal to be registered.\n   */\n  registerActions(portal: TemplatePortal): void {\n    if (this._actionsPortal) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single actions row.'\n      );\n    }\n    this._actionsPortal = portal;\n    this._componentRef?.instance._assignActions(portal, true);\n  }\n\n  /**\n   * Removes a portal containing action buttons from the timepicker.\n   * @param portal Portal to be removed.\n   */\n  removeActions(portal: TemplatePortal): void {\n    if (portal === this._actionsPortal) {\n      this._actionsPortal = null;\n      this._componentRef?.instance._assignActions(null, true);\n    }\n  }\n\n  /** Applies the current pending selection on the overlay to the model. */\n  _applyPendingSelection() {\n    this._componentRef?.instance?._applyPendingSelection();\n  }\n\n  /** Forwards relevant values from the timepicker to the timepicker content inside the overlay. */\n  protected _forwardContentValues(instance: MatTimepickerContent<S, T>): void {\n    const defaultPortal = new ComponentPortal(this._defaultActionsComponent);\n\n    instance.timepicker = this;\n    instance.color = this.color;\n    instance.mode = this.mode;\n    instance.isMeridiem = this.format === '12h';\n    instance.showToggleModeButton = this.showToggleModeButton;\n    instance.minuteInterval = this.minuteInterval;\n    instance.orientation = this.orientation;\n    instance._dialogLabelId = this.timepickerInput.getOverlayLabelId();\n    instance._assignActions(this._actionsPortal || defaultPortal, false);\n  }\n\n  /** Opens the overlay with the timepicker. */\n  private _openOverlay(): void {\n    this._destroyOverlay();\n\n    const isDialog = this.openAs === 'dialog';\n    const portal = new ComponentPortal<MatTimepickerContent<S, T>>(\n      MatTimepickerContent,\n      this._viewContainerRef\n    );\n\n    const overlayRef = (this._overlayRef = this._overlay.create(\n      new OverlayConfig({\n        positionStrategy: isDialog\n          ? this._getDialogStrategy()\n          : this._getDropdownStrategy(),\n        hasBackdrop: true,\n        backdropClass: [\n          isDialog\n            ? 'cdk-overlay-dark-backdrop'\n            : 'mat-overlay-transparent-backdrop',\n          this._backdropHarnessClass,\n        ],\n        direction: 'ltr',\n        scrollStrategy: isDialog\n          ? this._overlay.scrollStrategies.block()\n          : this._scrollStrategy(),\n        panelClass: `mat-timepicker-${this.openAs}`,\n      })\n    ));\n\n    this._getCloseStream(overlayRef).subscribe((event) => {\n      if (event) {\n        event.preventDefault();\n      }\n      this.close();\n    });\n\n    // The `preventDefault` call happens inside the timepicker as well, however focus moves into\n    // it inside a timeout which can give browsers a chance to fire off a keyboard event in-between\n    // that can scroll the page. Always block default actions of arrow keys for the\n    // entire overlay so the page doesn't get scrolled by accident.\n    overlayRef.keydownEvents().subscribe((event) => {\n      const keyCode = event.keyCode;\n\n      if (\n        keyCode === UP_ARROW ||\n        keyCode === DOWN_ARROW ||\n        keyCode === PAGE_UP ||\n        keyCode === PAGE_DOWN\n      ) {\n        event.preventDefault();\n      }\n    });\n\n    this._componentRef = overlayRef.attach(portal);\n    this._forwardContentValues(this._componentRef.instance);\n\n    // Update the position once the timepicker has rendered. Only relevant in dropdown mode.\n    if (!isDialog) {\n      this._ngZone.onStable\n        .pipe(first())\n        .subscribe(() => overlayRef.updatePosition());\n    }\n  }\n\n  /** Destroys the current overlay. */\n  private _destroyOverlay(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = this._componentRef = null;\n    }\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDialogStrategy() {\n    return this._overlay\n      .position()\n      .global()\n      .centerHorizontally()\n      .centerVertically();\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDropdownStrategy() {\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this.timepickerInput.getConnectedOverlayOrigin())\n      .withTransformOriginOn('.mat-timepicker-content')\n      .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      .withLockedPosition();\n\n    return this._setConnectedPositions(strategy);\n  }\n\n  /** Sets the positions of the timepicker in dropdown mode based on the current configuration. */\n  private _setConnectedPositions(\n    strategy: FlexibleConnectedPositionStrategy\n  ): FlexibleConnectedPositionStrategy {\n    const primaryX = this.xPosition === 'end' ? 'end' : 'start';\n    const secondaryX = primaryX === 'start' ? 'end' : 'start';\n    const primaryY = this.yPosition === 'above' ? 'bottom' : 'top';\n    const secondaryY = primaryY === 'top' ? 'bottom' : 'top';\n\n    return strategy.withPositions([\n      {\n        originX: primaryX,\n        originY: secondaryY,\n        overlayX: primaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: primaryX,\n        originY: primaryY,\n        overlayX: primaryX,\n        overlayY: secondaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: secondaryY,\n        overlayX: secondaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: primaryY,\n        overlayX: secondaryX,\n        overlayY: secondaryY,\n      },\n    ]);\n  }\n\n  /** Gets an observable that will emit when the overlay is supposed to be closed. */\n  private _getCloseStream(\n    overlayRef: OverlayRef\n  ): Observable<void | KeyboardEvent | MouseEvent> {\n    return merge(\n      overlayRef.backdropClick(),\n      overlayRef.detachments(),\n      overlayRef.keydownEvents().pipe(\n        filter((event) => {\n          // Closing on alt + up is only valid when there's an input associated with the timepicker.\n          return (\n            (event.keyCode === ESCAPE && !hasModifierKey(event)) ||\n            (this.timepickerInput &&\n              hasModifierKey(event, 'altKey') &&\n              event.keyCode === UP_ARROW)\n          );\n        })\n      )\n    );\n  }\n}\n"]}
|
|
458
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-base.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  ComponentRef,\n  ViewContainerRef,\n  Directive,\n  NgZone,\n  Inject,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef,\n  InjectionToken,\n  Optional,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { ThemePalette } from '@angular/material/core';\nimport { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';\nimport {\n  BooleanInput,\n  coerceBooleanProperty,\n  coerceNumberProperty,\n} from '@angular/cdk/coercion';\nimport {\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollStrategy,\n} from '@angular/cdk/overlay';\nimport {\n  ComponentPortal,\n  ComponentType,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  DOWN_ARROW,\n  ESCAPE,\n  hasModifierKey,\n  PAGE_DOWN,\n  PAGE_UP,\n  UP_ARROW,\n} from '@angular/cdk/keycodes';\nimport { filter, first, merge, Observable, Subject, take } from 'rxjs';\n\nimport { MatTimepickerContent } from './timepicker-content';\nimport { MAT_TIMEPICKER_SCROLL_STRATEGY } from './timepicker-scroll-strategy';\nimport {\n  ExtractTimeTypeFromSelection,\n  MatTimeSelectionModel,\n} from './time-selection-model';\nimport { MAT_DEFAULT_ACITONS } from './timepicker-actions-default';\nimport { TimepickerOrientation } from './orientation';\n\n/** Possible options for the timepicker to open. */\nexport type TimepickerOpenAs = 'dialog' | 'popup';\n\n/** Possible positions for the timepicker dropdown along the X axis. */\nexport type TimepickerDropdownPositionX = 'start' | 'end';\n\n/** Possible positions for the timepicker dropdown along the Y axis. */\nexport type TimepickerDropdownPositionY = 'above' | 'below';\n\n/** Possible options for the timepicker to display. */\nexport type TimepickerMode = 'input' | 'dial';\n\n/** Possible options for the timepicker period format. */\nexport type TimepickerFormat = '12h' | '24h';\n\n/** Form control that can be associated with a timepicker. */\nexport interface MatTimepickerControl<T> {\n  disabled: boolean;\n  min: T | null;\n  max: T | null;\n  stateChanges: Observable<void>;\n  getThemePalette(): ThemePalette;\n  getConnectedOverlayOrigin(): ElementRef;\n  getOverlayLabelId(): string | null;\n}\n\n/** A timepicker that can be attached to a {@link MatTimepickerControl}. */\nexport interface MatTimepickerPanel<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>,\n> {\n  /** Stream that emits whenever the timepicker is opened. */\n  openedStream: EventEmitter<void>;\n  /** Stream that emits whenever the timepicker is closed. */\n  closedStream: EventEmitter<void>;\n  /** Emits when the timepicker's state changes. */\n  stateChanges: Subject<void>;\n  /** Register an input with the timeepicker. */\n  registerInput(input: C): MatTimeSelectionModel<S, T>;\n}\n\n/**\n * Represents the default options for the form field that can be configured\n * using the `MAT_TIMEPICKER_DEFAULT_OPTIONS` injection token.\n */\nexport interface MatTimepickerDefaultOptions {\n  /** Default color of the timepicker. */\n  color?: ThemePalette;\n  /** Default timepicker mode. */\n  mode: TimepickerMode;\n  /** Defines how timepicker will be appeared. */\n  openAs: TimepickerOpenAs;\n  /** Default timepicker format. */\n  format: TimepickerFormat;\n  /** Should toggle face button be visible. */\n  showToggleModeButton: boolean;\n  /** Step for minutes. */\n  minuteInterval: number;\n  /** Orientation for dial mode. */\n  orientation: TimepickerOrientation;\n}\n\n/**\n * Injection token that can be used to configure the\n * default options for all timepickers within an app.\n */\nexport const MAT_TIMEPICKER_DEFAULT_OPTIONS =\n  new InjectionToken<MatTimepickerDefaultOptions>(\n    'MAT_TIMEPICKER_DEFAULT_OPTIONS',\n  );\n\n/** Default open as used by the timepicker. */\nconst DEFAULT_OPEN_AS: TimepickerOpenAs = 'popup';\n\n/** Default mode used by the timepicker. */\nconst DEFAULT_MODE: TimepickerMode = 'dial';\n\n/** Default format used by the timepicker. */\nconst DEFAULT_FORMAT: TimepickerFormat = '12h';\n\n/** Used to generate a unique ID for each timepicker instance. */\nlet timepickerUid = 0;\n\n@Directive()\nexport abstract class MatTimepickerBase<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>,\n> implements OnChanges\n{\n  /** Whether the timepicker pop-up should be disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled === undefined && this.timepickerInput\n      ? this.timepickerInput.disabled\n      : !!this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this._disabled) {\n      this._disabled = newValue;\n      this.stateChanges.next(undefined);\n    }\n  }\n  private _disabled: boolean;\n\n  /** Whether the timepicker is open. */\n  @Input()\n  get opened(): boolean {\n    return this._opened;\n  }\n  set opened(value: BooleanInput) {\n    coerceBooleanProperty(value) ? this.open() : this.close();\n  }\n  private _opened = false;\n\n  /** Whether the timepicker mode which determines what the timepicker will be opened as. */\n  @Input()\n  get openAs(): TimepickerOpenAs {\n    return this._openAs || this._defaults?.openAs || DEFAULT_OPEN_AS;\n  }\n  set openAs(value: TimepickerOpenAs) {\n    this._openAs = value;\n  }\n  private _openAs: TimepickerOpenAs;\n\n  /** Color palette to use on the timepicker's content. */\n  @Input()\n  get color(): ThemePalette {\n    return (\n      this._color ||\n      this._defaults?.color ||\n      (this.timepickerInput\n        ? this.timepickerInput.getThemePalette()\n        : undefined)\n    );\n  }\n  set color(value: ThemePalette) {\n    this._color = value;\n  }\n  private _color: ThemePalette;\n\n  /** Timepicker display mode. */\n  @Input()\n  get mode(): TimepickerMode {\n    return this._mode || this._defaults?.mode || DEFAULT_MODE;\n  }\n  set mode(value: TimepickerMode) {\n    this._mode = value;\n  }\n  private _mode: TimepickerMode;\n\n  /** Timepicker period format. */\n  @Input()\n  get format(): TimepickerFormat {\n    return this._format || this._defaults?.format || DEFAULT_FORMAT;\n  }\n  set format(value: TimepickerFormat) {\n    this._format = value;\n  }\n  private _format: TimepickerFormat;\n\n  /** Show or hide toggle button between dial and input. */\n  @Input()\n  get showToggleModeButton(): boolean {\n    return this._showToggleModeButton;\n  }\n  set showToggleModeButton(value: boolean) {\n    this._showToggleModeButton = value;\n  }\n  private _showToggleModeButton: boolean = true;\n\n  /** Step for minutes. */\n  @Input()\n  get minuteInterval(): number {\n    return this._minuteInterval || this._defaults?.minuteInterval || 1;\n  }\n  set minuteInterval(value: number) {\n    this._minuteInterval = coerceNumberProperty(value);\n  }\n  private _minuteInterval: number;\n\n  /** Orientation for dial mode. */\n  @Input()\n  get orientation(): TimepickerOrientation {\n    return this._orientation || this._defaults?.orientation || 'vertical';\n  }\n  set orientation(value: TimepickerOrientation) {\n    this._orientation = value;\n  }\n  private _orientation: TimepickerOrientation;\n\n  /**\n   * Whether the timepicker UI is in touch mode. In touch mode elements are larger for bigger touch targets.\n   */\n  @Input({ transform: booleanAttribute })\n  get touchUi(): boolean {\n    return this._touchUi;\n  }\n  set touchUi(value: boolean) {\n    this._touchUi = coerceBooleanProperty(value);\n\n    if (value) {\n      this.openAs = 'dialog';\n    }\n  }\n  private _touchUi: boolean = false;\n\n  /** Preferred position of the timepicker in the X axis. */\n  @Input()\n  xPosition: TimepickerDropdownPositionX = 'start';\n\n  /** Preferred position of the timepicker in the Y axis. */\n  @Input()\n  yPosition: TimepickerDropdownPositionY = 'below';\n\n  /**\n   * Whether to restore focus to the previously-focused element when the timepicker is closed.\n   * Note that automatic focus restoration is an accessibility feature and it is recommended that\n   * you provide your own equivalent, if you decide to turn it off.\n   */\n  @Input({ transform: booleanAttribute })\n  restoreFocus: boolean = true;\n\n  /** Emits when the timepicker has been opened. */\n  @Output('opened') readonly openedStream = new EventEmitter<void>();\n\n  /** Emits when the timepicker has been closed. */\n  @Output('closed') readonly closedStream = new EventEmitter<void>();\n\n  /** The id for the timepicker. */\n  id: string = `mat-timepicker-${timepickerUid++}`;\n\n  /** The input element this timepicker is associated with. */\n  timepickerInput!: C;\n\n  /** Portal with projected action buttons. */\n  _actionsPortal: TemplatePortal | null = null;\n\n  /** Emits when the timepicker's state changes. */\n  readonly stateChanges = new Subject<void>();\n\n  /** A reference to the overlay into which we've rendered the timepicker. */\n  private _overlayRef: OverlayRef | null;\n\n  /** Reference to the component instance rendered in the overlay. */\n  private _componentRef!: ComponentRef<MatTimepickerContent<S, T>> | null;\n\n  /** Unique class that will be added to the backdrop so that the test harnesses can look it up. */\n  private _backdropHarnessClass = `${this.id}-backdrop`;\n\n  /** The element that was focused before the timepicker was opened. */\n  private _focusedElementBeforeOpen: HTMLElement | null = null;\n\n  private _document = inject(DOCUMENT);\n\n  /** Scroll strategy. */\n  private _scrollStrategy: () => ScrollStrategy;\n\n  /** The minimum selectable time. */\n  _getMinTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.min;\n  }\n\n  /** The maximum selectable time. */\n  _getMaxTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.max;\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _overlay: Overlay,\n    private _ngZone: NgZone,\n    @Inject(MAT_TIMEPICKER_SCROLL_STRATEGY) scrollStrategy: any,\n    @Inject(MAT_DEFAULT_ACITONS)\n    private _defaultActionsComponent: ComponentType<any>,\n    private _model: MatTimeSelectionModel<S, T>,\n    @Optional()\n    @Inject(MAT_TIMEPICKER_DEFAULT_OPTIONS)\n    private _defaults?: MatTimepickerDefaultOptions,\n  ) {\n    this._scrollStrategy = scrollStrategy;\n\n    if (_defaults) {\n      this.showToggleModeButton =\n        _defaults.showToggleModeButton !== undefined\n          ? _defaults.showToggleModeButton\n          : true;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const positionChange = changes['xPosition'] || changes['yPosition'];\n\n    if (positionChange && !positionChange.firstChange && this._overlayRef) {\n      const positionStrategy = this._overlayRef.getConfig().positionStrategy;\n\n      if (positionStrategy instanceof FlexibleConnectedPositionStrategy) {\n        this._setConnectedPositions(positionStrategy);\n\n        if (this.opened) {\n          this._overlayRef.updatePosition();\n        }\n      }\n    }\n\n    this.stateChanges.next(undefined);\n  }\n\n  ngOnDestroy() {\n    this._destroyOverlay();\n    this.close();\n    this.stateChanges.complete();\n  }\n\n  /** Opens the timepicker. */\n  open(): void {\n    if (\n      this._opened ||\n      this.disabled ||\n      this._componentRef?.instance._isAnimating\n    ) {\n      return;\n    }\n\n    if (!this.timepickerInput) {\n      throw Error(\n        'Attempted to open an MatTimepicker with no associated input.',\n      );\n    }\n\n    this._focusedElementBeforeOpen = _getFocusedElementPierceShadowDom();\n    this._openOverlay();\n    this._opened = true;\n    this.openedStream.emit();\n  }\n\n  /** Closes the timepicker. */\n  close(): void {\n    if (!this._opened || this._componentRef?.instance._isAnimating) {\n      return;\n    }\n\n    const canRestoreFocus =\n      this.restoreFocus &&\n      this._focusedElementBeforeOpen &&\n      typeof this._focusedElementBeforeOpen.focus === 'function';\n\n    const completeClose = () => {\n      // The `_opened` could've been reset already if\n      // we got two events in quick succession.\n      if (this._opened) {\n        this._opened = false;\n        this.closedStream.emit();\n      }\n    };\n\n    if (this._componentRef) {\n      const { instance, location } = this._componentRef;\n      instance._startExitAnimation();\n      instance._animationDone.pipe(take(1)).subscribe(() => {\n        const activeElement = this._document.activeElement;\n\n        // Since we restore focus after the exit animation, we have to check that\n        // the user didn't move focus themselves inside the `close` handler.\n        if (\n          canRestoreFocus &&\n          (!activeElement ||\n            activeElement === this._document.activeElement ||\n            location.nativeElement.contains(activeElement))\n        ) {\n          this._focusedElementBeforeOpen!.focus();\n        }\n\n        this._focusedElementBeforeOpen = null;\n        this._destroyOverlay();\n      });\n\n      if (canRestoreFocus) {\n        setTimeout(completeClose);\n      } else {\n        completeClose();\n      }\n    }\n  }\n\n  /**\n   * Register an input with this timepicker.\n   * @param input The timepicker input to register with this timepicker.\n   * @returns Selection model that the input should hook itself up to.\n   */\n  registerInput(input: C): MatTimeSelectionModel<S, T> {\n    if (this.timepickerInput) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single input.',\n      );\n    }\n\n    this.timepickerInput = input;\n    return this._model;\n  }\n\n  /**\n   * Registers a portal containing action buttons with the timepicker.\n   * @param portal Portal to be registered.\n   */\n  registerActions(portal: TemplatePortal): void {\n    if (this._actionsPortal) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single actions row.',\n      );\n    }\n    this._actionsPortal = portal;\n    this._componentRef?.instance._assignActions(portal, true);\n  }\n\n  /**\n   * Removes a portal containing action buttons from the timepicker.\n   * @param portal Portal to be removed.\n   */\n  removeActions(portal: TemplatePortal): void {\n    if (portal === this._actionsPortal) {\n      this._actionsPortal = null;\n      this._componentRef?.instance._assignActions(null, true);\n    }\n  }\n\n  /** Applies the current pending selection on the overlay to the model. */\n  _applyPendingSelection() {\n    this._componentRef?.instance?._applyPendingSelection();\n  }\n\n  /** Forwards relevant values from the timepicker to the timepicker content inside the overlay. */\n  protected _forwardContentValues(instance: MatTimepickerContent<S, T>): void {\n    const defaultPortal = new ComponentPortal(this._defaultActionsComponent);\n\n    instance.timepicker = this;\n    instance.color = this.color;\n    instance.mode = this.mode;\n    instance.isMeridiem = this.format === '12h';\n    instance.showToggleModeButton = this.showToggleModeButton;\n    instance.minuteInterval = this.minuteInterval;\n    instance.orientation = this.orientation;\n    instance._dialogLabelId = this.timepickerInput.getOverlayLabelId();\n    instance._assignActions(this._actionsPortal || defaultPortal, false);\n  }\n\n  /** Opens the overlay with the timepicker. */\n  private _openOverlay(): void {\n    this._destroyOverlay();\n\n    const isDialog = this.openAs === 'dialog';\n    const portal = new ComponentPortal<MatTimepickerContent<S, T>>(\n      MatTimepickerContent,\n      this._viewContainerRef,\n    );\n\n    const overlayRef = (this._overlayRef = this._overlay.create(\n      new OverlayConfig({\n        positionStrategy: isDialog\n          ? this._getDialogStrategy()\n          : this._getDropdownStrategy(),\n        hasBackdrop: true,\n        backdropClass: [\n          isDialog\n            ? 'cdk-overlay-dark-backdrop'\n            : 'mat-overlay-transparent-backdrop',\n          this._backdropHarnessClass,\n        ],\n        direction: 'ltr',\n        scrollStrategy: isDialog\n          ? this._overlay.scrollStrategies.block()\n          : this._scrollStrategy(),\n        panelClass: `mat-timepicker-${this.openAs}`,\n      }),\n    ));\n\n    this._getCloseStream(overlayRef).subscribe((event) => {\n      if (event) {\n        event.preventDefault();\n      }\n      this.close();\n    });\n\n    // The `preventDefault` call happens inside the timepicker as well, however focus moves into\n    // it inside a timeout which can give browsers a chance to fire off a keyboard event in-between\n    // that can scroll the page. Always block default actions of arrow keys for the\n    // entire overlay so the page doesn't get scrolled by accident.\n    overlayRef.keydownEvents().subscribe((event) => {\n      const keyCode = event.keyCode;\n\n      if (\n        keyCode === UP_ARROW ||\n        keyCode === DOWN_ARROW ||\n        keyCode === PAGE_UP ||\n        keyCode === PAGE_DOWN\n      ) {\n        event.preventDefault();\n      }\n    });\n\n    this._componentRef = overlayRef.attach(portal);\n    this._forwardContentValues(this._componentRef.instance);\n\n    // Update the position once the timepicker has rendered. Only relevant in dropdown mode.\n    if (!isDialog) {\n      this._ngZone.onStable\n        .pipe(first())\n        .subscribe(() => overlayRef.updatePosition());\n    }\n  }\n\n  /** Destroys the current overlay. */\n  private _destroyOverlay(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = this._componentRef = null;\n    }\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDialogStrategy() {\n    return this._overlay\n      .position()\n      .global()\n      .centerHorizontally()\n      .centerVertically();\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDropdownStrategy() {\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this.timepickerInput.getConnectedOverlayOrigin())\n      .withTransformOriginOn('.mat-timepicker-content')\n      .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      .withLockedPosition();\n\n    return this._setConnectedPositions(strategy);\n  }\n\n  /** Sets the positions of the timepicker in dropdown mode based on the current configuration. */\n  private _setConnectedPositions(\n    strategy: FlexibleConnectedPositionStrategy,\n  ): FlexibleConnectedPositionStrategy {\n    const primaryX = this.xPosition === 'end' ? 'end' : 'start';\n    const secondaryX = primaryX === 'start' ? 'end' : 'start';\n    const primaryY = this.yPosition === 'above' ? 'bottom' : 'top';\n    const secondaryY = primaryY === 'top' ? 'bottom' : 'top';\n\n    return strategy.withPositions([\n      {\n        originX: primaryX,\n        originY: secondaryY,\n        overlayX: primaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: primaryX,\n        originY: primaryY,\n        overlayX: primaryX,\n        overlayY: secondaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: secondaryY,\n        overlayX: secondaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: primaryY,\n        overlayX: secondaryX,\n        overlayY: secondaryY,\n      },\n    ]);\n  }\n\n  /** Gets an observable that will emit when the overlay is supposed to be closed. */\n  private _getCloseStream(\n    overlayRef: OverlayRef,\n  ): Observable<void | KeyboardEvent | MouseEvent> {\n    return merge(\n      overlayRef.backdropClick(),\n      overlayRef.detachments(),\n      overlayRef.keydownEvents().pipe(\n        filter((event) => {\n          // Closing on alt + up is only valid when there's an input associated with the timepicker.\n          return (\n            (event.keyCode === ESCAPE && !hasModifierKey(event)) ||\n            (this.timepickerInput &&\n              hasModifierKey(event, 'altKey') &&\n              event.keyCode === UP_ARROW)\n          );\n        }),\n      ),\n    );\n  }\n}\n"]}
|