UNPKG

ng-zorro-antd-mobile

Version:

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

163 lines 13.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewEncapsulation, Input, HostBinding } from '@angular/core'; import { zh_CN, en_US } from '../../locale-provider/locale'; export class CalendarTimePickerComponent { constructor() { this.defaultProps = (/** @type {?} */ ({ minDate: new Date(0, 0, 0, 0, 0), maxDate: new Date(9999, 11, 31, 23, 59, 59), defaultValue: new Date(2000, 1, 1, 8), mode: 'time', datePickerViewLocale: zh_CN })); this.props = (/** @type {?} */ ({ minDate: new Date(0, 0, 0, 0, 0), maxDate: new Date(9999, 11, 31, 23, 59, 59), defaultValue: new Date(2000, 1, 1, 8), mode: 'time', datePickerViewLocale: zh_CN })); this.timePicker = true; this.onDateChange = (/** * @param {?} date * @return {?} */ (date) => { const { onValueChange } = this.props; if (onValueChange) { onValueChange(date.date); } }); } /** * @param {?} value * @return {?} */ set propsData(value) { this.props = Object.assign({}, this.props, value); if (this.props.locale && this.props.locale.today === 'Today') { this.props.datePickerViewLocale = en_US; } else { this.props.datePickerViewLocale = zh_CN; } } /** * @param {?} value * @return {?} */ set title(value) { this.props.title = value; } /** * @param {?} value * @return {?} */ set value(value) { this.props.value = value; } /** * @param {?} value * @return {?} */ set prefixCls(value) { this.props.prefixCls = value; } /** * @param {?} value * @return {?} */ set defaultValue(value) { this.props.defaultValue = value; } /** * @param {?} value * @return {?} */ set pickerPrefixCls(value) { this.props.pickerPrefixCls = value; } /** * @param {?} value * @return {?} */ set clientHeight(value) { this.props.clientHeight = value; /** @type {?} */ const height = (value && (value * 3) / 8 - 52) || Number.POSITIVE_INFINITY; this.selfHeight = (height > 164 || height < 0 ? 164 : height) + 'px'; } /** * @param {?} value * @return {?} */ set onValueChange(value) { this.props.onValueChange = value; } /** * @param {?=} date * @return {?} */ getMinTime(date) { /** @type {?} */ const minDate = (/** @type {?} */ (this.props.minDate)); if (!date || date.getFullYear() > minDate.getFullYear() || date.getMonth() > minDate.getMonth() || date.getDate() > minDate.getDate()) { return this.defaultProps.minDate; } return minDate; } /** * @param {?=} date * @return {?} */ getMaxTime(date) { /** @type {?} */ const maxDate = (/** @type {?} */ (this.props.maxDate)); if (!date || date.getFullYear() < maxDate.getFullYear() || date.getMonth() < maxDate.getMonth() || date.getDate() < maxDate.getDate()) { return this.defaultProps.maxDate; } return maxDate; } } CalendarTimePickerComponent.decorators = [ { type: Component, args: [{ selector: 'CalendarTimePicker, nzm-calendar-time-picker', template: "<div class=\"title\">{{ props.title }}</div>\n<DatePickerView\n [ngStyle]=\"{ height: selfHeight, overflow: 'hidden' }\"\n [mode]=\"props.mode\"\n [value]=\"props.value\"\n [locale]=\"props.datePickerViewLocale\"\n [minDate]=\"getMinTime(props.value || props.defaultValue || undefined)\"\n [maxDate]=\"getMaxTime(props.value || props.defaultValue || undefined)\"\n (onValueChange)=\"onDateChange($event)\"\n></DatePickerView>\n", encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ CalendarTimePickerComponent.ctorParameters = () => []; CalendarTimePickerComponent.propDecorators = { propsData: [{ type: Input }], title: [{ type: Input }], value: [{ type: Input }], prefixCls: [{ type: Input }], defaultValue: [{ type: Input }], pickerPrefixCls: [{ type: Input }], clientHeight: [{ type: Input }], onValueChange: [{ type: Input }], timePicker: [{ type: HostBinding, args: ['class.time-picker',] }] }; if (false) { /** @type {?} */ CalendarTimePickerComponent.prototype.defaultProps; /** @type {?} */ CalendarTimePickerComponent.prototype.props; /** @type {?} */ CalendarTimePickerComponent.prototype.selfHeight; /** @type {?} */ CalendarTimePickerComponent.prototype.timePicker; /** @type {?} */ CalendarTimePickerComponent.prototype.onDateChange; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["calendar/timepicker/timepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, Input, HostBinding } from '@angular/core';\nimport { zh_CN, en_US } from '../../locale-provider/locale';\nimport { CalendarTimePickerPropsType } from './PropsType';\n\n@Component({\n  selector: 'CalendarTimePicker, nzm-calendar-time-picker',\n  templateUrl: './timepicker.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class CalendarTimePickerComponent {\n  defaultProps = {\n    minDate: new Date(0, 0, 0, 0, 0),\n    maxDate: new Date(9999, 11, 31, 23, 59, 59),\n    defaultValue: new Date(2000, 1, 1, 8),\n    mode: 'time',\n    datePickerViewLocale: zh_CN\n  } as CalendarTimePickerPropsType;\n\n  props = {\n    minDate: new Date(0, 0, 0, 0, 0),\n    maxDate: new Date(9999, 11, 31, 23, 59, 59),\n    defaultValue: new Date(2000, 1, 1, 8),\n    mode: 'time',\n    datePickerViewLocale: zh_CN\n  } as CalendarTimePickerPropsType;\n\n  selfHeight: string;\n\n  @Input()\n  set propsData(value) {\n    this.props = {\n      ...this.props,\n      ...value\n    };\n\n    if (this.props.locale && this.props.locale.today === 'Today') {\n      this.props.datePickerViewLocale = en_US;\n    } else {\n      this.props.datePickerViewLocale = zh_CN;\n    }\n  }\n  @Input()\n  set title(value) {\n    this.props.title = value;\n  }\n  @Input()\n  set value(value) {\n    this.props.value = value;\n  }\n  @Input()\n  set prefixCls(value) {\n    this.props.prefixCls = value;\n  }\n  @Input()\n  set defaultValue(value) {\n    this.props.defaultValue = value;\n  }\n  @Input()\n  set pickerPrefixCls(value) {\n    this.props.pickerPrefixCls = value;\n  }\n  @Input()\n  set clientHeight(value) {\n    this.props.clientHeight = value;\n    const height = (value && (value * 3) / 8 - 52) || Number.POSITIVE_INFINITY;\n    this.selfHeight = (height > 164 || height < 0 ? 164 : height) + 'px';\n  }\n  @Input()\n  set onValueChange(value) {\n    this.props.onValueChange = value;\n  }\n\n  @HostBinding('class.time-picker')\n  timePicker: boolean = true;\n\n  constructor() {}\n\n  onDateChange = (date: { date: Date; index: number }) => {\n    const { onValueChange } = this.props;\n    if (onValueChange) {\n      onValueChange(date.date);\n    }\n  }\n\n  getMinTime(date?: Date) {\n    const minDate = this.props.minDate as Date;\n    if (\n      !date ||\n      date.getFullYear() > minDate.getFullYear() ||\n      date.getMonth() > minDate.getMonth() ||\n      date.getDate() > minDate.getDate()\n    ) {\n      return this.defaultProps.minDate;\n    }\n    return minDate;\n  }\n\n  getMaxTime(date?: Date) {\n    const maxDate = this.props.maxDate as Date;\n    if (\n      !date ||\n      date.getFullYear() < maxDate.getFullYear() ||\n      date.getMonth() < maxDate.getMonth() ||\n      date.getDate() < maxDate.getDate()\n    ) {\n      return this.defaultProps.maxDate;\n    }\n    return maxDate;\n  }\n}\n"]}