ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
494 lines • 40.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: date-table.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Alibaba.com 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://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
import { valueFunctionProp, CandyDate } from 'ng-zorro-antd/core';
import { DateHelperService, NzI18nService } from 'ng-zorro-antd/i18n';
/** @type {?} */
var DATE_ROW_NUM = 6;
/** @type {?} */
var DATE_COL_NUM = 7;
var DateTableComponent = /** @class */ (function () {
function DateTableComponent(i18n, dateHelper) {
this.i18n = i18n;
this.dateHelper = dateHelper;
this.prefixCls = 'ant-calendar';
this.showWeek = false;
this.dayHover = new EventEmitter(); // Emitted when hover on a day by mouse enter
// Emitted when hover on a day by mouse enter
this.valueChange = new EventEmitter();
}
Object.defineProperty(DateTableComponent.prototype, "value", {
get: /**
* @return {?}
*/
function () {
return this._value;
},
set:
// Range ONLY
/**
* @param {?} date
* @return {?}
*/
function (date) {
// Show today by default
this._value = this.activeDate = date || new CandyDate();
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
DateTableComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.render();
};
/**
* @param {?} changes
* @return {?}
*/
DateTableComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (this.isDateRealChange(changes.activeDate) ||
this.isDateRealChange(changes.value) ||
this.isDateRealChange(changes.selectedValue) ||
this.isDateRealChange(changes.hoverValue)) {
this.render();
}
};
/**
* @private
* @param {?} change
* @return {?}
*/
DateTableComponent.prototype.isDateRealChange = /**
* @private
* @param {?} change
* @return {?}
*/
function (change) {
if (change) {
/** @type {?} */
var previousValue_1 = change.previousValue;
/** @type {?} */
var currentValue = change.currentValue;
if (Array.isArray(currentValue)) {
return (!Array.isArray(previousValue_1) ||
currentValue.length !== previousValue_1.length ||
currentValue.some((/**
* @param {?} value
* @param {?} index
* @return {?}
*/
function (value, index) {
/** @type {?} */
var previousCandyDate = previousValue_1[index];
return previousCandyDate instanceof CandyDate
? previousCandyDate.isSameDay(value)
: previousCandyDate !== value;
})));
}
else {
return !this.isSameDate((/** @type {?} */ (previousValue_1)), currentValue);
}
}
return false;
};
/**
* @private
* @param {?} left
* @param {?} right
* @return {?}
*/
DateTableComponent.prototype.isSameDate = /**
* @private
* @param {?} left
* @param {?} right
* @return {?}
*/
function (left, right) {
return (!left && !right) || (left && right && right.isSameDay(left));
};
/**
* @private
* @return {?}
*/
DateTableComponent.prototype.render = /**
* @private
* @return {?}
*/
function () {
if (this.value) {
this.headWeekDays = this.makeHeadWeekDays();
this.weekRows = this.makeWeekRows();
}
};
/**
* @private
* @param {?} value
* @return {?}
*/
DateTableComponent.prototype.changeValueFromInside = /**
* @private
* @param {?} value
* @return {?}
*/
function (value) {
// Only change date not change time
/** @type {?} */
var newValue = this.value
.setYear(value.getYear())
.setMonth(value.getMonth())
.setDate(value.getDate());
this.valueChange.emit(newValue);
};
/**
* @private
* @return {?}
*/
DateTableComponent.prototype.makeHeadWeekDays = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var weekDays = [];
/** @type {?} */
var start = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });
for (var colIndex = 0; colIndex < DATE_COL_NUM; colIndex++) {
/** @type {?} */
var day = start.addDays(colIndex);
weekDays[colIndex] = {
short: this.dateHelper.format(day.nativeDate, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd'),
// eg. Tue
veryShort: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()) // eg. Tu
};
}
return weekDays;
};
/**
* @private
* @return {?}
*/
DateTableComponent.prototype.getVeryShortWeekFormat = /**
* @private
* @return {?}
*/
function () {
if (this.dateHelper.relyOnDatePipe) {
return this.i18n
.getLocaleId()
.toLowerCase()
.indexOf('zh') === 0
? 'EEEEE'
: 'EEEEEE'; // Use extreme short for chinese
}
return 'dd';
};
/**
* @private
* @return {?}
*/
DateTableComponent.prototype.makeWeekRows = /**
* @private
* @return {?}
*/
function () {
var _a;
var _this = this;
/** @type {?} */
var weekRows = [];
/** @type {?} */
var firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });
for (var week = 0; week < DATE_ROW_NUM; week++) {
/** @type {?} */
var weekStart = firstDayOfMonth.addDays(week * 7);
/** @type {?} */
var row = {
isActive: false,
isCurrent: false,
dateCells: [],
year: weekStart.getYear()
};
var _loop_1 = function (day) {
var _a;
/** @type {?} */
var date = weekStart.addDays(day);
/** @type {?} */
var dateFormat = this_1.dateHelper.relyOnDatePipe
? 'longDate'
: this_1.i18n.getLocaleData('DatePicker.lang.dateFormat', 'YYYY-MM-DD');
/** @type {?} */
var title = this_1.dateHelper.format(date.nativeDate, dateFormat);
/** @type {?} */
var label = this_1.dateHelper.format(date.nativeDate, this_1.dateHelper.relyOnDatePipe ? 'dd' : 'DD');
/** @type {?} */
var cell = {
value: date.nativeDate,
label: label,
isSelected: false,
isDisabled: false,
isToday: false,
title: title,
dateCellRender: valueFunctionProp(this_1.dateCellRender, date),
// Customized content
dateFullCellRender: valueFunctionProp(this_1.dateFullCellRender, date),
content: "" + date.getDate(),
onClick: (/**
* @return {?}
*/
function () { return _this.changeValueFromInside(date); }),
onMouseEnter: (/**
* @return {?}
*/
function () { return _this.dayHover.emit(date); })
};
if (this_1.showWeek && !row.weekNum) {
row.weekNum = this_1.dateHelper.getISOWeek(date.nativeDate);
}
if (date.isToday()) {
cell.isToday = true;
row.isCurrent = true;
}
if (Array.isArray(this_1.selectedValue) && date.isSameMonth(this_1.activeDate)) {
// Range selections
/** @type {?} */
var rangeValue = this_1.hoverValue && this_1.hoverValue.length ? this_1.hoverValue : this_1.selectedValue;
/** @type {?} */
var start = rangeValue[0];
/** @type {?} */
var end = rangeValue[1];
if (start) {
if (start.isSameDay(date)) {
cell.isSelectedStartDate = true;
cell.isSelected = true;
row.isActive = true;
}
if (end) {
if (end.isSameDay(date)) {
cell.isSelectedEndDate = true;
cell.isSelected = true;
row.isActive = true;
}
else if (date.isAfterDay(start) && date.isBeforeDay(end)) {
cell.isInRange = true;
}
}
}
}
else if (date.isSameDay(this_1.value)) {
cell.isSelected = true;
row.isActive = true;
}
if (this_1.disabledDate && this_1.disabledDate(date.nativeDate)) {
cell.isDisabled = true;
}
cell.classMap = (_a = {},
_a[this_1.prefixCls + "-cell"] = true,
_a[this_1.prefixCls + "-today"] = cell.isToday,
_a[this_1.prefixCls + "-last-month-cell"] = date.isBeforeMonth(this_1.activeDate),
_a[this_1.prefixCls + "-next-month-btn-day"] = date.isAfterMonth(this_1.activeDate),
_a[this_1.prefixCls + "-selected-day"] = cell.isSelected,
_a[this_1.prefixCls + "-disabled-cell"] = cell.isDisabled,
_a[this_1.prefixCls + "-selected-start-date"] = !!cell.isSelectedStartDate,
_a[this_1.prefixCls + "-selected-end-date"] = !!cell.isSelectedEndDate,
_a[this_1.prefixCls + "-in-range-cell"] = !!cell.isInRange,
_a);
row.dateCells.push(cell);
};
var this_1 = this;
for (var day = 0; day < 7; day++) {
_loop_1(day);
}
row.classMap = (_a = {},
_a[this.prefixCls + "-current-week"] = row.isCurrent,
_a[this.prefixCls + "-active-week"] = row.isActive,
_a);
weekRows.push(row);
}
return weekRows;
};
/**
* @param {?} _index
* @param {?} item
* @return {?}
*/
DateTableComponent.prototype.trackByDateFn = /**
* @param {?} _index
* @param {?} item
* @return {?}
*/
function (_index, item) {
return "" + item.title;
};
/**
* @param {?} _index
* @param {?} item
* @return {?}
*/
DateTableComponent.prototype.trackByWeekFn = /**
* @param {?} _index
* @param {?} item
* @return {?}
*/
function (_index, item) {
return item.year + "-" + item.weekNum;
};
DateTableComponent.decorators = [
{ type: Component, args: [{
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
// tslint:disable-next-line:component-selector
selector: 'date-table',
exportAs: 'dateTable',
template: "<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n <thead>\n <tr role=\"row\">\n <th *ngIf=\"showWeek\" role=\"columnheader\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n <span class=\"{{ prefixCls }}-column-header-inner\">x</span>\n </th>\n <th *ngFor=\"let cell of headWeekDays\" role=\"columnheader\" title=\"{{ cell.short }}\"\n class=\"{{ prefixCls }}-column-header\">\n <span class=\"{{ prefixCls }}-column-header-inner\">{{ cell.veryShort }}</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"{{ prefixCls }}-tbody\">\n <tr *ngFor=\"let row of weekRows;trackBy:trackByWeekFn\" [ngClass]=\"row.classMap\" role=\"row\">\n <td *ngIf=\"row.weekNum\" role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n {{ row.weekNum }}\n </td>\n <td *ngFor=\"let cell of row.dateCells;trackBy:trackByDateFn\" title=\"{{ cell.title }}\" role=\"gridcell\" [ngClass]=\"cell.classMap\"\n (click)=\"cell.isDisabled ? null : cell.onClick()\" (mouseenter)=\"cell.isDisabled ? null : cell.onMouseEnter()\"\n date-table-cell [prefixCls]=\"prefixCls\" [cell]=\"cell\">\n </td>\n </tr>\n </tbody>\n</table>"
}] }
];
/** @nocollapse */
DateTableComponent.ctorParameters = function () { return [
{ type: NzI18nService },
{ type: DateHelperService }
]; };
DateTableComponent.propDecorators = {
prefixCls: [{ type: Input }],
locale: [{ type: Input }],
selectedValue: [{ type: Input }],
hoverValue: [{ type: Input }],
value: [{ type: Input }],
activeDate: [{ type: Input }],
showWeek: [{ type: Input }],
disabledDate: [{ type: Input }],
dateCellRender: [{ type: Input }],
dateFullCellRender: [{ type: Input }],
dayHover: [{ type: Output }],
valueChange: [{ type: Output }]
};
return DateTableComponent;
}());
export { DateTableComponent };
if (false) {
/** @type {?} */
DateTableComponent.prototype._value;
/** @type {?} */
DateTableComponent.prototype.headWeekDays;
/** @type {?} */
DateTableComponent.prototype.weekRows;
/** @type {?} */
DateTableComponent.prototype.prefixCls;
/** @type {?} */
DateTableComponent.prototype.locale;
/** @type {?} */
DateTableComponent.prototype.selectedValue;
/** @type {?} */
DateTableComponent.prototype.hoverValue;
/** @type {?} */
DateTableComponent.prototype.activeDate;
/** @type {?} */
DateTableComponent.prototype.showWeek;
/** @type {?} */
DateTableComponent.prototype.disabledDate;
/** @type {?} */
DateTableComponent.prototype.dateCellRender;
/** @type {?} */
DateTableComponent.prototype.dateFullCellRender;
/** @type {?} */
DateTableComponent.prototype.dayHover;
/** @type {?} */
DateTableComponent.prototype.valueChange;
/**
* @type {?}
* @private
*/
DateTableComponent.prototype.i18n;
/**
* @type {?}
* @private
*/
DateTableComponent.prototype.dateHelper;
}
/**
* @record
*/
export function WeekDayLabel() { }
if (false) {
/** @type {?} */
WeekDayLabel.prototype.short;
/** @type {?} */
WeekDayLabel.prototype.veryShort;
}
/**
* @record
*/
export function DateCell() { }
if (false) {
/** @type {?} */
DateCell.prototype.value;
/** @type {?} */
DateCell.prototype.label;
/** @type {?} */
DateCell.prototype.title;
/** @type {?} */
DateCell.prototype.dateCellRender;
/** @type {?} */
DateCell.prototype.dateFullCellRender;
/** @type {?} */
DateCell.prototype.content;
/** @type {?|undefined} */
DateCell.prototype.isSelected;
/** @type {?|undefined} */
DateCell.prototype.isToday;
/** @type {?|undefined} */
DateCell.prototype.isDisabled;
/** @type {?|undefined} */
DateCell.prototype.isSelectedStartDate;
/** @type {?|undefined} */
DateCell.prototype.isSelectedEndDate;
/** @type {?|undefined} */
DateCell.prototype.isInRange;
/** @type {?|undefined} */
DateCell.prototype.classMap;
/**
* @param {?} date
* @return {?}
*/
DateCell.prototype.onClick = function (date) { };
/**
* @return {?}
*/
DateCell.prototype.onMouseEnter = function () { };
}
/**
* @record
*/
export function WeekRow() { }
if (false) {
/** @type {?|undefined} */
WeekRow.prototype.isCurrent;
/** @type {?|undefined} */
WeekRow.prototype.isActive;
/** @type {?|undefined} */
WeekRow.prototype.weekNum;
/** @type {?|undefined} */
WeekRow.prototype.year;
/** @type {?|undefined} */
WeekRow.prototype.classMap;
/** @type {?} */
WeekRow.prototype.dateCells;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-table.component.js","sourceRoot":"ng://ng-zorro-antd/calendar/","sources":["date-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com 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://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChange,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport { valueFunctionProp, CandyDate, FunctionProp } from 'ng-zorro-antd/core';\nimport { DateHelperService, NzCalendarI18nInterface, NzI18nService } from 'ng-zorro-antd/i18n';\n\nconst DATE_ROW_NUM = 6;\nconst DATE_COL_NUM = 7;\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // tslint:disable-next-line:component-selector\n  selector: 'date-table',\n  exportAs: 'dateTable',\n  templateUrl: 'date-table.component.html'\n})\nexport class DateTableComponent implements OnChanges, OnInit {\n  _value: CandyDate;\n  headWeekDays: WeekDayLabel[];\n  weekRows: WeekRow[];\n\n  @Input() prefixCls: string = 'ant-calendar';\n  @Input() locale: NzCalendarI18nInterface;\n  @Input() selectedValue: CandyDate[]; // Range ONLY\n  @Input() hoverValue: CandyDate[]; // Range ONLY\n\n  @Input()\n  set value(date: CandyDate) {\n    // Show today by default\n    this._value = this.activeDate = date || new CandyDate();\n  }\n\n  get value(): CandyDate {\n    return this._value;\n  }\n\n  @Input() activeDate: CandyDate;\n  @Input() showWeek: boolean = false;\n  @Input() disabledDate: (d: Date) => boolean;\n  @Input() dateCellRender: FunctionProp<TemplateRef<Date> | string>;\n  @Input() dateFullCellRender: FunctionProp<TemplateRef<Date> | string>;\n\n  @Output() readonly dayHover = new EventEmitter<CandyDate>(); // Emitted when hover on a day by mouse enter\n  @Output() readonly valueChange = new EventEmitter<CandyDate>();\n\n  constructor(private i18n: NzI18nService, private dateHelper: DateHelperService) {}\n\n  ngOnInit(): void {\n    this.render();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      this.isDateRealChange(changes.activeDate) ||\n      this.isDateRealChange(changes.value) ||\n      this.isDateRealChange(changes.selectedValue) ||\n      this.isDateRealChange(changes.hoverValue)\n    ) {\n      this.render();\n    }\n  }\n\n  private isDateRealChange(change: SimpleChange): boolean {\n    if (change) {\n      const previousValue: CandyDate | CandyDate[] = change.previousValue;\n      const currentValue: CandyDate | CandyDate[] = change.currentValue;\n      if (Array.isArray(currentValue)) {\n        return (\n          !Array.isArray(previousValue) ||\n          currentValue.length !== previousValue.length ||\n          currentValue.some((value, index) => {\n            const previousCandyDate = previousValue[index];\n            return previousCandyDate instanceof CandyDate\n              ? previousCandyDate.isSameDay(value)\n              : previousCandyDate !== value;\n          })\n        );\n      } else {\n        return !this.isSameDate(previousValue as CandyDate, currentValue);\n      }\n    }\n    return false;\n  }\n\n  private isSameDate(left: CandyDate, right: CandyDate): boolean {\n    return (!left && !right) || (left && right && right.isSameDay(left));\n  }\n\n  private render(): void {\n    if (this.value) {\n      this.headWeekDays = this.makeHeadWeekDays();\n      this.weekRows = this.makeWeekRows();\n    }\n  }\n\n  private changeValueFromInside(value: CandyDate): void {\n    // Only change date not change time\n    const newValue = this.value\n      .setYear(value.getYear())\n      .setMonth(value.getMonth())\n      .setDate(value.getDate());\n    this.valueChange.emit(newValue);\n  }\n\n  private makeHeadWeekDays(): WeekDayLabel[] {\n    const weekDays: WeekDayLabel[] = [];\n    const start = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n    for (let colIndex = 0; colIndex < DATE_COL_NUM; colIndex++) {\n      const day = start.addDays(colIndex);\n      weekDays[colIndex] = {\n        short: this.dateHelper.format(day.nativeDate, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd'), // eg. Tue\n        veryShort: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()) // eg. Tu\n      };\n    }\n    return weekDays;\n  }\n\n  private getVeryShortWeekFormat(): string {\n    if (this.dateHelper.relyOnDatePipe) {\n      return this.i18n\n        .getLocaleId()\n        .toLowerCase()\n        .indexOf('zh') === 0\n        ? 'EEEEE'\n        : 'EEEEEE'; // Use extreme short for chinese\n    }\n    return 'dd';\n  }\n\n  private makeWeekRows(): WeekRow[] {\n    const weekRows: WeekRow[] = [];\n    const firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n\n    for (let week = 0; week < DATE_ROW_NUM; week++) {\n      const weekStart = firstDayOfMonth.addDays(week * 7);\n      const row: WeekRow = {\n        isActive: false,\n        isCurrent: false,\n        dateCells: [],\n        year: weekStart.getYear()\n      };\n\n      for (let day = 0; day < 7; day++) {\n        const date = weekStart.addDays(day);\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.nativeDate, dateFormat);\n        const label = this.dateHelper.format(date.nativeDate, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');\n\n        const cell: DateCell = {\n          value: date.nativeDate,\n          label: label,\n          isSelected: false,\n          isDisabled: false,\n          isToday: false,\n          title: title,\n          dateCellRender: valueFunctionProp(this.dateCellRender, date), // Customized content\n          dateFullCellRender: valueFunctionProp(this.dateFullCellRender, date),\n          content: `${date.getDate()}`,\n          onClick: () => this.changeValueFromInside(date),\n          onMouseEnter: () => this.dayHover.emit(date)\n        };\n\n        if (this.showWeek && !row.weekNum) {\n          row.weekNum = this.dateHelper.getISOWeek(date.nativeDate);\n        }\n\n        if (date.isToday()) {\n          cell.isToday = true;\n          row.isCurrent = true;\n        }\n\n        if (Array.isArray(this.selectedValue) && date.isSameMonth(this.activeDate)) {\n          // Range selections\n          const rangeValue = this.hoverValue && this.hoverValue.length ? this.hoverValue : this.selectedValue;\n          const start = rangeValue[0];\n          const end = rangeValue[1];\n          if (start) {\n            if (start.isSameDay(date)) {\n              cell.isSelectedStartDate = true;\n              cell.isSelected = true;\n              row.isActive = true;\n            }\n            if (end) {\n              if (end.isSameDay(date)) {\n                cell.isSelectedEndDate = true;\n                cell.isSelected = true;\n                row.isActive = true;\n              } else if (date.isAfterDay(start) && date.isBeforeDay(end)) {\n                cell.isInRange = true;\n              }\n            }\n          }\n        } else if (date.isSameDay(this.value)) {\n          cell.isSelected = true;\n          row.isActive = true;\n        }\n\n        if (this.disabledDate && this.disabledDate(date.nativeDate)) {\n          cell.isDisabled = true;\n        }\n\n        cell.classMap = {\n          [`${this.prefixCls}-cell`]: true,\n          [`${this.prefixCls}-today`]: cell.isToday,\n          [`${this.prefixCls}-last-month-cell`]: date.isBeforeMonth(this.activeDate),\n          [`${this.prefixCls}-next-month-btn-day`]: date.isAfterMonth(this.activeDate),\n          [`${this.prefixCls}-selected-day`]: cell.isSelected,\n          [`${this.prefixCls}-disabled-cell`]: cell.isDisabled,\n          [`${this.prefixCls}-selected-start-date`]: !!cell.isSelectedStartDate,\n          [`${this.prefixCls}-selected-end-date`]: !!cell.isSelectedEndDate,\n          [`${this.prefixCls}-in-range-cell`]: !!cell.isInRange\n        };\n\n        row.dateCells.push(cell);\n      }\n\n      row.classMap = {\n        [`${this.prefixCls}-current-week`]: row.isCurrent,\n        [`${this.prefixCls}-active-week`]: row.isActive\n      };\n\n      weekRows.push(row);\n    }\n\n    return weekRows;\n  }\n\n  trackByDateFn(_index: number, item: DateCell): string {\n    return `${item.title}`;\n  }\n\n  trackByWeekFn(_index: number, item: WeekRow): string {\n    return `${item.year}-${item.weekNum}`;\n  }\n}\n\nexport interface WeekDayLabel {\n  short: string;\n  veryShort: string;\n}\n\nexport interface DateCell {\n  value: Date;\n  label: string;\n  title: string;\n  dateCellRender: TemplateRef<Date> | string;\n  dateFullCellRender: TemplateRef<Date> | string;\n  content: string;\n  isSelected?: boolean;\n  isToday?: boolean;\n  isDisabled?: boolean;\n  isSelectedStartDate?: boolean;\n  isSelectedEndDate?: boolean;\n  isInRange?: boolean;\n  classMap?: object;\n  onClick(date: CandyDate): void;\n  onMouseEnter(): void;\n}\n\nexport interface WeekRow {\n  isCurrent?: boolean; // Is the week that today stays in\n  isActive?: boolean; // Is the week that current setting date stays in\n  weekNum?: number;\n  year?: number;\n  classMap?: object;\n  dateCells: DateCell[];\n}\n"]}