ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
111 lines • 14.6 kB
JavaScript
import { Component, ViewEncapsulation, Input, HostBinding } from '@angular/core';
import { zh_CN, en_US } from 'ng-zorro-antd-mobile/locale-provider';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "ng-zorro-antd-mobile/date-picker-view";
export class CalendarTimePickerComponent {
set propsData(value) {
this.props = {
...this.props,
...value
};
if (this.props.locale && this.props.locale.today === 'Today') {
this.props.datePickerViewLocale = en_US;
}
else {
this.props.datePickerViewLocale = zh_CN;
}
}
set title(value) {
this.props.title = value;
}
set value(value) {
this.props.value = value;
}
set prefixCls(value) {
this.props.prefixCls = value;
}
set defaultValue(value) {
this.props.defaultValue = value;
}
set pickerPrefixCls(value) {
this.props.pickerPrefixCls = value;
}
set clientHeight(value) {
this.props.clientHeight = value;
const height = (value && (value * 3) / 8 - 52) || Number.POSITIVE_INFINITY;
this.selfHeight = (height > 164 || height < 0 ? 164 : height) + 'px';
}
set onValueChange(value) {
this.props.onValueChange = value;
}
constructor() {
this.defaultProps = {
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 = {
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 = (date) => {
const { onValueChange } = this.props;
if (onValueChange) {
onValueChange(date.date);
}
};
}
getMinTime(date) {
const minDate = this.props.minDate;
if (!date ||
date.getFullYear() > minDate.getFullYear() ||
date.getMonth() > minDate.getMonth() ||
date.getDate() > minDate.getDate()) {
return this.defaultProps.minDate;
}
return minDate;
}
getMaxTime(date) {
const maxDate = this.props.maxDate;
if (!date ||
date.getFullYear() < maxDate.getFullYear() ||
date.getMonth() < maxDate.getMonth() ||
date.getDate() < maxDate.getDate()) {
return this.defaultProps.maxDate;
}
return maxDate;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CalendarTimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: CalendarTimePickerComponent, selector: "CalendarTimePicker, nzm-calendar-time-picker", inputs: { propsData: "propsData", title: "title", value: "value", prefixCls: "prefixCls", defaultValue: "defaultValue", pickerPrefixCls: "pickerPrefixCls", clientHeight: "clientHeight", onValueChange: "onValueChange" }, host: { properties: { "class.time-picker": "this.timePicker" } }, ngImport: i0, 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", dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.DatePickerViewComponent, selector: "DatePickerView, nzm-date-picker-view", inputs: ["mode", "minDate", "maxDate", "value", "disabled", "indicatorStyle", "locale", "showErrorToast", "showErrorToastInterval"], outputs: ["onValueChange"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CalendarTimePickerComponent, decorators: [{
type: Component,
args: [{ selector: 'CalendarTimePicker, nzm-calendar-time-picker', encapsulation: ViewEncapsulation.None, 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" }]
}], ctorParameters: () => [], 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']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../components/calendar/timepicker/timepicker.component.ts","../../../../components/calendar/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, Input, HostBinding } from '@angular/core';\nimport { zh_CN, en_US } from 'ng-zorro-antd-mobile/locale-provider';\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","<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"]}