UNPKG

ng-zorro-antd-yj

Version:

An enterprise-class UI components based on Ant Design and Angular

548 lines 48 kB
/** * @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"]}