UNPKG

ng-zorro-antd-mobile

Version:

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

177 lines 24.2 kB
import { Component, HostBinding, ViewEncapsulation, Input, ElementRef, ViewChild } from '@angular/core'; import { CalendarDatePickerBaseComponent } from './datepicker.base.component'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../week-panel/week-panel.component"; import * as i3 from "../single-month/single-month.component"; export class CalendarDatePickerComponent extends CalendarDatePickerBaseComponent { constructor() { super(); this.transform = ''; this._initDelta = 0; this._lastY = 0; this._delta = this._initDelta; this.amCalendar = true; this.datePicker = true; this.genMonthComponent = (data) => { if (!data) { return; } return { monthData: data, locale: this.props.locale, rowSize: this.props.rowSize, onCellClick: this.baseOnCellClick, getDateExtra: this.props.getDateExtra, ref: dom => { data.componentRef = dom || data.componentRef || undefined; data.updateLayout = () => { this.computeHeight(data, dom); }; data.updateLayout(); } }; }; this.computeHeight = (data, singleMonth) => { if (singleMonth && singleMonth.wrapperDivDOM) { if (!data.height && !singleMonth.wrapperDivDOM.clientHeight) { setTimeout(() => this.computeHeight(data, singleMonth), 500); return; } data.height = singleMonth.wrapperDivDOM.clientHeight || data.height || 0; data.y = singleMonth.wrapperDivDOM.offsetTop || data.y || 0; } }; this.setLayout = (dom) => { if (dom) { const { onLayout } = this.props; if (onLayout) { onLayout(dom.clientHeight); } const scrollHandler = this.createOnScroll(); dom.onscroll = evt => { scrollHandler({ client: dom.clientHeight, full: evt.currentTarget.clientHeight, top: evt.currentTarget.scrollTop }); }; } }; this.setPanel = (dom) => { this._panel = dom; }; } set onCellClick(value) { this.props.onCellClick = value; } set endDate(value) { const oldProps = Object.assign({}, this.props); this.props.endDate = value; this.receiveProps(oldProps, this.props); } set startDate(value) { const oldProps = Object.assign({}, this.props); this.props.startDate = value; this.receiveProps(oldProps, this.props); } set propsData(value) { this.props = { ...this.props, ...value }; } set onSelectHasDisableDate(value) { this.props.onSelectHasDisableDate = value; } set onLayout(value) { this.props.onLayout = value; } onTouchStart(event) { this._lastY = event.touches[0].screenY || event.touches[0].pageY; this._delta = this._initDelta; } onTouchMove(event) { const ele = event.currentTarget; const isReachTop = ele.scrollTop === 0; if (isReachTop) { this._delta = (event.touches[0].screenY || event.touches[0].pageY) - this._lastY; if (this._delta > 0) { event.preventDefault(); if (this._delta > 80) { this._delta = 80; } } else { this._delta = 0; } this.setTransform(this._panel.style, `translate3d(0,${this._delta}px,0)`); } } onTouchEnd(event) { this.onFinish(); } onFinish() { if (this._delta > 40 && this.canLoadPrev()) { this.genMonthData(this.state.months[0].firstDate, -1); this.visibleMonth = this.state.months.slice(0, this.props.initalMonths); this.state.months.forEach(m => { if (m.updateLayout) { m.updateLayout(); } }); } this.setTransform(this._panel.style, `translate3d(0,0,0)`); this.setTransition(this._panel.style, '.3s'); setTimeout(() => { if (this._panel) { this.setTransition(this._panel.style, ''); } }, 300); } setTransform(nodeStyle, value) { this.transform = value; nodeStyle.transform = value; nodeStyle.webkitTransform = value; } setTransition(nodeStyle, value) { nodeStyle.transition = value; nodeStyle.webkitTransition = value; } ngOnInit() { this.init(); this.setLayout(this.layoutDom.nativeElement); this.setPanel(this.panelDom.nativeElement); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CalendarDatePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: CalendarDatePickerComponent, selector: "CalendarDatePicker, nzm-calendar-date-picker", inputs: { onCellClick: "onCellClick", endDate: "endDate", startDate: "startDate", propsData: "propsData", onSelectHasDisableDate: "onSelectHasDisableDate", onLayout: "onLayout" }, host: { properties: { "class.am-calendar": "this.amCalendar", "class.date-picker": "this.datePicker" } }, viewQueries: [{ propertyName: "layoutDom", first: true, predicate: ["layout"], descendants: true, static: true }, { propertyName: "panelDom", first: true, predicate: ["panel"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<CalendarWeekPanel [locale]=\"props.locale\"></CalendarWeekPanel>\n<div\n #layout\n class=\"wrapper\"\n style=\"overflow-x:hidden;overflow-y:visible;-webkit-overflow-scrolling:touch;\"\n (touchstart)=\"onTouchStart($event)\"\n (touchmove)=\"onTouchMove($event)\"\n (touchend)=\"onTouchEnd($event)\"\n>\n <div #panel [ngStyle]=\"{ transform: transform }\">\n <div *ngIf=\"canLoadPrev()\" class=\"load-tip\">{{ props.locale.loadPrevMonth }}</div>\n <div class=\"months\">\n <CalendarSingleMonth\n *ngFor=\"let item of visibleMonth; let i = index\"\n style=\"display: block;\"\n [data]=\"item.component\"\n ></CalendarSingleMonth>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.CalendarWeekPanelComponent, selector: "CalendarWeekPanel, nzm-calendar-week-panel", inputs: ["locale"] }, { kind: "component", type: i3.CalendarSingleMonthComponent, selector: "CalendarSingleMonth, nzm-single-month", inputs: ["data"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CalendarDatePickerComponent, decorators: [{ type: Component, args: [{ selector: 'CalendarDatePicker, nzm-calendar-date-picker', encapsulation: ViewEncapsulation.None, template: "<CalendarWeekPanel [locale]=\"props.locale\"></CalendarWeekPanel>\n<div\n #layout\n class=\"wrapper\"\n style=\"overflow-x:hidden;overflow-y:visible;-webkit-overflow-scrolling:touch;\"\n (touchstart)=\"onTouchStart($event)\"\n (touchmove)=\"onTouchMove($event)\"\n (touchend)=\"onTouchEnd($event)\"\n>\n <div #panel [ngStyle]=\"{ transform: transform }\">\n <div *ngIf=\"canLoadPrev()\" class=\"load-tip\">{{ props.locale.loadPrevMonth }}</div>\n <div class=\"months\">\n <CalendarSingleMonth\n *ngFor=\"let item of visibleMonth; let i = index\"\n style=\"display: block;\"\n [data]=\"item.component\"\n ></CalendarSingleMonth>\n </div>\n </div>\n</div>\n" }] }], ctorParameters: () => [], propDecorators: { layoutDom: [{ type: ViewChild, args: ['layout', { static: true }] }], panelDom: [{ type: ViewChild, args: ['panel', { static: true }] }], onCellClick: [{ type: Input }], endDate: [{ type: Input }], startDate: [{ type: Input }], propsData: [{ type: Input }], onSelectHasDisableDate: [{ type: Input }], onLayout: [{ type: Input }], amCalendar: [{ type: HostBinding, args: ['class.am-calendar'] }], datePicker: [{ type: HostBinding, args: ['class.date-picker'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../components/calendar/datepicker/datepicker.component.ts","../../../../components/calendar/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, OnInit, ViewEncapsulation, Input, ElementRef, ViewChild } from '@angular/core';\nimport { DateModels } from '../date/DataTypes';\nimport { CalendarDatePickerBaseComponent } from './datepicker.base.component';\n\n@Component({\n  selector: 'CalendarDatePicker, nzm-calendar-date-picker',\n  templateUrl: './datepicker.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class CalendarDatePickerComponent extends CalendarDatePickerBaseComponent implements OnInit {\n  constructor() {\n    super();\n  }\n\n  transform: string = '';\n  private _panel: any;\n  private _initDelta: number = 0;\n  private _lastY: number = 0;\n  private _delta: number = this._initDelta;\n\n  @ViewChild('layout', { static: true })\n  layoutDom: ElementRef;\n  @ViewChild('panel', { static: true })\n  panelDom: ElementRef;\n\n  @Input()\n  set onCellClick(value) {\n    this.props.onCellClick = value;\n  }\n  @Input()\n  set endDate(value) {\n    const oldProps = Object.assign({}, this.props);\n    this.props.endDate = value;\n    this.receiveProps(oldProps, this.props);\n  }\n  @Input()\n  set startDate(value) {\n    const oldProps = Object.assign({}, this.props);\n    this.props.startDate = value;\n    this.receiveProps(oldProps, this.props);\n  }\n  @Input()\n  set propsData(value) {\n    this.props = {\n      ...this.props,\n      ...value\n    };\n  }\n  @Input()\n  set onSelectHasDisableDate(value) {\n    this.props.onSelectHasDisableDate = value;\n  }\n  @Input()\n  set onLayout(value) {\n    this.props.onLayout = value;\n  }\n\n  @HostBinding('class.am-calendar') amCalendar: boolean = true;\n  @HostBinding('class.date-picker') datePicker: boolean = true;\n\n  genMonthComponent = (data?: DateModels.MonthData) => {\n    if (!data) {\n      return;\n    }\n    return {\n      monthData: data,\n      locale: this.props.locale,\n      rowSize: this.props.rowSize,\n      onCellClick: this.baseOnCellClick,\n      getDateExtra: this.props.getDateExtra,\n      ref: dom => {\n        data.componentRef = dom || data.componentRef || undefined;\n        data.updateLayout = () => {\n          this.computeHeight(data, dom);\n        };\n        data.updateLayout();\n      }\n    };\n  }\n\n  computeHeight = (data: DateModels.MonthData, singleMonth) => {\n    if (singleMonth && singleMonth.wrapperDivDOM) {\n      if (!data.height && !singleMonth.wrapperDivDOM.clientHeight) {\n        setTimeout(() => this.computeHeight(data, singleMonth), 500);\n        return;\n      }\n      data.height = singleMonth.wrapperDivDOM.clientHeight || data.height || 0;\n      data.y = singleMonth.wrapperDivDOM.offsetTop || data.y || 0;\n    }\n  }\n\n  setLayout = (dom: HTMLDivElement) => {\n    if (dom) {\n      const { onLayout } = this.props;\n\n      if (onLayout) {\n        onLayout(dom.clientHeight);\n      }\n\n      const scrollHandler = this.createOnScroll();\n      dom.onscroll = evt => {\n        scrollHandler({\n          client: dom.clientHeight,\n          full: (evt.currentTarget as HTMLDivElement).clientHeight,\n          top: (evt.currentTarget as HTMLDivElement).scrollTop\n        });\n      };\n    }\n  }\n\n  setPanel = (dom: HTMLDivElement) => {\n    this._panel = dom;\n  }\n\n  onTouchStart(event) {\n    this._lastY = event.touches[0].screenY || event.touches[0].pageY;\n    this._delta = this._initDelta;\n  }\n\n  onTouchMove(event) {\n    const ele = event.currentTarget;\n    const isReachTop = ele.scrollTop === 0;\n\n    if (isReachTop) {\n      this._delta = (event.touches[0].screenY || event.touches[0].pageY) - this._lastY;\n      if (this._delta > 0) {\n        event.preventDefault();\n        if (this._delta > 80) {\n          this._delta = 80;\n        }\n      } else {\n        this._delta = 0;\n      }\n      this.setTransform(this._panel.style, `translate3d(0,${this._delta}px,0)`);\n    }\n  }\n\n  onTouchEnd(event) {\n    this.onFinish();\n  }\n\n  onFinish() {\n    if (this._delta > 40 && this.canLoadPrev()) {\n      this.genMonthData(this.state.months[0].firstDate, -1);\n\n      this.visibleMonth = this.state.months.slice(0, this.props.initalMonths);\n\n      this.state.months.forEach(m => {\n        if (m.updateLayout) {\n          m.updateLayout();\n        }\n      });\n    }\n    this.setTransform(this._panel.style, `translate3d(0,0,0)`);\n    this.setTransition(this._panel.style, '.3s');\n    setTimeout(() => {\n      if (this._panel) {\n        this.setTransition(this._panel.style, '');\n      }\n    }, 300);\n  }\n\n  setTransform(nodeStyle: CSSStyleDeclaration, value: any) {\n    this.transform = value;\n    nodeStyle.transform = value;\n    nodeStyle.webkitTransform = value;\n  }\n\n  setTransition(nodeStyle: CSSStyleDeclaration, value: any) {\n    nodeStyle.transition = value;\n    nodeStyle.webkitTransition = value;\n  }\n\n  ngOnInit() {\n    this.init();\n    this.setLayout(this.layoutDom.nativeElement);\n    this.setPanel(this.panelDom.nativeElement);\n  }\n}\n","<CalendarWeekPanel [locale]=\"props.locale\"></CalendarWeekPanel>\n<div\n  #layout\n  class=\"wrapper\"\n  style=\"overflow-x:hidden;overflow-y:visible;-webkit-overflow-scrolling:touch;\"\n  (touchstart)=\"onTouchStart($event)\"\n  (touchmove)=\"onTouchMove($event)\"\n  (touchend)=\"onTouchEnd($event)\"\n>\n  <div #panel [ngStyle]=\"{ transform: transform }\">\n    <div *ngIf=\"canLoadPrev()\" class=\"load-tip\">{{ props.locale.loadPrevMonth }}</div>\n    <div class=\"months\">\n      <CalendarSingleMonth\n        *ngFor=\"let item of visibleMonth; let i = index\"\n        style=\"display: block;\"\n        [data]=\"item.component\"\n      ></CalendarSingleMonth>\n    </div>\n  </div>\n</div>\n"]}