UNPKG

tdesign-vue-next

Version:
264 lines (256 loc) 13.1 kB
/** * tdesign v1.11.5 * (c) 2025 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties'); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var _defineProperty = require('@babel/runtime/helpers/defineProperty'); var Vue = require('vue'); var input_index = require('../../input/index.js'); var loading_index = require('../../loading/index.js'); var hooks_tnode = require('../../_chunks/dep-a69ce597.js'); var hooks_useConfig = require('../../hooks/useConfig.js'); var hooks_useDefaultValue = require('../../hooks/useDefaultValue.js'); var hooks_useDisabled = require('../../hooks/useDisabled.js'); var hooks_useReadonly = require('../../hooks/useReadonly.js'); var pick = require('../../_chunks/dep-ba971aad.js'); var isObject = require('../../_chunks/dep-0a510359.js'); require('../../input/input.js'); require('tdesign-icons-vue-next'); require('../../input/props.js'); require('../../hooks/useGlobalIcon.js'); require('../../config-provider/hooks/useConfig.js'); require('../../_chunks/dep-b4c4a54b.js'); require('../../_chunks/dep-f8ff548f.js'); require('@babel/runtime/helpers/typeof'); require('../../_chunks/dep-30fb1b25.js'); require('dayjs'); require('../../_chunks/dep-b6c192db.js'); require('../../_chunks/dep-ba2090c8.js'); require('../../_chunks/dep-b27d3215.js'); require('../../_chunks/dep-ed572eb3.js'); require('../../_chunks/dep-047617bf.js'); require('../../_chunks/dep-bbe343d7.js'); require('../../_chunks/dep-50a41d31.js'); require('../../_chunks/dep-be3c3d53.js'); require('../../_chunks/dep-0c2ad01b.js'); require('../../_chunks/dep-5ad8a2ab.js'); require('../../_chunks/dep-8b98fa07.js'); require('../../_chunks/dep-b0b4fff1.js'); require('../../_chunks/dep-7a21da5b.js'); require('../../_chunks/dep-49fa220e.js'); require('../../_chunks/dep-02ebb419.js'); require('../../_chunks/dep-feae46a3.js'); require('../../_chunks/dep-abf21389.js'); require('../../_chunks/dep-7f32423d.js'); require('../../_chunks/dep-7c9e3d93.js'); require('../../_chunks/dep-61a7e281.js'); require('../../_chunks/dep-ecbaedee.js'); require('../../_chunks/dep-9de7d250.js'); require('../../_chunks/dep-6f8a66a3.js'); require('../../_chunks/dep-b8b9c2a3.js'); require('../../input/hooks/useInput.js'); require('../../form/consts/index.js'); require('../../hooks/useKeepAnimation.js'); require('../../hooks/useVModel.js'); require('../../_chunks/dep-76218bd8.js'); require('../../_chunks/dep-acb090bf.js'); require('../../_chunks/dep-e495f218.js'); require('../../_chunks/dep-bafc1f63.js'); require('../../input/hooks/useLengthLimit.js'); require('../../_chunks/dep-cef23b69.js'); require('../../_chunks/dep-25acc189.js'); require('@babel/runtime/helpers/toConsumableArray'); require('../../_chunks/dep-93cf0a54.js'); require('../../_chunks/dep-8afe2bf0.js'); require('../../_chunks/dep-cea0dc9b.js'); require('../../_chunks/dep-82a90f9f.js'); require('../../input/hooks/useInputEventHandler.js'); require('../../input/hooks/useInputWidth.js'); require('../../hooks/useResizeObserver.js'); require('../../utils/render-tnode.js'); require('../../_chunks/dep-db023c41.js'); require('../../_chunks/dep-c07d6878.js'); require('../../_chunks/dep-a957c564.js'); require('../../_chunks/dep-9a321a91.js'); require('../../input/input-group.js'); require('../../input/input-group-props.js'); require('../../utils/withInstall.js'); require('../../_chunks/dep-0d31a2f0.js'); require('../../loading/plugin.js'); require('../../loading/loading.js'); require('../../loading/icon/gradient.js'); require('../../_chunks/dep-b1b8272b.js'); require('../../utils/dom.js'); require('../../hooks/useTeleport.js'); require('../../loading/props.js'); require('../../_chunks/dep-d4796921.js'); require('../../_chunks/dep-62aae11c.js'); require('../../_chunks/dep-7c08b9a8.js'); require('../../_chunks/dep-56c837c8.js'); require('../../_chunks/dep-55d8c3ed.js'); require('../../_chunks/dep-fd1ddb6b.js'); require('../../_chunks/dep-d83ac33f.js'); require('../../_chunks/dep-8ba18d4f.js'); require('../../_chunks/dep-43bc982b.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _objectWithoutProperties__default = /*#__PURE__*/_interopDefaultLegacy(_objectWithoutProperties); var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray); var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty); var _excluded = ["tips"]; 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__default["default"](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 COMMON_PROPERTIES = ["status", "clearable", "disabled", "label", "placeholder", "readonly", "prefixIcon", "suffix", "suffixIcon", "onPaste", "onMouseenter", "onMouseleave", "size", "autofocus"]; var DEFAULT_KEYS = { label: "label", value: "value", children: "children" }; function getInputValue(value, keys) { var iKeys = _objectSpread(_objectSpread({}, DEFAULT_KEYS), keys); return isObject.isObject(value) ? value[iKeys.label] : value; } function useSingle(props, context, popupRef) { var _props$defaultInputVa; var _toRefs = Vue.toRefs(props), value = _toRefs.value, keys = _toRefs.keys, propsInputValue = _toRefs.inputValue; var classPrefix = hooks_useConfig.usePrefixClass(); var isSingleFocus = Vue.ref(props.autofocus); var inputRef = Vue.ref(); var _useDefaultValue = hooks_useDefaultValue["default"](propsInputValue, (_props$defaultInputVa = props.defaultInputValue) !== null && _props$defaultInputVa !== void 0 ? _props$defaultInputVa : "", props.onInputChange, "inputValue"), _useDefaultValue2 = _slicedToArray__default["default"](_useDefaultValue, 2), inputValue = _useDefaultValue2[0], setInputValue = _useDefaultValue2[1]; var renderTNode = hooks_tnode.useTNodeJSX(); var disable = hooks_useDisabled.useDisabled(); var isReadonly = hooks_useReadonly.useReadonly(); var commonInputProps = Vue.computed(function () { return _objectSpread(_objectSpread({}, pick.pick(props, COMMON_PROPERTIES)), {}, { disabled: disable.value, readonly: isReadonly.value }); }); var onInnerClear = function onInnerClear(context2) { var _context2$e, _props$onClear; context2 === null || context2 === void 0 || (_context2$e = context2.e) === null || _context2$e === void 0 || _context2$e.stopPropagation(); (_props$onClear = props.onClear) === null || _props$onClear === void 0 || _props$onClear.call(props, context2); setInputValue("", { trigger: "clear" }); }; var onInnerInputChange = function onInnerInputChange(value2, context2) { if (props.allowInput) { setInputValue(value2, _objectSpread(_objectSpread({}, context2), {}, { trigger: context2.trigger || "input" })); } }; var renderSelectSingle = function renderSelectSingle(popupVisible) { var _context$attrs; var singleValueDisplay = renderTNode("valueDisplay"); var displayedValue = popupVisible && props.allowInput ? inputValue.value : getInputValue(value.value, keys.value); var prefixContent = renderPrefixContent(singleValueDisplay, popupVisible); var inputProps = _objectSpread(_objectSpread({}, commonInputProps.value), {}, { value: renderInputDisplay(singleValueDisplay, displayedValue, popupVisible), label: prefixContent.length ? function () { return prefixContent; } : void 0, autoWidth: props.autoWidth, readonly: !props.allowInput || isReadonly.value, placeholder: renderPlaceholder(singleValueDisplay), suffixIcon: !disable.value && props.loading ? function () { return Vue.createVNode(loading_index.Loading, { "loading": true, "size": "small" }, null); } : props.suffixIcon, showClearIconOnEmpty: Boolean(props.clearable && (inputValue.value || displayedValue) && !disable.value && !isReadonly.value) }, props.inputProps); var _context$slots = context.slots; _context$slots.tips; var slots = _objectWithoutProperties__default["default"](_context$slots, _excluded); var inputClassProps = popupVisible ? ["".concat(classPrefix.value, "-input--focused"), "".concat(classPrefix.value, "-is-focused"), inputProps === null || inputProps === void 0 ? void 0 : inputProps.inputClass] : inputProps === null || inputProps === void 0 ? void 0 : inputProps.inputClass; var onEnter = function onEnter(val, context2) { var _props$onEnter; (_props$onEnter = props.onEnter) === null || _props$onEnter === void 0 || _props$onEnter.call(props, value.value, _objectSpread(_objectSpread({}, context2), {}, { inputValue: val })); }; var onFocus = function onFocus(val, context2) { var _popupRef$value, _props$onFocus; var overlayState = (_popupRef$value = popupRef.value) === null || _popupRef$value === void 0 ? void 0 : _popupRef$value.getOverlayState(); if (isSingleFocus.value || overlayState !== null && overlayState !== void 0 && overlayState.hover) return; isSingleFocus.value = true; (_props$onFocus = props.onFocus) === null || _props$onFocus === void 0 || _props$onFocus.call(props, value.value, _objectSpread(_objectSpread({}, context2), {}, { inputValue: val })); }; var onBlur = function onBlur(val, context2) { var _popupRef$value2, _props$onBlur; var overlayState = (_popupRef$value2 = popupRef.value) === null || _popupRef$value2 === void 0 ? void 0 : _popupRef$value2.getOverlayState(); isSingleFocus.value = false; if (overlayState !== null && overlayState !== void 0 && overlayState.hover) return; (_props$onBlur = props.onBlur) === null || _props$onBlur === void 0 || _props$onBlur.call(props, value.value, _objectSpread(_objectSpread({}, context2), {}, { inputValue: val })); }; return Vue.createVNode(input_index.Input, Vue.mergeProps({ "ref": inputRef, "style": (_context$attrs = context.attrs) === null || _context$attrs === void 0 ? void 0 : _context$attrs.style }, _objectSpread({ onChange: onInnerInputChange, onClear: onInnerClear, onEnter: onEnter, onFocus: onFocus, onBlur: onBlur }, inputProps), { "inputClass": inputClassProps }), slots); }; var renderPrefixContent = function renderPrefixContent(singleValueDisplay, popupVisible) { var label = renderTNode("label"); if (!label && !singleValueDisplay) { return []; } if (singleValueDisplay) { var _props$valueDisplayOp, _props$valueDisplayOp2; if ((_props$valueDisplayOp = props.valueDisplayOptions) !== null && _props$valueDisplayOp !== void 0 && _props$valueDisplayOp.usePlaceholder && !value.value || (_props$valueDisplayOp2 = props.valueDisplayOptions) !== null && _props$valueDisplayOp2 !== void 0 && _props$valueDisplayOp2.useInputDisplay && popupVisible) { return [label]; } } return [label, singleValueDisplay]; }; var renderInputDisplay = function renderInputDisplay(singleValueDisplay, displayedValue, popupVisible) { if (singleValueDisplay) { var _props$valueDisplayOp3, _props$valueDisplayOp4; if (!((_props$valueDisplayOp3 = props.valueDisplayOptions) !== null && _props$valueDisplayOp3 !== void 0 && _props$valueDisplayOp3.useInputDisplay) || (_props$valueDisplayOp4 = props.valueDisplayOptions) !== null && _props$valueDisplayOp4 !== void 0 && _props$valueDisplayOp4.useInputDisplay && !popupVisible) { return void 0; } } return displayedValue; }; var renderPlaceholder = function renderPlaceholder(singleValueDisplay) { if (singleValueDisplay) { var _props$valueDisplayOp5, _props$valueDisplayOp6; if (!((_props$valueDisplayOp5 = props.valueDisplayOptions) !== null && _props$valueDisplayOp5 !== void 0 && _props$valueDisplayOp5.usePlaceholder) || (_props$valueDisplayOp6 = props.valueDisplayOptions) !== null && _props$valueDisplayOp6 !== void 0 && _props$valueDisplayOp6.usePlaceholder && value.value) { return ""; } } return props.placeholder; }; return { inputRef: inputRef, isSingleFocus: isSingleFocus, commonInputProps: commonInputProps, singleInputValue: inputValue, onInnerClear: onInnerClear, renderSelectSingle: renderSelectSingle }; } exports.useSingle = useSingle; //# sourceMappingURL=useSingle.js.map