/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { fromEvent, merge, Subject } from 'rxjs'; import { filter, take, takeUntil } from 'rxjs/operators'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Input, NgZone, Output, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { NgbCalendar } from './ngb-calendar'; import { NgbDate } from './ngb-date'; import { NgbDatepickerService } from './datepicker-service'; import { NgbDatepickerKeyboardService } from './datepicker-keyboard-service'; import { NavigationEvent } from './datepicker-view-model'; import { NgbDatepickerConfig } from './datepicker-config'; import { NgbDateAdapter } from './adapters/ngb-date-adapter'; import { NgbDatepickerI18n } from './datepicker-i18n'; import { isChangedDate, isChangedMonth } from './datepicker-tools'; import { hasClassName } from '../util/util'; /** @type {?} */ var NGB_DATEPICKER_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return NgbDatepicker; })), multi: true }; /** * An event emitted right before the navigation happens and the month displayed by the datepicker changes. * @record */ export function NgbDatepickerNavigateEvent() { } if (false) { /** * The currently displayed month. * @type {?} */ NgbDatepickerNavigateEvent.prototype.current; /** * The month we're navigating to. * @type {?} */ NgbDatepickerNavigateEvent.prototype.next; /** * Calling this function will prevent navigation from happening. * * \@since 4.1.0 * @type {?} */ NgbDatepickerNavigateEvent.prototype.preventDefault; } /** * An interface that represents the readonly public state of the datepicker. * * Accessible via the `datepicker.state` getter * * \@since 5.2.0 * @record */ export function NgbDatepickerState() { } if (false) { /** * The earliest date that can be displayed or selected * @type {?} */ NgbDatepickerState.prototype.minDate; /** * The latest date that can be displayed or selected * @type {?} */ NgbDatepickerState.prototype.maxDate; /** * The first visible date of currently displayed months * @type {?} */ NgbDatepickerState.prototype.firstDate; /** * The last visible date of currently displayed months * @type {?} */ NgbDatepickerState.prototype.lastDate; /** * The date currently focused by the datepicker * @type {?} */ NgbDatepickerState.prototype.focusedDate; } /** * A highly configurable component that helps you with selecting calendar dates. * * `NgbDatepicker` is meant to be displayed inline on a page or put inside a popup. */ var NgbDatepicker = /** @class */ (function () { function NgbDatepicker(_service, _calendar, i18n, config, _keyboardService, cd, _elementRef, _ngbDateAdapter, _ngZone) { var _this = this; this._service = _service; this._calendar = _calendar; this.i18n = i18n; this._keyboardService = _keyboardService; this._elementRef = _elementRef; this._ngbDateAdapter = _ngbDateAdapter; this._ngZone = _ngZone; this._destroyed$ = new Subject(); this._publicState = (/** @type {?} */ ({})); /** * An event emitted right before the navigation happens and displayed month changes. * * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info. */ this.navigate = new EventEmitter(); /** * An event emitted when user selects a date using keyboard or mouse. * * The payload of the event is currently selected `NgbDate`. * * \@since 5.2.0 */ this.dateSelect = new EventEmitter(); /** * An event emitted when user selects a date using keyboard or mouse. * * The payload of the event is currently selected `NgbDate`. * * Please use 'dateSelect' output instead, this will be deprecated in version 6.0 due to collision with native * 'select' event. */ this.select = this.dateSelect; this.onChange = (/** * @param {?} _ * @return {?} */ function (_) { }); this.onTouched = (/** * @return {?} */ function () { }); ['dayTemplate', 'dayTemplateData', 'displayMonths', 'firstDayOfWeek', 'footerTemplate', 'markDisabled', 'minDate', 'maxDate', 'navigation', 'outsideDays', 'showWeekdays', 'showWeekNumbers', 'startDate'] .forEach((/** * @param {?} input * @return {?} */ function (input) { return _this[input] = config[input]; })); _service.dateSelect$.pipe(takeUntil(this._destroyed$)).subscribe((/** * @param {?} date * @return {?} */ function (date) { _this.dateSelect.emit(date); })); _service.model$.pipe(takeUntil(this._destroyed$)).subscribe((/** * @param {?} model * @return {?} */ function (model) { /** @type {?} */ var newDate = model.firstDate; /** @type {?} */ var oldDate = _this.model ? _this.model.firstDate : null; // update public state _this._publicState = { maxDate: model.maxDate, minDate: model.minDate, firstDate: model.firstDate, lastDate: model.lastDate, focusedDate: model.focusDate }; /** @type {?} */ var navigationPrevented = false; // emitting navigation event if the first month changes if (!newDate.equals(oldDate)) { _this.navigate.emit({ current: oldDate ? { year: oldDate.year, month: oldDate.month } : null, next: { year: newDate.year, month: newDate.month }, preventDefault: (/** * @return {?} */ function () { return navigationPrevented = true; }) }); // can't prevent the very first navigation if (navigationPrevented && oldDate !== null) { _this._service.open(oldDate); return; } } /** @type {?} */ var newSelectedDate = model.selectedDate; /** @type {?} */ var newFocusedDate = model.focusDate; /** @type {?} */ var oldFocusedDate = _this.model ? _this.model.focusDate : null; _this.model = model; // handling selection change if (isChangedDate(newSelectedDate, _this._controlValue)) { _this._controlValue = newSelectedDate; _this.onTouched(); _this.onChange(_this._ngbDateAdapter.toModel(newSelectedDate)); } // handling focus change if (isChangedDate(newFocusedDate, oldFocusedDate) && oldFocusedDate && model.focusVisible) { _this.focus(); } cd.markForCheck(); })); } Object.defineProperty(NgbDatepicker.prototype, "state", { /** * Returns the readonly public state of the datepicker * * @since 5.2.0 */ get: /** * Returns the readonly public state of the datepicker * * \@since 5.2.0 * @return {?} */ function () { return this._publicState; }, enumerable: true, configurable: true }); /** * Focuses on given date. */ /** * Focuses on given date. * @param {?} date * @return {?} */ NgbDatepicker.prototype.focusDate = /** * Focuses on given date. * @param {?} date * @return {?} */ function (date) { this._service.focus(NgbDate.from(date)); }; /** * Selects focused date. */ /** * Selects focused date. * @return {?} */ NgbDatepicker.prototype.focusSelect = /** * Selects focused date. * @return {?} */ function () { this._service.focusSelect(); }; /** * @return {?} */ NgbDatepicker.prototype.focus = /** * @return {?} */ function () { var _this = this; this._ngZone.onStable.asObservable().pipe(take(1)).subscribe((/** * @return {?} */ function () { /** @type {?} */ var elementToFocus = _this._elementRef.nativeElement.querySelector('div.ngb-dp-day[tabindex="0"]'); if (elementToFocus) { elementToFocus.focus(); } })); }; /** * Navigates to the provided date. * * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec. * If nothing or invalid date provided calendar will open current month. * * Use the `[startDate]` input as an alternative. */ /** * Navigates to the provided date. * * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec. * If nothing or invalid date provided calendar will open current month. * * Use the `[startDate]` input as an alternative. * @param {?=} date * @return {?} */ NgbDatepicker.prototype.navigateTo = /** * Navigates to the provided date. * * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec. * If nothing or invalid date provided calendar will open current month. * * Use the `[startDate]` input as an alternative. * @param {?=} date * @return {?} */ function (date) { this._service.open(NgbDate.from(date ? date.day ? (/** @type {?} */ (date)) : tslib_1.__assign({}, date, { day: 1 }) : null)); }; /** * @return {?} */ NgbDatepicker.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; this._ngZone.runOutsideAngular((/** * @return {?} */ function () { /** @type {?} */ var focusIns$ = fromEvent(_this._monthsEl.nativeElement, 'focusin'); /** @type {?} */ var focusOuts$ = fromEvent(_this._monthsEl.nativeElement, 'focusout'); var nativeElement = _this._elementRef.nativeElement; // we're changing 'focusVisible' only when entering or leaving months view // and ignoring all focus events where both 'target' and 'related' target are day cells merge(focusIns$, focusOuts$) .pipe(filter((/** * @param {?} __0 * @return {?} */ function (_a) { var target = _a.target, relatedTarget = _a.relatedTarget; return !(hasClassName(target, 'ngb-dp-day') && hasClassName(relatedTarget, 'ngb-dp-day') && nativeElement.contains((/** @type {?} */ (target))) && nativeElement.contains((/** @type {?} */ (relatedTarget)))); })), takeUntil(_this._destroyed$)) .subscribe((/** * @param {?} __0 * @return {?} */ function (_a) { var type = _a.type; return _this._ngZone.run((/** * @return {?} */ function () { return _this._service.set({ focusVisible: type === 'focusin' }); })); })); })); }; /** * @return {?} */ NgbDatepicker.prototype.ngOnDestroy = /** * @return {?} */ function () { this._destroyed$.next(); }; /** * @return {?} */ NgbDatepicker.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; if (this.model === undefined) { /** @type {?} */ var inputs_1 = {}; ['dayTemplateData', 'displayMonths', 'markDisabled', 'firstDayOfWeek', 'navigation', 'minDate', 'maxDate', 'outsideDays'] .forEach((/** * @param {?} name * @return {?} */ function (name) { return inputs_1[name] = _this[name]; })); this._service.set(inputs_1); this.navigateTo(this.startDate); } }; /** * @param {?} changes * @return {?} */ NgbDatepicker.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var _this = this; /** @type {?} */ var inputs = {}; ['dayTemplateData', 'displayMonths', 'markDisabled', 'firstDayOfWeek', 'navigation', 'minDate', 'maxDate', 'outsideDays'] .filter((/** * @param {?} name * @return {?} */ function (name) { return name in changes; })) .forEach((/** * @param {?} name * @return {?} */ function (name) { return inputs[name] = _this[name]; })); this._service.set(inputs); if ('startDate' in changes) { var _a = changes.startDate, currentValue = _a.currentValue, previousValue = _a.previousValue; if (isChangedMonth(previousValue, currentValue)) { this.navigateTo(this.startDate); } } }; /** * @param {?} date * @return {?} */ NgbDatepicker.prototype.onDateSelect = /** * @param {?} date * @return {?} */ function (date) { this._service.focus(date); this._service.select(date, { emitEvent: true }); }; /** * @param {?} event * @return {?} */ NgbDatepicker.prototype.onKeyDown = /** * @param {?} event * @return {?} */ function (event) { this._keyboardService.processKey(event, this, this._calendar); }; /** * @param {?} date * @return {?} */ NgbDatepicker.prototype.onNavigateDateSelect = /** * @param {?} date * @return {?} */ function (date) { this._service.open(date); }; /** * @param {?} event * @return {?} */ NgbDatepicker.prototype.onNavigateEvent = /** * @param {?} event * @return {?} */ function (event) { switch (event) { case NavigationEvent.PREV: this._service.open(this._calendar.getPrev(this.model.firstDate, 'm', 1)); break; case NavigationEvent.NEXT: this._service.open(this._calendar.getNext(this.model.firstDate, 'm', 1)); break; } }; /** * @param {?} fn * @return {?} */ NgbDatepicker.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** * @param {?} fn * @return {?} */ NgbDatepicker.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} disabled * @return {?} */ NgbDatepicker.prototype.setDisabledState = /** * @param {?} disabled * @return {?} */ function (disabled) { this._service.set({ disabled: disabled }); }; /** * @param {?} value * @return {?} */ NgbDatepicker.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this._controlValue = NgbDate.from(this._ngbDateAdapter.fromModel(value)); this._service.select(this._controlValue); }; NgbDatepicker.decorators = [ { type: Component, args: [{ exportAs: 'ngbDatepicker', selector: 'ngb-datepicker', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "\n \n
\n
\n
\n\n
\n \n \n
\n\n
\n \n
\n
1 && navigation === 'select')\"\n class=\"ngb-dp-month-name\">\n {{ i18n.getMonthFullName(month.number, month.year) }} {{ i18n.getYearNumerals(month.year) }}\n
\n \n \n
\n
\n
\n\n \n ", providers: [NGB_DATEPICKER_VALUE_ACCESSOR, NgbDatepickerService], styles: ["ngb-datepicker{border:1px solid #dfdfdf;border-radius:.25rem;display:inline-block}ngb-datepicker-month-view{pointer-events:auto}ngb-datepicker.dropdown-menu{padding:0}.ngb-dp-body{z-index:1050}.ngb-dp-header{border-bottom:0;border-radius:.25rem .25rem 0 0;padding-top:.25rem;background-color:#f8f9fa;background-color:var(--light)}.ngb-dp-months{display:-ms-flexbox;display:flex}.ngb-dp-month{pointer-events:none}.ngb-dp-month-name{font-size:larger;height:2rem;line-height:2rem;text-align:center;background-color:#f8f9fa;background-color:var(--light)}.ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,.ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-left:1rem}.ngb-dp-month:last-child .ngb-dp-week{padding-right:.25rem}.ngb-dp-month:first-child .ngb-dp-week{padding-left:.25rem}.ngb-dp-month .ngb-dp-week:last-child{padding-bottom:.25rem}"] }] } ]; /** @nocollapse */ NgbDatepicker.ctorParameters = function () { return [ { type: NgbDatepickerService }, { type: NgbCalendar }, { type: NgbDatepickerI18n }, { type: NgbDatepickerConfig }, { type: NgbDatepickerKeyboardService }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: NgbDateAdapter }, { type: NgZone } ]; }; NgbDatepicker.propDecorators = { _monthsEl: [{ type: ViewChild, args: ['months', { static: true },] }], dayTemplate: [{ type: Input }], dayTemplateData: [{ type: Input }], displayMonths: [{ type: Input }], firstDayOfWeek: [{ type: Input }], footerTemplate: [{ type: Input }], markDisabled: [{ type: Input }], maxDate: [{ type: Input }], minDate: [{ type: Input }], navigation: [{ type: Input }], outsideDays: [{ type: Input }], showWeekdays: [{ type: Input }], showWeekNumbers: [{ type: Input }], startDate: [{ type: Input }], navigate: [{ type: Output }], dateSelect: [{ type: Output }], select: [{ type: Output }] }; return NgbDatepicker; }()); export { NgbDatepicker }; if (false) { /** @type {?} */ NgbDatepicker.prototype.model; /** * @type {?} * @private */ NgbDatepicker.prototype._monthsEl; /** * @type {?} * @private */ NgbDatepicker.prototype._controlValue; /** * @type {?} * @private */ NgbDatepicker.prototype._destroyed$; /** * @type {?} * @private */ NgbDatepicker.prototype._publicState; /** * The reference to a custom template for the day. * * Allows to completely override the way a day 'cell' in the calendar is displayed. * * See [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext) for the data you get inside. * @type {?} */ NgbDatepicker.prototype.dayTemplate; /** * The callback to pass any arbitrary data to the template cell via the * [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext)'s `data` parameter. * * `current` is the month that is currently displayed by the datepicker. * * \@since 3.3.0 * @type {?} */ NgbDatepicker.prototype.dayTemplateData; /** * The number of months to display. * @type {?} */ NgbDatepicker.prototype.displayMonths; /** * The first day of the week. * * With default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun. * @type {?} */ NgbDatepicker.prototype.firstDayOfWeek; /** * The reference to the custom template for the datepicker footer. * * \@since 3.3.0 * @type {?} */ NgbDatepicker.prototype.footerTemplate; /** * The callback to mark some dates as disabled. * * It is called for each new date when navigating to a different month. * * `current` is the month that is currently displayed by the datepicker. * @type {?} */ NgbDatepicker.prototype.markDisabled; /** * The latest date that can be displayed or selected. * * If not provided, 'year' select box will display 10 years after the current month. * @type {?} */ NgbDatepicker.prototype.maxDate; /** * The earliest date that can be displayed or selected. * * If not provided, 'year' select box will display 10 years before the current month. * @type {?} */ NgbDatepicker.prototype.minDate; /** * Navigation type. * * * `"select"` - select boxes for month and navigation arrows * * `"arrows"` - only navigation arrows * * `"none"` - no navigation visible at all * @type {?} */ NgbDatepicker.prototype.navigation; /** * The way of displaying days that don't belong to the current month. * * * `"visible"` - days are visible * * `"hidden"` - days are hidden, white space preserved * * `"collapsed"` - days are collapsed, so the datepicker height might change between months * * For the 2+ months view, days in between months are never shown. * @type {?} */ NgbDatepicker.prototype.outsideDays; /** * If `true`, weekdays will be displayed. * @type {?} */ NgbDatepicker.prototype.showWeekdays; /** * If `true`, week numbers will be displayed. * @type {?} */ NgbDatepicker.prototype.showWeekNumbers; /** * The date to open calendar with. * * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec. * If nothing or invalid date is provided, calendar will open with current month. * * You could use `navigateTo(date)` method as an alternative. * @type {?} */ NgbDatepicker.prototype.startDate; /** * An event emitted right before the navigation happens and displayed month changes. * * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info. * @type {?} */ NgbDatepicker.prototype.navigate; /** * An event emitted when user selects a date using keyboard or mouse. * * The payload of the event is currently selected `NgbDate`. * * \@since 5.2.0 * @type {?} */ NgbDatepicker.prototype.dateSelect; /** * An event emitted when user selects a date using keyboard or mouse. * * The payload of the event is currently selected `NgbDate`. * * Please use 'dateSelect' output instead, this will be deprecated in version 6.0 due to collision with native * 'select' event. * @type {?} */ NgbDatepicker.prototype.select; /** @type {?} */ NgbDatepicker.prototype.onChange; /** @type {?} */ NgbDatepicker.prototype.onTouched; /** * @type {?} * @private */ NgbDatepicker.prototype._service; /** * @type {?} * @private */ NgbDatepicker.prototype._calendar; /** @type {?} */ NgbDatepicker.prototype.i18n; /** * @type {?} * @private */ NgbDatepicker.prototype._keyboardService; /** * @type {?} * @private */ NgbDatepicker.prototype._elementRef; /** * @type {?} * @private */ NgbDatepicker.prototype._ngbDateAdapter; /** * @type {?} * @private */ NgbDatepicker.prototype._ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["datepicker/datepicker.ts"],"names":[],"mappings":"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","sourcesContent":["import {fromEvent, merge, Subject} from 'rxjs';\nimport {filter, take, takeUntil} from 'rxjs/operators';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {NgbCalendar} from './ngb-calendar';\nimport {NgbDate} from './ngb-date';\nimport {DatepickerServiceInputs, NgbDatepickerService} from './datepicker-service';\nimport {NgbDatepickerKeyboardService} from './datepicker-keyboard-service';\nimport {DatepickerViewModel, NavigationEvent} from './datepicker-view-model';\nimport {DayTemplateContext} from './datepicker-day-template-context';\nimport {NgbDatepickerConfig} from './datepicker-config';\nimport {NgbDateAdapter} from './adapters/ngb-date-adapter';\nimport {NgbDateStruct} from './ngb-date-struct';\nimport {NgbDatepickerI18n} from './datepicker-i18n';\nimport {isChangedDate, isChangedMonth} from './datepicker-tools';\nimport {hasClassName} from '../util/util';\n\nconst NGB_DATEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NgbDatepicker),\n  multi: true\n};\n\n/**\n * An event emitted right before the navigation happens and the month displayed by the datepicker changes.\n */\nexport interface NgbDatepickerNavigateEvent {\n  /**\n   * The currently displayed month.\n   */\n  current: {year: number, month: number};\n\n  /**\n   * The month we're navigating to.\n   */\n  next: {year: number, month: number};\n\n  /**\n   * Calling this function will prevent navigation from happening.\n   *\n   * @since 4.1.0\n   */\n  preventDefault: () => void;\n}\n\n/**\n * An interface that represents the readonly public state of the datepicker.\n *\n * Accessible via the `datepicker.state` getter\n *\n * @since 5.2.0\n */\nexport interface NgbDatepickerState {\n  /**\n   * The earliest date that can be displayed or selected\n   */\n  readonly minDate: NgbDate;\n\n  /**\n   * The latest date that can be displayed or selected\n   */\n  readonly maxDate: NgbDate;\n\n  /**\n   * The first visible date of currently displayed months\n   */\n  readonly firstDate: NgbDate;\n\n  /**\n   * The last visible date of currently displayed months\n   */\n  readonly lastDate: NgbDate;\n\n  /**\n   * The date currently focused by the datepicker\n   */\n  readonly focusedDate: NgbDate;\n}\n\n/**\n * A highly configurable component that helps you with selecting calendar dates.\n *\n * `NgbDatepicker` is meant to be displayed inline on a page or put inside a popup.\n */\n@Component({\n  exportAs: 'ngbDatepicker',\n  selector: 'ngb-datepicker',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: ['./datepicker.scss'],\n  template: `\n    <ng-template #dt let-date=\"date\" let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\" let-focused=\"focused\">\n      <div ngbDatepickerDayView\n        [date]=\"date\"\n        [currentMonth]=\"currentMonth\"\n        [selected]=\"selected\"\n        [disabled]=\"disabled\"\n        [focused]=\"focused\">\n      </div>\n    </ng-template>\n\n    <div class=\"ngb-dp-header\">\n      <ngb-datepicker-navigation *ngIf=\"navigation !== 'none'\"\n        [date]=\"model.firstDate\"\n        [months]=\"model.months\"\n        [disabled]=\"model.disabled\"\n        [showSelect]=\"model.navigation === 'select'\"\n        [prevDisabled]=\"model.prevDisabled\"\n        [nextDisabled]=\"model.nextDisabled\"\n        [selectBoxes]=\"model.selectBoxes\"\n        (navigate)=\"onNavigateEvent($event)\"\n        (select)=\"onNavigateDateSelect($event)\">\n      </ngb-datepicker-navigation>\n    </div>\n\n    <div #months class=\"ngb-dp-months\" (keydown)=\"onKeyDown($event)\">\n      <ng-template ngFor let-month [ngForOf]=\"model.months\" let-i=\"index\">\n        <div class=\"ngb-dp-month\">\n          <div *ngIf=\"navigation === 'none' || (displayMonths > 1 && navigation === 'select')\"\n                class=\"ngb-dp-month-name\">\n            {{ i18n.getMonthFullName(month.number, month.year) }} {{ i18n.getYearNumerals(month.year) }}\n          </div>\n          <ngb-datepicker-month-view\n            [month]=\"month\"\n            [dayTemplate]=\"dayTemplate || dt\"\n            [showWeekdays]=\"showWeekdays\"\n            [showWeekNumbers]=\"showWeekNumbers\"\n            (select)=\"onDateSelect($event)\">\n          </ngb-datepicker-month-view>\n        </div>\n      </ng-template>\n    </div>\n\n    <ng-template [ngTemplateOutlet]=\"footerTemplate\"></ng-template>\n  `,\n  providers: [NGB_DATEPICKER_VALUE_ACCESSOR, NgbDatepickerService]\n})\nexport class NgbDatepicker implements OnDestroy,\n    OnChanges, OnInit, AfterViewInit, ControlValueAccessor {\n  model: DatepickerViewModel;\n\n  @ViewChild('months', {static: true}) private _monthsEl: ElementRef<HTMLElement>;\n  private _controlValue: NgbDate;\n  private _destroyed$ = new Subject<void>();\n  private _publicState: NgbDatepickerState = <any>{};\n\n  /**\n   * The reference to a custom template for the day.\n   *\n   * Allows to completely override the way a day 'cell' in the calendar is displayed.\n   *\n   * See [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext) for the data you get inside.\n   */\n  @Input() dayTemplate: TemplateRef<DayTemplateContext>;\n\n  /**\n   * The callback to pass any arbitrary data to the template cell via the\n   * [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext)'s `data` parameter.\n   *\n   * `current` is the month that is currently displayed by the datepicker.\n   *\n   * @since 3.3.0\n   */\n  @Input() dayTemplateData: (date: NgbDate, current: {year: number, month: number}) => any;\n\n  /**\n   * The number of months to display.\n   */\n  @Input() displayMonths: number;\n\n  /**\n   * The first day of the week.\n   *\n   * With default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun.\n   */\n  @Input() firstDayOfWeek: number;\n\n  /**\n   * The reference to the custom template for the datepicker footer.\n   *\n   * @since 3.3.0\n   */\n  @Input() footerTemplate: TemplateRef<any>;\n\n  /**\n   * The callback to mark some dates as disabled.\n   *\n   * It is called for each new date when navigating to a different month.\n   *\n   * `current` is the month that is currently displayed by the datepicker.\n   */\n  @Input() markDisabled: (date: NgbDate, current: {year: number, month: number}) => boolean;\n\n  /**\n   * The latest date that can be displayed or selected.\n   *\n   * If not provided, 'year' select box will display 10 years after the current month.\n   */\n  @Input() maxDate: NgbDateStruct;\n\n  /**\n   * The earliest date that can be displayed or selected.\n   *\n   * If not provided, 'year' select box will display 10 years before the current month.\n   */\n  @Input() minDate: NgbDateStruct;\n\n  /**\n   * Navigation type.\n   *\n   * * `\"select\"` - select boxes for month and navigation arrows\n   * * `\"arrows\"` - only navigation arrows\n   * * `\"none\"` - no navigation visible at all\n   */\n  @Input() navigation: 'select' | 'arrows' | 'none';\n\n  /**\n   * The way of displaying days that don't belong to the current month.\n   *\n   * * `\"visible\"` - days are visible\n   * * `\"hidden\"` - days are hidden, white space preserved\n   * * `\"collapsed\"` - days are collapsed, so the datepicker height might change between months\n   *\n   * For the 2+ months view, days in between months are never shown.\n   */\n  @Input() outsideDays: 'visible' | 'collapsed' | 'hidden';\n\n  /**\n   * If `true`, weekdays will be displayed.\n   */\n  @Input() showWeekdays: boolean;\n\n  /**\n   * If `true`, week numbers will be displayed.\n   */\n  @Input() showWeekNumbers: boolean;\n\n  /**\n   * The date to open calendar with.\n   *\n   * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.\n   * If nothing or invalid date is provided, calendar will open with current month.\n   *\n   * You could use `navigateTo(date)` method as an alternative.\n   */\n  @Input() startDate: {year: number, month: number, day?: number};\n\n  /**\n   * An event emitted right before the navigation happens and displayed month changes.\n   *\n   * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info.\n   */\n  @Output() navigate = new EventEmitter<NgbDatepickerNavigateEvent>();\n\n  /**\n   * An event emitted when user selects a date using keyboard or mouse.\n   *\n   * The payload of the event is currently selected `NgbDate`.\n   *\n   * @since 5.2.0\n   */\n  @Output() dateSelect = new EventEmitter<NgbDate>();\n\n  /**\n   * An event emitted when user selects a date using keyboard or mouse.\n   *\n   * The payload of the event is currently selected `NgbDate`.\n   *\n   * Please use 'dateSelect' output instead, this will be deprecated in version 6.0 due to collision with native\n   * 'select' event.\n   */\n  @Output() select = this.dateSelect;\n\n  onChange = (_: any) => {};\n  onTouched = () => {};\n\n  constructor(\n      private _service: NgbDatepickerService, private _calendar: NgbCalendar, public i18n: NgbDatepickerI18n,\n      config: NgbDatepickerConfig, private _keyboardService: NgbDatepickerKeyboardService, cd: ChangeDetectorRef,\n      private _elementRef: ElementRef<HTMLElement>, private _ngbDateAdapter: NgbDateAdapter<any>,\n      private _ngZone: NgZone) {\n    ['dayTemplate', 'dayTemplateData', 'displayMonths', 'firstDayOfWeek', 'footerTemplate', 'markDisabled', 'minDate',\n     'maxDate', 'navigation', 'outsideDays', 'showWeekdays', 'showWeekNumbers', 'startDate']\n        .forEach(input => this[input] = config[input]);\n\n    _service.dateSelect$.pipe(takeUntil(this._destroyed$)).subscribe(date => { this.dateSelect.emit(date); });\n\n    _service.model$.pipe(takeUntil(this._destroyed$)).subscribe(model => {\n      const newDate = model.firstDate;\n      const oldDate = this.model ? this.model.firstDate : null;\n\n      // update public state\n      this._publicState = {\n        maxDate: model.maxDate,\n        minDate: model.minDate,\n        firstDate: model.firstDate,\n        lastDate: model.lastDate,\n        focusedDate: model.focusDate\n      };\n\n      let navigationPrevented = false;\n      // emitting navigation event if the first month changes\n      if (!newDate.equals(oldDate)) {\n        this.navigate.emit({\n          current: oldDate ? {year: oldDate.year, month: oldDate.month} : null,\n          next: {year: newDate.year, month: newDate.month},\n          preventDefault: () => navigationPrevented = true\n        });\n\n        // can't prevent the very first navigation\n        if (navigationPrevented && oldDate !== null) {\n          this._service.open(oldDate);\n          return;\n        }\n      }\n\n      const newSelectedDate = model.selectedDate;\n      const newFocusedDate = model.focusDate;\n      const oldFocusedDate = this.model ? this.model.focusDate : null;\n\n      this.model = model;\n\n      // handling selection change\n      if (isChangedDate(newSelectedDate, this._controlValue)) {\n        this._controlValue = newSelectedDate;\n        this.onTouched();\n        this.onChange(this._ngbDateAdapter.toModel(newSelectedDate));\n      }\n\n      // handling focus change\n      if (isChangedDate(newFocusedDate, oldFocusedDate) && oldFocusedDate && model.focusVisible) {\n        this.focus();\n      }\n\n      cd.markForCheck();\n    });\n  }\n\n  /**\n   *  Returns the readonly public state of the datepicker\n   *\n   * @since 5.2.0\n   */\n  get state(): NgbDatepickerState { return this._publicState; }\n\n  /**\n   *  Focuses on given date.\n   */\n  focusDate(date: NgbDateStruct): void { this._service.focus(NgbDate.from(date)); }\n\n  /**\n   *  Selects focused date.\n   */\n  focusSelect(): void { this._service.focusSelect(); }\n\n  focus() {\n    this._ngZone.onStable.asObservable().pipe(take(1)).subscribe(() => {\n      const elementToFocus =\n          this._elementRef.nativeElement.querySelector<HTMLDivElement>('div.ngb-dp-day[tabindex=\"0\"]');\n      if (elementToFocus) {\n        elementToFocus.focus();\n      }\n    });\n  }\n\n  /**\n   * Navigates to the provided date.\n   *\n   * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.\n   * If nothing or invalid date provided calendar will open current month.\n   *\n   * Use the `[startDate]` input as an alternative.\n   */\n  navigateTo(date?: {year: number, month: number, day?: number}) {\n    this._service.open(NgbDate.from(date ? date.day ? date as NgbDateStruct : {...date, day: 1} : null));\n  }\n\n  ngAfterViewInit() {\n    this._ngZone.runOutsideAngular(() => {\n      const focusIns$ = fromEvent<FocusEvent>(this._monthsEl.nativeElement, 'focusin');\n      const focusOuts$ = fromEvent<FocusEvent>(this._monthsEl.nativeElement, 'focusout');\n      const {nativeElement} = this._elementRef;\n\n      // we're changing 'focusVisible' only when entering or leaving months view\n      // and ignoring all focus events where both 'target' and 'related' target are day cells\n      merge(focusIns$, focusOuts$)\n          .pipe(\n              filter(\n                  ({target, relatedTarget}) =>\n                      !(hasClassName(target, 'ngb-dp-day') && hasClassName(relatedTarget, 'ngb-dp-day') &&\n                        nativeElement.contains(target as Node) && nativeElement.contains(relatedTarget as Node))),\n              takeUntil(this._destroyed$))\n          .subscribe(({type}) => this._ngZone.run(() => this._service.set({focusVisible: type === 'focusin'})));\n    });\n  }\n\n  ngOnDestroy() { this._destroyed$.next(); }\n\n  ngOnInit() {\n    if (this.model === undefined) {\n      const inputs: DatepickerServiceInputs = {};\n      ['dayTemplateData', 'displayMonths', 'markDisabled', 'firstDayOfWeek', 'navigation', 'minDate', 'maxDate',\n       'outsideDays']\n          .forEach(name => inputs[name] = this[name]);\n      this._service.set(inputs);\n\n      this.navigateTo(this.startDate);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const inputs: DatepickerServiceInputs = {};\n    ['dayTemplateData', 'displayMonths', 'markDisabled', 'firstDayOfWeek', 'navigation', 'minDate', 'maxDate',\n     'outsideDays']\n        .filter(name => name in changes)\n        .forEach(name => inputs[name] = this[name]);\n    this._service.set(inputs);\n\n    if ('startDate' in changes) {\n      const {currentValue, previousValue} = changes.startDate;\n      if (isChangedMonth(previousValue, currentValue)) {\n        this.navigateTo(this.startDate);\n      }\n    }\n  }\n\n  onDateSelect(date: NgbDate) {\n    this._service.focus(date);\n    this._service.select(date, {emitEvent: true});\n  }\n\n  onKeyDown(event: KeyboardEvent) { this._keyboardService.processKey(event, this, this._calendar); }\n\n  onNavigateDateSelect(date: NgbDate) { this._service.open(date); }\n\n  onNavigateEvent(event: NavigationEvent) {\n    switch (event) {\n      case NavigationEvent.PREV:\n        this._service.open(this._calendar.getPrev(this.model.firstDate, 'm', 1));\n        break;\n      case NavigationEvent.NEXT:\n        this._service.open(this._calendar.getNext(this.model.firstDate, 'm', 1));\n        break;\n    }\n  }\n\n  registerOnChange(fn: (value: any) => any): void { this.onChange = fn; }\n\n  registerOnTouched(fn: () => any): void { this.onTouched = fn; }\n\n  setDisabledState(disabled: boolean) { this._service.set({disabled}); }\n\n  writeValue(value) {\n    this._controlValue = NgbDate.from(this._ngbDateAdapter.fromModel(value));\n    this._service.select(this._controlValue);\n  }\n}\n"]}