ng-zorro-antd-yj
Version:
An enterprise-class UI components based on Ant Design and Angular
548 lines • 48 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { coerceBooleanProperty } from '@angular/cdk/coercion';
import { forwardRef, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, HostBinding, Input, Output, TemplateRef, ViewEncapsulation } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import addDays from 'date-fns/add_days';
import differenceInCalendarDays from 'date-fns/difference_in_calendar_days';
import differenceInCalendarMonths from 'date-fns/difference_in_calendar_months';
import differenceInCalendarWeeks from 'date-fns/difference_in_calendar_weeks';
import endOfMonth from 'date-fns/end_of_month';
import isSameDay from 'date-fns/is_same_day';
import isSameMonth from 'date-fns/is_same_month';
import isSameYear from 'date-fns/is_same_year';
import isThisMonth from 'date-fns/is_this_month';
import isThisYear from 'date-fns/is_this_year';
import setMonth from 'date-fns/set_month';
import setYear from 'date-fns/set_year';
import startOfMonth from 'date-fns/start_of_month';
import startOfWeek from 'date-fns/start_of_week';
import startOfYear from 'date-fns/start_of_year';
import { DateHelperService } from '../i18n/date-helper.service';
import { NzI18nService } from '../i18n/nz-i18n.service';
import { NzDateCellDirective as DateCell, NzDateFullCellDirective as DateFullCell, NzMonthCellDirective as MonthCell, NzMonthFullCellDirective as MonthFullCell } from './nz-calendar-cells';
export class NzCalendarComponent {
/**
* @param {?} i18n
* @param {?} cdr
* @param {?} dateHelper
*/
constructor(i18n, cdr, dateHelper) {
this.i18n = i18n;
this.cdr = cdr;
this.dateHelper = dateHelper;
this.nzMode = 'month';
this.nzModeChange = new EventEmitter();
this.nzPanelChange = new EventEmitter();
this.nzSelectChange = new EventEmitter();
this.nzValueChange = new EventEmitter();
this.fullscreen = true;
this.daysInWeek = [];
this.monthsInYear = [];
this.dateMatrix = [];
this.activeDate = new Date();
this.currentDateRow = -1;
this.currentDateCol = -1;
this.activeDateRow = -1;
this.activeDateCol = -1;
this.currentMonthRow = -1;
this.currentMonthCol = -1;
this.activeMonthRow = -1;
this.activeMonthCol = -1;
this.dateCell = null;
this.dateFullCell = null;
this.monthCell = null;
this.monthFullCell = null;
this.currentDate = new Date();
this.onChangeFn = (/**
* @return {?}
*/
() => { });
this.onTouchFn = (/**
* @return {?}
*/
() => { });
}
/**
* @param {?} value
* @return {?}
*/
set nzValue(value) {
this.updateDate(value, false);
}
/**
* @param {?} value
* @return {?}
*/
set nzDateCell(value) {
this.dateCell = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzDateFullCell(value) {
this.dateFullCell = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzMonthCell(value) {
this.monthCell = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzMonthFullCell(value) {
this.monthFullCell = value;
}
/**
* @param {?} value
* @return {?}
*/
set nzFullscreen(value) {
this.fullscreen = coerceBooleanProperty(value);
}
/**
* @return {?}
*/
get nzFullscreen() {
return this.fullscreen;
}
/**
* @param {?} value
* @return {?}
*/
set nzCard(value) {
this.fullscreen = !coerceBooleanProperty(value);
}
/**
* @return {?}
*/
get nzCard() {
return !this.fullscreen;
}
/**
* @param {?} value
* @return {?}
*/
set dateCellChild(value) {
if (value) {
this.dateCell = value;
}
}
/**
* @param {?} value
* @return {?}
*/
set dateFullCellChild(value) {
if (value) {
this.dateFullCell = value;
}
}
/**
* @param {?} value
* @return {?}
*/
set monthCellChild(value) {
if (value) {
this.monthCell = value;
}
}
/**
* @param {?} value
* @return {?}
*/
set monthFullCellChild(value) {
if (value) {
this.monthFullCell = value;
}
}
/**
* @private
* @return {?}
*/
get calendarStart() {
return startOfWeek(startOfMonth(this.activeDate), { weekStartsOn: this.dateHelper.getFirstDayOfWeek() });
}
/**
* @return {?}
*/
ngOnInit() {
this.setUpDaysInWeek();
this.setUpMonthsInYear();
this.setUpDateMatrix();
this.calculateCurrentDate();
this.calculateActiveDate();
this.calculateCurrentMonth();
this.calculateActiveMonth();
}
/**
* @param {?} mode
* @return {?}
*/
onModeChange(mode) {
this.nzModeChange.emit(mode);
this.nzPanelChange.emit({ date: this.activeDate, mode });
}
/**
* @param {?} date
* @return {?}
*/
onDateSelect(date) {
this.updateDate(date);
this.nzSelectChange.emit(date);
}
/**
* @param {?} year
* @return {?}
*/
onYearSelect(year) {
/** @type {?} */
const date = setYear(this.activeDate, year);
this.updateDate(date);
this.nzSelectChange.emit(date);
}
/**
* @param {?} month
* @return {?}
*/
onMonthSelect(month) {
/** @type {?} */
const date = setMonth(this.activeDate, month);
this.updateDate(date);
this.nzSelectChange.emit(date);
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
this.updateDate(value || new Date(), false);
this.cdr.markForCheck();
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChangeFn = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouchFn = fn;
}
/**
* @private
* @param {?} date
* @param {?=} touched
* @return {?}
*/
updateDate(date, touched = true) {
/** @type {?} */
const dayChanged = !isSameDay(date, this.activeDate);
/** @type {?} */
const monthChanged = !isSameMonth(date, this.activeDate);
/** @type {?} */
const yearChanged = !isSameYear(date, this.activeDate);
this.activeDate = date;
if (dayChanged) {
this.calculateActiveDate();
}
if (monthChanged) {
this.setUpDateMatrix();
this.calculateCurrentDate();
this.calculateActiveMonth();
}
if (yearChanged) {
this.calculateCurrentMonth();
}
if (touched) {
this.onChangeFn(date);
this.onTouchFn();
this.nzValueChange.emit(date);
}
}
/**
* @private
* @return {?}
*/
setUpDaysInWeek() {
this.daysInWeek = [];
/** @type {?} */
const weekStart = startOfWeek(this.activeDate, { weekStartsOn: this.dateHelper.getFirstDayOfWeek() });
for (let i = 0; i < 7; i++) {
/** @type {?} */
const date = addDays(weekStart, i);
/** @type {?} */
const title = this.dateHelper.format(date, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd');
/** @type {?} */
const label = this.dateHelper.format(date, this.dateHelper.relyOnDatePipe ? 'EEEEEE' : 'dd');
this.daysInWeek.push({ title, label });
}
}
/**
* @private
* @return {?}
*/
setUpMonthsInYear() {
this.monthsInYear = [];
for (let i = 0; i < 12; i++) {
/** @type {?} */
const date = setMonth(this.activeDate, i);
/** @type {?} */
const title = this.dateHelper.format(date, 'MMM');
/** @type {?} */
const label = this.dateHelper.format(date, 'MMM');
/** @type {?} */
const start = startOfMonth(date);
this.monthsInYear.push({ title, label, start });
}
}
/**
* @private
* @return {?}
*/
setUpDateMatrix() {
this.dateMatrix = [];
/** @type {?} */
const monthStart = startOfMonth(this.activeDate);
/** @type {?} */
const monthEnd = endOfMonth(this.activeDate);
/** @type {?} */
const weekDiff = differenceInCalendarWeeks(monthEnd, monthStart, { weekStartsOn: this.dateHelper.getFirstDayOfWeek() }) + 2;
for (let week = 0; week < weekDiff; week++) {
/** @type {?} */
const row = [];
/** @type {?} */
const weekStart = addDays(this.calendarStart, week * 7);
for (let day = 0; day < 7; day++) {
/** @type {?} */
const date = addDays(weekStart, day);
/** @type {?} */
const monthDiff = differenceInCalendarMonths(date, this.activeDate);
/** @type {?} */
const dateFormat = this.dateHelper.relyOnDatePipe
? 'longDate'
: this.i18n.getLocaleData('DatePicker.lang.dateFormat', 'YYYY-MM-DD');
/** @type {?} */
const title = this.dateHelper.format(date, dateFormat);
/** @type {?} */
const label = this.dateHelper.format(date, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');
/** @type {?} */
const rel = monthDiff === 0 ? 'current' : monthDiff < 0 ? 'last' : 'next';
row.push({ title, label, rel, value: date });
}
this.dateMatrix.push(row);
}
}
/**
* @private
* @return {?}
*/
calculateCurrentDate() {
if (isThisMonth(this.activeDate)) {
this.currentDateRow = differenceInCalendarWeeks(this.currentDate, this.calendarStart, {
weekStartsOn: this.dateHelper.getFirstDayOfWeek()
});
this.currentDateCol = differenceInCalendarDays(this.currentDate, addDays(this.calendarStart, this.currentDateRow * 7));
}
else {
this.currentDateRow = -1;
this.currentDateCol = -1;
}
}
/**
* @private
* @return {?}
*/
calculateActiveDate() {
this.activeDateRow = differenceInCalendarWeeks(this.activeDate, this.calendarStart, {
weekStartsOn: this.dateHelper.getFirstDayOfWeek()
});
this.activeDateCol = differenceInCalendarDays(this.activeDate, addDays(this.calendarStart, this.activeDateRow * 7));
}
/**
* @private
* @return {?}
*/
calculateCurrentMonth() {
if (isThisYear(this.activeDate)) {
/** @type {?} */
const yearStart = startOfYear(this.currentDate);
/** @type {?} */
const monthDiff = differenceInCalendarMonths(this.currentDate, yearStart);
this.currentMonthRow = Math.floor(monthDiff / 3);
this.currentMonthCol = monthDiff % 3;
}
else {
this.currentMonthRow = -1;
this.currentMonthCol = -1;
}
}
/**
* @private
* @return {?}
*/
calculateActiveMonth() {
this.activeMonthRow = Math.floor(this.activeDate.getMonth() / 3);
this.activeMonthCol = this.activeDate.getMonth() % 3;
}
}
NzCalendarComponent.decorators = [
{ type: Component, args: [{
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
selector: 'nz-calendar',
template: "<nz-calendar-header [fullscreen]=\"fullscreen\" [activeDate]=\"activeDate\"\n [(mode)]=\"nzMode\" (modeChange)=\"onModeChange($event)\"\n (yearChange)=\"onYearSelect($event)\" (monthChange)=\"onMonthSelect($event)\">\n</nz-calendar-header>\n\n<div class=\"ant-fullcalendar ant-fullcalendar-full\" [ngClass]=\"fullscreen ? 'ant-fullcalendar-fullscreen' : ''\">\n <div class=\"ant-fullcalendar-calendar-body\">\n <ng-container *ngIf=\"nzMode === 'month' then monthModeTable else yearModeTable\"></ng-container>\n </div>\n</div>\n\n<ng-template #monthModeTable>\n <table class=\"ant-fullcalendar-table\" cellspacing=\"0\" role=\"grid\">\n <thead>\n <tr role=\"row\">\n <th *ngFor=\"let day of daysInWeek\" class=\"ant-fullcalendar-column-header\" role=\"columnheader\" [title]=\"day.title\">\n <span class=\"ant-fullcalendar-column-header-inner\">{{ day.label }}</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"ant-fullcalendar-tbody\">\n <tr *ngFor=\"let week of dateMatrix; index as row\"\n [class.ant-fullcalendar-current-week]=\"row === currentDateRow\"\n [class.ant-fullcalendar-active-week]=\"row === activeDateRow\">\n <td *ngFor=\"let day of week; index as col\" role=\"gridcell\" class=\"ant-fullcalendar-cell\" [title]=\"day.title\"\n [class.ant-fullcalendar-today]=\"row === currentDateRow && col === currentDateCol\"\n [class.ant-fullcalendar-selected-day]=\"row === activeDateRow && col === activeDateCol\"\n [class.ant-fullcalendar-last-month-cell]=\"day.rel === 'last'\"\n [class.ant-fullcalendar-next-month-btn-day]=\"day.rel === 'next'\"\n (click)=\"onDateSelect(day.value)\">\n <div class=\"ant-fullcalendar-date\">\n <ng-container *ngIf=\"dateFullCell else defaultCell\">\n <ng-container *ngTemplateOutlet=\"dateFullCell; context: {$implicit: day.value}\"></ng-container>\n </ng-container>\n <ng-template #defaultCell>\n <div class=\"ant-fullcalendar-value\">{{ day.label }}</div>\n <div *ngIf=\"dateCell\" class=\"ant-fullcalendar-content\">\n <ng-container *ngTemplateOutlet=\"dateCell; context: {$implicit: day.value}\"></ng-container>\n </div>\n </ng-template>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</ng-template>\n\n<ng-template #yearModeTable>\n <table class=\"ant-fullcalendar-month-panel-table\" cellspacing=\"0\" role=\"grid\">\n <tbody class=\"ant-fullcalendar-month-panel-tbody\">\n <tr *ngFor=\"let row of [0, 1, 2, 3]\" role=\"row\">\n <td *ngFor=\"let col of [0, 1, 2]\" role=\"gridcell\" [title]=\"monthsInYear[row * 3 + col].title\"\n class=\"ant-fullcalendar-month-panel-cell\"\n [class.ant-fullcalendar-month-panel-current-cell]=\"row === currentMonthRow && col === currentMonthCol\"\n [class.ant-fullcalendar-month-panel-selected-cell]=\"row === activeMonthRow && col === activeMonthCol\"\n (click)=\"onMonthSelect(row * 3 + col)\">\n <div class=\"ant-fullcalendar-month\">\n <ng-container *ngIf=\"monthFullCell else defaultCell\">\n <ng-container *ngTemplateOutlet=\"monthFullCell; context: {$implicit: monthsInYear[row * 3 + col].start}\"></ng-container>\n </ng-container>\n <ng-template #defaultCell>\n <div class=\"ant-fullcalendar-value\">{{ monthsInYear[row * 3 + col].label }}</div>\n <div *ngIf=\"monthCell\" class=\"ant-fullcalendar-content\">\n <ng-container *ngTemplateOutlet=\"monthCell; context: {$implicit: monthsInYear[row * 3 + col].start}\"></ng-container>\n </div>\n </ng-template>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</ng-template>\n",
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/**
* @return {?}
*/
() => NzCalendarComponent)), multi: true }]
}] }
];
/** @nocollapse */
NzCalendarComponent.ctorParameters = () => [
{ type: NzI18nService },
{ type: ChangeDetectorRef },
{ type: DateHelperService }
];
NzCalendarComponent.propDecorators = {
nzMode: [{ type: Input }],
nzModeChange: [{ type: Output }],
nzPanelChange: [{ type: Output }],
nzSelectChange: [{ type: Output }],
nzValue: [{ type: Input }],
nzValueChange: [{ type: Output }],
nzDateCell: [{ type: Input }],
nzDateFullCell: [{ type: Input }],
nzMonthCell: [{ type: Input }],
nzMonthFullCell: [{ type: Input }],
nzFullscreen: [{ type: Input }],
nzCard: [{ type: Input }],
dateCellChild: [{ type: ContentChild, args: [DateCell, { read: TemplateRef },] }],
dateFullCellChild: [{ type: ContentChild, args: [DateFullCell, { read: TemplateRef },] }],
monthCellChild: [{ type: ContentChild, args: [MonthCell, { read: TemplateRef },] }],
monthFullCellChild: [{ type: ContentChild, args: [MonthFullCell, { read: TemplateRef },] }],
fullscreen: [{ type: HostBinding, args: ['class.ant-fullcalendar--fullscreen',] }]
};
if (false) {
/** @type {?} */
NzCalendarComponent.prototype.nzMode;
/** @type {?} */
NzCalendarComponent.prototype.nzModeChange;
/** @type {?} */
NzCalendarComponent.prototype.nzPanelChange;
/** @type {?} */
NzCalendarComponent.prototype.nzSelectChange;
/** @type {?} */
NzCalendarComponent.prototype.nzValueChange;
/** @type {?} */
NzCalendarComponent.prototype.fullscreen;
/** @type {?} */
NzCalendarComponent.prototype.daysInWeek;
/** @type {?} */
NzCalendarComponent.prototype.monthsInYear;
/** @type {?} */
NzCalendarComponent.prototype.dateMatrix;
/** @type {?} */
NzCalendarComponent.prototype.activeDate;
/** @type {?} */
NzCalendarComponent.prototype.currentDateRow;
/** @type {?} */
NzCalendarComponent.prototype.currentDateCol;
/** @type {?} */
NzCalendarComponent.prototype.activeDateRow;
/** @type {?} */
NzCalendarComponent.prototype.activeDateCol;
/** @type {?} */
NzCalendarComponent.prototype.currentMonthRow;
/** @type {?} */
NzCalendarComponent.prototype.currentMonthCol;
/** @type {?} */
NzCalendarComponent.prototype.activeMonthRow;
/** @type {?} */
NzCalendarComponent.prototype.activeMonthCol;
/** @type {?} */
NzCalendarComponent.prototype.dateCell;
/** @type {?} */
NzCalendarComponent.prototype.dateFullCell;
/** @type {?} */
NzCalendarComponent.prototype.monthCell;
/** @type {?} */
NzCalendarComponent.prototype.monthFullCell;
/**
* @type {?}
* @private
*/
NzCalendarComponent.prototype.currentDate;
/**
* @type {?}
* @private
*/
NzCalendarComponent.prototype.onChangeFn;
/**
* @type {?}
* @private
*/
NzCalendarComponent.prototype.onTouchFn;
/**
* @type {?}
* @private
*/
NzCalendarComponent.prototype.i18n;
/**
* @type {?}
* @private
*/
NzCalendarComponent.prototype.cdr;
/**
* @type {?}
* @private
*/
NzCalendarComponent.prototype.dateHelper;
}
/**
* @record
*/
export function DayCellContext() { }
if (false) {
/** @type {?} */
DayCellContext.prototype.title;
/** @type {?} */
DayCellContext.prototype.label;
}
/**
* @record
*/
export function MonthCellContext() { }
if (false) {
/** @type {?} */
MonthCellContext.prototype.title;
/** @type {?} */
MonthCellContext.prototype.label;
/** @type {?} */
MonthCellContext.prototype.start;
}
/**
* @record
*/
export function DateCellContext() { }
if (false) {
/** @type {?} */
DateCellContext.prototype.title;
/** @type {?} */
DateCellContext.prototype.label;
/** @type {?} */
DateCellContext.prototype.rel;
/** @type {?} */
DateCellContext.prototype.value;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-calendar.component.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["calendar/nz-calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  forwardRef,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport addDays from 'date-fns/add_days';\nimport differenceInCalendarDays from 'date-fns/difference_in_calendar_days';\nimport differenceInCalendarMonths from 'date-fns/difference_in_calendar_months';\nimport differenceInCalendarWeeks from 'date-fns/difference_in_calendar_weeks';\nimport endOfMonth from 'date-fns/end_of_month';\nimport isSameDay from 'date-fns/is_same_day';\nimport isSameMonth from 'date-fns/is_same_month';\nimport isSameYear from 'date-fns/is_same_year';\nimport isThisMonth from 'date-fns/is_this_month';\nimport isThisYear from 'date-fns/is_this_year';\nimport setMonth from 'date-fns/set_month';\nimport setYear from 'date-fns/set_year';\nimport startOfMonth from 'date-fns/start_of_month';\nimport startOfWeek from 'date-fns/start_of_week';\nimport startOfYear from 'date-fns/start_of_year';\nimport { DateHelperService } from '../i18n/date-helper.service';\nimport { NzI18nService } from '../i18n/nz-i18n.service';\nimport {\n  NzDateCellDirective as DateCell,\n  NzDateFullCellDirective as DateFullCell,\n  NzMonthCellDirective as MonthCell,\n  NzMonthFullCellDirective as MonthFullCell\n} from './nz-calendar-cells';\n\nexport type ModeType = 'month' | 'year';\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'nz-calendar',\n  templateUrl: './nz-calendar.component.html',\n  providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NzCalendarComponent), multi: true }]\n})\nexport class NzCalendarComponent implements ControlValueAccessor, OnInit {\n  @Input() nzMode: ModeType = 'month';\n  @Output() readonly nzModeChange: EventEmitter<ModeType> = new EventEmitter();\n  @Output() readonly nzPanelChange: EventEmitter<{ date: Date; mode: ModeType }> = new EventEmitter();\n\n  @Output() readonly nzSelectChange: EventEmitter<Date> = new EventEmitter();\n\n  @Input() set nzValue(value: Date) {\n    this.updateDate(value, false);\n  }\n  @Output() readonly nzValueChange: EventEmitter<Date> = new EventEmitter();\n\n  @Input()\n  set nzDateCell(value: TemplateRef<{ $implicit: Date }>) {\n    this.dateCell = value;\n  }\n\n  @Input()\n  set nzDateFullCell(value: TemplateRef<{ $implicit: Date }>) {\n    this.dateFullCell = value;\n  }\n\n  @Input()\n  set nzMonthCell(value: TemplateRef<{ $implicit: Date }>) {\n    this.monthCell = value;\n  }\n\n  @Input()\n  set nzMonthFullCell(value: TemplateRef<{ $implicit: Date }>) {\n    this.monthFullCell = value;\n  }\n\n  @Input()\n  set nzFullscreen(value: boolean) {\n    this.fullscreen = coerceBooleanProperty(value);\n  }\n  get nzFullscreen(): boolean {\n    return this.fullscreen;\n  }\n\n  @Input()\n  set nzCard(value: boolean) {\n    this.fullscreen = !coerceBooleanProperty(value);\n  }\n  get nzCard(): boolean {\n    return !this.fullscreen;\n  }\n\n  @ContentChild(DateCell, { read: TemplateRef })\n  set dateCellChild(value: TemplateRef<{ $implicit: Date }>) {\n    if (value) {\n      this.dateCell = value;\n    }\n  }\n\n  @ContentChild(DateFullCell, { read: TemplateRef })\n  set dateFullCellChild(value: TemplateRef<{ $implicit: Date }>) {\n    if (value) {\n      this.dateFullCell = value;\n    }\n  }\n\n  @ContentChild(MonthCell, { read: TemplateRef })\n  set monthCellChild(value: TemplateRef<{ $implicit: Date }>) {\n    if (value) {\n      this.monthCell = value;\n    }\n  }\n\n  @ContentChild(MonthFullCell, { read: TemplateRef })\n  set monthFullCellChild(value: TemplateRef<{ $implicit: Date }>) {\n    if (value) {\n      this.monthFullCell = value;\n    }\n  }\n\n  @HostBinding('class.ant-fullcalendar--fullscreen')\n  fullscreen = true;\n\n  daysInWeek: DayCellContext[] = [];\n  monthsInYear: MonthCellContext[] = [];\n  dateMatrix: DateCellContext[][] = [];\n  activeDate: Date = new Date();\n  currentDateRow: number = -1;\n  currentDateCol: number = -1;\n  activeDateRow: number = -1;\n  activeDateCol: number = -1;\n  currentMonthRow: number = -1;\n  currentMonthCol: number = -1;\n  activeMonthRow: number = -1;\n  activeMonthCol: number = -1;\n  dateCell: TemplateRef<{ $implicit: Date }> | null = null;\n  dateFullCell: TemplateRef<{ $implicit: Date }> | null = null;\n  monthCell: TemplateRef<{ $implicit: Date }> | null = null;\n  monthFullCell: TemplateRef<{ $implicit: Date }> | null = null;\n\n  private currentDate = new Date();\n  private onChangeFn: (date: Date) => void = () => {};\n  private onTouchFn: () => void = () => {};\n\n  private get calendarStart(): Date {\n    return startOfWeek(startOfMonth(this.activeDate), { weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n  }\n\n  constructor(private i18n: NzI18nService, private cdr: ChangeDetectorRef, private dateHelper: DateHelperService) {}\n\n  ngOnInit(): void {\n    this.setUpDaysInWeek();\n    this.setUpMonthsInYear();\n    this.setUpDateMatrix();\n    this.calculateCurrentDate();\n    this.calculateActiveDate();\n    this.calculateCurrentMonth();\n    this.calculateActiveMonth();\n  }\n\n  onModeChange(mode: ModeType): void {\n    this.nzModeChange.emit(mode);\n    this.nzPanelChange.emit({ date: this.activeDate, mode });\n  }\n\n  onDateSelect(date: Date): void {\n    this.updateDate(date);\n    this.nzSelectChange.emit(date);\n  }\n\n  onYearSelect(year: number): void {\n    const date = setYear(this.activeDate, year);\n    this.updateDate(date);\n    this.nzSelectChange.emit(date);\n  }\n\n  onMonthSelect(month: number): void {\n    const date = setMonth(this.activeDate, month);\n    this.updateDate(date);\n    this.nzSelectChange.emit(date);\n  }\n\n  writeValue(value: Date | null): void {\n    this.updateDate(value || new Date(), false);\n    this.cdr.markForCheck();\n  }\n\n  registerOnChange(fn: (date: Date) => void): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouchFn = fn;\n  }\n\n  private updateDate(date: Date, touched: boolean = true): void {\n    const dayChanged = !isSameDay(date, this.activeDate);\n    const monthChanged = !isSameMonth(date, this.activeDate);\n    const yearChanged = !isSameYear(date, this.activeDate);\n\n    this.activeDate = date;\n\n    if (dayChanged) {\n      this.calculateActiveDate();\n    }\n    if (monthChanged) {\n      this.setUpDateMatrix();\n      this.calculateCurrentDate();\n      this.calculateActiveMonth();\n    }\n    if (yearChanged) {\n      this.calculateCurrentMonth();\n    }\n\n    if (touched) {\n      this.onChangeFn(date);\n      this.onTouchFn();\n      this.nzValueChange.emit(date);\n    }\n  }\n\n  private setUpDaysInWeek(): void {\n    this.daysInWeek = [];\n    const weekStart = startOfWeek(this.activeDate, { weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n    for (let i = 0; i < 7; i++) {\n      const date = addDays(weekStart, i);\n      const title = this.dateHelper.format(date, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd');\n      const label = this.dateHelper.format(date, this.dateHelper.relyOnDatePipe ? 'EEEEEE' : 'dd');\n      this.daysInWeek.push({ title, label });\n    }\n  }\n\n  private setUpMonthsInYear(): void {\n    this.monthsInYear = [];\n    for (let i = 0; i < 12; i++) {\n      const date = setMonth(this.activeDate, i);\n      const title = this.dateHelper.format(date, 'MMM');\n      const label = this.dateHelper.format(date, 'MMM');\n      const start = startOfMonth(date);\n      this.monthsInYear.push({ title, label, start });\n    }\n  }\n\n  private setUpDateMatrix(): void {\n    this.dateMatrix = [];\n    const monthStart = startOfMonth(this.activeDate);\n    const monthEnd = endOfMonth(this.activeDate);\n    const weekDiff =\n      differenceInCalendarWeeks(monthEnd, monthStart, { weekStartsOn: this.dateHelper.getFirstDayOfWeek() }) + 2;\n\n    for (let week = 0; week < weekDiff; week++) {\n      const row: DateCellContext[] = [];\n      const weekStart = addDays(this.calendarStart, week * 7);\n\n      for (let day = 0; day < 7; day++) {\n        const date = addDays(weekStart, day);\n        const monthDiff = differenceInCalendarMonths(date, this.activeDate);\n        const dateFormat = this.dateHelper.relyOnDatePipe\n          ? 'longDate'\n          : this.i18n.getLocaleData('DatePicker.lang.dateFormat', 'YYYY-MM-DD');\n        const title = this.dateHelper.format(date, dateFormat);\n        const label = this.dateHelper.format(date, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');\n        const rel = monthDiff === 0 ? 'current' : monthDiff < 0 ? 'last' : 'next';\n        row.push({ title, label, rel, value: date });\n      }\n      this.dateMatrix.push(row);\n    }\n  }\n\n  private calculateCurrentDate(): void {\n    if (isThisMonth(this.activeDate)) {\n      this.currentDateRow = differenceInCalendarWeeks(this.currentDate, this.calendarStart, {\n        weekStartsOn: this.dateHelper.getFirstDayOfWeek()\n      });\n      this.currentDateCol = differenceInCalendarDays(\n        this.currentDate,\n        addDays(this.calendarStart, this.currentDateRow * 7)\n      );\n    } else {\n      this.currentDateRow = -1;\n      this.currentDateCol = -1;\n    }\n  }\n\n  private calculateActiveDate(): void {\n    this.activeDateRow = differenceInCalendarWeeks(this.activeDate, this.calendarStart, {\n      weekStartsOn: this.dateHelper.getFirstDayOfWeek()\n    });\n    this.activeDateCol = differenceInCalendarDays(this.activeDate, addDays(this.calendarStart, this.activeDateRow * 7));\n  }\n\n  private calculateCurrentMonth(): void {\n    if (isThisYear(this.activeDate)) {\n      const yearStart = startOfYear(this.currentDate);\n      const monthDiff = differenceInCalendarMonths(this.currentDate, yearStart);\n      this.currentMonthRow = Math.floor(monthDiff / 3);\n      this.currentMonthCol = monthDiff % 3;\n    } else {\n      this.currentMonthRow = -1;\n      this.currentMonthCol = -1;\n    }\n  }\n\n  private calculateActiveMonth(): void {\n    this.activeMonthRow = Math.floor(this.activeDate.getMonth() / 3);\n    this.activeMonthCol = this.activeDate.getMonth() % 3;\n  }\n}\n\nexport interface DayCellContext {\n  title: string;\n  label: string;\n}\n\nexport interface MonthCellContext {\n  title: string;\n  label: string;\n  start: Date;\n}\n\nexport interface DateCellContext {\n  title: string;\n  label: string;\n  rel: 'last' | 'current' | 'next';\n  value: Date;\n}\n"]}