UNPKG

tdesign-react

Version:
204 lines (196 loc) 9.23 kB
/** * tdesign v1.16.6 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var defineProperty = require('../../_chunks/dep-1f6c39e3.js'); var slicedToArray = require('../../_chunks/dep-3281986a.js'); var React = require('react'); var dayjs = require('dayjs'); var timePicker_panel_SinglePanel = require('../../_chunks/dep-ac381086.js'); var log = require('../../_chunks/dep-ed99b2c6.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-90a93885.js'); require('../../_chunks/dep-54373955.js'); require('../../_chunks/dep-ef5bfcf1.js'); require('classnames'); require('../../_chunks/dep-f2e56581.js'); require('../../_chunks/dep-20f09a63.js'); require('../../_chunks/dep-ff9bf4c8.js'); require('../../_chunks/dep-4cbff404.js'); require('../../_chunks/dep-723e29d6.js'); require('../../_chunks/dep-4748ebeb.js'); require('../../_chunks/dep-615c149d.js'); require('../../_chunks/dep-0173c82c.js'); require('../../_util/noop.js'); require('../../hooks/useDebounce.js'); require('../../hooks/usePersistFn.js'); require('../../_chunks/dep-63bb9ba0.js'); require('../../hooks/usePropsRef.js'); require('../../_chunks/dep-ff301423.js'); require('../../_chunks/dep-0bd8b970.js'); require('../../_chunks/dep-0652d2a6.js'); require('../../_chunks/dep-8c9795f9.js'); require('../../_chunks/dep-d24b94bc.js'); require('../../_chunks/dep-c9025587.js'); require('../../_chunks/dep-d7d7df54.js'); require('../../_chunks/dep-a8d5081a.js'); require('../../_chunks/dep-0cf6dbad.js'); require('../../_chunks/dep-cb9114ad.js'); require('../../config-provider/ConfigContext.js'); require('../../_chunks/dep-875a5344.js'); require('../../_chunks/dep-e691746e.js'); require('../../_chunks/dep-9d3b1a05.js'); require('../../_chunks/dep-1f8c969d.js'); require('../../_chunks/dep-403f5edf.js'); require('../../_chunks/dep-6478e7e3.js'); require('../../_chunks/dep-8663a5c9.js'); require('../../_chunks/dep-50349518.js'); require('../../_chunks/dep-73ef2133.js'); require('../../_chunks/dep-cae1e5aa.js'); require('../../_chunks/dep-0b97e212.js'); require('../../_chunks/dep-1a7ce20e.js'); require('../../_chunks/dep-116af952.js'); require('../../_chunks/dep-f6a777ad.js'); require('../../button/Button.js'); require('../../_chunks/dep-79129c54.js'); require('../../hooks/useDomRefCallback.js'); require('../../hooks/useRipple.js'); require('../../_chunks/dep-4cca69f7.js'); require('../../hooks/useAnimation.js'); require('../../_chunks/dep-2bbded38.js'); require('../../_chunks/dep-202d6c73.js'); require('../../loading/index.js'); require('../../loading/Loading.js'); require('../../common/Portal.js'); require('react-dom'); require('../../hooks/useLayoutEffect.js'); require('../../hooks/useDefaultProps.js'); require('../../loading/defaultProps.js'); require('../../loading/gradient.js'); require('../../_chunks/dep-d7a3225b.js'); require('../../_chunks/dep-33be2db8.js'); require('../../_chunks/dep-989c8b4a.js'); require('../../_chunks/dep-4c4d8eee.js'); require('../../loading/plugin.js'); require('../../_util/react-render.js'); require('../../_chunks/dep-05097eca.js'); require('../../common/PluginContainer.js'); require('../../config-provider/ConfigProvider.js'); require('../../_chunks/dep-400d026f.js'); require('../../_chunks/dep-081faea2.js'); require('../../_chunks/dep-91b467dd.js'); require('../../_chunks/dep-18ca5cd9.js'); require('../../_chunks/dep-3facd669.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