UNPKG

ng-zorro-antd-mobile

Version:

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

161 lines 23 kB
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"]}