ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
358 lines • 26.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, HostBinding, ViewEncapsulation, Input, ElementRef, ViewChild } from '@angular/core';
import { CalendarDatePickerBaseComponent } from './datepicker.base.component';
var CalendarDatePickerComponent = /** @class */ (function (_super) {
tslib_1.__extends(CalendarDatePickerComponent, _super);
function CalendarDatePickerComponent() {
var _this = _super.call(this) || this;
_this.transform = '';
_this._initDelta = 0;
_this._lastY = 0;
_this._delta = _this._initDelta;
_this.amCalendar = true;
_this.datePicker = true;
_this.genMonthComponent = (/**
* @param {?=} data
* @return {?}
*/
function (data) {
if (!data) {
return;
}
return {
monthData: data,
locale: _this.props.locale,
rowSize: _this.props.rowSize,
onCellClick: _this.baseOnCellClick,
getDateExtra: _this.props.getDateExtra,
ref: (/**
* @param {?} dom
* @return {?}
*/
function (dom) {
data.componentRef = dom || data.componentRef || undefined;
data.updateLayout = (/**
* @return {?}
*/
function () {
_this.computeHeight(data, dom);
});
data.updateLayout();
})
};
});
_this.computeHeight = (/**
* @param {?} data
* @param {?} singleMonth
* @return {?}
*/
function (data, singleMonth) {
if (singleMonth && singleMonth.wrapperDivDOM) {
if (!data.height && !singleMonth.wrapperDivDOM.clientHeight) {
setTimeout((/**
* @return {?}
*/
function () { return _this.computeHeight(data, singleMonth); }), 500);
return;
}
data.height = singleMonth.wrapperDivDOM.clientHeight || data.height || 0;
data.y = singleMonth.wrapperDivDOM.offsetTop || data.y || 0;
}
});
_this.setLayout = (/**
* @param {?} dom
* @return {?}
*/
function (dom) {
if (dom) {
var onLayout = _this.props.onLayout;
if (onLayout) {
onLayout(dom.clientHeight);
}
/** @type {?} */
var scrollHandler_1 = _this.createOnScroll();
dom.onscroll = (/**
* @param {?} evt
* @return {?}
*/
function (evt) {
scrollHandler_1({
client: dom.clientHeight,
full: ((/** @type {?} */ (evt.currentTarget))).clientHeight,
top: ((/** @type {?} */ (evt.currentTarget))).scrollTop
});
});
}
});
_this.setPanel = (/**
* @param {?} dom
* @return {?}
*/
function (dom) {
_this._panel = dom;
});
return _this;
}
Object.defineProperty(CalendarDatePickerComponent.prototype, "onCellClick", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.props.onCellClick = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CalendarDatePickerComponent.prototype, "endDate", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var oldProps = Object.assign({}, this.props);
this.props.endDate = value;
this.receiveProps(oldProps, this.props);
},
enumerable: true,
configurable: true
});
Object.defineProperty(CalendarDatePickerComponent.prototype, "startDate", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var oldProps = Object.assign({}, this.props);
this.props.startDate = value;
this.receiveProps(oldProps, this.props);
},
enumerable: true,
configurable: true
});
Object.defineProperty(CalendarDatePickerComponent.prototype, "propsData", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.props = tslib_1.__assign({}, this.props, value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(CalendarDatePickerComponent.prototype, "onSelectHasDisableDate", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.props.onSelectHasDisableDate = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CalendarDatePickerComponent.prototype, "onLayout", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.props.onLayout = value;
},
enumerable: true,
configurable: true
});
/**
* @param {?} event
* @return {?}
*/
CalendarDatePickerComponent.prototype.onTouchStart = /**
* @param {?} event
* @return {?}
*/
function (event) {
this._lastY = event.touches[0].screenY || event.touches[0].pageY;
this._delta = this._initDelta;
};
/**
* @param {?} event
* @return {?}
*/
CalendarDatePickerComponent.prototype.onTouchMove = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var ele = event.currentTarget;
/** @type {?} */
var 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)");
}
};
/**
* @param {?} event
* @return {?}
*/
CalendarDatePickerComponent.prototype.onTouchEnd = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.onFinish();
};
/**
* @return {?}
*/
CalendarDatePickerComponent.prototype.onFinish = /**
* @return {?}
*/
function () {
var _this = this;
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((/**
* @param {?} m
* @return {?}
*/
function (m) {
if (m.updateLayout) {
m.updateLayout();
}
}));
}
this.setTransform(this._panel.style, "translate3d(0,0,0)");
this.setTransition(this._panel.style, '.3s');
setTimeout((/**
* @return {?}
*/
function () {
if (_this._panel) {
_this.setTransition(_this._panel.style, '');
}
}), 300);
};
/**
* @param {?} nodeStyle
* @param {?} value
* @return {?}
*/
CalendarDatePickerComponent.prototype.setTransform = /**
* @param {?} nodeStyle
* @param {?} value
* @return {?}
*/
function (nodeStyle, value) {
this.transform = value;
nodeStyle.transform = value;
nodeStyle.webkitTransform = value;
};
/**
* @param {?} nodeStyle
* @param {?} value
* @return {?}
*/
CalendarDatePickerComponent.prototype.setTransition = /**
* @param {?} nodeStyle
* @param {?} value
* @return {?}
*/
function (nodeStyle, value) {
nodeStyle.transition = value;
nodeStyle.webkitTransition = value;
};
/**
* @return {?}
*/
CalendarDatePickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.init();
this.setLayout(this.layoutDom.nativeElement);
this.setPanel(this.panelDom.nativeElement);
};
CalendarDatePickerComponent.decorators = [
{ type: Component, args: [{
selector: 'CalendarDatePicker, nzm-calendar-date-picker',
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",
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
CalendarDatePickerComponent.ctorParameters = function () { return []; };
CalendarDatePickerComponent.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',] }]
};
return CalendarDatePickerComponent;
}(CalendarDatePickerBaseComponent));
export { CalendarDatePickerComponent };
if (false) {
/** @type {?} */
CalendarDatePickerComponent.prototype.transform;
/**
* @type {?}
* @private
*/
CalendarDatePickerComponent.prototype._panel;
/**
* @type {?}
* @private
*/
CalendarDatePickerComponent.prototype._initDelta;
/**
* @type {?}
* @private
*/
CalendarDatePickerComponent.prototype._lastY;
/**
* @type {?}
* @private
*/
CalendarDatePickerComponent.prototype._delta;
/** @type {?} */
CalendarDatePickerComponent.prototype.layoutDom;
/** @type {?} */
CalendarDatePickerComponent.prototype.panelDom;
/** @type {?} */
CalendarDatePickerComponent.prototype.amCalendar;
/** @type {?} */
CalendarDatePickerComponent.prototype.datePicker;
/** @type {?} */
CalendarDatePickerComponent.prototype.genMonthComponent;
/** @type {?} */
CalendarDatePickerComponent.prototype.computeHeight;
/** @type {?} */
CalendarDatePickerComponent.prototype.setLayout;
/** @type {?} */
CalendarDatePickerComponent.prototype.setPanel;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["calendar/datepicker/datepicker.component.ts"],"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"]}