UNPKG

@matheo/datepicker

Version:

Angular material date+time picker

305 lines 50.7 kB
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