UNPKG

tdesign-vue-next

Version:
269 lines (261 loc) 13.2 kB
/** * tdesign v1.19.2 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var Vue = require('vue'); var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties'); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var _defineProperty = require('@babel/runtime/helpers/defineProperty'); var input_index = require('../../input/index.js'); var loading_index = require('../../loading/index.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); require('../../_chunks/dep-35e23c2b.js'); var index$2 = require('../../_chunks/dep-1862d466.js'); var index = require('../../_chunks/dep-0238ed9a.js'); var index$1 = require('../../_chunks/dep-0afce170.js'); var index$3 = require('../../_chunks/dep-362c5212.js'); require('../../_chunks/dep-0989c3be.js'); var index$4 = require('../../_chunks/dep-9dbade68.js'); var index$5 = require('../../_chunks/dep-a13f0135.js'); var pick = require('../../_chunks/dep-eb3114d9.js'); var isObject = require('../../_chunks/dep-bf76dead.js'); require('../../input/input.js'); require('tdesign-icons-vue-next'); require('../../input/props.js'); require('../../_chunks/dep-38acad3d.js'); require('../../config-provider/hooks/useConfig.js'); require('../../_chunks/dep-be1af85d.js'); require('../../_chunks/dep-db9c85b1.js'); require('../../_chunks/dep-4a7162e7.js'); require('dayjs'); require('../../_chunks/dep-82fe2026.js'); require('../../_chunks/dep-33b46a52.js'); require('../../_chunks/dep-930a2de5.js'); require('../../_chunks/dep-2dcf9237.js'); require('../../_chunks/dep-22dc294c.js'); require('../../_chunks/dep-c3bbd06c.js'); require('../../_chunks/dep-6d87f74d.js'); require('../../_chunks/dep-4cb26289.js'); require('../../_chunks/dep-281f7eb2.js'); require('../../_chunks/dep-f8f7b1af.js'); require('../../_chunks/dep-66d3f30f.js'); require('../../_chunks/dep-e1d22111.js'); require('../../_chunks/dep-754c0523.js'); require('../../_chunks/dep-7076a08a.js'); require('../../_chunks/dep-631750cd.js'); require('../../_chunks/dep-2fc884aa.js'); require('../../_chunks/dep-75d6da05.js'); require('../../_chunks/dep-274369eb.js'); require('../../_chunks/dep-df6e14a0.js'); require('../../_chunks/dep-c26a7d50.js'); require('../../input/hooks/useInput.js'); require('../../form/constants/index.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../../_chunks/dep-ce9c15f5.js'); require('../../_chunks/dep-9f98bf9b.js'); require('../../_chunks/dep-b2024592.js'); require('../../_chunks/dep-2fb8d44f.js'); require('../../_chunks/dep-80a41429.js'); require('../../input/hooks/useLengthLimit.js'); require('../../_chunks/dep-692bdebe.js'); require('../../_chunks/dep-2aa3d3cf.js'); require('../../_chunks/dep-3d29e358.js'); require('../../_chunks/dep-6212811d.js'); require('../../_chunks/dep-44195fb2.js'); require('../../_chunks/dep-74b143e0.js'); require('../../input/hooks/useInputEventHandler.js'); require('../../input/hooks/useInputWidth.js'); require('../../_chunks/dep-e2122882.js'); require('../../_chunks/dep-8d990e66.js'); require('../../_chunks/dep-a6551cc4.js'); require('../../_chunks/dep-7d9abefd.js'); require('../../_chunks/dep-91305690.js'); require('../../_chunks/dep-0b92e695.js'); require('../../input/input-group.js'); require('../../input/input-group-props.js'); require('../../_chunks/dep-e3edff33.js'); require('../../_chunks/dep-34cd76d4.js'); require('../../loading/plugin.js'); require('../../_chunks/dep-d632b788.js'); require('../../loading/icon/gradient.js'); require('../../_chunks/dep-4ba41627.js'); require('../../loading/props.js'); require('../../_chunks/dep-43dcd2db.js'); require('../../_chunks/dep-392dde71.js'); require('../../_chunks/dep-02ea4f3c.js'); require('../../_chunks/dep-5103206f.js'); require('../../_chunks/dep-7707ffe2.js'); require('../../_chunks/dep-74a5bebe.js'); require('../../_chunks/dep-4eca9add.js'); require('../../_chunks/dep-42740075.js'); require('../../_chunks/dep-9ac5c6ca.js'); require('../../_chunks/dep-690970a4.js'); require('../../_chunks/dep-7870f4cb.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 = index.usePrefixClass(); var isSingleFocus = Vue.ref(props.autofocus); var inputRef = Vue.ref(); var _useDefaultValue = index$1.useDefaultValue(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 = index$2.useTNodeJSX(); var isDisable = index$3.useDisabled(); var isReadonly = index$4.useReadonly(); var commonInputProps = Vue.computed(function () { return _objectSpread(_objectSpread({}, pick.pick(props, COMMON_PROPERTIES)), {}, { disabled: isDisable.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: !isDisable.value && props.loading ? function () { return Vue.createVNode(loading_index.Loading, { "loading": true, "size": "small" }, null); } : props.suffixIcon, showClearIconOnEmpty: Boolean(props.clearable && (inputValue.value || displayedValue) && !isDisable.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 })); }; var inputEvent = index$5.useEventForward(inputProps, { onChange: onInnerInputChange, onClear: onInnerClear, onEnter: onEnter, onFocus: onFocus, onBlur: onBlur }); 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 }, inputEvent.value, { "inputClass": inputClassProps }), slots); }; var renderPrefixContent = function renderPrefixContent(singleValueDisplay, popupVisible) { var label = renderTNode("label"); if (!label && !singleValueDisplay) { return []; } if (singleValueDisplay) { var _props$valueDisplayOp; if (!value.value || (_props$valueDisplayOp = props.valueDisplayOptions) !== null && _props$valueDisplayOp !== void 0 && _props$valueDisplayOp.useInputDisplay && popupVisible || popupVisible && props.allowInput) { return [label]; } } return [label, singleValueDisplay]; }; var renderInputDisplay = function renderInputDisplay(singleValueDisplay, displayedValue, popupVisible) { if (singleValueDisplay) { var _props$valueDisplayOp2, _props$valueDisplayOp3; if (popupVisible && props.allowInput) { return displayedValue; } if (!((_props$valueDisplayOp2 = props.valueDisplayOptions) !== null && _props$valueDisplayOp2 !== void 0 && _props$valueDisplayOp2.useInputDisplay) || (_props$valueDisplayOp3 = props.valueDisplayOptions) !== null && _props$valueDisplayOp3 !== void 0 && _props$valueDisplayOp3.useInputDisplay && !popupVisible) { return void 0; } } return displayedValue; }; var renderPlaceholder = function renderPlaceholder(singleValueDisplay) { if (singleValueDisplay) { var _props$valueDisplayOp4, _props$valueDisplayOp5; if (!value.value || props.allowInput && props.popupVisible) return props.placeholder; if (!((_props$valueDisplayOp4 = props.valueDisplayOptions) !== null && _props$valueDisplayOp4 !== void 0 && _props$valueDisplayOp4.usePlaceholder) || (_props$valueDisplayOp5 = props.valueDisplayOptions) !== null && _props$valueDisplayOp5 !== void 0 && _props$valueDisplayOp5.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