ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
161 lines • 23 kB
JavaScript
import { Component, ViewEncapsulation, HostBinding, Input, ElementRef } from '@angular/core';
import { DateModels } from '../date/DataTypes';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class CalendarSingleMonthComponent {
set data(value) {
this.props = {
...this.props,
...value
};
}
constructor(_elementRef) {
this._elementRef = _elementRef;
this.props = {
rowSize: 'normal'
};
this.state = {
weekComponents: []
};
this.singleMonth = true;
this.genWeek = (weeksData, index) => {
const { getDateExtra, monthData, onCellClick, locale, rowSize } = this.props;
let rowCls = 'row';
let weeksDataList = [];
if (rowSize === 'xl') {
rowCls += ' row-xl';
}
weeksData.forEach((day, dayOfWeek) => {
const extra = (getDateExtra && getDateExtra(new Date(day.tick))) || {};
let info = extra.info;
const disable = extra.disable || day.outOfDate;
let cls = 'date';
let lCls = 'left';
let rCls = 'right';
let infoCls = 'info';
if (dayOfWeek === 0 || dayOfWeek === 6) {
cls += ' grey';
}
if (disable) {
cls += ' disable';
}
else if (info) {
cls += ' important';
}
if (day.selected) {
cls += ' date-selected';
let styleType = day.selected;
switch (styleType) {
case DateModels.SelectType.Only:
info = locale.begin;
infoCls += ' date-selected';
break;
case DateModels.SelectType.All:
info = locale.begin_over;
infoCls += ' date-selected';
break;
case DateModels.SelectType.Start:
info = locale.begin;
infoCls += ' date-selected';
if (dayOfWeek === 6 || day.isLastOfMonth) {
styleType = DateModels.SelectType.All;
}
break;
case DateModels.SelectType.Middle:
if (dayOfWeek === 0 || day.isFirstOfMonth) {
if (day.isLastOfMonth || dayOfWeek === 6) {
styleType = DateModels.SelectType.All;
}
else {
styleType = DateModels.SelectType.Start;
}
}
else if (dayOfWeek === 6 || day.isLastOfMonth) {
styleType = DateModels.SelectType.End;
}
break;
case DateModels.SelectType.End:
info = locale.over;
infoCls += ' date-selected';
if (dayOfWeek === 0 || day.isFirstOfMonth) {
styleType = DateModels.SelectType.All;
}
break;
}
switch (styleType) {
case DateModels.SelectType.Single:
case DateModels.SelectType.Only:
case DateModels.SelectType.All:
cls += ' selected-single';
break;
case DateModels.SelectType.Start:
cls += ' selected-start';
rCls += ' date-selected';
break;
case DateModels.SelectType.Middle:
cls += ' selected-middle';
lCls += ' date-selected';
rCls += ' date-selected';
break;
case DateModels.SelectType.End:
cls += ' selected-end';
lCls += ' date-selected';
break;
}
}
weeksDataList[dayOfWeek] = {
lCls,
cls,
day,
rCls,
infoCls,
info,
extra,
disable,
onCellClick: onCellClick,
monthData
};
});
this.state.weekComponents[index] = {
index: index,
rowCls,
weeksDataList
};
};
this.updateWeeks = (monthData) => {
(monthData || this.props.monthData).weeks.forEach((week, index) => {
this.genWeek(week, index);
});
};
this.setWarpper = (dom) => {
this.wrapperDivDOM = dom;
};
}
onClickCell(item) {
if (!item.disable && item.onCellClick) {
item.onCellClick(item.day, item.monthData);
}
}
ngOnInit() {
this.setWarpper(this._elementRef.nativeElement);
this.props.monthData.weeks.forEach((week, index) => {
this.genWeek(week, index);
});
}
ngAfterViewInit() {
this.ref = this.props.ref;
this.ref(this);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CalendarSingleMonthComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: CalendarSingleMonthComponent, selector: "CalendarSingleMonth, nzm-single-month", inputs: { data: "data" }, host: { properties: { "class.single-month": "this.singleMonth" } }, ngImport: i0, template: "<div class=\"month-title\">\n {{ props.monthData.title }}\n</div>\n<div class=\"date\">\n <div *ngFor=\"let row of state.weekComponents; let i = index\" [ngClass]=\"row.rowCls\">\n <div\n *ngFor=\"let cell of row.weeksDataList; let j = index\"\n class=\"{{ 'cell ' + ((cell.extra && cell.extra.cellCls) || '') }}\"\n (click)=\"onClickCell(cell)\"\n >\n <div *ngIf=\"row.extra && row.extra.cellRender\">test</div>\n <div *ngIf=\"!row.extra || (row.extra && row.extra.cellRender)\" class=\"date-wrapper\">\n <span [ngClass]=\"cell.lCls\"></span>\n <div [ngClass]=\"cell.cls\">\n {{ (cell.day && cell.day.dayOfMonth) || '' }}\n </div>\n <span [ngClass]=\"cell.rCls\"></span>\n </div>\n <div *ngIf=\"!row.extra || (row.extra && row.extra.cellRender)\" [ngClass]=\"cell.infoCls\">\n {{ cell.info }}\n </div>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CalendarSingleMonthComponent, decorators: [{
type: Component,
args: [{ selector: 'CalendarSingleMonth, nzm-single-month', encapsulation: ViewEncapsulation.None, template: "<div class=\"month-title\">\n {{ props.monthData.title }}\n</div>\n<div class=\"date\">\n <div *ngFor=\"let row of state.weekComponents; let i = index\" [ngClass]=\"row.rowCls\">\n <div\n *ngFor=\"let cell of row.weeksDataList; let j = index\"\n class=\"{{ 'cell ' + ((cell.extra && cell.extra.cellCls) || '') }}\"\n (click)=\"onClickCell(cell)\"\n >\n <div *ngIf=\"row.extra && row.extra.cellRender\">test</div>\n <div *ngIf=\"!row.extra || (row.extra && row.extra.cellRender)\" class=\"date-wrapper\">\n <span [ngClass]=\"cell.lCls\"></span>\n <div [ngClass]=\"cell.cls\">\n {{ (cell.day && cell.day.dayOfMonth) || '' }}\n </div>\n <span [ngClass]=\"cell.rCls\"></span>\n </div>\n <div *ngIf=\"!row.extra || (row.extra && row.extra.cellRender)\" [ngClass]=\"cell.infoCls\">\n {{ cell.info }}\n </div>\n </div>\n </div>\n</div>\n" }]
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { data: [{
type: Input
}], singleMonth: [{
type: HostBinding,
args: ['class.single-month']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-month.component.js","sourceRoot":"","sources":["../../../../components/calendar/single-month/single-month.component.ts","../../../../components/calendar/single-month/single-month.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewEncapsulation, HostBinding, Input, ElementRef, AfterViewInit } from '@angular/core';\nimport { DateModels } from '../date/DataTypes';\nimport { CalendarSingleMonthPropsType } from './PropsType';\n\n@Component({\n  selector: 'CalendarSingleMonth, nzm-single-month',\n  templateUrl: './single-month.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class CalendarSingleMonthComponent implements OnInit, AfterViewInit {\n  props = {\n    rowSize: 'normal'\n  } as CalendarSingleMonthPropsType;\n\n  state = {\n    weekComponents: []\n  };\n  ref: (dom) => void;\n  wrapperDivDOM: HTMLDivElement | null;\n\n  @Input()\n  set data(value) {\n    this.props = {\n      ...this.props,\n      ...value\n    };\n  }\n\n  @HostBinding('class.single-month') singleMonth: boolean = true;\n\n  constructor(private _elementRef: ElementRef) {}\n\n  genWeek = (weeksData: DateModels.CellData[], index: number) => {\n    const { getDateExtra, monthData, onCellClick, locale, rowSize } = this.props;\n    let rowCls = 'row';\n    let weeksDataList = [];\n    if (rowSize === 'xl') {\n      rowCls += ' row-xl';\n    }\n\n    weeksData.forEach((day, dayOfWeek) => {\n      const extra = (getDateExtra && getDateExtra(new Date(day.tick))) || {};\n      let info = extra.info;\n      const disable = extra.disable || day.outOfDate;\n\n      let cls = 'date';\n      let lCls = 'left';\n      let rCls = 'right';\n      let infoCls = 'info';\n\n      if (dayOfWeek === 0 || dayOfWeek === 6) {\n        cls += ' grey';\n      }\n\n      if (disable) {\n        cls += ' disable';\n      } else if (info) {\n        cls += ' important';\n      }\n\n      if (day.selected) {\n        cls += ' date-selected';\n        let styleType = day.selected;\n        switch (styleType) {\n          case DateModels.SelectType.Only:\n            info = locale.begin;\n            infoCls += ' date-selected';\n            break;\n          case DateModels.SelectType.All:\n            info = locale.begin_over;\n            infoCls += ' date-selected';\n            break;\n\n          case DateModels.SelectType.Start:\n            info = locale.begin;\n            infoCls += ' date-selected';\n            if (dayOfWeek === 6 || day.isLastOfMonth) {\n              styleType = DateModels.SelectType.All;\n            }\n            break;\n          case DateModels.SelectType.Middle:\n            if (dayOfWeek === 0 || day.isFirstOfMonth) {\n              if (day.isLastOfMonth || dayOfWeek === 6) {\n                styleType = DateModels.SelectType.All;\n              } else {\n                styleType = DateModels.SelectType.Start;\n              }\n            } else if (dayOfWeek === 6 || day.isLastOfMonth) {\n              styleType = DateModels.SelectType.End;\n            }\n            break;\n          case DateModels.SelectType.End:\n            info = locale.over;\n            infoCls += ' date-selected';\n            if (dayOfWeek === 0 || day.isFirstOfMonth) {\n              styleType = DateModels.SelectType.All;\n            }\n            break;\n        }\n\n        switch (styleType) {\n          case DateModels.SelectType.Single:\n          case DateModels.SelectType.Only:\n          case DateModels.SelectType.All:\n            cls += ' selected-single';\n            break;\n          case DateModels.SelectType.Start:\n            cls += ' selected-start';\n            rCls += ' date-selected';\n            break;\n          case DateModels.SelectType.Middle:\n            cls += ' selected-middle';\n            lCls += ' date-selected';\n            rCls += ' date-selected';\n            break;\n          case DateModels.SelectType.End:\n            cls += ' selected-end';\n            lCls += ' date-selected';\n            break;\n        }\n      }\n\n      weeksDataList[dayOfWeek] = {\n        lCls,\n        cls,\n        day,\n        rCls,\n        infoCls,\n        info,\n        extra,\n        disable,\n        onCellClick: onCellClick,\n        monthData\n      };\n    });\n\n    this.state.weekComponents[index] = {\n      index: index,\n      rowCls,\n      weeksDataList\n    };\n  }\n\n  updateWeeks = (monthData?: DateModels.MonthData) => {\n    (monthData || this.props.monthData).weeks.forEach((week, index) => {\n      this.genWeek(week, index);\n    });\n  }\n\n  setWarpper = (dom: HTMLDivElement) => {\n    this.wrapperDivDOM = dom;\n  }\n\n  onClickCell(item) {\n    if (!item.disable && item.onCellClick) {\n      item.onCellClick(item.day, item.monthData);\n    }\n  }\n\n  ngOnInit() {\n    this.setWarpper(this._elementRef.nativeElement);\n    this.props.monthData.weeks.forEach((week, index) => {\n      this.genWeek(week, index);\n    });\n  }\n\n  ngAfterViewInit() {\n    this.ref = this.props.ref;\n    this.ref(this);\n  }\n}\n","<div class=\"month-title\">\n  {{ props.monthData.title }}\n</div>\n<div class=\"date\">\n  <div *ngFor=\"let row of state.weekComponents; let i = index\" [ngClass]=\"row.rowCls\">\n    <div\n      *ngFor=\"let cell of row.weeksDataList; let j = index\"\n      class=\"{{ 'cell ' + ((cell.extra && cell.extra.cellCls) || '') }}\"\n      (click)=\"onClickCell(cell)\"\n    >\n      <div *ngIf=\"row.extra && row.extra.cellRender\">test</div>\n      <div *ngIf=\"!row.extra || (row.extra && row.extra.cellRender)\" class=\"date-wrapper\">\n        <span [ngClass]=\"cell.lCls\"></span>\n        <div [ngClass]=\"cell.cls\">\n          {{ (cell.day && cell.day.dayOfMonth) || '' }}\n        </div>\n        <span [ngClass]=\"cell.rCls\"></span>\n      </div>\n      <div *ngIf=\"!row.extra || (row.extra && row.extra.cellRender)\" [ngClass]=\"cell.infoCls\">\n        {{ cell.info }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}