UNPKG

xdesign-vue-next

Version:

XDesign Component for vue-next

288 lines (284 loc) 12.9 kB
/** * xdesign v1.0.6 * (c) 2023 xdesign * @license MIT */ import { _ as _defineProperty } from '../_chunks/dep-f9e836af.mjs'; import { _ as _slicedToArray } from '../_chunks/dep-32d4c595.mjs'; import { isVNode, defineComponent, toRefs, ref, computed, nextTick, createVNode, mergeProps } from 'vue'; import props from './props.mjs'; import { Input } from '../input/index.mjs'; import { Popup } from '../popup/index.mjs'; import useCommonClassName from '../hooks/useCommonClassName.mjs'; import AutoCompleteOptionList from './option-list.mjs'; import useVModel from '../hooks/useVModel.mjs'; import { useConfig } from '../config-provider/useConfig.mjs'; import '../hooks/index.mjs'; import { useContent, useTNodeJSX } from '../hooks/tnode.mjs'; import '../_chunks/dep-82805301.mjs'; import '../_chunks/dep-89b966f4.mjs'; import '../input/input.mjs'; import '../_chunks/dep-8b0014b3.mjs'; import '../_chunks/dep-84ddb5ec.mjs'; import '../_chunks/dep-53e379cd.mjs'; import '../input/props.mjs'; import '../form/hooks.mjs'; import '../hooks/useConfig.mjs'; import '../input/useInput.mjs'; import '../form/const.mjs'; import '../input/useLengthLimit.mjs'; import '../_common/js/log/index.mjs'; import '../_common/js/log/log.mjs'; import '../_common/js/utils/helper.mjs'; import '../_chunks/dep-5bec687c.mjs'; import '../_chunks/dep-11fa9c2c.mjs'; import '../_chunks/dep-10a947a6.mjs'; import '../_chunks/dep-b75d8d74.mjs'; import '../_chunks/dep-a95026f2.mjs'; import '../_chunks/dep-068e912d.mjs'; import '../_chunks/dep-addc2a84.mjs'; import '../_chunks/dep-5a2ce53e.mjs'; import '../_chunks/dep-1bae6a97.mjs'; import '../_chunks/dep-23f91684.mjs'; import '../_chunks/dep-6ad18815.mjs'; import '../input/useInputEventHandler.mjs'; import '../input/useInputWidth.mjs'; import '../input/input-group.mjs'; import '../input/input-group-props.mjs'; import '../utils/withInstall.mjs'; import './style/css.mjs'; import '../input/type.mjs'; import '../_chunks/dep-1cc1c24f.mjs'; import '../_chunks/dep-91ac8f71.mjs'; import '../_chunks/dep-c4737535.mjs'; import '../_chunks/dep-81c83986.mjs'; import '../_chunks/dep-6aa0223b.mjs'; import '../_chunks/dep-db381ece.mjs'; import '../_chunks/dep-5755c21c.mjs'; import '../_chunks/dep-7f239c43.mjs'; import '../_chunks/dep-6f04869e.mjs'; import '../_chunks/dep-d32fbbb3.mjs'; import '../_chunks/dep-dafada74.mjs'; import '../_chunks/dep-6e7b37b8.mjs'; import '../_chunks/dep-e1ab85c5.mjs'; import '../_chunks/dep-5f0e0453.mjs'; import '../_chunks/dep-71f84cf2.mjs'; import '../_chunks/dep-0e832fc7.mjs'; import '../_chunks/dep-69963a8c.mjs'; import '../_chunks/dep-8d1c9a23.mjs'; import '../_chunks/dep-03412fab.mjs'; import '../_chunks/dep-205ff58d.mjs'; import '../_chunks/dep-b09f48fa.mjs'; import '../_chunks/dep-26bf361a.mjs'; import '../_chunks/dep-3ec3335a.mjs'; import '../_chunks/dep-ed4e7c50.mjs'; import '../_chunks/dep-a666b9ad.mjs'; import '../_common/js/global-config/default-config.mjs'; import '../_common/js/global-config/locale/en_US.mjs'; import '../config-provider/type.mjs'; import '../_chunks/dep-a628549d.mjs'; import '../_chunks/dep-4903a8a8.mjs'; import '../_chunks/dep-7dcfa37a.mjs'; import '../_chunks/dep-f4eba04c.mjs'; import '../_chunks/dep-735bcd0d.mjs'; import '../_chunks/dep-765678ef.mjs'; import '../_chunks/dep-8db27830.mjs'; import '../_chunks/dep-ae4bffa5.mjs'; import '../utils/render-tnode.mjs'; import '../_chunks/dep-9d7ebc32.mjs'; import '../hooks/icon.mjs'; import '../hooks/slot.mjs'; import '../hooks/useDefaultValue.mjs'; import '../hooks/useDestroyOnClose.mjs'; import '../hooks/useKeepAnimation.mjs'; import '../hooks/useRipple.mjs'; import '../utils/set-style.mjs'; import '../hooks/useVirtualScroll.mjs'; import '../hooks/useImagePreviewUrl.mjs'; import '../_common/js/upload/utils.mjs'; import '../popup/popup.mjs'; import '@popperjs/core'; import '../_chunks/dep-0c786bea.mjs'; import '../_chunks/dep-e727a519.mjs'; import '../utils/dom.mjs'; import '../utils/easing.mjs'; import '../_common/js/utils/set-style.mjs'; import '../popup/container.mjs'; import '../popup/props.mjs'; import '../hooks/useResizeObserver.mjs'; import '../popup/type.mjs'; import './highlight-option.mjs'; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } function _isSlot(s) { return typeof s === 'function' || Object.prototype.toString.call(s) === '[object Object]' && !isVNode(s); } var _AutoComplete = defineComponent({ name: "XAutoComplete", props: props, setup: function setup(props2, _ref) { var slots = _ref.slots; var _toRefs = toRefs(props2), value = _toRefs.value, modelValue = _toRefs.modelValue; var _useVModel = useVModel(value, modelValue, props2.defaultValue, props2.onChange), _useVModel2 = _slicedToArray(_useVModel, 2), tValue = _useVModel2[0], setTValue = _useVModel2[1]; var renderContent = useContent(); var renderTNodeJSX = useTNodeJSX(); var _useCommonClassName = useCommonClassName(), classPrefix = _useCommonClassName.classPrefix, sizeClassNames = _useCommonClassName.sizeClassNames; var _useConfig = useConfig("input"), global = _useConfig.globalConfig; var popupVisible = ref(); var optionListRef = 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 = computed(function () { return ["".concat(classPrefix.value, "-auto-complete")]; }); var popupClasses = 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 = 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) { setTValue(value2, context); }; var innerInputProps = computed(function () { var tProps = _objectSpread({ value: tValue.value, size: props2.size }, props2.inputProps); return tProps; }); var onInnerFocus = function onInnerFocus(value2, context) { var _props2$onFocus; popupVisible.value = true; (_props2$onFocus = props2.onFocus) === null || _props2$onFocus === void 0 ? void 0 : _props2$onFocus.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); nextTick(function () { var _optionListRef$value; (_optionListRef$value = optionListRef.value) === null || _optionListRef$value === void 0 ? void 0 : _optionListRef$value.addKeyboardListener(); }); }; var onInnerBlur = function onInnerBlur(value2, context) { var _props2$onBlur; (_props2$onBlur = props2.onBlur) === null || _props2$onBlur === void 0 ? 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 ? 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 ? 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 ? void 0 : _props2$onEnter.call(props2, _objectSpread(_objectSpread({}, context), {}, { value: value2 })); }; var onInnerSelect = function onInnerSelect(value2, context) { var _props2$onSelect; if (props2.readonly || props2.disabled) return; popupVisible.value = false; setTValue(value2, context); (_props2$onSelect = props2.onSelect) === null || _props2$onSelect === void 0 ? void 0 : _props2$onSelect.call(props2, value2, context); }; var onPopupVisibleChange = function onPopupVisibleChange(visible, _ref2) { var trigger = _ref2.trigger; if (trigger !== "trigger-element-click") { popupVisible.value = visible; } }; return function () { var _props2$placeholder, _props2$options; var triggerNode = renderContent("default", "triggerElement") || createVNode(Input, mergeProps({ "placeholder": (_props2$placeholder = props2.placeholder) !== null && _props2$placeholder !== void 0 ? _props2$placeholder : global.value.placeholder, "tips": props2.tips, "status": props2.status, "readonly": props2.readonly, "disabled": props2.disabled, "autofocus": props2.autofocus, "clearable": props2.clearable, "onChange": onInputChange, "onFocus": onInnerFocus, "onBlur": onInnerBlur, "onClear": props2.onClear, "onCompositionend": onInnerCompositionend, "onCompositionstart": onInnerCompositionstart, "onEnter": onInnerEnter }, innerInputProps.value), slots); var listContent = createVNode(AutoCompleteOptionList, { "ref": optionListRef, "value": tValue.value, "options": props2.options, "size": props2.size, "sizeClassNames": sizeClassNames, "onSelect": onInnerSelect, "popupVisible": popupVisible.value, "highlightKeyword": props2.highlightKeyword, "filterable": props2.filterable, "filter": props2.filter }, { option: slots.option }); var topContent = renderTNodeJSX("panelTopContent"); var bottomContent = renderTNodeJSX("panelBottomContent"); var panelContent = Boolean(topContent || ((_props2$options = props2.options) === null || _props2$options === void 0 ? void 0 : _props2$options.length) || bottomContent) ? createVNode("div", { "class": "".concat(classPrefix.value, "-autocomplete__panel") }, [topContent, listContent, bottomContent]) : null; var popupProps = _objectSpread(_objectSpread({}, props2.popupProps), {}, { overlayInnerStyle: getOverlayStyle, overlayInnerClassName: popupInnerClasses.value, overlayClassName: popupClasses.value }); return createVNode("div", { "class": classes.value }, [createVNode(Popup, mergeProps({ "visible": popupVisible.value, "onVisibleChange": onPopupVisibleChange, "trigger": "focus", "placement": "bottom-left", "hideEmptyPopup": true, "content": panelContent ? function () { return panelContent; } : null }, popupProps), _isSlot(triggerNode) ? triggerNode : { "default": function _default() { return [triggerNode]; } })]); }; } }); export { _AutoComplete as default }; //# sourceMappingURL=auto-complete.mjs.map