UNPKG

tdesign-vue

Version:
324 lines (320 loc) 15.7 kB
/** * tdesign v1.14.1 * (c) 2025 tdesign * @license MIT */ import _defineProperty from '@babel/runtime/helpers/defineProperty'; import { defineComponent, toRefs, ref, computed, watch, onMounted, nextTick } from '@vue/composition-api'; import { debounce, range, padStart } from 'lodash-es'; import dayjs from 'dayjs'; import { c as customParseFormat } from '../../_chunks/dep-655d809c.js'; import { panelColProps } from './props.js'; import { EPickerCols, TWELVE_HOUR_FORMAT, AM, MERIDIEM_LIST, PM } from '../../_common/js/time-picker/const.js'; import { getPickerCols, closestLookup } from '../../_common/js/time-picker/utils.js'; import { useConfig } from '../../config-provider/useConfig.js'; import '../../_chunks/dep-fdb1b253.js'; import '../props.js'; import '../../_chunks/dep-84c94da7.js'; import '../../config-provider/context.js'; import '../../_common/js/global-config/default-config.js'; import '../../_common/js/global-config/locale/zh_CN.js'; import '../../_chunks/dep-ba613a02.js'; import '@babel/runtime/helpers/typeof'; import '../../_common/js/global-config/t.js'; import '@babel/runtime/helpers/slicedToArray'; function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } dayjs.extend(customParseFormat); var timeArr = [EPickerCols.hour, EPickerCols.minute, EPickerCols.second, EPickerCols.milliSecond]; var panelOffset = { top: 15, bottom: 21 }; var SinglePanel = defineComponent({ name: "TTimePickerPanelCol", props: _objectSpread(_objectSpread({}, panelColProps()), {}, { position: String, triggerScroll: Boolean, onChange: Function, resetTriggerScroll: Function, disableTime: Function, isShowPanel: Boolean }), setup: function setup(props, ctx) { var _toRefs = toRefs(props), steps = _toRefs.steps, value = _toRefs.value, format = _toRefs.format, position = _toRefs.position, triggerScroll = _toRefs.triggerScroll; var _useConfig = useConfig("timePicker"), global = _useConfig.global; var _useConfig2 = useConfig(), classPrefix = _useConfig2.classPrefix; var cols = ref([]); var bodyRef = ref(); var maskRef = ref(null); var dayjsValue = computed(function () { var isStepsSet = !!steps.value.filter(function (v) { return v > 1; }).length; if (value.value) return dayjs(value.value, format.value); if (isStepsSet) return dayjs().hour(0).minute(0).second(0); return dayjs(); }); var panelClassName = computed(function () { return "".concat(classPrefix.value, "-time-picker__panel"); }); watch(function () { return dayjsValue.value; }, function () { if (dayjsValue.value && value.value) updateTimeScrollPos(true); }); watch(function () { return triggerScroll.value; }, function () { if (triggerScroll.value) { updateTimeScrollPos(true); } }); onMounted(function () { cols.value = getPickerCols(format.value); }); var getItemHeight = function getItemHeight() { var _maskRef$value; var maskDom = (_maskRef$value = maskRef.value) === null || _maskRef$value === void 0 ? void 0 : _maskRef$value.querySelector("div"); if (!maskDom) { return { offsetHeight: 0, margin: 0 }; } return { offsetHeight: maskDom.offsetHeight, margin: parseInt(getComputedStyle(maskDom).marginTop, 10) }; }; var timeItemCanUsed = function timeItemCanUsed(col, el) { var colIdx = timeArr.indexOf(col); if (colIdx !== -1) { var _props$disableTime; var params = [dayjsValue.value.hour(), dayjsValue.value.minute(), dayjsValue.value.second()]; var n = Number(el); if (col === EPickerCols.hour && TWELVE_HOUR_FORMAT.test(props.format) && dayjsValue.value.hour() >= 12) { n += 12; } params[colIdx] = n; return !((_props$disableTime = props.disableTime) !== null && _props$disableTime !== void 0 && (_props$disableTime = _props$disableTime.call.apply(_props$disableTime, [props].concat(params, [{ partial: position.value || "start" }]))) !== null && _props$disableTime !== void 0 && (_props$disableTime = _props$disableTime[col]) !== null && _props$disableTime !== void 0 && _props$disableTime.includes(n)); } return true; }; var getColList = function getColList(col) { var count = 0; if (timeArr.includes(col)) { var colIdx = timeArr.indexOf(col); var colStep = steps.value[colIdx] || 1; if (col === EPickerCols.hour) count = TWELVE_HOUR_FORMAT.test(format.value) ? 11 : 23;else if (col === EPickerCols.milliSecond) count = 999;else count = 59; var colList = range(0, count + 1, Number(colStep)).map(function (v) { return padStart(String(v), 2, "0"); }) || []; return props.hideDisabledTime && !!props.disableTime ? colList.filter(function (t) { var _props$disableTime2; var params = [dayjsValue.value.hour(), dayjsValue.value.minute(), dayjsValue.value.second(), dayjsValue.value.millisecond()]; var n = Number(t); if (col === EPickerCols.hour && TWELVE_HOUR_FORMAT.test(props.format) && dayjsValue.value.hour() >= 12) { n += 12; } params[colIdx] = n; return !((_props$disableTime2 = props.disableTime) !== null && _props$disableTime2 !== void 0 && (_props$disableTime2 = _props$disableTime2.call.apply(_props$disableTime2, [props].concat(params, [{ partial: position.value || "start" }]))) !== null && _props$disableTime2 !== void 0 && (_props$disableTime2 = _props$disableTime2[col]) !== null && _props$disableTime2 !== void 0 && _props$disableTime2.includes(n)); }) : colList; } return MERIDIEM_LIST; }; var getScrollDistance = function getScrollDistance(col, time) { if (col === EPickerCols.hour && /[h]{1}/.test(format.value)) { time %= 12; } var itemIdx = getColList(col).indexOf(padStart(String(time), 2, "0")); var _getItemHeight = getItemHeight(), offsetHeight = _getItemHeight.offsetHeight, margin = _getItemHeight.margin; var timeItemTotalHeight = offsetHeight + margin; var distance = Math.abs(Math.max(0, itemIdx) * timeItemTotalHeight); return distance; }; var handleScroll = function handleScroll(col, e) { var _ctx$refs, _props$onChange; var val; var formattedVal; if (!props.isShowPanel) return; var scrollTop = ((_ctx$refs = ctx.refs["".concat(col, "Col")]) === null || _ctx$refs === void 0 ? void 0 : _ctx$refs.scrollTop) + panelOffset.top; var _getItemHeight2 = getItemHeight(), offsetHeight = _getItemHeight2.offsetHeight, margin = _getItemHeight2.margin; var timeItemTotalHeight = offsetHeight + margin; var colStep = Math.abs(Math.round(scrollTop / timeItemTotalHeight + 0.5)); var meridiem = MERIDIEM_LIST[Math.min(colStep - 1, 1)].toLowerCase(); if (Number.isNaN(colStep)) colStep = 1; if (timeArr.includes(col)) { var max = 59; if (col === EPickerCols.hour) max = /[h]{1}/.test(format.value) ? 11 : 23;else if (col === EPickerCols.milliSecond) max = 999; var colIdx = timeArr.indexOf(col); var availableArr = range(0, max + 1, Number(steps.value[colIdx]) || 1); val = closestLookup(availableArr, Number(getColList(col)[Math.min(colStep - 1, max + 1, availableArr.length - 1)]), Number(steps.value[colIdx]) || 1); if (Number.isNaN(val)) val = availableArr[availableArr.length - 1]; if (col === EPickerCols.hour && cols.value.includes(EPickerCols.meridiem) && dayjsValue.value.hour() >= 12) { val = Number(val) + 12; } } else val = meridiem; var distance = getScrollDistance(col, val); if (!dayjs(dayjsValue.value).isValid() || value.value && !dayjs(value.value, format.value, true).isValid()) return; if (timeArr.includes(col)) { if (timeItemCanUsed(col, val)) { var _dayjsValue$value$col, _dayjsValue$value; formattedVal = (_dayjsValue$value$col = (_dayjsValue$value = dayjsValue.value)[col]) === null || _dayjsValue$value$col === void 0 ? void 0 : _dayjsValue$value$col.call(_dayjsValue$value, val).format(format.value); } else { formattedVal = dayjsValue.value.format(format.value); } } else { var currentHour = dayjsValue.value.hour(); if (meridiem === AM && currentHour >= 12) { formattedVal = dayjsValue.value.hour(currentHour - 12).format(format.value); } else if (meridiem === PM && currentHour < 12) { formattedVal = dayjsValue.value.hour(currentHour + 12).format(format.value); } else { formattedVal = dayjsValue.value.format(format.value); } } if (formattedVal !== value.value) (_props$onChange = props.onChange) === null || _props$onChange === void 0 || _props$onChange.call(props, formattedVal, e); if (distance !== scrollTop) { var _scrollCtrl$scrollTo; var scrollCtrl = ctx.refs["".concat(col, "Col")]; if (!scrollCtrl || scrollCtrl.scrollTop === distance) return; (_scrollCtrl$scrollTo = scrollCtrl.scrollTo) === null || _scrollCtrl$scrollTo === void 0 || _scrollCtrl$scrollTo.call(scrollCtrl, { top: distance, behavior: "smooth" }); } }; var scrollToTime = function scrollToTime(col, time, idx) { var _scrollCtrl$scrollTo2; var behavior = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : "auto"; var distance = getScrollDistance(col, time); var scrollCtrl = ctx.refs["".concat(col, "Col")]; if (!scrollCtrl || scrollCtrl.scrollTop === distance || !timeItemCanUsed(col, time)) return; (_scrollCtrl$scrollTo2 = scrollCtrl.scrollTo) === null || _scrollCtrl$scrollTo2 === void 0 || _scrollCtrl$scrollTo2.call(scrollCtrl, { top: distance, behavior: behavior }); }; var handleTimeItemClick = function handleTimeItemClick(col, el, idx, e) { if (!timeItemCanUsed(col, el)) return; if (timeArr.includes(col)) { if (col === EPickerCols.hour && dayjsValue.value.hour() >= 12 && cols.value.includes(EPickerCols.meridiem)) { el = Number(el) + 12; } scrollToTime(col, el, idx, "smooth"); } else { var currentHour = dayjsValue.value.hour(); if (el === AM && currentHour >= 12) { var _props$onChange2; (_props$onChange2 = props.onChange) === null || _props$onChange2 === void 0 || _props$onChange2.call(props, dayjsValue.value.hour(currentHour - 12).format(format.value), e); } else if (el === PM && currentHour < 12) { var _props$onChange3; (_props$onChange3 = props.onChange) === null || _props$onChange3 === void 0 || _props$onChange3.call(props, dayjsValue.value.hour(currentHour + 12).format(format.value), e); } } }; var updateTimeScrollPos = function updateTimeScrollPos() { var isAutoScroll = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; var behavior = value.value && !isAutoScroll ? "smooth" : "auto"; var isStepsSet = !!steps.value.filter(function (v) { return v > 1; }).length; nextTick(function () { cols.value.forEach(function (col, idx) { if (!isStepsSet || isStepsSet && value.value) { var _dayjsValue$value$col2, _dayjsValue$value2; scrollToTime(col, timeArr.includes(col) ? (_dayjsValue$value$col2 = (_dayjsValue$value2 = dayjsValue.value)[col]) === null || _dayjsValue$value$col2 === void 0 ? void 0 : _dayjsValue$value$col2.call(_dayjsValue$value2) : dayjsValue.value.locale("en").format("a"), idx, behavior); } else { var _getColList; scrollToTime(col, (_getColList = getColList(col)) === null || _getColList === void 0 ? void 0 : _getColList[0], idx, behavior); } }); }); props.resetTriggerScroll(); }; var isCurrent = function isCurrent(col, colItem) { var _dayjsValue$value$col3, _dayjsValue$value3; var colVal; if (col === EPickerCols.meridiem) { var currentMeridiem = dayjsValue.value.locale("en").format("a"); return currentMeridiem === colItem; } colVal = (_dayjsValue$value$col3 = (_dayjsValue$value3 = dayjsValue.value)[col]) === null || _dayjsValue$value$col3 === void 0 ? void 0 : _dayjsValue$value$col3.call(_dayjsValue$value3); if (col === EPickerCols.hour && /[h]{1}/.test(format.value)) { colVal %= 12; } return colVal === Number(colItem); }; return { getColList: getColList, isCurrent: isCurrent, bodyRef: bodyRef, maskRef: maskRef, global: global, classPrefix: classPrefix, panelClassName: panelClassName, cols: cols, timeItemCanUsed: timeItemCanUsed, handleScroll: handleScroll, handleTimeItemClick: handleTimeItemClick }; }, render: function render() { var _this$cols$map, _this$cols, _this$cols$map2, _this$cols2, _this = this; var h = arguments[0]; return h("div", { "class": "".concat(this.panelClassName, "-body"), "ref": "bodyRef" }, [h("div", { "class": "".concat(this.panelClassName, "-body-active-mask"), "ref": "maskRef" }, [(_this$cols$map = (_this$cols = this.cols).map) === null || _this$cols$map === void 0 ? void 0 : _this$cols$map.call(_this$cols, function (col, idx) { return h("div", { "key": "".concat(col, "_").concat(idx) }); })]), (_this$cols$map2 = (_this$cols2 = this.cols).map) === null || _this$cols$map2 === void 0 ? void 0 : _this$cols$map2.call(_this$cols2, function (col, idx) { return h("ul", { "key": "".concat(col, "_").concat(idx), "ref": "".concat(col, "Col"), "class": "".concat(_this.panelClassName, "-body-scroll"), "on": { "scroll": debounce(function (e) { return _this.handleScroll(col, e); }, 50) } }, [_this.getColList(col).map(function (el) { return h("li", { "key": el, "class": ["".concat(_this.panelClassName, "-body-scroll-item"), _defineProperty(_defineProperty({}, "".concat(_this.classPrefix, "-is-disabled"), !_this.timeItemCanUsed(col, el)), "".concat(_this.classPrefix, "-is-current"), _this.isCurrent(col, el))], "on": { "click": function click(e) { return _this.handleTimeItemClick(col, el, idx, e); } } }, [timeArr.includes(col) ? TWELVE_HOUR_FORMAT.test(_this.format) && col === EPickerCols.hour && el === "00" ? "12" : el : _this.global[el === AM ? "anteMeridiem" : "postMeridiem"]]); })]); })]); } }); export { SinglePanel as default }; //# sourceMappingURL=single-panel.js.map