@dhutaryan/ngx-mat-timepicker 16.3.1 → 16.4.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 +6 -9
- package/esm2022/lib/timepicker-base.mjs +71 -17
- package/esm2022/lib/timepicker-content.mjs +23 -5
- package/esm2022/lib/timepicker-input-base.mjs +35 -4
- package/esm2022/lib/timepicker-toggle.mjs +29 -5
- package/fesm2022/dhutaryan-ngx-mat-timepicker.mjs +167 -59
- package/fesm2022/dhutaryan-ngx-mat-timepicker.mjs.map +1 -1
- package/lib/timepicker-base.d.ts +24 -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
|
@@ -38,18 +38,16 @@ export class MatClockDials extends MatTimeFaceBase {
|
|
|
38
38
|
focusActiveCell() {
|
|
39
39
|
this._ngZone.runOutsideAngular(() => {
|
|
40
40
|
this._ngZone.onStable.pipe(take(1)).subscribe(() => {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
if
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
}
|
|
52
|
-
}, 50);
|
|
41
|
+
const activeCell = this._elementRef.nativeElement.querySelector('.mat-timepicker-content .mat-clock-dial-cell-active');
|
|
42
|
+
if (activeCell) {
|
|
43
|
+
activeCell.focus();
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const activePoint = this._elementRef.nativeElement.querySelector('.mat-timepicker-content .mat-clock-dial-hand-point');
|
|
47
|
+
if (activePoint) {
|
|
48
|
+
// if no active cell we need to focus a small dot
|
|
49
|
+
activePoint.focus();
|
|
50
|
+
}
|
|
53
51
|
});
|
|
54
52
|
});
|
|
55
53
|
}
|
|
@@ -85,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
85
83
|
}] }, { type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { orientation: [{
|
|
86
84
|
type: Input
|
|
87
85
|
}] } });
|
|
88
|
-
//# 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 { 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';\n\nexport type MatDialView = 'hours' | 'minutes';\n\n@Component({\n  selector: 'mat-clock-dials',\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  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\n  [title]=\"_intl.dialsTitle\"\n  [orientation]=\"orientation\"\n>\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    <ng-template [ngIf]=\"isHoursView\">\n      <mat-hours-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedHour]=\"selectedHour\"\n        [isMeridiem]=\"isMeridiem\"\n        [availableHours]=\"_getAvailableHours()\"\n        (selectedChange)=\"_onHourChanged($event)\"\n        (keydown)=\"_onKeydown($event, 'hour')\"\n      ></mat-hours-clock-dial>\n    </ng-template>\n    <ng-template [ngIf]=\"!isHoursView\">\n      <mat-minutes-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedMinute]=\"selectedMinute\"\n        [interval]=\"minuteInterval\"\n        [availableMinutes]=\"availableMinutes\"\n        (selectedChange)=\"_onMinuteSelected($event)\"\n        (keydown)=\"_onKeydown($event, 'minute')\"\n      ></mat-minutes-clock-dial>\n    </ng-template>\n  </div>\n</mat-timepicker-content-layout>\n"]}
|
|
86
|
+
//# 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 { 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';\n\nexport type MatDialView = 'hours' | 'minutes';\n\n@Component({\n  selector: 'mat-clock-dials',\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  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\n  [title]=\"_intl.dialsTitle\"\n  [orientation]=\"orientation\"\n>\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    <ng-template [ngIf]=\"isHoursView\">\n      <mat-hours-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedHour]=\"selectedHour\"\n        [isMeridiem]=\"isMeridiem\"\n        [availableHours]=\"_getAvailableHours()\"\n        (selectedChange)=\"_onHourChanged($event)\"\n        (keydown)=\"_onKeydown($event, 'hour')\"\n      ></mat-hours-clock-dial>\n    </ng-template>\n    <ng-template [ngIf]=\"!isHoursView\">\n      <mat-minutes-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedMinute]=\"selectedMinute\"\n        [interval]=\"minuteInterval\"\n        [availableMinutes]=\"availableMinutes\"\n        (selectedChange)=\"_onMinuteSelected($event)\"\n        (keydown)=\"_onKeydown($event, 'minute')\"\n      ></mat-minutes-clock-dial>\n    </ng-template>\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: "16.2.5", 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=
|
|
@@ -145,14 +145,11 @@ export class MatTimeInputs extends MatTimeFaceBase {
|
|
|
145
145
|
focusActiveCell() {
|
|
146
146
|
this._ngZone.runOutsideAngular(() => {
|
|
147
147
|
this._ngZone.onStable.pipe(take(1)).subscribe(() => {
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
);
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
this._skipNextTickFocus = true;
|
|
154
|
-
}
|
|
155
|
-
});
|
|
148
|
+
const activeCell = this._elementRef.nativeElement.querySelector('.mat-timepicker-content input');
|
|
149
|
+
if (activeCell && !this._skipNextTickFocus) {
|
|
150
|
+
activeCell.focus();
|
|
151
|
+
this._skipNextTickFocus = true;
|
|
152
|
+
}
|
|
156
153
|
});
|
|
157
154
|
});
|
|
158
155
|
}
|
|
@@ -167,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
167
164
|
}], ctorParameters: function () { return [{ type: i1.MatTimepickerIntl }, { type: i2.TimeAdapter, decorators: [{
|
|
168
165
|
type: Optional
|
|
169
166
|
}] }, { type: i0.NgZone }, { type: i0.ElementRef }]; } });
|
|
170
|
-
//# 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 { 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 { 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';\n\n@Directive({\n  selector: 'input[matHourInput]',\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  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  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 =\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}\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"]}
|
|
167
|
+
//# 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 { 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 { 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';\n\n@Directive({\n  selector: 'input[matHourInput]',\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  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  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, } from '@angular/core';
|
|
1
|
+
import { Input, Directive, Inject, Output, EventEmitter, InjectionToken, Optional, 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. */
|
|
@@ -96,6 +99,17 @@ export class MatTimepickerBase {
|
|
|
96
99
|
set orientation(value) {
|
|
97
100
|
this._orientation = value;
|
|
98
101
|
}
|
|
102
|
+
/**
|
|
103
|
+
* Whether to restore focus to the previously-focused element when the timepicker is closed.
|
|
104
|
+
* Note that automatic focus restoration is an accessibility feature and it is recommended that
|
|
105
|
+
* you provide your own equivalent, if you decide to turn it off.
|
|
106
|
+
*/
|
|
107
|
+
get restoreFocus() {
|
|
108
|
+
return this._restoreFocus;
|
|
109
|
+
}
|
|
110
|
+
set restoreFocus(value) {
|
|
111
|
+
this._restoreFocus = coerceBooleanProperty(value);
|
|
112
|
+
}
|
|
99
113
|
/** The minimum selectable time. */
|
|
100
114
|
_getMinTime() {
|
|
101
115
|
return this.timepickerInput && this.timepickerInput.min;
|
|
@@ -117,14 +131,22 @@ export class MatTimepickerBase {
|
|
|
117
131
|
this.xPosition = 'start';
|
|
118
132
|
/** Preferred position of the timepicker in the Y axis. */
|
|
119
133
|
this.yPosition = 'below';
|
|
134
|
+
this._restoreFocus = true;
|
|
135
|
+
/** Emits when the timepicker has been opened. */
|
|
136
|
+
this.openedStream = new EventEmitter();
|
|
120
137
|
/** Emits when the timepicker has been closed. */
|
|
121
138
|
this.closedStream = new EventEmitter();
|
|
122
139
|
/** The id for the timepicker. */
|
|
123
140
|
this.id = `mat-timepicker-${timepickerUid++}`;
|
|
124
141
|
/** Portal with projected action buttons. */
|
|
125
142
|
this._actionsPortal = null;
|
|
143
|
+
/** Emits when the timepicker's state changes. */
|
|
144
|
+
this.stateChanges = new Subject();
|
|
126
145
|
/** Unique class that will be added to the backdrop so that the test harnesses can look it up. */
|
|
127
146
|
this._backdropHarnessClass = `${this.id}-backdrop`;
|
|
147
|
+
/** The element that was focused before the timepicker was opened. */
|
|
148
|
+
this._focusedElementBeforeOpen = null;
|
|
149
|
+
this._document = inject(DOCUMENT);
|
|
128
150
|
this._scrollStrategy = scrollStrategy;
|
|
129
151
|
if (_defaults) {
|
|
130
152
|
this.showToggleModeButton =
|
|
@@ -144,39 +166,66 @@ export class MatTimepickerBase {
|
|
|
144
166
|
}
|
|
145
167
|
}
|
|
146
168
|
}
|
|
169
|
+
this.stateChanges.next(undefined);
|
|
147
170
|
}
|
|
148
171
|
ngOnDestroy() {
|
|
149
172
|
this._destroyOverlay();
|
|
150
173
|
this.close();
|
|
174
|
+
this.stateChanges.complete();
|
|
151
175
|
}
|
|
152
176
|
/** Opens the timepicker. */
|
|
153
177
|
open() {
|
|
154
|
-
if (this._opened ||
|
|
178
|
+
if (this._opened ||
|
|
179
|
+
this.disabled ||
|
|
180
|
+
this._componentRef?.instance._isAnimating) {
|
|
155
181
|
return;
|
|
156
182
|
}
|
|
157
183
|
if (!this.timepickerInput) {
|
|
158
184
|
throw Error('Attempted to open an MatTimepicker with no associated input.');
|
|
159
185
|
}
|
|
186
|
+
this._focusedElementBeforeOpen = _getFocusedElementPierceShadowDom();
|
|
160
187
|
this._openOverlay();
|
|
161
188
|
this._opened = true;
|
|
189
|
+
this.openedStream.emit();
|
|
162
190
|
}
|
|
163
191
|
/** Closes the timepicker. */
|
|
164
192
|
close() {
|
|
165
|
-
if (!this._opened) {
|
|
193
|
+
if (!this._opened || this._componentRef?.instance._isAnimating) {
|
|
166
194
|
return;
|
|
167
195
|
}
|
|
196
|
+
const canRestoreFocus = this.restoreFocus &&
|
|
197
|
+
this._focusedElementBeforeOpen &&
|
|
198
|
+
typeof this._focusedElementBeforeOpen.focus === 'function';
|
|
199
|
+
const completeClose = () => {
|
|
200
|
+
// The `_opened` could've been reset already if
|
|
201
|
+
// we got two events in quick succession.
|
|
202
|
+
if (this._opened) {
|
|
203
|
+
this._opened = false;
|
|
204
|
+
this.closedStream.emit();
|
|
205
|
+
}
|
|
206
|
+
};
|
|
168
207
|
if (this._componentRef) {
|
|
169
|
-
const instance = this._componentRef
|
|
170
|
-
instance.
|
|
171
|
-
instance._animationDone
|
|
172
|
-
.
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
208
|
+
const { instance, location } = this._componentRef;
|
|
209
|
+
instance._startExitAnimation();
|
|
210
|
+
instance._animationDone.pipe(take(1)).subscribe(() => {
|
|
211
|
+
const activeElement = this._document.activeElement;
|
|
212
|
+
// Since we restore focus after the exit animation, we have to check that
|
|
213
|
+
// the user didn't move focus themselves inside the `close` handler.
|
|
214
|
+
if (canRestoreFocus &&
|
|
215
|
+
(!activeElement ||
|
|
216
|
+
activeElement === this._document.activeElement ||
|
|
217
|
+
location.nativeElement.contains(activeElement))) {
|
|
218
|
+
this._focusedElementBeforeOpen.focus();
|
|
219
|
+
}
|
|
220
|
+
this._focusedElementBeforeOpen = null;
|
|
221
|
+
this._destroyOverlay();
|
|
222
|
+
});
|
|
223
|
+
if (canRestoreFocus) {
|
|
224
|
+
setTimeout(completeClose);
|
|
225
|
+
}
|
|
226
|
+
else {
|
|
227
|
+
completeClose();
|
|
228
|
+
}
|
|
180
229
|
}
|
|
181
230
|
}
|
|
182
231
|
/**
|
|
@@ -349,7 +398,7 @@ export class MatTimepickerBase {
|
|
|
349
398
|
})));
|
|
350
399
|
}
|
|
351
400
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", 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 }); }
|
|
352
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: MatTimepickerBase, inputs: { disabled: "disabled", opened: "opened", openAs: "openAs", color: "color", mode: "mode", format: "format", showToggleModeButton: "showToggleModeButton", minuteInterval: "minuteInterval", orientation: "orientation", xPosition: "xPosition", yPosition: "yPosition" }, outputs: { closedStream: "closed" }, usesOnChanges: true, ngImport: i0 }); }
|
|
401
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: MatTimepickerBase, inputs: { disabled: "disabled", opened: "opened", openAs: "openAs", color: "color", mode: "mode", format: "format", showToggleModeButton: "showToggleModeButton", minuteInterval: "minuteInterval", orientation: "orientation", xPosition: "xPosition", yPosition: "yPosition", restoreFocus: "restoreFocus" }, outputs: { openedStream: "opened", closedStream: "closed" }, usesOnChanges: true, ngImport: i0 }); }
|
|
353
402
|
}
|
|
354
403
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatTimepickerBase, decorators: [{
|
|
355
404
|
type: Directive
|
|
@@ -386,8 +435,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
386
435
|
type: Input
|
|
387
436
|
}], yPosition: [{
|
|
388
437
|
type: Input
|
|
438
|
+
}], restoreFocus: [{
|
|
439
|
+
type: Input
|
|
440
|
+
}], openedStream: [{
|
|
441
|
+
type: Output,
|
|
442
|
+
args: ['opened']
|
|
389
443
|
}], closedStream: [{
|
|
390
444
|
type: Output,
|
|
391
445
|
args: ['closed']
|
|
392
446
|
}] } });
|
|
393
|
-
//# 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} 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  /** 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"]}
|
|
447
|
+
//# 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  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  /** 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()\n  get restoreFocus(): boolean {\n    return this._restoreFocus;\n  }\n  set restoreFocus(value: BooleanInput) {\n    this._restoreFocus = coerceBooleanProperty(value);\n  }\n  private _restoreFocus = 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"]}
|