| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.timePickerProps = exports.default = void 0;
- var _vue = require("vue");
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
- var _generatePicker = _interopRequireDefault(require("../date-picker/generatePicker"));
- var _props = require("../date-picker/generatePicker/props");
- var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
- var _FormItemContext = require("../form/FormItemContext");
- var _omit = _interopRequireDefault(require("../_util/omit"));
- var _type = require("../_util/type");
- const timePickerProps = () => ({
- format: String,
- showNow: (0, _type.booleanType)(),
- showHour: (0, _type.booleanType)(),
- showMinute: (0, _type.booleanType)(),
- showSecond: (0, _type.booleanType)(),
- use12Hours: (0, _type.booleanType)(),
- hourStep: Number,
- minuteStep: Number,
- secondStep: Number,
- hideDisabledOptions: (0, _type.booleanType)(),
- popupClassName: String,
- status: (0, _type.stringType)()
- });
- exports.timePickerProps = timePickerProps;
- function createTimePicker(generateConfig) {
- const DatePicker = (0, _generatePicker.default)(generateConfig, (0, _extends2.default)((0, _extends2.default)({}, timePickerProps()), {
- order: {
- type: Boolean,
- default: true
- }
- }));
- const {
- TimePicker: InternalTimePicker,
- RangePicker: InternalRangePicker
- } = DatePicker;
- const TimePicker = (0, _vue.defineComponent)({
- name: 'ATimePicker',
- inheritAttrs: false,
- props: (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, (0, _props.commonProps)()), (0, _props.datePickerProps)()), timePickerProps()), {
- addon: {
- type: Function
- }
- }),
- slots: Object,
- setup(p, _ref) {
- let {
- slots,
- expose,
- emit,
- attrs
- } = _ref;
- const props = p;
- const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
- (0, _devWarning.default)(!(slots.addon || props.addon), 'TimePicker', '`addon` is deprecated. Please use `v-slot:renderExtraFooter` instead.');
- const pickerRef = (0, _vue.ref)();
- expose({
- focus: () => {
- var _a;
- (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.focus();
- },
- blur: () => {
- var _a;
- (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.blur();
- }
- });
- const onChange = (value, dateString) => {
- emit('update:value', value);
- emit('change', value, dateString);
- formItemContext.onFieldChange();
- };
- const onOpenChange = open => {
- emit('update:open', open);
- emit('openChange', open);
- };
- const onFocus = e => {
- emit('focus', e);
- };
- const onBlur = e => {
- emit('blur', e);
- formItemContext.onFieldBlur();
- };
- const onOk = value => {
- emit('ok', value);
- };
- return () => {
- const {
- id = formItemContext.id.value
- } = props;
- //restProps.addon
- return (0, _vue.createVNode)(InternalTimePicker, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), (0, _omit.default)(props, ['onUpdate:value', 'onUpdate:open'])), {}, {
- "id": id,
- "dropdownClassName": props.popupClassName,
- "mode": undefined,
- "ref": pickerRef,
- "renderExtraFooter": props.addon || slots.addon || props.renderExtraFooter || slots.renderExtraFooter,
- "onChange": onChange,
- "onOpenChange": onOpenChange,
- "onFocus": onFocus,
- "onBlur": onBlur,
- "onOk": onOk
- }), slots);
- };
- }
- });
- const TimeRangePicker = (0, _vue.defineComponent)({
- name: 'ATimeRangePicker',
- inheritAttrs: false,
- props: (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, (0, _props.commonProps)()), (0, _props.rangePickerProps)()), timePickerProps()), {
- order: {
- type: Boolean,
- default: true
- }
- }),
- slots: Object,
- setup(p, _ref2) {
- let {
- slots,
- expose,
- emit,
- attrs
- } = _ref2;
- const props = p;
- const pickerRef = (0, _vue.ref)();
- const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
- expose({
- focus: () => {
- var _a;
- (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.focus();
- },
- blur: () => {
- var _a;
- (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.blur();
- }
- });
- const onChange = (values, dateStrings) => {
- emit('update:value', values);
- emit('change', values, dateStrings);
- formItemContext.onFieldChange();
- };
- const onOpenChange = open => {
- emit('update:open', open);
- emit('openChange', open);
- };
- const onFocus = e => {
- emit('focus', e);
- };
- const onBlur = e => {
- emit('blur', e);
- formItemContext.onFieldBlur();
- };
- const onPanelChange = (values, modes) => {
- emit('panelChange', values, modes);
- };
- const onOk = values => {
- emit('ok', values);
- };
- const onCalendarChange = (values, dateStrings, info) => {
- emit('calendarChange', values, dateStrings, info);
- };
- return () => {
- const {
- id = formItemContext.id.value
- } = props;
- return (0, _vue.createVNode)(InternalRangePicker, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), (0, _omit.default)(props, ['onUpdate:open', 'onUpdate:value'])), {}, {
- "id": id,
- "dropdownClassName": props.popupClassName,
- "picker": "time",
- "mode": undefined,
- "ref": pickerRef,
- "onChange": onChange,
- "onOpenChange": onOpenChange,
- "onFocus": onFocus,
- "onBlur": onBlur,
- "onPanelChange": onPanelChange,
- "onOk": onOk,
- "onCalendarChange": onCalendarChange
- }), slots);
- };
- }
- });
- return {
- TimePicker,
- TimeRangePicker
- };
- }
- var _default = exports.default = createTimePicker;
|