UNPKG

tdesign-vue-next

Version:
289 lines (281 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 _defineProperty = require('@babel/runtime/helpers/defineProperty'); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var autoComplete_props = require('./props.js'); var input_index = require('../input/index.js'); var popup_index = require('../popup/index.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); require('../_chunks/dep-35e23c2b.js'); var index$1 = require('../_chunks/dep-1862d466.js'); var index$2 = require('../_chunks/dep-38acad3d.js'); var configProvider_hooks_useConfig = require('../config-provider/hooks/useConfig.js'); var index$3 = require('../_chunks/dep-362c5212.js'); require('../_chunks/dep-0989c3be.js'); var index$4 = require('../_chunks/dep-9dbade68.js'); var index = require('../_chunks/dep-ce9c15f5.js'); var index$5 = require('../_chunks/dep-a13f0135.js'); var autoComplete_components_optionList = require('./components/option-list.js'); require('../input/input.js'); require('@babel/runtime/helpers/objectWithoutProperties'); require('tdesign-icons-vue-next'); require('../input/props.js'); require('../_chunks/dep-0238ed9a.js'); require('../_chunks/dep-c26a7d50.js'); require('../input/hooks/useInput.js'); require('../form/constants/index.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-631750cd.js'); require('../_chunks/dep-22dc294c.js'); require('../_chunks/dep-4cb26289.js'); require('../_chunks/dep-44195fb2.js'); require('../_chunks/dep-bf76dead.js'); require('../input/hooks/useInputEventHandler.js'); require('../input/hooks/useInputWidth.js'); require('../_chunks/dep-e2122882.js'); require('../input/input-group.js'); require('../input/input-group-props.js'); require('../_chunks/dep-e3edff33.js'); require('../_chunks/dep-8d990e66.js'); require('../_chunks/dep-2dcf9237.js'); require('../_chunks/dep-a6551cc4.js'); require('../_chunks/dep-7d9abefd.js'); require('../_chunks/dep-2fb8d44f.js'); require('../_chunks/dep-80a41429.js'); require('../_chunks/dep-91305690.js'); require('../_chunks/dep-0b92e695.js'); require('../_chunks/dep-b2024592.js'); require('../_chunks/dep-9f98bf9b.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-c3bbd06c.js'); require('../_chunks/dep-6d87f74d.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-2fc884aa.js'); require('../_chunks/dep-75d6da05.js'); require('../_chunks/dep-274369eb.js'); require('../_chunks/dep-df6e14a0.js'); require('../_chunks/dep-74b143e0.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../popup/popup.js'); require('@popperjs/core'); require('../_chunks/dep-4ba41627.js'); require('../popup/container.js'); require('../popup/props.js'); require('../_chunks/dep-9bee89d3.js'); require('../_chunks/dep-027cd76f.js'); require('../_chunks/dep-ae4040c5.js'); require('../_chunks/dep-79476fcb.js'); require('../_chunks/dep-cc12ca1a.js'); require('../_chunks/dep-a4be1915.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty); var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_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__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; } function _isSlot(s) { return typeof s === 'function' || Object.prototype.toString.call(s) === '[object Object]' && !Vue.isVNode(s); } var _AutoComplete = Vue.defineComponent({ name: "TAutoComplete", props: autoComplete_props["default"], setup: function setup(props2, _ref) { var slots = _ref.slots; var _toRefs = Vue.toRefs(props2), value = _toRefs.value, modelValue = _toRefs.modelValue; var _useVModel = index.useVModel(value, modelValue, props2.defaultValue, props2.onChange), _useVModel2 = _slicedToArray__default["default"](_useVModel, 2), tValue = _useVModel2[0], setTValue = _useVModel2[1]; var renderContent = index$1.useContent(); var renderTNodeJSX = index$1.useTNodeJSX(); var _useCommonClassName = index$2.useCommonClassName(), classPrefix = _useCommonClassName.classPrefix, SIZE = _useCommonClassName.SIZE; var _useConfig = configProvider_hooks_useConfig.useConfig("input"), global = _useConfig.globalConfig; var isDisabled = index$3.useDisabled(); var isReadonly = index$4.useReadonly(); var popupVisible = Vue.ref(); var optionListRef = Vue.ref(); var getOverlayStyle = function getOverlayStyle(trigger, popupElement) { var _props2$popupProps; var triggerWidth = trigger.getBoundingClientRect().width || trigger.offsetWidth || trigger.clientWidth; var popupWidth = popupElement.getBoundingClientRect().width || popupElement.offsetWidth || popupElement.clientWidth; return _objectSpread({ width: triggerWidth >= popupWidth ? "".concat(triggerWidth, "px") : "auto" }, (_props2$popupProps = props2.popupProps) === null || _props2$popupProps === void 0 ? void 0 : _props2$popupProps.overlayInnerStyle); }; var classes = Vue.computed(function () { return ["".concat(classPrefix.value, "-auto-complete")]; }); var popupClasses = Vue.computed(function () { var _props2$popupProps2; var classes2 = ["".concat(classPrefix.value, "-select__dropdown")]; if ((_props2$popupProps2 = props2.popupProps) !== null && _props2$popupProps2 !== void 0 && _props2$popupProps2.overlayClassName) { classes2 = classes2.concat(props2.popupProps.overlayClassName); } return classes2; }); var popupInnerClasses = Vue.computed(function () { var _props2$popupProps3; var classes2 = ["".concat(classPrefix.value, "-select__dropdown-inner")]; if ((_props2$popupProps3 = props2.popupProps) !== null && _props2$popupProps3 !== void 0 && _props2$popupProps3.overlayInnerClassName) { classes2 = classes2.concat(props2.popupProps.overlayInnerClassName); } return classes2; }); var onInputChange = function onInputChange(value2, context) { popupVisible.value = true; setTValue(value2, context); }; var innerInputProps = Vue.computed(function () { var tProps = _objectSpread({ value: tValue.value, size: props2.size }, props2.inputProps); return tProps; }); var onInnerFocus = function onInnerFocus(value2, context) { var _props2$onFocus; if (isReadonly.value || isDisabled.value) return; popupVisible.value = true; (_props2$onFocus = props2.onFocus) === null || _props2$onFocus === void 0 || _props2$onFocus.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); Vue.nextTick(function () { var _optionListRef$value; (_optionListRef$value = optionListRef.value) === null || _optionListRef$value === void 0 || _optionListRef$value.addKeyboardListener(); }); }; var onInnerBlur = function onInnerBlur(value2, context) { var _props2$onBlur; (_props2$onBlur = props2.onBlur) === null || _props2$onBlur === void 0 || _props2$onBlur.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); }; var onInnerCompositionend = function onInnerCompositionend(value2, context) { var _props2$onComposition; (_props2$onComposition = props2.onCompositionend) === null || _props2$onComposition === void 0 || _props2$onComposition.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); }; var onInnerCompositionstart = function onInnerCompositionstart(value2, context) { var _props2$onComposition2; (_props2$onComposition2 = props2.onCompositionstart) === null || _props2$onComposition2 === void 0 || _props2$onComposition2.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); }; var onInnerEnter = function onInnerEnter(value2, context) { var _props2$onEnter; (_props2$onEnter = props2.onEnter) === null || _props2$onEnter === void 0 || _props2$onEnter.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); }; var onInnerSelect = function onInnerSelect(value2, context) { var _props2$onSelect; if (isReadonly.value || isDisabled.value) return; popupVisible.value = false; setTValue(value2, context); (_props2$onSelect = props2.onSelect) === null || _props2$onSelect === void 0 || _props2$onSelect.call(props2, value2, context); }; var onPopupVisibleChange = function onPopupVisibleChange(visible, _ref2) { var trigger = _ref2.trigger; if (isReadonly.value || isDisabled.value) return; if (trigger !== "trigger-element-click") { popupVisible.value = visible; } }; return function () { var _props2$placeholder; var inputEvents = index$5.useEventForward(innerInputProps.value, { onChange: onInputChange, onFocus: onInnerFocus, onBlur: onInnerBlur, onClear: props2.onClear, onCompositionend: onInnerCompositionend, onCompositionstart: onInnerCompositionstart, onEnter: onInnerEnter }); var triggerNode = renderContent("default", "triggerElement") || Vue.createVNode(input_index.Input, Vue.mergeProps({ "borderless": props2.borderless, "placeholder": (_props2$placeholder = props2.placeholder) !== null && _props2$placeholder !== void 0 ? _props2$placeholder : global.value.placeholder, "tips": props2.tips, "status": props2.status, "readonly": isReadonly.value, "disabled": isDisabled.value, "autofocus": props2.autofocus, "clearable": props2.clearable }, inputEvents.value), slots); var listContent = Array.isArray(props2.options) && Vue.createVNode(autoComplete_components_optionList["default"], { "ref": optionListRef, "value": tValue.value, "options": props2.options, "size": props2.size, "sizeClassNames": SIZE, "onSelect": onInnerSelect, "popupVisible": popupVisible.value, "highlightKeyword": props2.highlightKeyword, "filterable": props2.filterable, "filter": props2.filter, "empty": renderTNodeJSX("empty") }, { option: slots.option }); var topContent = renderTNodeJSX("panelTopContent"); var bottomContent = renderTNodeJSX("panelBottomContent"); var panelContent = topContent || listContent || bottomContent ? Vue.createVNode("div", { "class": "".concat(classPrefix.value, "-auto-complete__panel") }, [topContent, listContent, bottomContent]) : null; var popupProps = _objectSpread(_objectSpread({}, props2.popupProps), {}, { overlayInnerStyle: getOverlayStyle, overlayInnerClassName: popupInnerClasses.value, overlayClassName: popupClasses.value }); var popupEvents = index$5.useEventForward(popupProps, { onVisibleChange: onPopupVisibleChange }); return Vue.createVNode("div", { "class": classes.value }, [Vue.createVNode(popup_index.Popup, Vue.mergeProps({ "visible": popupVisible.value, "onVisibleChange": onPopupVisibleChange, "trigger": "focus", "placement": "bottom-left", "hideEmptyPopup": true, "content": panelContent ? function () { return panelContent; } : null }, popupEvents.value), _isSlot(triggerNode) ? triggerNode : { "default": function _default() { return [triggerNode]; } })]); }; } }); exports["default"] = _AutoComplete; //# sourceMappingURL=auto-complete.js.map