You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
495 lines
67 KiB
495 lines
67 KiB
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
import { DateAdapter, MAT_DATE_FORMATS, } from '@angular/material/core';
|
|
import { Subject } from 'rxjs';
|
|
import { createMissingDateImplError } from './datepicker-errors';
|
|
import { MatDatepickerIntl } from './datepicker-intl';
|
|
import { MatMonthView } from './month-view';
|
|
import { getActiveOffset, isSameMultiYearView, MatMultiYearView, yearsPerPage } from './multi-year-view';
|
|
import { MatYearView } from './year-view';
|
|
import { MAT_SINGLE_DATE_SELECTION_MODEL_PROVIDER, DateRange } from './date-selection-model';
|
|
/** Counter used to generate unique IDs. */
|
|
import * as ɵngcc0 from '@angular/core';
|
|
import * as ɵngcc1 from './datepicker-intl';
|
|
import * as ɵngcc2 from '@angular/material/core';
|
|
import * as ɵngcc3 from '@angular/material/button';
|
|
import * as ɵngcc4 from '@angular/cdk/a11y';
|
|
import * as ɵngcc5 from '@angular/cdk/portal';
|
|
import * as ɵngcc6 from '@angular/common';
|
|
import * as ɵngcc7 from './month-view';
|
|
import * as ɵngcc8 from './year-view';
|
|
import * as ɵngcc9 from './multi-year-view';
|
|
|
|
const _c0 = ["*"];
|
|
function MatCalendar_ng_template_0_Template(rf, ctx) { }
|
|
function MatCalendar_mat_month_view_2_Template(rf, ctx) { if (rf & 1) {
|
|
const _r5 = ɵngcc0.ɵɵgetCurrentView();
|
|
ɵngcc0.ɵɵelementStart(0, "mat-month-view", 5);
|
|
ɵngcc0.ɵɵlistener("activeDateChange", function MatCalendar_mat_month_view_2_Template_mat_month_view_activeDateChange_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r5); const ctx_r4 = ɵngcc0.ɵɵnextContext(); return ctx_r4.activeDate = $event; })("_userSelection", function MatCalendar_mat_month_view_2_Template_mat_month_view__userSelection_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r5); const ctx_r6 = ɵngcc0.ɵɵnextContext(); return ctx_r6._dateSelected($event); });
|
|
ɵngcc0.ɵɵelementEnd();
|
|
} if (rf & 2) {
|
|
const ctx_r1 = ɵngcc0.ɵɵnextContext();
|
|
ɵngcc0.ɵɵproperty("activeDate", ctx_r1.activeDate)("selected", ctx_r1.selected)("dateFilter", ctx_r1.dateFilter)("maxDate", ctx_r1.maxDate)("minDate", ctx_r1.minDate)("dateClass", ctx_r1.dateClass)("comparisonStart", ctx_r1.comparisonStart)("comparisonEnd", ctx_r1.comparisonEnd);
|
|
} }
|
|
function MatCalendar_mat_year_view_3_Template(rf, ctx) { if (rf & 1) {
|
|
const _r8 = ɵngcc0.ɵɵgetCurrentView();
|
|
ɵngcc0.ɵɵelementStart(0, "mat-year-view", 6);
|
|
ɵngcc0.ɵɵlistener("activeDateChange", function MatCalendar_mat_year_view_3_Template_mat_year_view_activeDateChange_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r8); const ctx_r7 = ɵngcc0.ɵɵnextContext(); return ctx_r7.activeDate = $event; })("monthSelected", function MatCalendar_mat_year_view_3_Template_mat_year_view_monthSelected_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r8); const ctx_r9 = ɵngcc0.ɵɵnextContext(); return ctx_r9._monthSelectedInYearView($event); })("selectedChange", function MatCalendar_mat_year_view_3_Template_mat_year_view_selectedChange_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r8); const ctx_r10 = ɵngcc0.ɵɵnextContext(); return ctx_r10._goToDateInView($event, "month"); });
|
|
ɵngcc0.ɵɵelementEnd();
|
|
} if (rf & 2) {
|
|
const ctx_r2 = ɵngcc0.ɵɵnextContext();
|
|
ɵngcc0.ɵɵproperty("activeDate", ctx_r2.activeDate)("selected", ctx_r2.selected)("dateFilter", ctx_r2.dateFilter)("maxDate", ctx_r2.maxDate)("minDate", ctx_r2.minDate)("dateClass", ctx_r2.dateClass);
|
|
} }
|
|
function MatCalendar_mat_multi_year_view_4_Template(rf, ctx) { if (rf & 1) {
|
|
const _r12 = ɵngcc0.ɵɵgetCurrentView();
|
|
ɵngcc0.ɵɵelementStart(0, "mat-multi-year-view", 7);
|
|
ɵngcc0.ɵɵlistener("activeDateChange", function MatCalendar_mat_multi_year_view_4_Template_mat_multi_year_view_activeDateChange_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r12); const ctx_r11 = ɵngcc0.ɵɵnextContext(); return ctx_r11.activeDate = $event; })("yearSelected", function MatCalendar_mat_multi_year_view_4_Template_mat_multi_year_view_yearSelected_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r12); const ctx_r13 = ɵngcc0.ɵɵnextContext(); return ctx_r13._yearSelectedInMultiYearView($event); })("selectedChange", function MatCalendar_mat_multi_year_view_4_Template_mat_multi_year_view_selectedChange_0_listener($event) { ɵngcc0.ɵɵrestoreView(_r12); const ctx_r14 = ɵngcc0.ɵɵnextContext(); return ctx_r14._goToDateInView($event, "year"); });
|
|
ɵngcc0.ɵɵelementEnd();
|
|
} if (rf & 2) {
|
|
const ctx_r3 = ɵngcc0.ɵɵnextContext();
|
|
ɵngcc0.ɵɵproperty("activeDate", ctx_r3.activeDate)("selected", ctx_r3.selected)("dateFilter", ctx_r3.dateFilter)("maxDate", ctx_r3.maxDate)("minDate", ctx_r3.minDate)("dateClass", ctx_r3.dateClass);
|
|
} }
|
|
let uniqueId = 0;
|
|
/** Default header for MatCalendar */
|
|
export class MatCalendarHeader {
|
|
constructor(_intl, calendar, _dateAdapter, _dateFormats, changeDetectorRef) {
|
|
this._intl = _intl;
|
|
this.calendar = calendar;
|
|
this._dateAdapter = _dateAdapter;
|
|
this._dateFormats = _dateFormats;
|
|
this._buttonDescriptionId = `mat-calendar-button-${uniqueId++}`;
|
|
this.calendar.stateChanges.subscribe(() => changeDetectorRef.markForCheck());
|
|
}
|
|
/** The label for the current calendar view. */
|
|
get periodButtonText() {
|
|
if (this.calendar.currentView == 'month') {
|
|
return this._dateAdapter
|
|
.format(this.calendar.activeDate, this._dateFormats.display.monthYearLabel)
|
|
.toLocaleUpperCase();
|
|
}
|
|
if (this.calendar.currentView == 'year') {
|
|
return this._dateAdapter.getYearName(this.calendar.activeDate);
|
|
}
|
|
// The offset from the active year to the "slot" for the starting year is the
|
|
// *actual* first rendered year in the multi-year view, and the last year is
|
|
// just yearsPerPage - 1 away.
|
|
const activeYear = this._dateAdapter.getYear(this.calendar.activeDate);
|
|
const minYearOfPage = activeYear - getActiveOffset(this._dateAdapter, this.calendar.activeDate, this.calendar.minDate, this.calendar.maxDate);
|
|
const maxYearOfPage = minYearOfPage + yearsPerPage - 1;
|
|
const minYearName = this._dateAdapter.getYearName(this._dateAdapter.createDate(minYearOfPage, 0, 1));
|
|
const maxYearName = this._dateAdapter.getYearName(this._dateAdapter.createDate(maxYearOfPage, 0, 1));
|
|
return this._intl.formatYearRange(minYearName, maxYearName);
|
|
}
|
|
get periodButtonLabel() {
|
|
return this.calendar.currentView == 'month' ?
|
|
this._intl.switchToMultiYearViewLabel : this._intl.switchToMonthViewLabel;
|
|
}
|
|
/** The label for the previous button. */
|
|
get prevButtonLabel() {
|
|
return {
|
|
'month': this._intl.prevMonthLabel,
|
|
'year': this._intl.prevYearLabel,
|
|
'multi-year': this._intl.prevMultiYearLabel
|
|
}[this.calendar.currentView];
|
|
}
|
|
/** The label for the next button. */
|
|
get nextButtonLabel() {
|
|
return {
|
|
'month': this._intl.nextMonthLabel,
|
|
'year': this._intl.nextYearLabel,
|
|
'multi-year': this._intl.nextMultiYearLabel
|
|
}[this.calendar.currentView];
|
|
}
|
|
/** Handles user clicks on the period label. */
|
|
currentPeriodClicked() {
|
|
this.calendar.currentView = this.calendar.currentView == 'month' ? 'multi-year' : 'month';
|
|
}
|
|
/** Handles user clicks on the previous button. */
|
|
previousClicked() {
|
|
this.calendar.activeDate = this.calendar.currentView == 'month' ?
|
|
this._dateAdapter.addCalendarMonths(this.calendar.activeDate, -1) :
|
|
this._dateAdapter.addCalendarYears(this.calendar.activeDate, this.calendar.currentView == 'year' ? -1 : -yearsPerPage);
|
|
}
|
|
/** Handles user clicks on the next button. */
|
|
nextClicked() {
|
|
this.calendar.activeDate = this.calendar.currentView == 'month' ?
|
|
this._dateAdapter.addCalendarMonths(this.calendar.activeDate, 1) :
|
|
this._dateAdapter.addCalendarYears(this.calendar.activeDate, this.calendar.currentView == 'year' ? 1 : yearsPerPage);
|
|
}
|
|
/** Whether the previous period button is enabled. */
|
|
previousEnabled() {
|
|
if (!this.calendar.minDate) {
|
|
return true;
|
|
}
|
|
return !this.calendar.minDate ||
|
|
!this._isSameView(this.calendar.activeDate, this.calendar.minDate);
|
|
}
|
|
/** Whether the next period button is enabled. */
|
|
nextEnabled() {
|
|
return !this.calendar.maxDate ||
|
|
!this._isSameView(this.calendar.activeDate, this.calendar.maxDate);
|
|
}
|
|
/** Whether the two dates represent the same view in the current view mode (month or year). */
|
|
_isSameView(date1, date2) {
|
|
if (this.calendar.currentView == 'month') {
|
|
return this._dateAdapter.getYear(date1) == this._dateAdapter.getYear(date2) &&
|
|
this._dateAdapter.getMonth(date1) == this._dateAdapter.getMonth(date2);
|
|
}
|
|
if (this.calendar.currentView == 'year') {
|
|
return this._dateAdapter.getYear(date1) == this._dateAdapter.getYear(date2);
|
|
}
|
|
// Otherwise we are in 'multi-year' view.
|
|
return isSameMultiYearView(this._dateAdapter, date1, date2, this.calendar.minDate, this.calendar.maxDate);
|
|
}
|
|
}
|
|
MatCalendarHeader.ɵfac = function MatCalendarHeader_Factory(t) { return new (t || MatCalendarHeader)(ɵngcc0.ɵɵdirectiveInject(ɵngcc1.MatDatepickerIntl), ɵngcc0.ɵɵdirectiveInject(forwardRef(() => MatCalendar)), ɵngcc0.ɵɵdirectiveInject(ɵngcc2.DateAdapter, 8), ɵngcc0.ɵɵdirectiveInject(MAT_DATE_FORMATS, 8), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ChangeDetectorRef)); };
|
|
MatCalendarHeader.ɵcmp = /*@__PURE__*/ ɵngcc0.ɵɵdefineComponent({ type: MatCalendarHeader, selectors: [["mat-calendar-header"]], exportAs: ["matCalendarHeader"], ngContentSelectors: _c0, decls: 10, vars: 10, consts: [[1, "mat-calendar-header"], [1, "mat-calendar-controls"], ["mat-button", "", "type", "button", "cdkAriaLive", "polite", 1, "mat-calendar-period-button", 3, "click"], [1, "mat-calendar-arrow"], [1, "mat-calendar-spacer"], ["mat-icon-button", "", "type", "button", 1, "mat-calendar-previous-button", 3, "disabled", "click"], ["mat-icon-button", "", "type", "button", 1, "mat-calendar-next-button", 3, "disabled", "click"]], template: function MatCalendarHeader_Template(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵprojectionDef();
|
|
ɵngcc0.ɵɵelementStart(0, "div", 0);
|
|
ɵngcc0.ɵɵelementStart(1, "div", 1);
|
|
ɵngcc0.ɵɵelementStart(2, "button", 2);
|
|
ɵngcc0.ɵɵlistener("click", function MatCalendarHeader_Template_button_click_2_listener() { return ctx.currentPeriodClicked(); });
|
|
ɵngcc0.ɵɵelementStart(3, "span");
|
|
ɵngcc0.ɵɵtext(4);
|
|
ɵngcc0.ɵɵelementEnd();
|
|
ɵngcc0.ɵɵelement(5, "div", 3);
|
|
ɵngcc0.ɵɵelementEnd();
|
|
ɵngcc0.ɵɵelement(6, "div", 4);
|
|
ɵngcc0.ɵɵprojection(7);
|
|
ɵngcc0.ɵɵelementStart(8, "button", 5);
|
|
ɵngcc0.ɵɵlistener("click", function MatCalendarHeader_Template_button_click_8_listener() { return ctx.previousClicked(); });
|
|
ɵngcc0.ɵɵelementEnd();
|
|
ɵngcc0.ɵɵelementStart(9, "button", 6);
|
|
ɵngcc0.ɵɵlistener("click", function MatCalendarHeader_Template_button_click_9_listener() { return ctx.nextClicked(); });
|
|
ɵngcc0.ɵɵelementEnd();
|
|
ɵngcc0.ɵɵelementEnd();
|
|
ɵngcc0.ɵɵelementEnd();
|
|
} if (rf & 2) {
|
|
ɵngcc0.ɵɵadvance(2);
|
|
ɵngcc0.ɵɵattribute("aria-label", ctx.periodButtonLabel)("aria-describedby", ctx._buttonDescriptionId);
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵattribute("id", ctx._buttonDescriptionId);
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵtextInterpolate(ctx.periodButtonText);
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵclassProp("mat-calendar-invert", ctx.calendar.currentView !== "month");
|
|
ɵngcc0.ɵɵadvance(3);
|
|
ɵngcc0.ɵɵproperty("disabled", !ctx.previousEnabled());
|
|
ɵngcc0.ɵɵattribute("aria-label", ctx.prevButtonLabel);
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵproperty("disabled", !ctx.nextEnabled());
|
|
ɵngcc0.ɵɵattribute("aria-label", ctx.nextButtonLabel);
|
|
} }, directives: [ɵngcc3.MatButton, ɵngcc4.CdkAriaLive], encapsulation: 2, changeDetection: 0 });
|
|
MatCalendarHeader.ctorParameters = () => [
|
|
{ type: MatDatepickerIntl },
|
|
{ type: MatCalendar, decorators: [{ type: Inject, args: [forwardRef(() => MatCalendar),] }] },
|
|
{ type: DateAdapter, decorators: [{ type: Optional }] },
|
|
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [MAT_DATE_FORMATS,] }] },
|
|
{ type: ChangeDetectorRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatCalendarHeader, [{
|
|
type: Component,
|
|
args: [{
|
|
selector: 'mat-calendar-header',
|
|
template: "<div class=\"mat-calendar-header\">\n <div class=\"mat-calendar-controls\">\n <button mat-button type=\"button\" class=\"mat-calendar-period-button\"\n (click)=\"currentPeriodClicked()\" [attr.aria-label]=\"periodButtonLabel\"\n [attr.aria-describedby]=\"_buttonDescriptionId\"\n cdkAriaLive=\"polite\">\n <span [attr.id]=\"_buttonDescriptionId\">{{periodButtonText}}</span>\n <div class=\"mat-calendar-arrow\"\n [class.mat-calendar-invert]=\"calendar.currentView !== 'month'\"></div>\n </button>\n\n <div class=\"mat-calendar-spacer\"></div>\n\n <ng-content></ng-content>\n\n <button mat-icon-button type=\"button\" class=\"mat-calendar-previous-button\"\n [disabled]=\"!previousEnabled()\" (click)=\"previousClicked()\"\n [attr.aria-label]=\"prevButtonLabel\">\n </button>\n\n <button mat-icon-button type=\"button\" class=\"mat-calendar-next-button\"\n [disabled]=\"!nextEnabled()\" (click)=\"nextClicked()\"\n [attr.aria-label]=\"nextButtonLabel\">\n </button>\n </div>\n</div>\n",
|
|
exportAs: 'matCalendarHeader',
|
|
encapsulation: ViewEncapsulation.None,
|
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
}]
|
|
}], function () { return [{ type: ɵngcc1.MatDatepickerIntl }, { type: MatCalendar, decorators: [{
|
|
type: Inject,
|
|
args: [forwardRef(() => MatCalendar)]
|
|
}] }, { type: ɵngcc2.DateAdapter, decorators: [{
|
|
type: Optional
|
|
}] }, { type: undefined, decorators: [{
|
|
type: Optional
|
|
}, {
|
|
type: Inject,
|
|
args: [MAT_DATE_FORMATS]
|
|
}] }, { type: ɵngcc0.ChangeDetectorRef }]; }, null); })();
|
|
/** A calendar that is used as part of the datepicker. */
|
|
export class MatCalendar {
|
|
constructor(_intl, _dateAdapter, _dateFormats, _changeDetectorRef) {
|
|
this._dateAdapter = _dateAdapter;
|
|
this._dateFormats = _dateFormats;
|
|
this._changeDetectorRef = _changeDetectorRef;
|
|
/**
|
|
* 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;
|
|
/** Whether the calendar should be started in month or year view. */
|
|
this.startView = 'month';
|
|
/** Emits when the currently selected date changes. */
|
|
this.selectedChange = new EventEmitter();
|
|
/**
|
|
* Emits the year chosen in multiyear view.
|
|
* This doesn't imply a change on the selected date.
|
|
*/
|
|
this.yearSelected = new EventEmitter();
|
|
/**
|
|
* Emits the month chosen in year view.
|
|
* This doesn't imply a change on the selected date.
|
|
*/
|
|
this.monthSelected = new EventEmitter();
|
|
/**
|
|
* Emits when the current view changes.
|
|
*/
|
|
this.viewChanged = new EventEmitter(true);
|
|
/** Emits when any date is selected. */
|
|
this._userSelection = new EventEmitter();
|
|
/**
|
|
* Emits whenever there is a state change that the header may need to respond to.
|
|
*/
|
|
this.stateChanges = new Subject();
|
|
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
if (!this._dateAdapter) {
|
|
throw createMissingDateImplError('DateAdapter');
|
|
}
|
|
if (!this._dateFormats) {
|
|
throw createMissingDateImplError('MAT_DATE_FORMATS');
|
|
}
|
|
}
|
|
this._intlChanges = _intl.changes.subscribe(() => {
|
|
_changeDetectorRef.markForCheck();
|
|
this.stateChanges.next();
|
|
});
|
|
}
|
|
/** A date representing the period (month or year) to start the calendar in. */
|
|
get startAt() { return this._startAt; }
|
|
set startAt(value) {
|
|
this._startAt = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
}
|
|
/** The currently selected date. */
|
|
get selected() { return this._selected; }
|
|
set selected(value) {
|
|
if (value instanceof DateRange) {
|
|
this._selected = value;
|
|
}
|
|
else {
|
|
this._selected = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
}
|
|
}
|
|
/** The minimum selectable date. */
|
|
get minDate() { return this._minDate; }
|
|
set minDate(value) {
|
|
this._minDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
}
|
|
/** The maximum selectable date. */
|
|
get maxDate() { return this._maxDate; }
|
|
set maxDate(value) {
|
|
this._maxDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
|
}
|
|
/**
|
|
* The current active date. This determines which time period is shown and which date is
|
|
* highlighted when using keyboard navigation.
|
|
*/
|
|
get activeDate() { return this._clampedActiveDate; }
|
|
set activeDate(value) {
|
|
this._clampedActiveDate = this._dateAdapter.clampDate(value, this.minDate, this.maxDate);
|
|
this.stateChanges.next();
|
|
this._changeDetectorRef.markForCheck();
|
|
}
|
|
/** Whether the calendar is in month view. */
|
|
get currentView() { return this._currentView; }
|
|
set currentView(value) {
|
|
const viewChangedResult = this._currentView !== value ? value : null;
|
|
this._currentView = value;
|
|
this._moveFocusOnNextTick = true;
|
|
this._changeDetectorRef.markForCheck();
|
|
if (viewChangedResult) {
|
|
this.viewChanged.emit(viewChangedResult);
|
|
}
|
|
}
|
|
ngAfterContentInit() {
|
|
this._calendarHeaderPortal = new ComponentPortal(this.headerComponent || MatCalendarHeader);
|
|
this.activeDate = this.startAt || this._dateAdapter.today();
|
|
// Assign to the private property since we don't want to move focus on init.
|
|
this._currentView = this.startView;
|
|
}
|
|
ngAfterViewChecked() {
|
|
if (this._moveFocusOnNextTick) {
|
|
this._moveFocusOnNextTick = false;
|
|
this.focusActiveCell();
|
|
}
|
|
}
|
|
ngOnDestroy() {
|
|
this._intlChanges.unsubscribe();
|
|
this.stateChanges.complete();
|
|
}
|
|
ngOnChanges(changes) {
|
|
const change = changes['minDate'] || changes['maxDate'] || changes['dateFilter'];
|
|
if (change && !change.firstChange) {
|
|
const view = this._getCurrentViewComponent();
|
|
if (view) {
|
|
// We need to `detectChanges` manually here, because the `minDate`, `maxDate` etc. are
|
|
// passed down to the view via data bindings which won't be up-to-date when we call `_init`.
|
|
this._changeDetectorRef.detectChanges();
|
|
view._init();
|
|
}
|
|
}
|
|
this.stateChanges.next();
|
|
}
|
|
/** Focuses the active date. */
|
|
focusActiveCell() {
|
|
this._getCurrentViewComponent()._focusActiveCell(false);
|
|
}
|
|
/** Updates today's date after an update of the active date */
|
|
updateTodaysDate() {
|
|
this._getCurrentViewComponent()._init();
|
|
}
|
|
/** Handles date selection in the month view. */
|
|
_dateSelected(event) {
|
|
const date = event.value;
|
|
if (this.selected instanceof DateRange ||
|
|
(date && !this._dateAdapter.sameDate(date, this.selected))) {
|
|
this.selectedChange.emit(date);
|
|
}
|
|
this._userSelection.emit(event);
|
|
}
|
|
/** Handles year selection in the multiyear view. */
|
|
_yearSelectedInMultiYearView(normalizedYear) {
|
|
this.yearSelected.emit(normalizedYear);
|
|
}
|
|
/** Handles month selection in the year view. */
|
|
_monthSelectedInYearView(normalizedMonth) {
|
|
this.monthSelected.emit(normalizedMonth);
|
|
}
|
|
/** Handles year/month selection in the multi-year/year views. */
|
|
_goToDateInView(date, view) {
|
|
this.activeDate = date;
|
|
this.currentView = view;
|
|
}
|
|
/** Returns the component instance that corresponds to the current calendar view. */
|
|
_getCurrentViewComponent() {
|
|
// The return type is explicitly written as a union to ensure that the Closure compiler does
|
|
// not optimize calls to _init(). Without the explict return type, TypeScript narrows it to
|
|
// only the first component type. See https://github.com/angular/components/issues/22996.
|
|
return this.monthView || this.yearView || this.multiYearView;
|
|
}
|
|
}
|
|
MatCalendar.ɵfac = function MatCalendar_Factory(t) { return new (t || MatCalendar)(ɵngcc0.ɵɵdirectiveInject(ɵngcc1.MatDatepickerIntl), ɵngcc0.ɵɵdirectiveInject(ɵngcc2.DateAdapter, 8), ɵngcc0.ɵɵdirectiveInject(MAT_DATE_FORMATS, 8), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ChangeDetectorRef)); };
|
|
MatCalendar.ɵcmp = /*@__PURE__*/ ɵngcc0.ɵɵdefineComponent({ type: MatCalendar, selectors: [["mat-calendar"]], viewQuery: function MatCalendar_Query(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵviewQuery(MatMonthView, 5);
|
|
ɵngcc0.ɵɵviewQuery(MatYearView, 5);
|
|
ɵngcc0.ɵɵviewQuery(MatMultiYearView, 5);
|
|
} if (rf & 2) {
|
|
let _t;
|
|
ɵngcc0.ɵɵqueryRefresh(_t = ɵngcc0.ɵɵloadQuery()) && (ctx.monthView = _t.first);
|
|
ɵngcc0.ɵɵqueryRefresh(_t = ɵngcc0.ɵɵloadQuery()) && (ctx.yearView = _t.first);
|
|
ɵngcc0.ɵɵqueryRefresh(_t = ɵngcc0.ɵɵloadQuery()) && (ctx.multiYearView = _t.first);
|
|
} }, hostAttrs: [1, "mat-calendar"], inputs: { startView: "startView", startAt: "startAt", selected: "selected", minDate: "minDate", maxDate: "maxDate", headerComponent: "headerComponent", dateFilter: "dateFilter", dateClass: "dateClass", comparisonStart: "comparisonStart", comparisonEnd: "comparisonEnd" }, outputs: { selectedChange: "selectedChange", yearSelected: "yearSelected", monthSelected: "monthSelected", viewChanged: "viewChanged", _userSelection: "_userSelection" }, exportAs: ["matCalendar"], features: [ɵngcc0.ɵɵProvidersFeature([MAT_SINGLE_DATE_SELECTION_MODEL_PROVIDER]), ɵngcc0.ɵɵNgOnChangesFeature], decls: 5, vars: 5, consts: [[3, "cdkPortalOutlet"], ["cdkMonitorSubtreeFocus", "", "tabindex", "-1", 1, "mat-calendar-content", 3, "ngSwitch"], [3, "activeDate", "selected", "dateFilter", "maxDate", "minDate", "dateClass", "comparisonStart", "comparisonEnd", "activeDateChange", "_userSelection", 4, "ngSwitchCase"], [3, "activeDate", "selected", "dateFilter", "maxDate", "minDate", "dateClass", "activeDateChange", "monthSelected", "selectedChange", 4, "ngSwitchCase"], [3, "activeDate", "selected", "dateFilter", "maxDate", "minDate", "dateClass", "activeDateChange", "yearSelected", "selectedChange", 4, "ngSwitchCase"], [3, "activeDate", "selected", "dateFilter", "maxDate", "minDate", "dateClass", "comparisonStart", "comparisonEnd", "activeDateChange", "_userSelection"], [3, "activeDate", "selected", "dateFilter", "maxDate", "minDate", "dateClass", "activeDateChange", "monthSelected", "selectedChange"], [3, "activeDate", "selected", "dateFilter", "maxDate", "minDate", "dateClass", "activeDateChange", "yearSelected", "selectedChange"]], template: function MatCalendar_Template(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵtemplate(0, MatCalendar_ng_template_0_Template, 0, 0, "ng-template", 0);
|
|
ɵngcc0.ɵɵelementStart(1, "div", 1);
|
|
ɵngcc0.ɵɵtemplate(2, MatCalendar_mat_month_view_2_Template, 1, 8, "mat-month-view", 2);
|
|
ɵngcc0.ɵɵtemplate(3, MatCalendar_mat_year_view_3_Template, 1, 6, "mat-year-view", 3);
|
|
ɵngcc0.ɵɵtemplate(4, MatCalendar_mat_multi_year_view_4_Template, 1, 6, "mat-multi-year-view", 4);
|
|
ɵngcc0.ɵɵelementEnd();
|
|
} if (rf & 2) {
|
|
ɵngcc0.ɵɵproperty("cdkPortalOutlet", ctx._calendarHeaderPortal);
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵproperty("ngSwitch", ctx.currentView);
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵproperty("ngSwitchCase", "month");
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵproperty("ngSwitchCase", "year");
|
|
ɵngcc0.ɵɵadvance(1);
|
|
ɵngcc0.ɵɵproperty("ngSwitchCase", "multi-year");
|
|
} }, directives: [ɵngcc5.CdkPortalOutlet, ɵngcc4.CdkMonitorFocus, ɵngcc6.NgSwitch, ɵngcc6.NgSwitchCase, ɵngcc7.MatMonthView, ɵngcc8.MatYearView, ɵngcc9.MatMultiYearView], styles: [".mat-calendar{display:block}.mat-calendar-header{padding:8px 8px 0 8px}.mat-calendar-content{padding:0 8px 8px 8px;outline:none}.mat-calendar-controls{display:flex;margin:5% calc(33% / 7 - 16px)}.mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:.04}.mat-calendar-spacer{flex:1 1 auto}.mat-calendar-period-button{min-width:0}.mat-calendar-arrow{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top-width:5px;border-top-style:solid;margin:0 0 0 5px;vertical-align:middle}.mat-calendar-arrow.mat-calendar-invert{transform:rotate(180deg)}[dir=rtl] .mat-calendar-arrow{margin:0 5px 0 0}.mat-calendar-previous-button,.mat-calendar-next-button{position:relative}.mat-calendar-previous-button::after,.mat-calendar-next-button::after{top:0;left:0;right:0;bottom:0;position:absolute;content:\"\";margin:15.5px;border:0 solid currentColor;border-top-width:2px}[dir=rtl] .mat-calendar-previous-button,[dir=rtl] .mat-calendar-next-button{transform:rotate(180deg)}.mat-calendar-previous-button::after{border-left-width:2px;transform:translateX(2px) rotate(-45deg)}.mat-calendar-next-button::after{border-right-width:2px;transform:translateX(-2px) rotate(45deg)}.mat-calendar-table{border-spacing:0;border-collapse:collapse;width:100%}.mat-calendar-table-header th{text-align:center;padding:0 0 8px 0}.mat-calendar-table-header-divider{position:relative;height:1px}.mat-calendar-table-header-divider::after{content:\"\";position:absolute;top:0;left:-8px;right:-8px;height:1px}.mat-calendar-abbr{text-decoration:none}\n"], encapsulation: 2, changeDetection: 0 });
|
|
MatCalendar.ctorParameters = () => [
|
|
{ type: MatDatepickerIntl },
|
|
{ type: DateAdapter, decorators: [{ type: Optional }] },
|
|
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [MAT_DATE_FORMATS,] }] },
|
|
{ type: ChangeDetectorRef }
|
|
];
|
|
MatCalendar.propDecorators = {
|
|
headerComponent: [{ type: Input }],
|
|
startAt: [{ type: Input }],
|
|
startView: [{ type: Input }],
|
|
selected: [{ type: Input }],
|
|
minDate: [{ type: Input }],
|
|
maxDate: [{ type: Input }],
|
|
dateFilter: [{ type: Input }],
|
|
dateClass: [{ type: Input }],
|
|
comparisonStart: [{ type: Input }],
|
|
comparisonEnd: [{ type: Input }],
|
|
selectedChange: [{ type: Output }],
|
|
yearSelected: [{ type: Output }],
|
|
monthSelected: [{ type: Output }],
|
|
viewChanged: [{ type: Output }],
|
|
_userSelection: [{ type: Output }],
|
|
monthView: [{ type: ViewChild, args: [MatMonthView,] }],
|
|
yearView: [{ type: ViewChild, args: [MatYearView,] }],
|
|
multiYearView: [{ type: ViewChild, args: [MatMultiYearView,] }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatCalendar, [{
|
|
type: Component,
|
|
args: [{
|
|
selector: 'mat-calendar',
|
|
template: "<ng-template [cdkPortalOutlet]=\"_calendarHeaderPortal\"></ng-template>\n\n<div class=\"mat-calendar-content\" [ngSwitch]=\"currentView\" cdkMonitorSubtreeFocus tabindex=\"-1\">\n <mat-month-view\n *ngSwitchCase=\"'month'\"\n [(activeDate)]=\"activeDate\"\n [selected]=\"selected\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [dateClass]=\"dateClass\"\n [comparisonStart]=\"comparisonStart\"\n [comparisonEnd]=\"comparisonEnd\"\n (_userSelection)=\"_dateSelected($event)\">\n </mat-month-view>\n\n <mat-year-view\n *ngSwitchCase=\"'year'\"\n [(activeDate)]=\"activeDate\"\n [selected]=\"selected\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [dateClass]=\"dateClass\"\n (monthSelected)=\"_monthSelectedInYearView($event)\"\n (selectedChange)=\"_goToDateInView($event, 'month')\">\n </mat-year-view>\n\n <mat-multi-year-view\n *ngSwitchCase=\"'multi-year'\"\n [(activeDate)]=\"activeDate\"\n [selected]=\"selected\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [dateClass]=\"dateClass\"\n (yearSelected)=\"_yearSelectedInMultiYearView($event)\"\n (selectedChange)=\"_goToDateInView($event, 'year')\">\n </mat-multi-year-view>\n</div>\n",
|
|
host: {
|
|
'class': 'mat-calendar'
|
|
},
|
|
exportAs: 'matCalendar',
|
|
encapsulation: ViewEncapsulation.None,
|
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
providers: [MAT_SINGLE_DATE_SELECTION_MODEL_PROVIDER],
|
|
styles: [".mat-calendar{display:block}.mat-calendar-header{padding:8px 8px 0 8px}.mat-calendar-content{padding:0 8px 8px 8px;outline:none}.mat-calendar-controls{display:flex;margin:5% calc(33% / 7 - 16px)}.mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:.04}.mat-calendar-spacer{flex:1 1 auto}.mat-calendar-period-button{min-width:0}.mat-calendar-arrow{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top-width:5px;border-top-style:solid;margin:0 0 0 5px;vertical-align:middle}.mat-calendar-arrow.mat-calendar-invert{transform:rotate(180deg)}[dir=rtl] .mat-calendar-arrow{margin:0 5px 0 0}.mat-calendar-previous-button,.mat-calendar-next-button{position:relative}.mat-calendar-previous-button::after,.mat-calendar-next-button::after{top:0;left:0;right:0;bottom:0;position:absolute;content:\"\";margin:15.5px;border:0 solid currentColor;border-top-width:2px}[dir=rtl] .mat-calendar-previous-button,[dir=rtl] .mat-calendar-next-button{transform:rotate(180deg)}.mat-calendar-previous-button::after{border-left-width:2px;transform:translateX(2px) rotate(-45deg)}.mat-calendar-next-button::after{border-right-width:2px;transform:translateX(-2px) rotate(45deg)}.mat-calendar-table{border-spacing:0;border-collapse:collapse;width:100%}.mat-calendar-table-header th{text-align:center;padding:0 0 8px 0}.mat-calendar-table-header-divider{position:relative;height:1px}.mat-calendar-table-header-divider::after{content:\"\";position:absolute;top:0;left:-8px;right:-8px;height:1px}.mat-calendar-abbr{text-decoration:none}\n"]
|
|
}]
|
|
}], function () { return [{ type: ɵngcc1.MatDatepickerIntl }, { type: ɵngcc2.DateAdapter, decorators: [{
|
|
type: Optional
|
|
}] }, { type: undefined, decorators: [{
|
|
type: Optional
|
|
}, {
|
|
type: Inject,
|
|
args: [MAT_DATE_FORMATS]
|
|
}] }, { type: ɵngcc0.ChangeDetectorRef }]; }, { startView: [{
|
|
type: Input
|
|
}], selectedChange: [{
|
|
type: Output
|
|
}], yearSelected: [{
|
|
type: Output
|
|
}], monthSelected: [{
|
|
type: Output
|
|
}], viewChanged: [{
|
|
type: Output
|
|
}], _userSelection: [{
|
|
type: Output
|
|
}], startAt: [{
|
|
type: Input
|
|
}], selected: [{
|
|
type: Input
|
|
}], minDate: [{
|
|
type: Input
|
|
}], maxDate: [{
|
|
type: Input
|
|
}], headerComponent: [{
|
|
type: Input
|
|
}], dateFilter: [{
|
|
type: Input
|
|
}], dateClass: [{
|
|
type: Input
|
|
}], comparisonStart: [{
|
|
type: Input
|
|
}], comparisonEnd: [{
|
|
type: Input
|
|
}], monthView: [{
|
|
type: ViewChild,
|
|
args: [MatMonthView]
|
|
}], yearView: [{
|
|
type: ViewChild,
|
|
args: [MatYearView]
|
|
}], multiYearView: [{
|
|
type: ViewChild,
|
|
args: [MatMultiYearView]
|
|
}] }); })();
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"calendar.js","sources":["../../../../../../src/material/datepicker/calendar.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ComponentPortal, ComponentType, Portal} from '@angular/cdk/portal';\nimport {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  DateAdapter,\n  MAT_DATE_FORMATS,\n  MatDateFormats,\n} from '@angular/material/core';\nimport {Subject, Subscription} from 'rxjs';\nimport {MatCalendarUserEvent, MatCalendarCellClassFunction} from './calendar-body';\nimport {createMissingDateImplError} from './datepicker-errors';\nimport {MatDatepickerIntl} from './datepicker-intl';\nimport {MatMonthView} from './month-view';\nimport {\n  getActiveOffset,\n  isSameMultiYearView,\n  MatMultiYearView,\n  yearsPerPage\n} from './multi-year-view';\nimport {MatYearView} from './year-view';\nimport {MAT_SINGLE_DATE_SELECTION_MODEL_PROVIDER, DateRange} from './date-selection-model';\n\n/**\n * Possible views for the calendar.\n * @docs-private\n */\nexport type MatCalendarView = 'month' | 'year' | 'multi-year';\n\n/** Counter used to generate unique IDs. */\nlet uniqueId = 0;\n\n/** Default header for MatCalendar */\n@Component({\n  selector: 'mat-calendar-header',\n  templateUrl: 'calendar-header.html',\n  exportAs: 'matCalendarHeader',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MatCalendarHeader<D> {\n  _buttonDescriptionId = `mat-calendar-button-${uniqueId++}`;\n\n  constructor(private _intl: MatDatepickerIntl,\n              @Inject(forwardRef(() => MatCalendar)) public calendar: MatCalendar<D>,\n              @Optional() private _dateAdapter: DateAdapter<D>,\n              @Optional() @Inject(MAT_DATE_FORMATS) private _dateFormats: MatDateFormats,\n              changeDetectorRef: ChangeDetectorRef) {\n\n    this.calendar.stateChanges.subscribe(() => changeDetectorRef.markForCheck());\n  }\n\n  /** The label for the current calendar view. */\n  get periodButtonText(): string {\n    if (this.calendar.currentView == 'month') {\n      return this._dateAdapter\n          .format(this.calendar.activeDate, this._dateFormats.display.monthYearLabel)\n              .toLocaleUpperCase();\n    }\n    if (this.calendar.currentView == 'year') {\n      return this._dateAdapter.getYearName(this.calendar.activeDate);\n    }\n\n    // The offset from the active year to the \"slot\" for the starting year is the\n    // *actual* first rendered year in the multi-year view, and the last year is\n    // just yearsPerPage - 1 away.\n    const activeYear = this._dateAdapter.getYear(this.calendar.activeDate);\n    const minYearOfPage = activeYear - getActiveOffset(\n      this._dateAdapter, this.calendar.activeDate, this.calendar.minDate, this.calendar.maxDate);\n    const maxYearOfPage = minYearOfPage + yearsPerPage - 1;\n    const minYearName =\n      this._dateAdapter.getYearName(this._dateAdapter.createDate(minYearOfPage, 0, 1));\n    const maxYearName =\n      this._dateAdapter.getYearName(this._dateAdapter.createDate(maxYearOfPage, 0, 1));\n    return this._intl.formatYearRange(minYearName, maxYearName);\n  }\n\n  get periodButtonLabel(): string {\n    return this.calendar.currentView == 'month' ?\n        this._intl.switchToMultiYearViewLabel : this._intl.switchToMonthViewLabel;\n  }\n\n  /** The label for the previous button. */\n  get prevButtonLabel(): string {\n    return {\n      'month': this._intl.prevMonthLabel,\n      'year': this._intl.prevYearLabel,\n      'multi-year': this._intl.prevMultiYearLabel\n    }[this.calendar.currentView];\n  }\n\n  /** The label for the next button. */\n  get nextButtonLabel(): string {\n    return {\n      'month': this._intl.nextMonthLabel,\n      'year': this._intl.nextYearLabel,\n      'multi-year': this._intl.nextMultiYearLabel\n    }[this.calendar.currentView];\n  }\n\n  /** Handles user clicks on the period label. */\n  currentPeriodClicked(): void {\n    this.calendar.currentView = this.calendar.currentView == 'month' ? 'multi-year' : 'month';\n  }\n\n  /** Handles user clicks on the previous button. */\n  previousClicked(): void {\n    this.calendar.activeDate = this.calendar.currentView == 'month' ?\n        this._dateAdapter.addCalendarMonths(this.calendar.activeDate, -1) :\n            this._dateAdapter.addCalendarYears(\n                this.calendar.activeDate, this.calendar.currentView == 'year' ? -1 : -yearsPerPage\n            );\n  }\n\n  /** Handles user clicks on the next button. */\n  nextClicked(): void {\n    this.calendar.activeDate = this.calendar.currentView == 'month' ?\n        this._dateAdapter.addCalendarMonths(this.calendar.activeDate, 1) :\n            this._dateAdapter.addCalendarYears(\n                this.calendar.activeDate,\n                    this.calendar.currentView == 'year' ? 1 : yearsPerPage\n            );\n  }\n\n  /** Whether the previous period button is enabled. */\n  previousEnabled(): boolean {\n    if (!this.calendar.minDate) {\n      return true;\n    }\n    return !this.calendar.minDate ||\n        !this._isSameView(this.calendar.activeDate, this.calendar.minDate);\n  }\n\n  /** Whether the next period button is enabled. */\n  nextEnabled(): boolean {\n    return !this.calendar.maxDate ||\n        !this._isSameView(this.calendar.activeDate, this.calendar.maxDate);\n  }\n\n  /** Whether the two dates represent the same view in the current view mode (month or year). */\n  private _isSameView(date1: D, date2: D): boolean {\n    if (this.calendar.currentView == 'month') {\n      return this._dateAdapter.getYear(date1) == this._dateAdapter.getYear(date2) &&\n          this._dateAdapter.getMonth(date1) == this._dateAdapter.getMonth(date2);\n    }\n    if (this.calendar.currentView == 'year') {\n      return this._dateAdapter.getYear(date1) == this._dateAdapter.getYear(date2);\n    }\n    // Otherwise we are in 'multi-year' view.\n    return isSameMultiYearView(\n      this._dateAdapter, date1, date2, this.calendar.minDate, this.calendar.maxDate);\n  }\n}\n\n/** A calendar that is used as part of the datepicker. */\n@Component({\n  selector: 'mat-calendar',\n  templateUrl: 'calendar.html',\n  styleUrls: ['calendar.css'],\n  host: {\n    'class': 'mat-calendar',\n  },\n  exportAs: 'matCalendar',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [MAT_SINGLE_DATE_SELECTION_MODEL_PROVIDER]\n})\nexport class MatCalendar<D> implements AfterContentInit, AfterViewChecked, OnDestroy, OnChanges {\n  /** An input indicating the type of the header component, if set. */\n  @Input() headerComponent: ComponentType<any>;\n\n  /** A portal containing the header component type for this calendar. */\n  _calendarHeaderPortal: Portal<any>;\n\n  private _intlChanges: Subscription;\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  /** A date representing the period (month or year) to start the calendar in. */\n  @Input()\n  get startAt(): D | null { return this._startAt; }\n  set startAt(value: D | null) {\n    this._startAt = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  private _startAt: D | null;\n\n  /** Whether the calendar should be started in month or year view. */\n  @Input() startView: MatCalendarView = 'month';\n\n  /** The currently selected date. */\n  @Input()\n  get selected(): DateRange<D> | D | null { return this._selected; }\n  set selected(value: DateRange<D> | D | null) {\n    if (value instanceof DateRange) {\n      this._selected = value;\n    } else {\n      this._selected = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n    }\n  }\n  private _selected: DateRange<D> | D | null;\n\n  /** The minimum selectable date. */\n  @Input()\n  get minDate(): D | null { return this._minDate; }\n  set minDate(value: D | null) {\n    this._minDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  private _minDate: D | null;\n\n  /** The maximum selectable date. */\n  @Input()\n  get maxDate(): D | null { return this._maxDate; }\n  set maxDate(value: D | null) {\n    this._maxDate = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n  }\n  private _maxDate: D | null;\n\n  /** Function used to filter which dates are selectable. */\n  @Input() dateFilter: (date: D) => boolean;\n\n  /** Function that can be used to add custom CSS classes to dates. */\n  @Input() dateClass: MatCalendarCellClassFunction<D>;\n\n  /** Start of the comparison range. */\n  @Input() comparisonStart: D | null;\n\n  /** End of the comparison range. */\n  @Input() comparisonEnd: D | null;\n\n  /** Emits when the currently selected date changes. */\n  @Output() readonly selectedChange: EventEmitter<D | null> = new EventEmitter<D | null>();\n\n  /**\n   * Emits the year chosen in multiyear view.\n   * This doesn't imply a change on the selected date.\n   */\n  @Output() readonly yearSelected: EventEmitter<D> = new EventEmitter<D>();\n\n  /**\n   * Emits the month chosen in year view.\n   * This doesn't imply a change on the selected date.\n   */\n  @Output() readonly monthSelected: EventEmitter<D> = new EventEmitter<D>();\n\n  /**\n   * Emits when the current view changes.\n   */\n  @Output() readonly viewChanged: EventEmitter<MatCalendarView> =\n    new EventEmitter<MatCalendarView>(true);\n\n  /** Emits when any date is selected. */\n  @Output() readonly _userSelection: EventEmitter<MatCalendarUserEvent<D | null>> =\n      new EventEmitter<MatCalendarUserEvent<D | null>>();\n\n  /** Reference to the current month view component. */\n  @ViewChild(MatMonthView) monthView: MatMonthView<D>;\n\n  /** Reference to the current year view component. */\n  @ViewChild(MatYearView) yearView: MatYearView<D>;\n\n  /** Reference to the current multi-year view component. */\n  @ViewChild(MatMultiYearView) multiYearView: MatMultiYearView<D>;\n\n  /**\n   * The current active date. This determines which time period is shown and which date is\n   * highlighted when using keyboard navigation.\n   */\n  get activeDate(): D { return this._clampedActiveDate; }\n  set activeDate(value: D) {\n    this._clampedActiveDate = this._dateAdapter.clampDate(value, this.minDate, this.maxDate);\n    this.stateChanges.next();\n    this._changeDetectorRef.markForCheck();\n  }\n  private _clampedActiveDate: D;\n\n  /** Whether the calendar is in month view. */\n  get currentView(): MatCalendarView { return this._currentView; }\n  set currentView(value: MatCalendarView) {\n    const viewChangedResult = this._currentView !== value ? value : null;\n    this._currentView = value;\n    this._moveFocusOnNextTick = true;\n    this._changeDetectorRef.markForCheck();\n    if (viewChangedResult) {\n      this.viewChanged.emit(viewChangedResult);\n    }\n  }\n  private _currentView: MatCalendarView;\n\n  /**\n   * Emits whenever there is a state change that the header may need to respond to.\n   */\n  readonly stateChanges = new Subject<void>();\n\n  constructor(_intl: MatDatepickerIntl,\n              @Optional() private _dateAdapter: DateAdapter<D>,\n              @Optional() @Inject(MAT_DATE_FORMATS) private _dateFormats: MatDateFormats,\n              private _changeDetectorRef: ChangeDetectorRef) {\n\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this._dateAdapter) {\n        throw createMissingDateImplError('DateAdapter');\n      }\n\n      if (!this._dateFormats) {\n        throw createMissingDateImplError('MAT_DATE_FORMATS');\n      }\n    }\n\n    this._intlChanges = _intl.changes.subscribe(() => {\n      _changeDetectorRef.markForCheck();\n      this.stateChanges.next();\n    });\n  }\n\n  ngAfterContentInit() {\n    this._calendarHeaderPortal = new ComponentPortal(this.headerComponent || MatCalendarHeader);\n    this.activeDate = this.startAt || this._dateAdapter.today();\n\n    // Assign to the private property since we don't want to move focus on init.\n    this._currentView = this.startView;\n  }\n\n  ngAfterViewChecked() {\n    if (this._moveFocusOnNextTick) {\n      this._moveFocusOnNextTick = false;\n      this.focusActiveCell();\n    }\n  }\n\n  ngOnDestroy() {\n    this._intlChanges.unsubscribe();\n    this.stateChanges.complete();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const change =\n        changes['minDate'] || changes['maxDate'] || changes['dateFilter'];\n\n    if (change && !change.firstChange) {\n      const view = this._getCurrentViewComponent();\n\n      if (view) {\n        // We need to `detectChanges` manually here, because the `minDate`, `maxDate` etc. are\n        // passed down to the view via data bindings which won't be up-to-date when we call `_init`.\n        this._changeDetectorRef.detectChanges();\n        view._init();\n      }\n    }\n\n    this.stateChanges.next();\n  }\n\n  /** Focuses the active date. */\n  focusActiveCell() {\n    this._getCurrentViewComponent()._focusActiveCell(false);\n  }\n\n  /** Updates today's date after an update of the active date */\n  updateTodaysDate() {\n    this._getCurrentViewComponent()._init();\n  }\n\n  /** Handles date selection in the month view. */\n  _dateSelected(event: MatCalendarUserEvent<D | null>): void {\n    const date = event.value;\n\n    if (this.selected instanceof DateRange ||\n        (date && !this._dateAdapter.sameDate(date, this.selected))) {\n      this.selectedChange.emit(date);\n    }\n\n    this._userSelection.emit(event);\n  }\n\n  /** Handles year selection in the multiyear view. */\n  _yearSelectedInMultiYearView(normalizedYear: D) {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  /** Handles month selection in the year view. */\n  _monthSelectedInYearView(normalizedMonth: D) {\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /** Handles year/month selection in the multi-year/year views. */\n  _goToDateInView(date: D, view: 'month' | 'year' | 'multi-year'): void {\n    this.activeDate = date;\n    this.currentView = view;\n  }\n\n  /** Returns the component instance that corresponds to the current calendar view. */\n  private _getCurrentViewComponent(): MatMonthView<D> | MatYearView<D> | MatMultiYearView<D> {\n    // The return type is explicitly written as a union to ensure that the Closure compiler does\n    // not optimize calls to _init(). Without the explict return type, TypeScript narrows it to\n    // only the first component type. See https://github.com/angular/components/issues/22996.\n    return this.monthView || this.yearView || this.multiYearView;\n  }\n}\n"]}
|