ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
387 lines • 40.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/date-table.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __extends, __read } from "tslib";
/**
* 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 { CandyDate } from 'ng-zorro-antd/core/time';
import { valueFunctionProp } from 'ng-zorro-antd/core/util';
import { DateHelperService, NzI18nService } from 'ng-zorro-antd/i18n';
import { AbstractTable } from './abstract-table';
import { transCompatFormat } from './util';
var DateTableComponent = /** @class */ (function (_super) {
__extends(DateTableComponent, _super);
function DateTableComponent(i18n, dateHelper) {
var _this = _super.call(this) || this;
_this.i18n = i18n;
_this.dateHelper = dateHelper;
_this.selectedValue = []; // Range ONLY
// Range ONLY
_this.hoverValue = []; // Range ONLY
// Range ONLY
_this.dayHover = new EventEmitter(); // Emitted when hover on a day by mouse enter
return _this;
}
/**
* @param {?} changes
* @return {?}
*/
DateTableComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
_super.prototype.ngOnChanges.call(this, 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
* @param {?} value
* @return {?}
*/
DateTableComponent.prototype.changeValueFromInside = /**
* @private
* @param {?} value
* @return {?}
*/
function (value) {
// Only change date not change time
this.activeDate = this.activeDate.setYear(value.getYear()).setMonth(value.getMonth()).setDate(value.getDate());
this.valueChange.emit(this.activeDate);
if (!this.activeDate.isSameMonth(this.value)) {
this.render();
}
};
/**
* @return {?}
*/
DateTableComponent.prototype.makeHeadRow = /**
* @return {?}
*/
function () {
/** @type {?} */
var weekDays = [];
/** @type {?} */
var start = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });
for (var colIndex = 0; colIndex < this.MAX_COL; colIndex++) {
/** @type {?} */
var day = start.addDays(colIndex);
weekDays.push({
value: day.nativeDate,
title: this.dateHelper.format(day.nativeDate, 'E'),
// eg. Tue
content: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()),
// eg. Tu,
isSelected: false,
isDisabled: false,
onClick: /**
* @return {?}
*/
function () { },
onMouseEnter: /**
* @return {?}
*/
function () { }
});
}
return weekDays;
};
/**
* @private
* @return {?}
*/
DateTableComponent.prototype.getVeryShortWeekFormat = /**
* @private
* @return {?}
*/
function () {
return this.i18n.getLocaleId().toLowerCase().indexOf('zh') === 0 ? 'EEEEE' : 'EEEEEE'; // Use extreme short for chinese
};
/**
* @return {?}
*/
DateTableComponent.prototype.makeBodyRows = /**
* @return {?}
*/
function () {
var _a;
var _this = this;
var _b;
/** @type {?} */
var weekRows = [];
/** @type {?} */
var firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });
for (var week = 0; week < this.MAX_ROW; week++) {
/** @type {?} */
var weekStart = firstDayOfMonth.addDays(week * 7);
/** @type {?} */
var row = {
isActive: false,
isCurrent: false,
dateCells: [],
year: weekStart.getYear()
};
var _loop_1 = function (day) {
/** @type {?} */
var date = weekStart.addDays(day);
/** @type {?} */
var dateFormat = transCompatFormat(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, 'dd');
/** @type {?} */
var cell = {
value: date.nativeDate,
label: label,
isSelected: false,
isDisabled: false,
isToday: false,
title: title,
cellRender: valueFunctionProp((/** @type {?} */ (this_1.cellRender)), date),
// Customized content
fullCellRender: valueFunctionProp((/** @type {?} */ (this_1.fullCellRender)), 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) && this_1.selectedValue.length > 0) || (this_1.hoverValue && this_1.hoverValue.length > 0)) &&
date.isSameMonth(this_1.activeDate)) {
var _a = __read(this_1.hoverValue, 2), startHover = _a[0], endHover = _a[1];
var _b = __read(this_1.selectedValue, 2), startSelected = _b[0], endSelected = _b[1];
// Selected
if (startSelected && startSelected.isSameDay(date)) {
cell.isSelectedStartDate = true;
cell.isSelected = true;
row.isActive = true;
}
if (endSelected && endSelected.isSameDay(date)) {
cell.isSelectedEndDate = true;
cell.isSelected = true;
row.isActive = true;
}
else if (date.isAfterDay(startSelected) && date.isBeforeDay(endSelected)) {
cell.isInSelectedRange = true;
}
if (startHover && endHover) {
// Hover
if (startHover.isSameDay(date)) {
cell.isHoverStartDate = true;
}
if (endHover.isSameDay(date)) {
cell.isHoverEndDate = true;
}
if (date.isLastDayOfMonth()) {
cell.isLastDayOfMonth = true;
}
if (date.isFirstDayOfMonth()) {
cell.isFirstDayOfMonth = true;
}
}
if (startSelected && !endSelected) {
cell.isStartSingle = true;
}
if (!startSelected && endSelected) {
cell.isEndSingle = true;
}
if (date.isAfterDay(startHover) && date.isBeforeDay(endHover)) {
cell.isInHoverRange = true;
}
}
else if (date.isSameDay(this_1.value)) {
cell.isSelected = true;
row.isActive = true;
}
if ((_b = this_1.disabledDate) === null || _b === void 0 ? void 0 : _b.call(this_1, date.nativeDate)) {
cell.isDisabled = true;
}
cell.classMap = this_1.getClassMap(cell);
row.dateCells.push(cell);
};
var this_1 = this;
for (var day = 0; day < 7; day++) {
_loop_1(day);
}
row.classMap = (_a = {},
_a[this.prefixCls + "-week-panel-row"] = this.showWeek,
_a[this.prefixCls + "-week-panel-row-selected"] = this.showWeek && row.isActive,
_a);
weekRows.push(row);
}
return weekRows;
};
/**
* @param {?} cell
* @return {?}
*/
DateTableComponent.prototype.getClassMap = /**
* @param {?} cell
* @return {?}
*/
function (cell) {
var _a;
/** @type {?} */
var date = new CandyDate(cell.value);
return _a = {},
_a["ant-picker-cell"] = true,
_a["ant-picker-cell-today"] = !!cell.isToday,
_a["ant-picker-cell-in-view"] = date.isSameMonth(this.activeDate),
_a["ant-picker-cell-selected"] = cell.isSelected,
_a["ant-picker-cell-disabled"] = cell.isDisabled,
_a["ant-picker-cell-in-range"] = !!cell.isInSelectedRange,
_a["ant-picker-cell-range-start"] = !!cell.isSelectedStartDate,
_a["ant-picker-cell-range-end"] = !!cell.isSelectedEndDate,
_a["ant-picker-cell-range-start-single"] = !!cell.isStartSingle,
_a["ant-picker-cell-range-end-single"] = !!cell.isEndSingle,
_a["ant-picker-cell-range-hover"] = !!cell.isInHoverRange,
_a["ant-picker-cell-range-hover-start"] = !!cell.isHoverStartDate,
_a["ant-picker-cell-range-hover-end"] = !!cell.isHoverEndDate,
_a["ant-picker-cell-range-hover-edge-start"] = !!cell.isFirstDayOfMonth,
_a["ant-picker-cell-range-hover-edge-end"] = !!cell.isLastDayOfMonth,
_a;
};
/**
* @param {?} _index
* @param {?} item
* @return {?}
*/
DateTableComponent.prototype.trackByBodyRow = /**
* @param {?} _index
* @param {?} item
* @return {?}
*/
function (_index, item) {
return item.year + "-" + item.weekNum;
};
/**
* @param {?} _index
* @param {?} item
* @return {?}
*/
DateTableComponent.prototype.trackByBodyColumn = /**
* @param {?} _index
* @param {?} item
* @return {?}
*/
function (_index, item) {
return (/** @type {?} */ (item.title));
};
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=\"ant-picker-content\" cellspacing=\"0\" role=\"grid\">\n <thead *ngIf=\"headRow && headRow.length > 0\">\n <tr role=\"row\">\n <th *ngIf=\"showWeek\" role=\"columnheader\"></th>\n <th *ngFor=\"let cell of headRow\" role=\"columnheader\" title=\"{{ cell.title }}\">\n {{ cell.content }}\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of bodyRows; trackBy: trackByBodyRow\" [ngClass]=\"row.classMap!\" role=\"row\">\n <td *ngIf=\"row.weekNum\" role=\"gridcell\" class=\"{{ prefixCls }}-cell-week\">\n {{ row.weekNum }}\n </td>\n <td\n *ngFor=\"let cell of row.dateCells; trackBy: trackByBodyColumn\"\n title=\"{{ cell.title }}\"\n role=\"gridcell\"\n [ngClass]=\"cell.classMap!\"\n (click)=\"cell.isDisabled ? null : cell.onClick()\"\n (mouseenter)=\"cell.onMouseEnter()\"\n >\n <ng-container [ngSwitch]=\"prefixCls\">\n <ng-container *ngSwitchCase=\"'ant-picker'\">\n <ng-container [ngSwitch]=\"true\">\n <ng-container *ngSwitchCase=\"isTemplateRef(cell.cellRender)\">\n <!-- *ngSwitchCase not has type assertion support, the cellRender type here is TemplateRef -->\n <ng-container\n *ngTemplateOutlet=\"$any(cell.cellRender); context: { $implicit: cell.value }\"\n ></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"isNonEmptyString(cell.cellRender)\">\n <span [innerHTML]=\"cell.cellRender\"></span>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <div\n class=\"{{ prefixCls }}-cell-inner\"\n [attr.aria-selected]=\"cell.isSelected\"\n [attr.aria-disabled]=\"cell.isDisabled\"\n >\n {{ cell.content }}\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'ant-picker-calendar'\">\n <div\n class=\"{{ prefixCls }}-date ant-picker-cell-inner\"\n [class.ant-picker-calendar-date-today]=\"cell.isToday\"\n >\n <ng-container *ngIf=\"cell.fullCellRender; else defaultCell\">\n <ng-container\n *ngTemplateOutlet=\"$any(cell.fullCellRender); context: { $implicit: cell.value }\"\n >\n </ng-container>\n </ng-container>\n <ng-template #defaultCell>\n <div class=\"{{ prefixCls }}-date-value\">{{ cell.content }}</div>\n <div class=\"{{ prefixCls }}-date-content\">\n <ng-container\n *ngTemplateOutlet=\"$any(cell.cellRender); context: { $implicit: cell.value }\"\n >\n </ng-container>\n </div>\n </ng-template>\n </div>\n </ng-container>\n </ng-container>\n </td>\n </tr>\n </tbody>\n</table>\n"
}] }
];
/** @nocollapse */
DateTableComponent.ctorParameters = function () { return [
{ type: NzI18nService },
{ type: DateHelperService }
]; };
DateTableComponent.propDecorators = {
locale: [{ type: Input }],
selectedValue: [{ type: Input }],
hoverValue: [{ type: Input }],
dayHover: [{ type: Output }]
};
return DateTableComponent;
}(AbstractTable));
export { DateTableComponent };
if (false) {
/** @type {?} */
DateTableComponent.prototype.locale;
/** @type {?} */
DateTableComponent.prototype.selectedValue;
/** @type {?} */
DateTableComponent.prototype.hoverValue;
/** @type {?} */
DateTableComponent.prototype.dayHover;
/**
* @type {?}
* @private
*/
DateTableComponent.prototype.i18n;
/**
* @type {?}
* @private
*/
DateTableComponent.prototype.dateHelper;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-table.component.js","sourceRoot":"ng://ng-zorro-antd/date-picker/","sources":["lib/date-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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  ViewEncapsulation\n} from '@angular/core';\nimport { CandyDate } from 'ng-zorro-antd/core/time';\nimport { valueFunctionProp } from 'ng-zorro-antd/core/util';\n\nimport { DateHelperService, NzCalendarI18nInterface, NzI18nService } from 'ng-zorro-antd/i18n';\nimport { AbstractTable } from './abstract-table';\nimport { DateBodyRow, DateCell, DayCell } from './interface';\nimport { transCompatFormat } from './util';\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: './abstract-table.html'\n})\nexport class DateTableComponent extends AbstractTable implements OnChanges, OnInit {\n  @Input() locale!: NzCalendarI18nInterface;\n  @Input() selectedValue: CandyDate[] = []; // Range ONLY\n  @Input() hoverValue: CandyDate[] = []; // Range ONLY\n\n  @Output() readonly dayHover = new EventEmitter<CandyDate>(); // Emitted when hover on a day by mouse enter\n\n  constructor(private i18n: NzI18nService, private dateHelper: DateHelperService) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    super.ngOnChanges(changes);\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 ? previousCandyDate.isSameDay(value) : 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 changeValueFromInside(value: CandyDate): void {\n    // Only change date not change time\n    this.activeDate = this.activeDate.setYear(value.getYear()).setMonth(value.getMonth()).setDate(value.getDate());\n    this.valueChange.emit(this.activeDate);\n\n    if (!this.activeDate.isSameMonth(this.value)) {\n      this.render();\n    }\n  }\n\n  makeHeadRow(): DayCell[] {\n    const weekDays: DayCell[] = [];\n    const start = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n    for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n      const day = start.addDays(colIndex);\n      weekDays.push({\n        value: day.nativeDate,\n        title: this.dateHelper.format(day.nativeDate, 'E'), // eg. Tue\n        content: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()), // eg. Tu,\n        isSelected: false,\n        isDisabled: false,\n        onClick(): void {},\n        onMouseEnter(): void {}\n      });\n    }\n    return weekDays;\n  }\n\n  private getVeryShortWeekFormat(): string {\n    return this.i18n.getLocaleId().toLowerCase().indexOf('zh') === 0 ? 'EEEEE' : 'EEEEEE'; // Use extreme short for chinese\n  }\n\n  makeBodyRows(): DateBodyRow[] {\n    const weekRows: DateBodyRow[] = [];\n    const firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.dateHelper.getFirstDayOfWeek() });\n\n    for (let week = 0; week < this.MAX_ROW; week++) {\n      const weekStart = firstDayOfMonth.addDays(week * 7);\n      const row: DateBodyRow = {\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 = transCompatFormat(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, 'dd');\n\n        const cell: DayCell = {\n          value: date.nativeDate,\n          label: label,\n          isSelected: false,\n          isDisabled: false,\n          isToday: false,\n          title: title,\n          cellRender: valueFunctionProp(this.cellRender!, date), // Customized content\n          fullCellRender: valueFunctionProp(this.fullCellRender!, 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 (\n          ((Array.isArray(this.selectedValue) && this.selectedValue.length > 0) || (this.hoverValue && this.hoverValue.length > 0)) &&\n          date.isSameMonth(this.activeDate)\n        ) {\n          const [startHover, endHover] = this.hoverValue;\n          const [startSelected, endSelected] = this.selectedValue;\n\n          // Selected\n          if (startSelected && startSelected.isSameDay(date)) {\n            cell.isSelectedStartDate = true;\n            cell.isSelected = true;\n            row.isActive = true;\n          }\n          if (endSelected && endSelected.isSameDay(date)) {\n            cell.isSelectedEndDate = true;\n            cell.isSelected = true;\n            row.isActive = true;\n          } else if (date.isAfterDay(startSelected) && date.isBeforeDay(endSelected)) {\n            cell.isInSelectedRange = true;\n          }\n\n          if (startHover && endHover) {\n            // Hover\n            if (startHover.isSameDay(date)) {\n              cell.isHoverStartDate = true;\n            }\n            if (endHover.isSameDay(date)) {\n              cell.isHoverEndDate = true;\n            }\n            if (date.isLastDayOfMonth()) {\n              cell.isLastDayOfMonth = true;\n            }\n            if (date.isFirstDayOfMonth()) {\n              cell.isFirstDayOfMonth = true;\n            }\n          }\n\n          if (startSelected && !endSelected) {\n            cell.isStartSingle = true;\n          }\n\n          if (!startSelected && endSelected) {\n            cell.isEndSingle = true;\n          }\n\n          if (date.isAfterDay(startHover) && date.isBeforeDay(endHover)) {\n            cell.isInHoverRange = true;\n          }\n        } else if (date.isSameDay(this.value)) {\n          cell.isSelected = true;\n          row.isActive = true;\n        }\n\n        if (this.disabledDate?.(date.nativeDate)) {\n          cell.isDisabled = true;\n        }\n\n        cell.classMap = this.getClassMap(cell);\n\n        row.dateCells.push(cell);\n      }\n\n      row.classMap = {\n        [`${this.prefixCls}-week-panel-row`]: this.showWeek,\n        [`${this.prefixCls}-week-panel-row-selected`]: this.showWeek && row.isActive\n      };\n\n      weekRows.push(row);\n    }\n\n    return weekRows;\n  }\n\n  getClassMap(cell: DayCell): { [key: string]: boolean } {\n    const date = new CandyDate(cell.value);\n    return {\n      [`ant-picker-cell`]: true,\n      [`ant-picker-cell-today`]: !!cell.isToday,\n      [`ant-picker-cell-in-view`]: date.isSameMonth(this.activeDate),\n      [`ant-picker-cell-selected`]: cell.isSelected,\n      [`ant-picker-cell-disabled`]: cell.isDisabled,\n      [`ant-picker-cell-in-range`]: !!cell.isInSelectedRange,\n      [`ant-picker-cell-range-start`]: !!cell.isSelectedStartDate,\n      [`ant-picker-cell-range-end`]: !!cell.isSelectedEndDate,\n      [`ant-picker-cell-range-start-single`]: !!cell.isStartSingle,\n      [`ant-picker-cell-range-end-single`]: !!cell.isEndSingle,\n      [`ant-picker-cell-range-hover`]: !!cell.isInHoverRange,\n      [`ant-picker-cell-range-hover-start`]: !!cell.isHoverStartDate,\n      [`ant-picker-cell-range-hover-end`]: !!cell.isHoverEndDate,\n      [`ant-picker-cell-range-hover-edge-start`]: !!cell.isFirstDayOfMonth,\n      [`ant-picker-cell-range-hover-edge-end`]: !!cell.isLastDayOfMonth\n    };\n  }\n\n  trackByBodyRow(_index: number, item: DateBodyRow): string {\n    return `${item.year}-${item.weekNum}`;\n  }\n\n  trackByBodyColumn(_index: number, item: DateCell): string {\n    return item.title as string;\n  }\n}\n"]}