@matheo/datepicker
Version:
Angular material date+time picker
305 lines • 50.7 kB
JavaScript
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewEncapsulation, } from '@angular/core';
import { MAT_DATE_FORMATS } from '@angular/material/core';
import { DateAdapter, } from '@matheo/datepicker/core';
import { createMissingDateImplError } from './datepicker-errors';
import * as i0 from "@angular/core";
import * as i1 from "@matheo/datepicker/core";
import * as i2 from "@angular/common";
export const CLOCK_RADIUS = 50;
export const CLOCK_INNER_RADIUS = 27.5;
export const CLOCK_OUTER_RADIUS = 41.25;
export const CLOCK_TICK_RADIUS = 7.0833;
/**
* A clock that is used as part of the datepicker.
* @docs-private
*/
export class MatClockView {
constructor(_changeDetectorRef, _element, _dateAdapter, _dateFormats) {
this._changeDetectorRef = _changeDetectorRef;
this._element = _element;
this._dateAdapter = _dateAdapter;
this._dateFormats = _dateFormats;
this.clockStep = 1;
this.twelveHour = false;
this.currentViewChange = new EventEmitter();
/** Emits when a new date is selected. */
this.selectedChange = new EventEmitter();
/** Emits when any date is selected. */
this._userSelection = new EventEmitter();
// Hours and Minutes representing the clock view.
this._hours = [];
this._minutes = [];
if (!this._dateAdapter) {
throw createMissingDateImplError('DateAdapter');
}
if (!this._dateFormats) {
throw createMissingDateImplError('MAT_DATE_FORMATS');
}
this.mouseMoveListener = (event) => {
this._handleMousemove(event);
};
this.mouseUpListener = () => {
this._handleMouseup();
};
}
/**
* The time to display in this clock view. (the rest is ignored)
*/
get activeDate() {
return this._activeDate;
}
set activeDate(value) {
const oldActiveDate = this._activeDate;
const validDate = this._getValidDateOrNull(this._dateAdapter.deserialize(value)) ||
this._dateAdapter.today();
this._activeDate = this._dateAdapter.clampDate(validDate, this.minDate, this.maxDate);
if (oldActiveDate &&
this._dateAdapter.compareDate(oldActiveDate, this._activeDate)) {
this._init();
}
}
// The currently selected date.
get selected() {
return this._selected;
}
set selected(value) {
this._selected = this._getValidDateOrNull(this._dateAdapter.deserialize(value));
}
/** The minimum selectable date. */
get minDate() {
return this._minDate;
}
set minDate(value) {
this._minDate = this._getValidDateOrNull(this._dateAdapter.deserialize(value));
}
/** The maximum selectable date. */
get maxDate() {
return this._maxDate;
}
set maxDate(value) {
this._maxDate = this._getValidDateOrNull(this._dateAdapter.deserialize(value));
}
updateSize() {
const { offsetWidth, offsetHeight } = this._element.nativeElement;
this._size = (offsetWidth < offsetHeight ? offsetWidth : offsetHeight) * 0.9;
this._changeDetectorRef.detectChanges();
}
get inHourView() {
return this.currentView === 'hour';
}
get _hand() {
this._selectedHour = this._dateAdapter.getHours(this.activeDate);
this._selectedMinute = this._dateAdapter.getMinutes(this.activeDate);
let radius = CLOCK_OUTER_RADIUS;
let deg = 0;
if (this.inHourView) {
const outer = this.twelveHour || this._selectedHour >= 0 && this._selectedHour < 12;
radius = outer ? CLOCK_OUTER_RADIUS : CLOCK_INNER_RADIUS;
deg = Math.round(this._selectedHour * (360 / (24 / 2)));
}
else {
deg = Math.round(this._selectedMinute * (360 / 60));
}
return {
transform: `rotate(${deg}deg)`,
height: `${radius}%`,
'margin-top': `${50 - radius}%`,
transition: this._draggingMouse ? 'none' : 'all 300ms ease',
};
}
ngAfterViewInit() {
this.updateSize();
}
ngAfterContentInit() {
this._init();
}
// Handles mousedown events on the clock body.
_handleMousedown(event) {
this._draggingMouse = true;
document.addEventListener('mousemove', this.mouseMoveListener);
document.addEventListener('touchmove', this.mouseMoveListener);
document.addEventListener('mouseup', this.mouseUpListener);
document.addEventListener('touchend', this.mouseUpListener);
this.setTime(event);
}
_handleMousemove(event) {
event.preventDefault();
this.setTime(event);
}
_handleMouseup() {
this._draggingMouse = false;
document.removeEventListener('mousemove', this.mouseMoveListener);
document.removeEventListener('touchmove', this.mouseMoveListener);
document.removeEventListener('mouseup', this.mouseUpListener);
document.removeEventListener('touchend', this.mouseUpListener);
if (this.dateFilter && !this.dateFilter(this.activeDate, this.currentView)) {
return;
}
if (this.inHourView) {
// we refresh the valid minutes
this.currentViewChange.emit('minute');
this.selectedChange.emit(this.activeDate);
this._init();
}
else {
this._userSelection.emit({ value: this.activeDate, event });
}
}
// Initializes this clock view.
_init() {
this._hours.length = 0;
this._minutes.length = 0;
const hourNames = this._dateAdapter.getHourNames();
const minuteNames = this._dateAdapter.getMinuteNames();
if (this.twelveHour) {
this._anteMeridian = this._dateAdapter.getHours(this.activeDate) < 12;
for (let i = 0; i < hourNames.length / 2; i++) {
const radian = (i / 6) * Math.PI;
const radius = CLOCK_OUTER_RADIUS;
const date = this._dateAdapter.createDate(this._dateAdapter.getYear(this.activeDate), this._dateAdapter.getMonth(this.activeDate), this._dateAdapter.getDate(this.activeDate), this._anteMeridian ? i : i + 12, 0, 0, 0);
this._hours.push({
value: this._anteMeridian ? i : i + 12,
displayValue: i === 0 ? hourNames[12] : hourNames[i],
enabled: !this.dateFilter || this.dateFilter(date, 'hour'),
cssClasses: this.dateClass ? this.dateClass(date, 'hour') : undefined,
top: CLOCK_RADIUS - Math.cos(radian) * radius - CLOCK_TICK_RADIUS,
left: CLOCK_RADIUS + Math.sin(radian) * radius - CLOCK_TICK_RADIUS,
});
}
}
else {
for (let i = 0; i < hourNames.length; i++) {
const radian = (i / 6) * Math.PI;
const outer = i > 0 && i < 13;
const radius = outer ? CLOCK_OUTER_RADIUS : CLOCK_INNER_RADIUS;
const hour = i % 12 ? i : (i === 0 ? 12 : 0);
const date = this._dateAdapter.createDate(this._dateAdapter.getYear(this.activeDate), this._dateAdapter.getMonth(this.activeDate), this._dateAdapter.getDate(this.activeDate), hour, 0, 0, 0);
this._hours.push({
value: hour,
displayValue: hourNames[hour],
enabled: !this.dateFilter || this.dateFilter(date, 'hour'),
cssClasses: this.dateClass ? this.dateClass(date, 'hour') : undefined,
top: CLOCK_RADIUS - Math.cos(radian) * radius - CLOCK_TICK_RADIUS,
left: CLOCK_RADIUS + Math.sin(radian) * radius - CLOCK_TICK_RADIUS,
fontSize: i > 0 && i < 13 ? '' : '80%',
});
}
}
for (let i = 0; i < minuteNames.length; i += 5) {
const radian = (i / 30) * Math.PI;
const date = this._dateAdapter.createDate(this._dateAdapter.getYear(this.activeDate), this._dateAdapter.getMonth(this.activeDate), this._dateAdapter.getDate(this.activeDate), this._dateAdapter.getHours(this.activeDate), i, 0, 0);
this._minutes.push({
value: i,
displayValue: i === 0 ? '00' : minuteNames[i],
enabled: !this.dateFilter || this.dateFilter(date, 'minute'),
cssClasses: this.dateClass ? this.dateClass(date, 'minute') : undefined,
top: CLOCK_RADIUS -
Math.cos(radian) * CLOCK_OUTER_RADIUS -
CLOCK_TICK_RADIUS,
left: CLOCK_RADIUS +
Math.sin(radian) * CLOCK_OUTER_RADIUS -
CLOCK_TICK_RADIUS,
});
}
this._changeDetectorRef.markForCheck();
}
// Set Time
setTime(event) {
const trigger = this._element.nativeElement;
const triggerRect = trigger.getBoundingClientRect();
const width = trigger.offsetWidth;
const height = trigger.offsetHeight;
const pageX = event.pageX !== undefined ? event.pageX : event.touches[0].pageX;
const pageY = event.pageY !== undefined ? event.pageY : event.touches[0].pageY;
const x = width / 2 - (pageX - triggerRect.left - window.pageXOffset);
const y = height / 2 - (pageY - triggerRect.top - window.pageYOffset);
const unit = Math.PI /
(this.inHourView ? 6 : this.clockStep ? 30 / this.clockStep : 30);
const z = Math.sqrt(x * x + y * y);
const avg = (width * (CLOCK_OUTER_RADIUS / 100) + width * (CLOCK_INNER_RADIUS / 100)) / 2;
const outer = this.inHourView && z > avg - 16 /* button radius */;
let radian = Math.atan2(-x, y);
if (radian < 0) {
radian = Math.PI * 2 + radian;
}
let value = Math.round(radian / unit);
let date = this._dateAdapter.clone(this.activeDate);
if (this.inHourView) {
if (value === 12) {
value = 0;
}
value = this.twelveHour
? (this._anteMeridian ? value : value + 12)
: (outer ? value : value + 12);
date = this._dateAdapter.setHours(date, value);
}
else {
if (this.clockStep) {
value *= this.clockStep;
}
if (value === 60) {
value = 0;
}
date = this._dateAdapter.setMinutes(date, value);
}
// validate if the resulting value is disabled and do not take action
if (this.dateFilter && !this.dateFilter(date, this.currentView)) {
return;
}
// we don't want to re-render the clock
this._activeDate = date;
this.selectedChange.emit(this.activeDate);
}
_focusActiveCell() { }
/**
* @param obj The object to check.
* @returns The given object if it is both a date instance and valid, otherwise null.
*/
_getValidDateOrNull(obj) {
return this._dateAdapter.isDateInstance(obj) && this._dateAdapter.isValid(obj) ? obj : null;
}
}
/** @nocollapse */ /** @nocollapse */ MatClockView.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: MatClockView, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.DateAdapter, optional: true }, { token: MAT_DATE_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ /** @nocollapse */ MatClockView.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: MatClockView, selector: "mat-clock-view", inputs: { activeDate: "activeDate", selected: "selected", minDate: "minDate", maxDate: "maxDate", dateFilter: "dateFilter", dateClass: "dateClass", clockStep: "clockStep", twelveHour: "twelveHour", currentView: "currentView" }, outputs: { currentViewChange: "currentViewChange", selectedChange: "selectedChange", _userSelection: "_userSelection" }, host: { attributes: { "role": "clock" }, listeners: { "mousedown": "_handleMousedown($event)", "window:resize": "updateSize()" } }, exportAs: ["matClockView"], ngImport: i0, template: "<div class=\"mat-clock\" [style.width.px]=\"_size\" [style.height.px]=\"_size\">\n <div class=\"mat-clock-center\"></div>\n <div class=\"mat-clock-hand\" [ngStyle]=\"_hand\"></div>\n\n <div class=\"mat-clock-hours\" [class.active]=\"inHourView\">\n <div *ngFor=\"let item of _hours\"\n class=\"mat-clock-cell\"\n [ngClass]=\"item.cssClasses\"\n [class.mat-clock-cell-selected]=\"_selectedHour == item.value\"\n [class.mat-clock-cell-disabled]=\"!item.enabled\"\n [style.top.%]=\"item.top\"\n [style.left.%]=\"item.left\"\n [style.fontSize]=\"item.fontSize\">\n {{ item.displayValue }}\n </div>\n </div>\n\n <div class=\"mat-clock-minutes\" [class.active]=\"!inHourView\">\n <div *ngFor=\"let item of _minutes\"\n class=\"mat-clock-cell\"\n [ngClass]=\"item.cssClasses\"\n [class.mat-clock-cell-selected]=\"_selectedMinute == item.value\"\n [class.mat-clock-cell-disabled]=\"!item.enabled\"\n [style.top.%]=\"item.top\"\n [style.left.%]=\"item.left\">\n {{ item.displayValue }}\n </div>\n </div>\n</div>\n", directives: [{ type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: MatClockView, decorators: [{
type: Component,
args: [{ selector: 'mat-clock-view', exportAs: 'matClockView', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
role: 'clock',
'(mousedown)': '_handleMousedown($event)'
}, preserveWhitespaces: false, template: "<div class=\"mat-clock\" [style.width.px]=\"_size\" [style.height.px]=\"_size\">\n <div class=\"mat-clock-center\"></div>\n <div class=\"mat-clock-hand\" [ngStyle]=\"_hand\"></div>\n\n <div class=\"mat-clock-hours\" [class.active]=\"inHourView\">\n <div *ngFor=\"let item of _hours\"\n class=\"mat-clock-cell\"\n [ngClass]=\"item.cssClasses\"\n [class.mat-clock-cell-selected]=\"_selectedHour == item.value\"\n [class.mat-clock-cell-disabled]=\"!item.enabled\"\n [style.top.%]=\"item.top\"\n [style.left.%]=\"item.left\"\n [style.fontSize]=\"item.fontSize\">\n {{ item.displayValue }}\n </div>\n </div>\n\n <div class=\"mat-clock-minutes\" [class.active]=\"!inHourView\">\n <div *ngFor=\"let item of _minutes\"\n class=\"mat-clock-cell\"\n [ngClass]=\"item.cssClasses\"\n [class.mat-clock-cell-selected]=\"_selectedMinute == item.value\"\n [class.mat-clock-cell-disabled]=\"!item.enabled\"\n [style.top.%]=\"item.top\"\n [style.left.%]=\"item.left\">\n {{ item.displayValue }}\n </div>\n </div>\n</div>\n" }]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.DateAdapter, decorators: [{
type: Optional
}] }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [MAT_DATE_FORMATS]
}] }]; }, propDecorators: { activeDate: [{
type: Input
}], selected: [{
type: Input
}], minDate: [{
type: Input
}], maxDate: [{
type: Input
}], dateFilter: [{
type: Input
}], dateClass: [{
type: Input
}], clockStep: [{
type: Input
}], twelveHour: [{
type: Input
}], currentView: [{
type: Input
}], currentViewChange: [{
type: Output
}], selectedChange: [{
type: Output
}], _userSelection: [{
type: Output
}], updateSize: [{
type: HostListener,
args: ['window:resize']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clock-view.js","sourceRoot":"","sources":["../../../../../libs/datepicker/src/lib/clock-view.ts","../../../../../libs/datepicker/src/lib/clock-view.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {MAT_DATE_FORMATS} from '@angular/material/core';\nimport {\n  DateAdapter,\n  MatDateFormats,\n} from '@matheo/datepicker/core';\nimport {MatCalendarCellClassFunction, MatCalendarUserEvent} from './calendar-body';\nimport {createMissingDateImplError} from './datepicker-errors';\nimport {DateFilterFn} from './datepicker-input-base';\n\nexport const CLOCK_RADIUS = 50;\nexport const CLOCK_INNER_RADIUS = 27.5;\nexport const CLOCK_OUTER_RADIUS = 41.25;\nexport const CLOCK_TICK_RADIUS = 7.0833;\n\nexport type ClockView = 'hour' | 'minute';\n\n/**\n * A clock that is used as part of the datepicker.\n * @docs-private\n */\n@Component({\n  selector: 'mat-clock-view',\n  templateUrl: 'clock-view.html',\n  exportAs: 'matClockView',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    role: 'clock',\n    '(mousedown)': '_handleMousedown($event)'\n  },\n  preserveWhitespaces: false\n})\nexport class MatClockView<D> implements AfterViewInit, AfterContentInit {\n  /**\n   * The time to display in this clock view. (the rest is ignored)\n   */\n  @Input()\n  get activeDate(): D {\n    return this._activeDate;\n  }\n  set activeDate(value: D) {\n    const oldActiveDate = this._activeDate;\n    const validDate =\n      this._getValidDateOrNull(this._dateAdapter.deserialize(value)) ||\n      this._dateAdapter.today();\n    this._activeDate = this._dateAdapter.clampDate(\n      validDate,\n      this.minDate,\n      this.maxDate\n    );\n\n    if (\n      oldActiveDate &&\n      this._dateAdapter.compareDate(oldActiveDate, this._activeDate)\n    ) {\n      this._init();\n    }\n  }\n  private _activeDate: D;\n\n  // The currently selected date.\n  @Input()\n  get selected(): D | null {\n    return this._selected;\n  }\n  set selected(value: D | null) {\n    this._selected = this._getValidDateOrNull(\n      this._dateAdapter.deserialize(value)\n    );\n  }\n  private _selected: D | null;\n\n  /** The minimum selectable date. */\n  @Input()\n  get minDate(): D | null {\n    return this._minDate;\n  }\n  set minDate(value: D | null) {\n    this._minDate = this._getValidDateOrNull(\n      this._dateAdapter.deserialize(value)\n    );\n  }\n  private _minDate: D | null;\n\n  /** The maximum selectable date. */\n  @Input()\n  get maxDate(): D | null {\n    return this._maxDate;\n  }\n  set maxDate(value: D | null) {\n    this._maxDate = this._getValidDateOrNull(\n      this._dateAdapter.deserialize(value)\n    );\n  }\n  private _maxDate: D | null;\n\n  // A function used to filter which dates are selectable.\n  @Input() dateFilter: DateFilterFn<D>;\n\n  /** Function that can be used to add custom CSS classes to dates. */\n  @Input() dateClass: MatCalendarCellClassFunction<D>;\n\n  @Input() clockStep: number = 1;\n\n  @Input() twelveHour: Boolean = false;\n\n  @Input() currentView: ClockView;\n\n  @Output() currentViewChange = new EventEmitter<ClockView>();\n\n  /** Emits when a new date is selected. */\n  @Output()\n  readonly selectedChange: EventEmitter<D | null> = new EventEmitter<D | null>();\n\n  /** Emits when any date is selected. */\n  @Output() readonly _userSelection = new EventEmitter<MatCalendarUserEvent<D | null>>();\n\n  @HostListener('window:resize')\n  updateSize() {\n    const { offsetWidth, offsetHeight } = this._element.nativeElement;\n    this._size = (offsetWidth < offsetHeight ? offsetWidth : offsetHeight) * 0.9;\n    this._changeDetectorRef.detectChanges();\n  }\n\n  // Hours and Minutes representing the clock view.\n  _hours: any[] = [];\n  _minutes: any[] = [];\n\n  _draggingMouse: boolean;\n  _selectedHour: number | null;\n  _selectedMinute: number | null;\n  _anteMeridian: boolean;\n  _size: number;\n\n  private mouseMoveListener: any;\n  private mouseUpListener: any;\n\n  get inHourView(): boolean {\n    return this.currentView === 'hour';\n  }\n\n  get _hand(): any {\n    this._selectedHour = this._dateAdapter.getHours(this.activeDate);\n    this._selectedMinute = this._dateAdapter.getMinutes(this.activeDate);\n    let radius = CLOCK_OUTER_RADIUS;\n    let deg = 0;\n\n    if (this.inHourView) {\n      const outer = this.twelveHour || this._selectedHour >= 0 && this._selectedHour < 12;\n      radius = outer ? CLOCK_OUTER_RADIUS : CLOCK_INNER_RADIUS;\n      deg = Math.round(this._selectedHour * (360 / (24 / 2)));\n    } else {\n      deg = Math.round(this._selectedMinute * (360 / 60));\n    }\n\n    return {\n      transform: `rotate(${deg}deg)`,\n      height: `${radius}%`,\n      'margin-top': `${50 - radius}%`,\n      transition: this._draggingMouse ? 'none' : 'all 300ms ease',\n    };\n  }\n\n  constructor(\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _element: ElementRef,\n    @Optional() public _dateAdapter: DateAdapter<D>,\n    @Optional()\n    @Inject(MAT_DATE_FORMATS)\n    private _dateFormats: MatDateFormats\n  ) {\n    if (!this._dateAdapter) {\n      throw createMissingDateImplError('DateAdapter');\n    }\n    if (!this._dateFormats) {\n      throw createMissingDateImplError('MAT_DATE_FORMATS');\n    }\n\n    this.mouseMoveListener = (event: any) => {\n      this._handleMousemove(event);\n    };\n    this.mouseUpListener = () => {\n      this._handleMouseup();\n    };\n  }\n\n  ngAfterViewInit() {\n    this.updateSize();\n  }\n\n  ngAfterContentInit() {\n    this._init();\n  }\n\n  // Handles mousedown events on the clock body.\n  _handleMousedown(event: any) {\n    this._draggingMouse = true;\n    document.addEventListener('mousemove', this.mouseMoveListener);\n    document.addEventListener('touchmove', this.mouseMoveListener);\n    document.addEventListener('mouseup', this.mouseUpListener);\n    document.addEventListener('touchend', this.mouseUpListener);\n    this.setTime(event);\n  }\n\n  _handleMousemove(event: any) {\n    event.preventDefault();\n    this.setTime(event);\n  }\n\n  _handleMouseup() {\n    this._draggingMouse = false;\n    document.removeEventListener('mousemove', this.mouseMoveListener);\n    document.removeEventListener('touchmove', this.mouseMoveListener);\n    document.removeEventListener('mouseup', this.mouseUpListener);\n    document.removeEventListener('touchend', this.mouseUpListener);\n\n    if (this.dateFilter && !this.dateFilter(this.activeDate, this.currentView)) {\n      return;\n    }\n\n    if (this.inHourView) {\n      // we refresh the valid minutes\n      this.currentViewChange.emit('minute');\n      this.selectedChange.emit(this.activeDate);\n      this._init();\n    } else {\n      this._userSelection.emit({ value: this.activeDate, event });\n    }\n  }\n\n  // Initializes this clock view.\n  _init() {\n    this._hours.length = 0;\n    this._minutes.length = 0;\n\n    const hourNames = this._dateAdapter.getHourNames();\n    const minuteNames = this._dateAdapter.getMinuteNames();\n\n    if (this.twelveHour) {\n      this._anteMeridian = this._dateAdapter.getHours(this.activeDate) < 12;\n\n      for (let i = 0; i < hourNames.length / 2; i++) {\n        const radian = (i / 6) * Math.PI;\n        const radius = CLOCK_OUTER_RADIUS;\n        const date = this._dateAdapter.createDate(\n          this._dateAdapter.getYear(this.activeDate),\n          this._dateAdapter.getMonth(this.activeDate),\n          this._dateAdapter.getDate(this.activeDate),\n          this._anteMeridian ? i : i + 12,\n          0,\n          0,\n          0\n        );\n        this._hours.push({\n          value: this._anteMeridian ? i : i + 12,\n          displayValue: i === 0 ? hourNames[12] : hourNames[i],\n          enabled: !this.dateFilter || this.dateFilter(date, 'hour'),\n          cssClasses: this.dateClass ? this.dateClass(date, 'hour') : undefined,\n          top: CLOCK_RADIUS - Math.cos(radian) * radius - CLOCK_TICK_RADIUS,\n          left: CLOCK_RADIUS + Math.sin(radian) * radius - CLOCK_TICK_RADIUS,\n        });\n      }\n    } else {\n      for (let i = 0; i < hourNames.length; i++) {\n        const radian = (i / 6) * Math.PI;\n        const outer = i > 0 && i < 13;\n        const radius = outer ? CLOCK_OUTER_RADIUS : CLOCK_INNER_RADIUS;\n        const hour = i % 12 ? i : (i === 0 ? 12 : 0);\n        const date = this._dateAdapter.createDate(\n          this._dateAdapter.getYear(this.activeDate),\n          this._dateAdapter.getMonth(this.activeDate),\n          this._dateAdapter.getDate(this.activeDate),\n          hour,\n          0,\n          0,\n          0\n        );\n        this._hours.push({\n          value: hour,\n          displayValue: hourNames[hour],\n          enabled: !this.dateFilter || this.dateFilter(date, 'hour'),\n          cssClasses: this.dateClass ? this.dateClass(date, 'hour') : undefined,\n          top: CLOCK_RADIUS - Math.cos(radian) * radius - CLOCK_TICK_RADIUS,\n          left: CLOCK_RADIUS + Math.sin(radian) * radius - CLOCK_TICK_RADIUS,\n          fontSize: i > 0 && i < 13 ? '' : '80%',\n        });\n      }\n    }\n\n    for (let i = 0; i < minuteNames.length; i += 5) {\n      const radian = (i / 30) * Math.PI;\n      const date = this._dateAdapter.createDate(\n        this._dateAdapter.getYear(this.activeDate),\n        this._dateAdapter.getMonth(this.activeDate),\n        this._dateAdapter.getDate(this.activeDate),\n        this._dateAdapter.getHours(this.activeDate),\n        i,\n        0,\n        0\n      );\n      this._minutes.push({\n        value: i,\n        displayValue: i === 0 ? '00' : minuteNames[i],\n        enabled: !this.dateFilter || this.dateFilter(date, 'minute'),\n        cssClasses: this.dateClass ? this.dateClass(date, 'minute') : undefined,\n        top:\n          CLOCK_RADIUS -\n          Math.cos(radian) * CLOCK_OUTER_RADIUS -\n          CLOCK_TICK_RADIUS,\n        left:\n          CLOCK_RADIUS +\n          Math.sin(radian) * CLOCK_OUTER_RADIUS -\n          CLOCK_TICK_RADIUS,\n      });\n    }\n\n    this._changeDetectorRef.markForCheck();\n  }\n\n  // Set Time\n  private setTime(event: any) {\n    const trigger = this._element.nativeElement;\n    const triggerRect = trigger.getBoundingClientRect();\n    const width = trigger.offsetWidth;\n    const height = trigger.offsetHeight;\n    const pageX =\n      event.pageX !== undefined ? event.pageX : event.touches[0].pageX;\n    const pageY =\n      event.pageY !== undefined ? event.pageY : event.touches[0].pageY;\n    const x = width / 2 - (pageX - triggerRect.left - window.pageXOffset);\n    const y = height / 2 - (pageY - triggerRect.top - window.pageYOffset);\n    const unit =\n      Math.PI /\n      (this.inHourView ? 6 : this.clockStep ? 30 / this.clockStep : 30);\n    const z = Math.sqrt(x * x + y * y);\n    const avg = (width * (CLOCK_OUTER_RADIUS / 100) + width * (CLOCK_INNER_RADIUS / 100)) / 2;\n    const outer = this.inHourView && z > avg - 16 /* button radius */;\n\n    let radian = Math.atan2(-x, y);\n    if (radian < 0) {\n      radian = Math.PI * 2 + radian;\n    }\n    let value = Math.round(radian / unit);\n\n    let date = this._dateAdapter.clone(this.activeDate);\n\n    if (this.inHourView) {\n      if (value === 12) {\n        value = 0;\n      }\n      value = this.twelveHour\n        ? (this._anteMeridian ? value : value + 12)\n        : (outer ? value : value + 12);\n      date = this._dateAdapter.setHours(date, value);\n    } else {\n      if (this.clockStep) {\n        value *= this.clockStep;\n      }\n      if (value === 60) {\n        value = 0;\n      }\n      date = this._dateAdapter.setMinutes(date, value);\n    }\n\n    // validate if the resulting value is disabled and do not take action\n    if (this.dateFilter && !this.dateFilter(date, this.currentView)) {\n      return;\n    }\n\n    // we don't want to re-render the clock\n    this._activeDate = date;\n    this.selectedChange.emit(this.activeDate);\n  }\n\n  _focusActiveCell() {}\n\n  /**\n   * @param obj The object to check.\n   * @returns The given object if it is both a date instance and valid, otherwise null.\n   */\n  private _getValidDateOrNull(obj: any): D | null {\n    return this._dateAdapter.isDateInstance(obj) && this._dateAdapter.isValid(obj) ? obj : null;\n  }\n}\n","<div class=\"mat-clock\" [style.width.px]=\"_size\" [style.height.px]=\"_size\">\n  <div class=\"mat-clock-center\"></div>\n  <div class=\"mat-clock-hand\" [ngStyle]=\"_hand\"></div>\n\n  <div class=\"mat-clock-hours\" [class.active]=\"inHourView\">\n    <div *ngFor=\"let item of _hours\"\n      class=\"mat-clock-cell\"\n      [ngClass]=\"item.cssClasses\"\n      [class.mat-clock-cell-selected]=\"_selectedHour == item.value\"\n      [class.mat-clock-cell-disabled]=\"!item.enabled\"\n      [style.top.%]=\"item.top\"\n      [style.left.%]=\"item.left\"\n      [style.fontSize]=\"item.fontSize\">\n      {{ ite