UNPKG

tdesign-react

Version:
202 lines (194 loc) 9.15 kB
/** * tdesign v1.13.2 * (c) 2025 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var defineProperty = require('../../_chunks/dep-cc768e34.js'); var slicedToArray = require('../../_chunks/dep-e17e2d31.js'); var React = require('react'); var dayjs = require('dayjs'); var timePicker_panel_SinglePanel = require('../../_chunks/dep-4c561432.js'); var log = require('../../_chunks/dep-4bc3c0ab.js'); var hooks_useConfig = require('../../hooks/useConfig.js'); var button_index = require('../../button/index.js'); var timePicker_hooks_useTimePickerTextConfig = require('../hooks/useTimePickerTextConfig.js'); require('../../_chunks/dep-6d4d8660.js'); require('../../_chunks/dep-b7d577ac.js'); require('classnames'); require('../../_chunks/dep-863f50e4.js'); require('../../_chunks/dep-c915e145.js'); require('../../_chunks/dep-780eda7b.js'); require('../../_chunks/dep-f076775e.js'); require('../../_chunks/dep-f0379c5f.js'); require('../../_chunks/dep-ddacd27a.js'); require('../../_chunks/dep-ac58e1cc.js'); require('../../_util/noop.js'); require('../../hooks/useDebounce.js'); require('../../hooks/usePersistFn.js'); require('../../_chunks/dep-1bcdd0a4.js'); require('../../hooks/usePropsRef.js'); require('../../_chunks/dep-e2c832a5.js'); require('../../_chunks/dep-c87d9752.js'); require('../../_chunks/dep-4671b9bd.js'); require('../../_chunks/dep-bed9d73e.js'); require('../../_chunks/dep-cab13149.js'); require('../../_chunks/dep-62193a48.js'); require('../../_chunks/dep-028b759d.js'); require('../../_chunks/dep-d42c60f4.js'); require('../../_chunks/dep-05b4c661.js'); require('../../config-provider/ConfigContext.js'); require('../../_chunks/dep-3a869b87.js'); require('../../_chunks/dep-7da96a57.js'); require('../../_chunks/dep-07b911d8.js'); require('../../_chunks/dep-4b02d669.js'); require('../../_chunks/dep-8a116183.js'); require('../../_chunks/dep-47bdc05f.js'); require('../../_chunks/dep-a30819a4.js'); require('../../_chunks/dep-6a7ba247.js'); require('../../_chunks/dep-bd956a2d.js'); require('../../_chunks/dep-0cdb3286.js'); require('../../_chunks/dep-865c186c.js'); require('../../_chunks/dep-f4e58639.js'); require('../../_chunks/dep-781a2854.js'); require('../../_chunks/dep-1ef213f8.js'); require('../../button/Button.js'); require('../../_chunks/dep-810b3643.js'); require('../../hooks/useDomRefCallback.js'); require('../../hooks/useRipple.js'); require('../../_chunks/dep-58719304.js'); require('../../hooks/useAnimation.js'); require('../../_chunks/dep-3f65dfe7.js'); require('../../_chunks/dep-3e2d2665.js'); require('../../loading/index.js'); require('../../loading/Loading.js'); require('../../common/Portal.js'); require('react-dom'); require('../../hooks/useLayoutEffect.js'); require('../../loading/gradient.js'); require('../../_chunks/dep-b8d4cf07.js'); require('../../_chunks/dep-64a1054a.js'); require('../../_chunks/dep-422caf30.js'); require('../../loading/defaultProps.js'); require('../../hooks/useDefaultProps.js'); require('../../loading/plugin.js'); require('../../_util/react-render.js'); require('../../_chunks/dep-a93b6608.js'); require('../../common/PluginContainer.js'); require('../../config-provider/ConfigProvider.js'); require('../../_chunks/dep-ed886f2a.js'); require('../../_chunks/dep-aeef4e56.js'); require('../../_chunks/dep-0c1ca63f.js'); require('../../_chunks/dep-fd5d57c1.js'); require('../../_chunks/dep-ac2874ce.js'); require('../../_chunks/dep-6cfc06a0.js'); require('../../_chunks/dep-5d9d080b.js'); require('../../button/defaultProps.js'); require('../../_util/parseTNode.js'); require('../../locale/LocalReceiver.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var React__default = /*#__PURE__*/_interopDefaultLegacy(React); var dayjs__default = /*#__PURE__*/_interopDefaultLegacy(dayjs); 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._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; } var TimePickerPanel = function TimePickerPanel(props) { var _props$format = props.format, format = _props$format === void 0 ? timePicker_panel_SinglePanel.DEFAULT_FORMAT : _props$format, _props$steps = props.steps, steps = _props$steps === void 0 ? timePicker_panel_SinglePanel.DEFAULT_STEPS : _props$steps, handleConfirmClick = props.handleConfirmClick, isFooterDisplay = props.isFooterDisplay, onChange = props.onChange, value = props.value, _props$isShowPanel = props.isShowPanel, isShowPanel = _props$isShowPanel === void 0 ? true : _props$isShowPanel, _props$presets = props.presets, presets = _props$presets === void 0 ? null : _props$presets; var _useState = React.useState(false), _useState2 = slicedToArray._slicedToArray(_useState, 2), triggerScroll = _useState2[0], toggleTriggerScroll = _useState2[1]; var _useConfig = hooks_useConfig["default"](), classPrefix = _useConfig.classPrefix; var TEXT_CONFIG = timePicker_hooks_useTimePickerTextConfig.useTimePickerTextConfig(); var panelClassName = "".concat(classPrefix, "-time-picker__panel"); var showNowTimeBtn = !!steps.filter(function (v) { return Number(v) > 1; }).length; var defaultValue = React.useMemo(function () { var formattedValue = dayjs__default["default"](value, format); if (value && formattedValue.isValid()) { return formattedValue.format(format); } return dayjs__default["default"]().hour(0).minute(0).second(0).format(format); }, [value, format]); React.useEffect(function () { if (isShowPanel) toggleTriggerScroll(true); }, [isShowPanel]); var resetTriggerScroll = React.useCallback(function () { toggleTriggerScroll(false); }, [toggleTriggerScroll]); var handlePresetClick = function handlePresetClick(presetValue) { var presetVal = typeof presetValue === "function" ? presetValue() : presetValue; if (typeof props.activeIndex === "number") { if (Array.isArray(presetVal)) { var _props$onChange; (_props$onChange = props.onChange) === null || _props$onChange === void 0 || _props$onChange.call(props, presetVal[props.activeIndex]); } else { log.log.error("TimePicker", "preset: ".concat(presets, " \u9884\u8BBE\u503C\u5FC5\u987B\u662F\u6570\u7EC4!")); } } else { var _props$onChange2; (_props$onChange2 = props.onChange) === null || _props$onChange2 === void 0 || _props$onChange2.call(props, presetVal); } }; var renderFooter = function renderFooter() { if (presets) { return Object.keys(presets).map(function (preset) { return /* @__PURE__ */React__default["default"].createElement(button_index.Button, { key: preset, theme: "primary", size: "small", variant: "text", onClick: function onClick() { handlePresetClick(presets[preset]); } }, preset); }); } return !showNowTimeBtn ? /* @__PURE__ */React__default["default"].createElement(button_index.Button, { theme: "primary", variant: "text", size: "small", onClick: function onClick() { onChange === null || onChange === void 0 || onChange(dayjs__default["default"]().format(format)); } }, TEXT_CONFIG.nowTime) : null; }; return /* @__PURE__ */React__default["default"].createElement("div", { className: panelClassName }, /* @__PURE__ */React__default["default"].createElement("div", { className: "".concat(panelClassName, "-section-body") }, /* @__PURE__ */React__default["default"].createElement(timePicker_panel_SinglePanel.SinglePanel, _objectSpread(_objectSpread({}, props), {}, { onChange: onChange, format: format, steps: steps, value: dayjs__default["default"](value, format).isValid() ? value : defaultValue, triggerScroll: triggerScroll, isVisible: isShowPanel, resetTriggerScroll: resetTriggerScroll }))), isFooterDisplay ? /* @__PURE__ */React__default["default"].createElement("div", { className: "".concat(panelClassName, "-section-footer") }, /* @__PURE__ */React__default["default"].createElement(button_index.Button, { size: "small", theme: "primary", variant: "base", disabled: !props.value, onClick: function onClick() { handleConfirmClick === null || handleConfirmClick === void 0 || handleConfirmClick(defaultValue); } }, TEXT_CONFIG.confirm), renderFooter()) : null); }; exports["default"] = TimePickerPanel; //# sourceMappingURL=TimePickerPanel.js.map