@danielmoncada/angular-datetime-picker
Version:
Angular Date Time Picker
363 lines • 49 kB
JavaScript
/**
* calendar.component
*/
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Input, NgZone, Optional, Output } from '@angular/core';
import { OwlDateTimeIntl } from './date-time-picker-intl.service';
import { DateTimeAdapter } from './adapter/date-time-adapter.class';
import { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';
import { DateView } from './date-time.class';
import { take } from 'rxjs/operators';
import { Subscription } from 'rxjs';
export class OwlCalendarComponent {
constructor(elmRef, pickerIntl, ngZone, cdRef, dateTimeAdapter, dateTimeFormats) {
this.elmRef = elmRef;
this.pickerIntl = pickerIntl;
this.ngZone = ngZone;
this.cdRef = cdRef;
this.dateTimeAdapter = dateTimeAdapter;
this.dateTimeFormats = dateTimeFormats;
this.DateView = DateView;
this._selecteds = [];
/**
* The view that the calendar should start in.
*/
this.startView = DateView.MONTH;
/**
* Whether to should only the year and multi-year views.
*/
this.yearOnly = false;
/**
* Whether to should only the multi-year view.
*/
this.multiyearOnly = false;
/** Emits when the currently picker moment changes. */
this.pickerMomentChange = new EventEmitter();
/** Emits when the currently selected date changes. */
this.selectedChange = new EventEmitter();
/** Emits when any date is selected. */
this.userSelection = new EventEmitter();
/**
* Emits the selected year. This doesn't imply a change on the selected date
* */
this.yearSelected = new EventEmitter();
/**
* Emits the selected month. This doesn't imply a change on the selected date
* */
this.monthSelected = new EventEmitter();
this.intlChangesSub = Subscription.EMPTY;
/**
* Used for scheduling that focus should be moved to the active cell on the next tick.
* We need to schedule it, rather than do it immediately, because we have to wait
* for Angular to re-evaluate the view children.
*/
this.moveFocusOnNextTick = false;
/**
* Date filter for the month and year view
*/
this.dateFilterForViews = (date) => {
return (!!date &&
(!this.dateFilter || this.dateFilter(date)) &&
(!this.minDate ||
this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&
(!this.maxDate ||
this.dateTimeAdapter.compare(date, this.maxDate) <= 0));
};
this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {
this.cdRef.markForCheck();
});
}
get minDate() {
return this._minDate;
}
set minDate(value) {
value = this.dateTimeAdapter.deserialize(value);
value = this.getValidDate(value);
this._minDate = value
? this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(value), this.dateTimeAdapter.getMonth(value), this.dateTimeAdapter.getDate(value))
: null;
}
get maxDate() {
return this._maxDate;
}
set maxDate(value) {
value = this.dateTimeAdapter.deserialize(value);
value = this.getValidDate(value);
this._maxDate = value
? this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(value), this.dateTimeAdapter.getMonth(value), this.dateTimeAdapter.getDate(value))
: null;
}
get pickerMoment() {
return this._pickerMoment;
}
set pickerMoment(value) {
value = this.dateTimeAdapter.deserialize(value);
this._pickerMoment =
this.getValidDate(value) || this.dateTimeAdapter.now();
}
get selected() {
return this._selected;
}
set selected(value) {
value = this.dateTimeAdapter.deserialize(value);
this._selected = this.getValidDate(value);
}
get selecteds() {
return this._selecteds;
}
set selecteds(values) {
this._selecteds = values.map(v => {
v = this.dateTimeAdapter.deserialize(v);
return this.getValidDate(v);
});
}
get periodButtonText() {
return this.isMonthView
? this.dateTimeAdapter.format(this.pickerMoment, this.dateTimeFormats.monthYearLabel)
: this.dateTimeAdapter.getYearName(this.pickerMoment);
}
get periodButtonLabel() {
return this.isMonthView
? this.pickerIntl.switchToMultiYearViewLabel
: this.pickerIntl.switchToMonthViewLabel;
}
get prevButtonLabel() {
if (this._currentView === DateView.MONTH) {
return this.pickerIntl.prevMonthLabel;
}
else if (this._currentView === DateView.YEAR) {
return this.pickerIntl.prevYearLabel;
}
else {
return null;
}
}
get nextButtonLabel() {
if (this._currentView === DateView.MONTH) {
return this.pickerIntl.nextMonthLabel;
}
else if (this._currentView === DateView.YEAR) {
return this.pickerIntl.nextYearLabel;
}
else {
return null;
}
}
get currentView() {
return this._currentView;
}
set currentView(view) {
this._currentView = view;
this.moveFocusOnNextTick = true;
}
get isInSingleMode() {
return this.selectMode === 'single';
}
get isInRangeMode() {
return (this.selectMode === 'range' ||
this.selectMode === 'rangeFrom' ||
this.selectMode === 'rangeTo');
}
get showControlArrows() {
return this._currentView !== DateView.MULTI_YEARS;
}
get isMonthView() {
return this._currentView === DateView.MONTH;
}
/**
* Bind class 'owl-dt-calendar' to host
* */
get owlDTCalendarClass() {
return true;
}
ngOnInit() {
}
ngAfterContentInit() {
this._currentView = this.startView;
}
ngAfterViewChecked() {
if (this.moveFocusOnNextTick) {
this.moveFocusOnNextTick = false;
this.focusActiveCell();
}
}
ngOnDestroy() {
this.intlChangesSub.unsubscribe();
}
/**
* Toggle between month view and year view
*/
toggleViews() {
let nextView = null;
if (this._currentView === DateView.MONTH) {
nextView = DateView.MULTI_YEARS;
}
else {
if (this.multiyearOnly) {
nextView = DateView.MULTI_YEARS;
}
else if (this.yearOnly) {
nextView = this._currentView === DateView.YEAR ? DateView.MULTI_YEARS : DateView.YEAR;
}
else {
nextView = DateView.MONTH;
}
}
this.currentView = nextView;
}
/**
* Handles user clicks on the previous button.
* */
previousClicked() {
this.pickerMoment = this.isMonthView
? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1)
: this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1);
this.pickerMomentChange.emit(this.pickerMoment);
}
/**
* Handles user clicks on the next button.
* */
nextClicked() {
this.pickerMoment = this.isMonthView
? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1)
: this.dateTimeAdapter.addCalendarYears(this.pickerMoment, 1);
this.pickerMomentChange.emit(this.pickerMoment);
}
dateSelected(date) {
if (!this.dateFilterForViews(date)) {
return;
}
this.selectedChange.emit(date);
/*if ((this.isInSingleMode && !this.dateTimeAdapter.isSameDay(date, this.selected)) ||
this.isInRangeMode) {
this.selectedChange.emit(date);
}*/
}
/**
* Change the pickerMoment value and switch to a specific view
*/
goToDateInView(date, view) {
this.handlePickerMomentChange(date);
if ((!this.yearOnly && !this.multiyearOnly) ||
(this.multiyearOnly && (view !== DateView.MONTH && view !== DateView.YEAR)) ||
(this.yearOnly && view !== DateView.MONTH)) {
this.currentView = view;
}
return;
}
/**
* Change the pickerMoment value
*/
handlePickerMomentChange(date) {
this.pickerMoment = this.dateTimeAdapter.clampDate(date, this.minDate, this.maxDate);
this.pickerMomentChange.emit(this.pickerMoment);
return;
}
userSelected() {
this.userSelection.emit();
}
/**
* Whether the previous period button is enabled.
*/
prevButtonEnabled() {
return (!this.minDate || !this.isSameView(this.pickerMoment, this.minDate));
}
/**
* Whether the next period button is enabled.
*/
nextButtonEnabled() {
return (!this.maxDate || !this.isSameView(this.pickerMoment, this.maxDate));
}
/**
* Focus to the host element
* */
focusActiveCell() {
this.ngZone.runOutsideAngular(() => {
this.ngZone.onStable
.asObservable()
.pipe(take(1))
.subscribe(() => {
this.elmRef.nativeElement
.querySelector('.owl-dt-calendar-cell-active')
.focus();
});
});
}
selectYearInMultiYearView(normalizedYear) {
this.yearSelected.emit(normalizedYear);
}
selectMonthInYearView(normalizedMonth) {
this.monthSelected.emit(normalizedMonth);
}
/**
* Whether the two dates represent the same view in the current view mode (month or year).
*/
isSameView(date1, date2) {
if (this._currentView === DateView.MONTH) {
return !!(date1 &&
date2 &&
this.dateTimeAdapter.getYear(date1) ===
this.dateTimeAdapter.getYear(date2) &&
this.dateTimeAdapter.getMonth(date1) ===
this.dateTimeAdapter.getMonth(date2));
}
else if (this._currentView === DateView.YEAR) {
return !!(date1 &&
date2 &&
this.dateTimeAdapter.getYear(date1) ===
this.dateTimeAdapter.getYear(date2));
}
else {
return false;
}
}
/**
* Get a valid date object
*/
getValidDate(obj) {
return this.dateTimeAdapter.isDateInstance(obj) &&
this.dateTimeAdapter.isValid(obj)
? obj
: null;
}
}
OwlCalendarComponent.decorators = [
{ type: Component, args: [{
selector: 'owl-date-time-calendar',
exportAs: 'owlDateTimeCalendar',
template: "<div class=\"owl-dt-calendar-control\">\n <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\" tabindex=\"0\"\n [style.visibility]=\"showControlArrows? 'visible': 'hidden'\"\n [disabled]=\"!prevButtonEnabled()\"\n [attr.aria-label]=\"prevButtonLabel\"\n (click)=\"previousClicked()\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n version=\"1.1\" x=\"0px\" y=\"0px\" viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background:new 0 0 250.738 250.738;\" xml:space=\"preserve\"\n width=\"100%\" height=\"100%\">\n <path style=\"fill-rule: evenodd; clip-rule: evenodd;\" d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546 c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681 l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"/>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n <div class=\"owl-dt-calendar-control-content\">\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n type=\"button\" tabindex=\"0\"\n [attr.aria-label]=\"periodButtonLabel\"\n (click)=\"toggleViews()\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n {{periodButtonText}}\n\n <span class=\"owl-dt-control-button-arrow\"\n [style.transform]=\"'rotate(' + (isMonthView? 0 : 180) +'deg)'\">\n <!-- <editor-fold desc=\"SVG Arrow\"> -->\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n width=\"50%\" height=\"50%\" viewBox=\"0 0 292.362 292.362\" style=\"enable-background:new 0 0 292.362 292.362;\"\n xml:space=\"preserve\">\n <g>\n <path d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\"/>\n </g>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </span>\n </button>\n </div>\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\" tabindex=\"0\"\n [style.visibility]=\"showControlArrows? 'visible': 'hidden'\"\n [disabled]=\"!nextButtonEnabled()\"\n [attr.aria-label]=\"nextButtonLabel\"\n (click)=\"nextClicked()\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n viewBox=\"0 0 250.738 250.738\" style=\"enable-background:new 0 0 250.738 250.738;\" xml:space=\"preserve\">\n <path style=\"fill-rule:evenodd;clip-rule:evenodd;\" d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n C197.237,120.447,195.534,115.448,191.75,111.689z\"/>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n</div>\n<div class=\"owl-dt-calendar-main\" cdkMonitorSubtreeFocus [ngSwitch]=\"currentView\" tabindex=\"-1\">\n <owl-date-time-month-view\n *ngSwitchCase=\"DateView.MONTH\"\n [pickerMoment]=\"pickerMoment\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n [hideOtherMonths]=\"hideOtherMonths\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (selectedChange)=\"dateSelected($event)\"\n (userSelection)=\"userSelected()\"></owl-date-time-month-view>\n\n <owl-date-time-year-view\n *ngSwitchCase=\"DateView.YEAR\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (monthSelected)=\"selectMonthInYearView($event)\"\n (change)=\"goToDateInView($event, DateView.MONTH)\"></owl-date-time-year-view>\n\n <owl-date-time-multi-year-view\n *ngSwitchCase=\"DateView.MULTI_YEARS\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (yearSelected)=\"selectYearInMultiYearView($event)\"\n (change)=\"goToDateInView($event, DateView.YEAR)\"></owl-date-time-multi-year-view>\n</div>\n",
host: {
'[class.owl-dt-calendar]': 'owlDTCalendarClass'
},
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [""]
},] }
];
OwlCalendarComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: OwlDateTimeIntl },
{ type: NgZone },
{ type: ChangeDetectorRef },
{ type: DateTimeAdapter, decorators: [{ type: Optional }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [OWL_DATE_TIME_FORMATS,] }] }
];
OwlCalendarComponent.propDecorators = {
minDate: [{ type: Input }],
maxDate: [{ type: Input }],
pickerMoment: [{ type: Input }],
selected: [{ type: Input }],
selecteds: [{ type: Input }],
dateFilter: [{ type: Input }],
firstDayOfWeek: [{ type: Input }],
selectMode: [{ type: Input }],
startView: [{ type: Input }],
yearOnly: [{ type: Input }],
multiyearOnly: [{ type: Input }],
hideOtherMonths: [{ type: Input }],
pickerMomentChange: [{ type: Output }],
selectedChange: [{ type: Output }],
userSelection: [{ type: Output }],
yearSelected: [{ type: Output }],
monthSelected: [{ type: Output }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * calendar.component\n */\n\nimport {\n    AfterContentInit,\n    AfterViewChecked,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output\n} from '@angular/core';\nimport {OwlDateTimeIntl} from './date-time-picker-intl.service';\nimport {DateTimeAdapter} from './adapter/date-time-adapter.class';\nimport {OWL_DATE_TIME_FORMATS, OwlDateTimeFormats} from './adapter/date-time-format.class';\nimport {DateView, DateViewType, SelectMode} from './date-time.class';\nimport {take} from 'rxjs/operators';\nimport {Subscription} from 'rxjs';\n\n@Component({\n    selector: 'owl-date-time-calendar',\n    exportAs: 'owlDateTimeCalendar',\n    templateUrl: './calendar.component.html',\n    styleUrls: ['./calendar.component.scss'],\n    host: {\n        '[class.owl-dt-calendar]': 'owlDTCalendarClass'\n    },\n    preserveWhitespaces: false,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlCalendarComponent<T>\n    implements OnInit, AfterContentInit, AfterViewChecked, OnDestroy {\n\n    DateView = DateView;\n\n    @Input()\n    get minDate(): T | null {\n        return this._minDate;\n    }\n\n    set minDate(value: T | null) {\n        value = this.dateTimeAdapter.deserialize(value);\n        value = this.getValidDate(value);\n\n        this._minDate = value\n            ? this.dateTimeAdapter.createDate(\n                this.dateTimeAdapter.getYear(value),\n                this.dateTimeAdapter.getMonth(value),\n                this.dateTimeAdapter.getDate(value)\n            )\n            : null;\n    }\n\n    @Input()\n    get maxDate(): T | null {\n        return this._maxDate;\n    }\n\n    set maxDate(value: T | null) {\n        value = this.dateTimeAdapter.deserialize(value);\n        value = this.getValidDate(value);\n\n        this._maxDate = value\n            ? this.dateTimeAdapter.createDate(\n                this.dateTimeAdapter.getYear(value),\n                this.dateTimeAdapter.getMonth(value),\n                this.dateTimeAdapter.getDate(value)\n            )\n            : null;\n    }\n\n    @Input()\n    get pickerMoment() {\n        return this._pickerMoment;\n    }\n\n    set pickerMoment(value: T) {\n        value = this.dateTimeAdapter.deserialize(value);\n        this._pickerMoment =\n            this.getValidDate(value) || this.dateTimeAdapter.now();\n    }\n\n    @Input()\n    get selected(): T | null {\n        return this._selected;\n    }\n\n    set selected(value: T | null) {\n        value = this.dateTimeAdapter.deserialize(value);\n        this._selected = this.getValidDate(value);\n    }\n\n    @Input()\n    get selecteds(): T[] {\n        return this._selecteds;\n    }\n\n    set selecteds(values: T[]) {\n        this._selecteds = values.map(v => {\n            v = this.dateTimeAdapter.deserialize(v);\n            return this.getValidDate(v);\n        });\n    }\n\n    get periodButtonText(): string {\n        return this.isMonthView\n            ? this.dateTimeAdapter.format(\n                this.pickerMoment,\n                this.dateTimeFormats.monthYearLabel\n            )\n            : this.dateTimeAdapter.getYearName(this.pickerMoment);\n    }\n\n    get periodButtonLabel(): string {\n        return this.isMonthView\n            ? this.pickerIntl.switchToMultiYearViewLabel\n            : this.pickerIntl.switchToMonthViewLabel;\n    }\n\n    get prevButtonLabel(): string {\n        if (this._currentView === DateView.MONTH) {\n            return this.pickerIntl.prevMonthLabel;\n        } else if (this._currentView === DateView.YEAR) {\n            return this.pickerIntl.prevYearLabel;\n        } else {\n            return null;\n        }\n    }\n\n    get nextButtonLabel(): string {\n        if (this._currentView === DateView.MONTH) {\n            return this.pickerIntl.nextMonthLabel;\n        } else if (this._currentView === DateView.YEAR) {\n            return this.pickerIntl.nextYearLabel;\n        } else {\n            return null;\n        }\n    }\n\n    get currentView(): DateViewType {\n        return this._currentView;\n    }\n\n    set currentView(view: DateViewType) {\n        this._currentView = view;\n        this.moveFocusOnNextTick = true;\n    }\n\n    get isInSingleMode(): boolean {\n        return this.selectMode === 'single';\n    }\n\n    get isInRangeMode(): boolean {\n        return (\n            this.selectMode === 'range' ||\n            this.selectMode === 'rangeFrom' ||\n            this.selectMode === 'rangeTo'\n        );\n    }\n\n    get showControlArrows(): boolean {\n        return this._currentView !== DateView.MULTI_YEARS;\n    }\n\n    get isMonthView() {\n        return this._currentView === DateView.MONTH;\n    }\n\n    /**\n     * Bind class 'owl-dt-calendar' to host\n     * */\n    get owlDTCalendarClass(): boolean {\n        return true;\n    }\n\n    constructor(\n        private elmRef: ElementRef,\n        private pickerIntl: OwlDateTimeIntl,\n        private ngZone: NgZone,\n        private cdRef: ChangeDetectorRef,\n        @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n        @Optional()\n        @Inject(OWL_DATE_TIME_FORMATS)\n        private dateTimeFormats: OwlDateTimeFormats\n    ) {\n        this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {\n            this.cdRef.markForCheck();\n        });\n    }\n\n    /**\n     * Date filter for the month and year view\n     * */\n    @Input()\n    dateFilter: (date: T) => boolean;\n\n    /**\n     * Set the first day of week\n     */\n    @Input()\n    firstDayOfWeek: number;\n\n    /** The minimum selectable date. */\n    private _minDate: T | null;\n\n    /** The maximum selectable date. */\n    private _maxDate: T | null;\n\n    /** The current picker moment */\n    private _pickerMoment: T;\n\n    @Input()\n    selectMode: SelectMode;\n\n    /** The currently selected moment. */\n    private _selected: T | null;\n\n    private _selecteds: T[] = [];\n\n    /**\n     * The view that the calendar should start in.\n     */\n    @Input()\n    startView: DateViewType = DateView.MONTH;\n\n    /**\n     * Whether to should only the year and multi-year views.\n     */\n    @Input()\n    yearOnly = false;\n\n    /**\n     * Whether to should only the multi-year view.\n     */\n    @Input()\n    multiyearOnly = false;\n\n    /**\n     * Whether to hide dates in other months at the start or end of the current month.\n     * */\n    @Input()\n    hideOtherMonths: boolean;\n\n    /** Emits when the currently picker moment changes. */\n    @Output()\n    pickerMomentChange = new EventEmitter<T>();\n\n    /** Emits when the currently selected date changes. */\n    @Output()\n    selectedChange = new EventEmitter<T>();\n\n    /** Emits when any date is selected. */\n    @Output()\n    userSelection = new EventEmitter<void>();\n\n    /**\n     * Emits the selected year. This doesn't imply a change on the selected date\n     * */\n    @Output()\n    readonly yearSelected = new EventEmitter<T>();\n\n    /**\n     * Emits the selected month. This doesn't imply a change on the selected date\n     * */\n    @Output()\n    readonly monthSelected = new EventEmitter<T>();\n\n    private _currentView: DateViewType;\n\n    private intlChangesSub = Subscription.EMPTY;\n\n    /**\n     * Used for scheduling that focus should be moved to the active cell on the next tick.\n     * We need to schedule it, rather than do it immediately, because we have to wait\n     * for Angular to re-evaluate the view children.\n     */\n    private moveFocusOnNextTick = false;\n\n    /**\n     * Date filter for the month and year view\n     */\n    public dateFilterForViews = (date: T) => {\n        return (\n            !!date &&\n            (!this.dateFilter || this.dateFilter(date)) &&\n            (!this.minDate ||\n                this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&\n            (!this.maxDate ||\n                this.dateTimeAdapter.compare(date, this.maxDate) <= 0)\n        );\n    };\n\n    public ngOnInit() {\n    }\n\n    public ngAfterContentInit(): void {\n        this._currentView = this.startView;\n    }\n\n    public ngAfterViewChecked() {\n        if (this.moveFocusOnNextTick) {\n            this.moveFocusOnNextTick = false;\n            this.focusActiveCell();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.intlChangesSub.unsubscribe();\n    }\n\n    /**\n     * Toggle between month view and year view\n     */\n    public toggleViews(): void {\n        let nextView = null;\n        if (this._currentView === DateView.MONTH) {\n            nextView = DateView.MULTI_YEARS;\n        } else {\n            if (this.multiyearOnly) {\n                nextView = DateView.MULTI_YEARS;\n            } else if (this.yearOnly) {\n                nextView = this._currentView === DateView.YEAR ? DateView.MULTI_YEARS : DateView.YEAR;\n            } else {\n                nextView = DateView.MONTH;\n            }\n        }\n        this.currentView = nextView;\n    }\n\n    /**\n     * Handles user clicks on the previous button.\n     * */\n    public previousClicked(): void {\n        this.pickerMoment = this.isMonthView\n            ? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1)\n            : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1);\n\n        this.pickerMomentChange.emit(this.pickerMoment);\n    }\n\n    /**\n     * Handles user clicks on the next button.\n     * */\n    public nextClicked(): void {\n        this.pickerMoment = this.isMonthView\n            ? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1)\n            : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, 1);\n\n        this.pickerMomentChange.emit(this.pickerMoment);\n    }\n\n    public dateSelected(date: T): void {\n        if (!this.dateFilterForViews(date)) {\n            return;\n        }\n\n        this.selectedChange.emit(date);\n\n        /*if ((this.isInSingleMode && !this.dateTimeAdapter.isSameDay(date, this.selected)) ||\n            this.isInRangeMode) {\n            this.selectedChange.emit(date);\n        }*/\n    }\n\n    /**\n     * Change the pickerMoment value and switch to a specific view\n     */\n    public goToDateInView(\n        date: T,\n        view: DateViewType\n    ): void {\n        this.handlePickerMomentChange(date);\n        if ((!this.yearOnly && !this.multiyearOnly) ||\n            (this.multiyearOnly && (view !== DateView.MONTH && view !== DateView.YEAR)) ||\n            (this.yearOnly && view !== DateView.MONTH)) {\n            this.currentView = view;\n        }\n        return;\n    }\n\n    /**\n     * Change the pickerMoment value\n     */\n    public handlePickerMomentChange(date: T): void {\n        this.pickerMoment = this.dateTimeAdapter.clampDate(\n            date,\n            this.minDate,\n            this.maxDate\n        );\n        this.pickerMomentChange.emit(this.pickerMoment);\n        return;\n    }\n\n    public userSelected(): void {\n        this.userSelection.emit();\n    }\n\n    /**\n     * Whether the previous period button is enabled.\n     */\n    public prevButtonEnabled(): boolean {\n        return (\n            !this.minDate || !this.isSameView(this.pickerMoment, this.minDate)\n        );\n    }\n\n    /**\n     * Whether the next period button is enabled.\n     */\n    public nextButtonEnabled(): boolean {\n        return (\n            !this.maxDate || !this.isSameView(this.pickerMoment, this.maxDate)\n        );\n    }\n\n    /**\n     * Focus to the host element\n     * */\n    public focusActiveCell() {\n        this.ngZone.runOutsideAngular(() => {\n            this.ngZone.onStable\n                .asObservable()\n                .pipe(take(1))\n                .subscribe(() => {\n                    this.elmRef.nativeElement\n                        .querySelector('.owl-dt-calendar-cell-active')\n                        .focus();\n                });\n        });\n    }\n\n    public selectYearInMultiYearView(normalizedYear: T): void {\n        this.yearSelected.emit(normalizedYear);\n    }\n\n    public selectMonthInYearView(normalizedMonth: T): void {\n        this.monthSelected.emit(normalizedMonth);\n    }\n\n    /**\n     * Whether the two dates represent the same view in the current view mode (month or year).\n     */\n    private isSameView(date1: T, date2: T): boolean {\n        if (this._currentView === DateView.MONTH) {\n            return !!(\n                date1 &&\n                date2 &&\n                this.dateTimeAdapter.getYear(date1) ===\n                this.dateTimeAdapter.getYear(date2) &&\n                this.dateTimeAdapter.getMonth(date1) ===\n                this.dateTimeAdapter.getMonth(date2)\n            );\n        } else if (this._currentView === DateView.YEAR) {\n            return !!(\n                date1 &&\n                date2 &&\n                this.dateTimeAdapter.getYear(date1) ===\n                this.dateTimeAdapter.getYear(date2)\n            );\n        } else {\n            return false;\n        }\n    }\n\n    /**\n     * Get a valid date object\n     */\n    private getValidDate(obj: any): T | null {\n        return this.dateTimeAdapter.isDateInstance(obj) &&\n        this.dateTimeAdapter.isValid(obj)\n            ? obj\n            : null;\n    }\n}\n"]}