@element-plus/nightly 0.0.20240711 → 0.0.20240713
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.full.js +5 -2
- package/dist/index.full.min.js +3 -3
- package/dist/index.full.min.js.map +1 -1
- package/dist/index.full.min.mjs +12 -12
- package/dist/index.full.min.mjs.map +1 -1
- package/dist/index.full.mjs +6 -3
- package/dist/locale/af.js +1 -1
- package/dist/locale/af.min.js +1 -1
- package/dist/locale/af.min.mjs +1 -1
- package/dist/locale/af.mjs +1 -1
- package/dist/locale/ar-eg.js +1 -1
- package/dist/locale/ar-eg.min.js +1 -1
- package/dist/locale/ar-eg.min.mjs +1 -1
- package/dist/locale/ar-eg.mjs +1 -1
- package/dist/locale/ar.js +1 -1
- package/dist/locale/ar.min.js +1 -1
- package/dist/locale/ar.min.mjs +1 -1
- package/dist/locale/ar.mjs +1 -1
- package/dist/locale/az.js +1 -1
- package/dist/locale/az.min.js +1 -1
- package/dist/locale/az.min.mjs +1 -1
- package/dist/locale/az.mjs +1 -1
- package/dist/locale/bg.js +1 -1
- package/dist/locale/bg.min.js +1 -1
- package/dist/locale/bg.min.mjs +1 -1
- package/dist/locale/bg.mjs +1 -1
- package/dist/locale/bn.js +1 -1
- package/dist/locale/bn.min.js +1 -1
- package/dist/locale/bn.min.mjs +1 -1
- package/dist/locale/bn.mjs +1 -1
- package/dist/locale/ca.js +1 -1
- package/dist/locale/ca.min.js +1 -1
- package/dist/locale/ca.min.mjs +1 -1
- package/dist/locale/ca.mjs +1 -1
- package/dist/locale/ckb.js +1 -1
- package/dist/locale/ckb.min.js +1 -1
- package/dist/locale/ckb.min.mjs +1 -1
- package/dist/locale/ckb.mjs +1 -1
- package/dist/locale/cs.js +1 -1
- package/dist/locale/cs.min.js +1 -1
- package/dist/locale/cs.min.mjs +1 -1
- package/dist/locale/cs.mjs +1 -1
- package/dist/locale/da.js +1 -1
- package/dist/locale/da.min.js +1 -1
- package/dist/locale/da.min.mjs +1 -1
- package/dist/locale/da.mjs +1 -1
- package/dist/locale/de.js +1 -1
- package/dist/locale/de.min.js +1 -1
- package/dist/locale/de.min.mjs +1 -1
- package/dist/locale/de.mjs +1 -1
- package/dist/locale/el.js +1 -1
- package/dist/locale/el.min.js +1 -1
- package/dist/locale/el.min.mjs +1 -1
- package/dist/locale/el.mjs +1 -1
- package/dist/locale/en.js +1 -1
- package/dist/locale/en.min.js +1 -1
- package/dist/locale/en.min.mjs +1 -1
- package/dist/locale/en.mjs +1 -1
- package/dist/locale/eo.js +1 -1
- package/dist/locale/eo.min.js +1 -1
- package/dist/locale/eo.min.mjs +1 -1
- package/dist/locale/eo.mjs +1 -1
- package/dist/locale/es.js +1 -1
- package/dist/locale/es.min.js +1 -1
- package/dist/locale/es.min.mjs +1 -1
- package/dist/locale/es.mjs +1 -1
- package/dist/locale/et.js +1 -1
- package/dist/locale/et.min.js +1 -1
- package/dist/locale/et.min.mjs +1 -1
- package/dist/locale/et.mjs +1 -1
- package/dist/locale/eu.js +1 -1
- package/dist/locale/eu.min.js +1 -1
- package/dist/locale/eu.min.mjs +1 -1
- package/dist/locale/eu.mjs +1 -1
- package/dist/locale/fa.js +1 -1
- package/dist/locale/fa.min.js +1 -1
- package/dist/locale/fa.min.mjs +1 -1
- package/dist/locale/fa.mjs +1 -1
- package/dist/locale/fi.js +1 -1
- package/dist/locale/fi.min.js +1 -1
- package/dist/locale/fi.min.mjs +1 -1
- package/dist/locale/fi.mjs +1 -1
- package/dist/locale/fr.js +1 -1
- package/dist/locale/fr.min.js +1 -1
- package/dist/locale/fr.min.mjs +1 -1
- package/dist/locale/fr.mjs +1 -1
- package/dist/locale/he.js +1 -1
- package/dist/locale/he.min.js +1 -1
- package/dist/locale/he.min.mjs +1 -1
- package/dist/locale/he.mjs +1 -1
- package/dist/locale/hr.js +1 -1
- package/dist/locale/hr.min.js +1 -1
- package/dist/locale/hr.min.mjs +1 -1
- package/dist/locale/hr.mjs +1 -1
- package/dist/locale/hu.js +1 -1
- package/dist/locale/hu.min.js +1 -1
- package/dist/locale/hu.min.mjs +1 -1
- package/dist/locale/hu.mjs +1 -1
- package/dist/locale/hy-am.js +1 -1
- package/dist/locale/hy-am.min.js +1 -1
- package/dist/locale/hy-am.min.mjs +1 -1
- package/dist/locale/hy-am.mjs +1 -1
- package/dist/locale/id.js +1 -1
- package/dist/locale/id.min.js +1 -1
- package/dist/locale/id.min.mjs +1 -1
- package/dist/locale/id.mjs +1 -1
- package/dist/locale/it.js +1 -1
- package/dist/locale/it.min.js +1 -1
- package/dist/locale/it.min.mjs +1 -1
- package/dist/locale/it.mjs +1 -1
- package/dist/locale/ja.js +1 -1
- package/dist/locale/ja.min.js +1 -1
- package/dist/locale/ja.min.mjs +1 -1
- package/dist/locale/ja.mjs +1 -1
- package/dist/locale/kk.js +1 -1
- package/dist/locale/kk.min.js +1 -1
- package/dist/locale/kk.min.mjs +1 -1
- package/dist/locale/kk.mjs +1 -1
- package/dist/locale/km.js +1 -1
- package/dist/locale/km.min.js +1 -1
- package/dist/locale/km.min.mjs +1 -1
- package/dist/locale/km.mjs +1 -1
- package/dist/locale/ko.js +1 -1
- package/dist/locale/ko.min.js +1 -1
- package/dist/locale/ko.min.mjs +1 -1
- package/dist/locale/ko.mjs +1 -1
- package/dist/locale/ku.js +1 -1
- package/dist/locale/ku.min.js +1 -1
- package/dist/locale/ku.min.mjs +1 -1
- package/dist/locale/ku.mjs +1 -1
- package/dist/locale/ky.js +1 -1
- package/dist/locale/ky.min.js +1 -1
- package/dist/locale/ky.min.mjs +1 -1
- package/dist/locale/ky.mjs +1 -1
- package/dist/locale/lt.js +1 -1
- package/dist/locale/lt.min.js +1 -1
- package/dist/locale/lt.min.mjs +1 -1
- package/dist/locale/lt.mjs +1 -1
- package/dist/locale/lv.js +1 -1
- package/dist/locale/lv.min.js +1 -1
- package/dist/locale/lv.min.mjs +1 -1
- package/dist/locale/lv.mjs +1 -1
- package/dist/locale/mg.js +1 -1
- package/dist/locale/mg.min.js +1 -1
- package/dist/locale/mg.min.mjs +1 -1
- package/dist/locale/mg.mjs +1 -1
- package/dist/locale/mn.js +1 -1
- package/dist/locale/mn.min.js +1 -1
- package/dist/locale/mn.min.mjs +1 -1
- package/dist/locale/mn.mjs +1 -1
- package/dist/locale/nb-no.js +1 -1
- package/dist/locale/nb-no.min.js +1 -1
- package/dist/locale/nb-no.min.mjs +1 -1
- package/dist/locale/nb-no.mjs +1 -1
- package/dist/locale/nl.js +1 -1
- package/dist/locale/nl.min.js +1 -1
- package/dist/locale/nl.min.mjs +1 -1
- package/dist/locale/nl.mjs +1 -1
- package/dist/locale/pa.js +1 -1
- package/dist/locale/pa.min.js +1 -1
- package/dist/locale/pa.min.mjs +1 -1
- package/dist/locale/pa.mjs +1 -1
- package/dist/locale/pl.js +1 -1
- package/dist/locale/pl.min.js +1 -1
- package/dist/locale/pl.min.mjs +1 -1
- package/dist/locale/pl.mjs +1 -1
- package/dist/locale/pt-br.js +1 -1
- package/dist/locale/pt-br.min.js +1 -1
- package/dist/locale/pt-br.min.mjs +1 -1
- package/dist/locale/pt-br.mjs +1 -1
- package/dist/locale/pt.js +1 -1
- package/dist/locale/pt.min.js +1 -1
- package/dist/locale/pt.min.mjs +1 -1
- package/dist/locale/pt.mjs +1 -1
- package/dist/locale/ro.js +1 -1
- package/dist/locale/ro.min.js +1 -1
- package/dist/locale/ro.min.mjs +1 -1
- package/dist/locale/ro.mjs +1 -1
- package/dist/locale/ru.js +1 -1
- package/dist/locale/ru.min.js +1 -1
- package/dist/locale/ru.min.mjs +1 -1
- package/dist/locale/ru.mjs +1 -1
- package/dist/locale/sk.js +1 -1
- package/dist/locale/sk.min.js +1 -1
- package/dist/locale/sk.min.mjs +1 -1
- package/dist/locale/sk.mjs +1 -1
- package/dist/locale/sl.js +1 -1
- package/dist/locale/sl.min.js +1 -1
- package/dist/locale/sl.min.mjs +1 -1
- package/dist/locale/sl.mjs +1 -1
- package/dist/locale/sr.js +1 -1
- package/dist/locale/sr.min.js +1 -1
- package/dist/locale/sr.min.mjs +1 -1
- package/dist/locale/sr.mjs +1 -1
- package/dist/locale/sv.js +1 -1
- package/dist/locale/sv.min.js +1 -1
- package/dist/locale/sv.min.mjs +1 -1
- package/dist/locale/sv.mjs +1 -1
- package/dist/locale/sw.js +1 -1
- package/dist/locale/sw.min.js +1 -1
- package/dist/locale/sw.min.mjs +1 -1
- package/dist/locale/sw.mjs +1 -1
- package/dist/locale/ta.js +1 -1
- package/dist/locale/ta.min.js +1 -1
- package/dist/locale/ta.min.mjs +1 -1
- package/dist/locale/ta.mjs +1 -1
- package/dist/locale/th.js +1 -1
- package/dist/locale/th.min.js +1 -1
- package/dist/locale/th.min.mjs +1 -1
- package/dist/locale/th.mjs +1 -1
- package/dist/locale/tk.js +1 -1
- package/dist/locale/tk.min.js +1 -1
- package/dist/locale/tk.min.mjs +1 -1
- package/dist/locale/tk.mjs +1 -1
- package/dist/locale/tr.js +1 -1
- package/dist/locale/tr.min.js +1 -1
- package/dist/locale/tr.min.mjs +1 -1
- package/dist/locale/tr.mjs +1 -1
- package/dist/locale/ug-cn.js +1 -1
- package/dist/locale/ug-cn.min.js +1 -1
- package/dist/locale/ug-cn.min.mjs +1 -1
- package/dist/locale/ug-cn.mjs +1 -1
- package/dist/locale/uk.js +1 -1
- package/dist/locale/uk.min.js +1 -1
- package/dist/locale/uk.min.mjs +1 -1
- package/dist/locale/uk.mjs +1 -1
- package/dist/locale/uz-uz.js +1 -1
- package/dist/locale/uz-uz.min.js +1 -1
- package/dist/locale/uz-uz.min.mjs +1 -1
- package/dist/locale/uz-uz.mjs +1 -1
- package/dist/locale/vi.js +1 -1
- package/dist/locale/vi.min.js +1 -1
- package/dist/locale/vi.min.mjs +1 -1
- package/dist/locale/vi.mjs +1 -1
- package/dist/locale/zh-cn.js +1 -1
- package/dist/locale/zh-cn.min.js +1 -1
- package/dist/locale/zh-cn.min.mjs +1 -1
- package/dist/locale/zh-cn.mjs +1 -1
- package/dist/locale/zh-tw.js +1 -1
- package/dist/locale/zh-tw.min.js +1 -1
- package/dist/locale/zh-tw.min.mjs +1 -1
- package/dist/locale/zh-tw.mjs +1 -1
- package/es/components/autocomplete/index.mjs +2 -2
- package/es/components/autocomplete/src/autocomplete.mjs +81 -364
- package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
- package/es/components/autocomplete/src/autocomplete2.mjs +364 -81
- package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
- package/es/components/index.mjs +1 -1
- package/es/components/virtual-list/src/builders/build-list.mjs +4 -1
- package/es/components/virtual-list/src/builders/build-list.mjs.map +1 -1
- package/es/index.mjs +1 -1
- package/es/version.d.ts +1 -1
- package/es/version.mjs +1 -1
- package/es/version.mjs.map +1 -1
- package/lib/components/autocomplete/index.js +2 -2
- package/lib/components/autocomplete/src/autocomplete.js +81 -363
- package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
- package/lib/components/autocomplete/src/autocomplete2.js +363 -81
- package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
- package/lib/components/index.js +1 -1
- package/lib/components/virtual-list/src/builders/build-list.js +3 -0
- package/lib/components/virtual-list/src/builders/build-list.js.map +1 -1
- package/lib/index.js +1 -1
- package/lib/version.d.ts +1 -1
- package/lib/version.js +1 -1
- package/lib/version.js.map +1 -1
- package/package.json +2 -2
- package/tags.json +1 -1
- package/web-types.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"autocomplete.js","sources":["../../../../../../packages/components/autocomplete/src/autocomplete.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"popperRef\"\n :visible=\"suggestionVisible\"\n :placement=\"placement\"\n :fallback-placements=\"['bottom-start', 'top-start']\"\n :popper-class=\"[ns.e('popper'), popperClass]\"\n :teleported=\"teleported\"\n :gpu-acceleration=\"false\"\n pure\n manual-mode\n effect=\"light\"\n trigger=\"click\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n persistent\n role=\"listbox\"\n @before-show=\"onSuggestionShow\"\n @hide=\"onHide\"\n >\n <div\n ref=\"listboxRef\"\n :class=\"[ns.b(), $attrs.class]\"\n :style=\"styles\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n :aria-expanded=\"suggestionVisible\"\n :aria-owns=\"listboxId\"\n >\n <el-input\n ref=\"inputRef\"\n v-bind=\"attrs\"\n :clearable=\"clearable\"\n :disabled=\"disabled\"\n :name=\"name\"\n :model-value=\"modelValue\"\n :aria-label=\"ariaLabel\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown.up.prevent=\"highlight(highlightedIndex - 1)\"\n @keydown.down.prevent=\"highlight(highlightedIndex + 1)\"\n @keydown.enter=\"handleKeyEnter\"\n @keydown.tab=\"close\"\n @keydown.esc=\"handleKeyEscape\"\n @mousedown=\"handleMouseDown\"\n >\n <template v-if=\"$slots.prepend\" #prepend>\n <slot name=\"prepend\" />\n </template>\n <template v-if=\"$slots.append\" #append>\n <slot name=\"append\" />\n </template>\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template v-if=\"$slots.suffix\" #suffix>\n <slot name=\"suffix\" />\n </template>\n </el-input>\n </div>\n <template #content>\n <div\n ref=\"regionRef\"\n :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n :style=\"{\n [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n outline: 'none',\n }\"\n role=\"region\"\n >\n <el-scrollbar\n :id=\"listboxId\"\n tag=\"ul\"\n :wrap-class=\"ns.be('suggestion', 'wrap')\"\n :view-class=\"ns.be('suggestion', 'list')\"\n role=\"listbox\"\n >\n <li v-if=\"suggestionLoading\">\n <slot name=\"loading\">\n <el-icon :class=\"ns.is('loading')\">\n <Loading />\n </el-icon>\n </slot>\n </li>\n <template v-else>\n <li\n v-for=\"(item, index) in suggestions\"\n :id=\"`${listboxId}-item-${index}`\"\n :key=\"index\"\n :class=\"{ highlighted: highlightedIndex === index }\"\n role=\"option\"\n :aria-selected=\"highlightedIndex === index\"\n @click=\"handleSelect(item)\"\n >\n <slot :item=\"item\">{{ item[valueKey] }}</slot>\n </li>\n </template>\n </el-scrollbar>\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, useAttrs as useRawAttrs } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { onClickOutside } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useAttrs, useId, useNamespace } from '@element-plus/hooks'\nimport { isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits, autocompleteProps } from './autocomplete'\nimport type { AutocompleteData } from './autocomplete'\n\nimport type { StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n name: COMPONENT_NAME,\n inheritAttrs: false,\n})\n\nconst props = defineProps(autocompleteProps)\nconst emit = defineEmits(autocompleteEmits)\n\nconst attrs = useAttrs()\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref<AutocompleteData>([])\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n const isValidData = suggestions.value.length > 0\n return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n if (inputRef.value) {\n return Array.from<HTMLInputElement>(\n inputRef.value.$el.querySelectorAll('input')\n )\n }\n return []\n})\n\nconst onSuggestionShow = () => {\n if (suggestionVisible.value) {\n dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n }\n}\n\nconst onHide = () => {\n highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n if (suggestionDisabled.value) return\n\n const cb = (suggestionList: AutocompleteData) => {\n loading.value = false\n if (suggestionDisabled.value) return\n\n if (isArray(suggestionList)) {\n suggestions.value = suggestionList\n highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n } else {\n throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n }\n }\n\n loading.value = true\n if (isArray(props.fetchSuggestions)) {\n cb(props.fetchSuggestions)\n } else {\n const result = await props.fetchSuggestions(queryString, cb)\n if (isArray(result)) cb(result)\n }\n}\nconst debouncedGetData = debounce(getData, props.debounce)\n\nconst handleInput = (value: string) => {\n const valuePresented = !!value\n\n emit(INPUT_EVENT, value)\n emit(UPDATE_MODEL_EVENT, value)\n\n suggestionDisabled.value = false\n activated.value ||= valuePresented\n\n if (!props.triggerOnFocus && !value) {\n suggestionDisabled.value = true\n suggestions.value = []\n return\n }\n\n debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n if (disabled.value) return\n if (\n (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n refInput.value.includes(document.activeElement as HTMLInputElement)\n ) {\n activated.value = true\n }\n}\n\nconst handleChange = (value: string) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(props.modelValue))\n }\n } else {\n ignoreFocusEvent = false\n }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n setTimeout(() => {\n // validate current focus event is inside el-tooltip-content\n // if so, ignore the blur event and the next focus event\n if (popperRef.value?.isFocusInsideContent()) {\n ignoreFocusEvent = true\n return\n }\n activated.value && close()\n emit('blur', evt)\n })\n}\n\nconst handleClear = () => {\n activated.value = false\n emit(UPDATE_MODEL_EVENT, '')\n emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n if (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\n }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n if (suggestionVisible.value) {\n evt.preventDefault()\n evt.stopPropagation()\n close()\n }\n}\n\nconst close = () => {\n activated.value = false\n}\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: any) => {\n emit(INPUT_EVENT, item[props.valueKey])\n emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n emit('select', item)\n suggestions.value = []\n highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n if (!suggestionVisible.value || loading.value) return\n\n if (index < 0) {\n highlightedIndex.value = -1\n return\n }\n\n if (index >= suggestions.value.length) {\n index = suggestions.value.length - 1\n }\n const suggestion = regionRef.value!.querySelector(\n `.${ns.be('suggestion', 'wrap')}`\n )!\n const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n `.${ns.be('suggestion', 'list')} li`\n )!\n const highlightItem = suggestionList[index]\n const scrollTop = suggestion.scrollTop\n const { offsetTop, scrollHeight } = highlightItem\n\n if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n suggestion.scrollTop += scrollHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop -= scrollHeight\n }\n highlightedIndex.value = index\n // TODO: use Volar generate dts to fix it.\n ;(inputRef.value as any).ref!.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\n\nonClickOutside(listboxRef, () => {\n suggestionVisible.value && close()\n})\n\nonMounted(() => {\n // TODO: use Volar generate dts to fix it.\n ;(inputRef.value as any).ref!.setAttribute('role', 'textbox')\n ;(inputRef.value as any).ref!.setAttribute('aria-autocomplete', 'list')\n ;(inputRef.value as any).ref!.setAttribute('aria-controls', 'id')\n ;(inputRef.value as any).ref!.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n // get readonly attr\n readonly = (inputRef.value as any).ref!.hasAttribute('readonly')\n})\n\ndefineExpose({\n /** @description the index of the currently highlighted item */\n highlightedIndex,\n /** @description autocomplete whether activated */\n activated,\n /** @description remote search loading status */\n loading,\n /** @description el-input component instance */\n inputRef,\n /** @description el-tooltip component instance */\n popperRef,\n /** @description fetch suggestions result */\n suggestions,\n /** @description triggers when a suggestion is clicked */\n handleSelect,\n /** @description handle keyboard enter event */\n handleKeyEnter,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n /** @description close suggestion */\n close,\n /** @description highlight an item in a suggestion */\n highlight,\n})\n</script>\n"],"names":["useAttrs","useRawAttrs","useFormDisabled","useNamespace","ref","useId","computed","isArray","throwError","debounce","INPUT_EVENT","UPDATE_MODEL_EVENT","CHANGE_EVENT","onClickOutside","onMounted"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"autocomplete.js","sources":["../../../../../../packages/components/autocomplete/src/autocomplete.ts"],"sourcesContent":["import { NOOP } from '@vue/shared'\nimport {\n buildProps,\n definePropType,\n isObject,\n isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { useAriaProps } from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\n\nexport type AutocompleteData = Record<string, any>[]\nexport type AutocompleteFetchSuggestionsCallback = (\n data: AutocompleteData\n) => void\nexport type AutocompleteFetchSuggestions =\n | ((\n queryString: string,\n cb: AutocompleteFetchSuggestionsCallback\n ) => Awaitable<AutocompleteData> | void)\n | AutocompleteData\n\nexport const autocompleteProps = buildProps({\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey: {\n type: String,\n default: 'value',\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description placement of the popup menu\n */\n placement: {\n type: definePropType<Placement>(String),\n values: [\n 'top',\n 'top-start',\n 'top-end',\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n ],\n default: 'bottom-start',\n },\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions: {\n type: definePropType<AutocompleteFetchSuggestions>([Function, Array]),\n default: NOOP,\n },\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass: {\n type: String,\n default: '',\n },\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading: {\n type: Boolean,\n default: false,\n },\n teleported: useTooltipContentProps.teleported,\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to show clear button\n */\n clearable: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to disable\n */\n disabled: {\n type: Boolean,\n default: false,\n },\n /**\n * @description same as `name` in native input\n */\n name: String,\n ...useAriaProps(['ariaLabel']),\n} as const)\nexport type AutocompleteProps = ExtractPropTypes<typeof autocompleteProps>\n\nexport const autocompleteEmits = {\n [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n [INPUT_EVENT]: (value: string) => isString(value),\n [CHANGE_EVENT]: (value: string) => isString(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n select: (item: Record<string, any>) => isObject(item),\n}\nexport type AutocompleteEmits = typeof autocompleteEmits\n\nexport type AutocompleteInstance = InstanceType<typeof Autocomplete>\n"],"names":["buildProps","definePropType","NOOP","useTooltipContentProps","useAriaProps","UPDATE_MODEL_EVENT","isString","INPUT_EVENT","CHANGE_EVENT","isObject"],"mappings":";;;;;;;;;;;;;;AAcY,MAAC,iBAAiB,GAAGA,kBAAU,CAAC;AAC5C,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEC,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,MAAM,EAAE;AACZ,MAAM,KAAK;AACX,MAAM,WAAW;AACjB,MAAM,SAAS;AACf,MAAM,QAAQ;AACd,MAAM,cAAc;AACpB,MAAM,YAAY;AAClB,KAAK;AACL,IAAI,OAAO,EAAE,cAAc;AAC3B,GAAG;AACH,EAAE,gBAAgB,EAAE;AACpB,IAAI,IAAI,EAAEA,sBAAc,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC3C,IAAI,OAAO,EAAEC,WAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,cAAc,EAAE;AAClB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,mBAAmB,EAAE;AACvB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,UAAU,EAAEC,8BAAsB,CAAC,UAAU;AAC/C,EAAE,kBAAkB,EAAE;AACtB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,IAAI,EAAE,MAAM;AACd,EAAE,GAAGC,kBAAY,CAAC,CAAC,WAAW,CAAC,CAAC;AAChC,CAAC,EAAE;AACS,MAAC,iBAAiB,GAAG;AACjC,EAAE,CAACC,wBAAkB,GAAG,CAAC,KAAK,KAAKC,eAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,CAACC,iBAAW,GAAG,CAAC,KAAK,KAAKD,eAAQ,CAAC,KAAK,CAAC;AAC3C,EAAE,CAACE,kBAAY,GAAG,CAAC,KAAK,KAAKF,eAAQ,CAAC,KAAK,CAAC;AAC5C,EAAE,KAAK,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC3C,EAAE,IAAI,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC1C,EAAE,KAAK,EAAE,MAAM,IAAI;AACnB,EAAE,MAAM,EAAE,CAAC,IAAI,KAAKG,eAAQ,CAAC,IAAI,CAAC;AAClC;;;;;"}
|
|
@@ -2,91 +2,373 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var
|
|
6
|
-
require('
|
|
7
|
-
require('
|
|
5
|
+
var vue = require('vue');
|
|
6
|
+
var lodashUnified = require('lodash-unified');
|
|
7
|
+
var core = require('@vueuse/core');
|
|
8
|
+
var iconsVue = require('@element-plus/icons-vue');
|
|
8
9
|
require('../../../hooks/index.js');
|
|
10
|
+
require('../../../utils/index.js');
|
|
9
11
|
require('../../../constants/index.js');
|
|
10
|
-
var
|
|
11
|
-
var
|
|
12
|
-
var index = require('
|
|
12
|
+
var index$6 = require('../../input/index.js');
|
|
13
|
+
var index$4 = require('../../scrollbar/index.js');
|
|
14
|
+
var index$3 = require('../../tooltip/index.js');
|
|
15
|
+
var index$5 = require('../../icon/index.js');
|
|
16
|
+
require('../../form/index.js');
|
|
17
|
+
var autocomplete = require('./autocomplete.js');
|
|
18
|
+
var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
|
|
19
|
+
var index = require('../../../hooks/use-attrs/index.js');
|
|
20
|
+
var useFormCommonProps = require('../../form/src/hooks/use-form-common-props.js');
|
|
21
|
+
var index$1 = require('../../../hooks/use-namespace/index.js');
|
|
22
|
+
var index$2 = require('../../../hooks/use-id/index.js');
|
|
23
|
+
var shared = require('@vue/shared');
|
|
24
|
+
var error = require('../../../utils/error.js');
|
|
13
25
|
var event = require('../../../constants/event.js');
|
|
14
26
|
|
|
15
|
-
const
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
27
|
+
const _hoisted_1 = ["aria-expanded", "aria-owns"];
|
|
28
|
+
const _hoisted_2 = { key: 0 };
|
|
29
|
+
const _hoisted_3 = ["id", "aria-selected", "onClick"];
|
|
30
|
+
const COMPONENT_NAME = "ElAutocomplete";
|
|
31
|
+
const __default__ = vue.defineComponent({
|
|
32
|
+
name: COMPONENT_NAME,
|
|
33
|
+
inheritAttrs: false
|
|
34
|
+
});
|
|
35
|
+
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
36
|
+
...__default__,
|
|
37
|
+
props: autocomplete.autocompleteProps,
|
|
38
|
+
emits: autocomplete.autocompleteEmits,
|
|
39
|
+
setup(__props, { expose, emit }) {
|
|
40
|
+
const props = __props;
|
|
41
|
+
const attrs = index.useAttrs();
|
|
42
|
+
const rawAttrs = vue.useAttrs();
|
|
43
|
+
const disabled = useFormCommonProps.useFormDisabled();
|
|
44
|
+
const ns = index$1.useNamespace("autocomplete");
|
|
45
|
+
const inputRef = vue.ref();
|
|
46
|
+
const regionRef = vue.ref();
|
|
47
|
+
const popperRef = vue.ref();
|
|
48
|
+
const listboxRef = vue.ref();
|
|
49
|
+
let readonly = false;
|
|
50
|
+
let ignoreFocusEvent = false;
|
|
51
|
+
const suggestions = vue.ref([]);
|
|
52
|
+
const highlightedIndex = vue.ref(-1);
|
|
53
|
+
const dropdownWidth = vue.ref("");
|
|
54
|
+
const activated = vue.ref(false);
|
|
55
|
+
const suggestionDisabled = vue.ref(false);
|
|
56
|
+
const loading = vue.ref(false);
|
|
57
|
+
const listboxId = index$2.useId();
|
|
58
|
+
const styles = vue.computed(() => rawAttrs.style);
|
|
59
|
+
const suggestionVisible = vue.computed(() => {
|
|
60
|
+
const isValidData = suggestions.value.length > 0;
|
|
61
|
+
return (isValidData || loading.value) && activated.value;
|
|
62
|
+
});
|
|
63
|
+
const suggestionLoading = vue.computed(() => !props.hideLoading && loading.value);
|
|
64
|
+
const refInput = vue.computed(() => {
|
|
65
|
+
if (inputRef.value) {
|
|
66
|
+
return Array.from(inputRef.value.$el.querySelectorAll("input"));
|
|
67
|
+
}
|
|
68
|
+
return [];
|
|
69
|
+
});
|
|
70
|
+
const onSuggestionShow = () => {
|
|
71
|
+
if (suggestionVisible.value) {
|
|
72
|
+
dropdownWidth.value = `${inputRef.value.$el.offsetWidth}px`;
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
const onHide = () => {
|
|
76
|
+
highlightedIndex.value = -1;
|
|
77
|
+
};
|
|
78
|
+
const getData = async (queryString) => {
|
|
79
|
+
if (suggestionDisabled.value)
|
|
80
|
+
return;
|
|
81
|
+
const cb = (suggestionList) => {
|
|
82
|
+
loading.value = false;
|
|
83
|
+
if (suggestionDisabled.value)
|
|
84
|
+
return;
|
|
85
|
+
if (shared.isArray(suggestionList)) {
|
|
86
|
+
suggestions.value = suggestionList;
|
|
87
|
+
highlightedIndex.value = props.highlightFirstItem ? 0 : -1;
|
|
88
|
+
} else {
|
|
89
|
+
error.throwError(COMPONENT_NAME, "autocomplete suggestions must be an array");
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
loading.value = true;
|
|
93
|
+
if (shared.isArray(props.fetchSuggestions)) {
|
|
94
|
+
cb(props.fetchSuggestions);
|
|
95
|
+
} else {
|
|
96
|
+
const result = await props.fetchSuggestions(queryString, cb);
|
|
97
|
+
if (shared.isArray(result))
|
|
98
|
+
cb(result);
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
const debouncedGetData = lodashUnified.debounce(getData, props.debounce);
|
|
102
|
+
const handleInput = (value) => {
|
|
103
|
+
const valuePresented = !!value;
|
|
104
|
+
emit(event.INPUT_EVENT, value);
|
|
105
|
+
emit(event.UPDATE_MODEL_EVENT, value);
|
|
106
|
+
suggestionDisabled.value = false;
|
|
107
|
+
activated.value || (activated.value = valuePresented);
|
|
108
|
+
if (!props.triggerOnFocus && !value) {
|
|
109
|
+
suggestionDisabled.value = true;
|
|
110
|
+
suggestions.value = [];
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
debouncedGetData(value);
|
|
114
|
+
};
|
|
115
|
+
const handleMouseDown = (event) => {
|
|
116
|
+
var _a;
|
|
117
|
+
if (disabled.value)
|
|
118
|
+
return;
|
|
119
|
+
if (((_a = event.target) == null ? void 0 : _a.tagName) !== "INPUT" || refInput.value.includes(document.activeElement)) {
|
|
120
|
+
activated.value = true;
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
const handleChange = (value) => {
|
|
124
|
+
emit(event.CHANGE_EVENT, value);
|
|
125
|
+
};
|
|
126
|
+
const handleFocus = (evt) => {
|
|
127
|
+
if (!ignoreFocusEvent) {
|
|
128
|
+
activated.value = true;
|
|
129
|
+
emit("focus", evt);
|
|
130
|
+
if (props.triggerOnFocus && !readonly) {
|
|
131
|
+
debouncedGetData(String(props.modelValue));
|
|
132
|
+
}
|
|
133
|
+
} else {
|
|
134
|
+
ignoreFocusEvent = false;
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
const handleBlur = (evt) => {
|
|
138
|
+
setTimeout(() => {
|
|
139
|
+
var _a;
|
|
140
|
+
if ((_a = popperRef.value) == null ? void 0 : _a.isFocusInsideContent()) {
|
|
141
|
+
ignoreFocusEvent = true;
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
activated.value && close();
|
|
145
|
+
emit("blur", evt);
|
|
146
|
+
});
|
|
147
|
+
};
|
|
148
|
+
const handleClear = () => {
|
|
149
|
+
activated.value = false;
|
|
150
|
+
emit(event.UPDATE_MODEL_EVENT, "");
|
|
151
|
+
emit("clear");
|
|
152
|
+
};
|
|
153
|
+
const handleKeyEnter = async () => {
|
|
154
|
+
if (suggestionVisible.value && highlightedIndex.value >= 0 && highlightedIndex.value < suggestions.value.length) {
|
|
155
|
+
handleSelect(suggestions.value[highlightedIndex.value]);
|
|
156
|
+
} else if (props.selectWhenUnmatched) {
|
|
157
|
+
emit("select", { value: props.modelValue });
|
|
158
|
+
suggestions.value = [];
|
|
159
|
+
highlightedIndex.value = -1;
|
|
160
|
+
}
|
|
161
|
+
};
|
|
162
|
+
const handleKeyEscape = (evt) => {
|
|
163
|
+
if (suggestionVisible.value) {
|
|
164
|
+
evt.preventDefault();
|
|
165
|
+
evt.stopPropagation();
|
|
166
|
+
close();
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
const close = () => {
|
|
170
|
+
activated.value = false;
|
|
171
|
+
};
|
|
172
|
+
const focus = () => {
|
|
173
|
+
var _a;
|
|
174
|
+
(_a = inputRef.value) == null ? void 0 : _a.focus();
|
|
175
|
+
};
|
|
176
|
+
const blur = () => {
|
|
177
|
+
var _a;
|
|
178
|
+
(_a = inputRef.value) == null ? void 0 : _a.blur();
|
|
179
|
+
};
|
|
180
|
+
const handleSelect = async (item) => {
|
|
181
|
+
emit(event.INPUT_EVENT, item[props.valueKey]);
|
|
182
|
+
emit(event.UPDATE_MODEL_EVENT, item[props.valueKey]);
|
|
183
|
+
emit("select", item);
|
|
184
|
+
suggestions.value = [];
|
|
185
|
+
highlightedIndex.value = -1;
|
|
186
|
+
};
|
|
187
|
+
const highlight = (index) => {
|
|
188
|
+
if (!suggestionVisible.value || loading.value)
|
|
189
|
+
return;
|
|
190
|
+
if (index < 0) {
|
|
191
|
+
highlightedIndex.value = -1;
|
|
192
|
+
return;
|
|
193
|
+
}
|
|
194
|
+
if (index >= suggestions.value.length) {
|
|
195
|
+
index = suggestions.value.length - 1;
|
|
196
|
+
}
|
|
197
|
+
const suggestion = regionRef.value.querySelector(`.${ns.be("suggestion", "wrap")}`);
|
|
198
|
+
const suggestionList = suggestion.querySelectorAll(`.${ns.be("suggestion", "list")} li`);
|
|
199
|
+
const highlightItem = suggestionList[index];
|
|
200
|
+
const scrollTop = suggestion.scrollTop;
|
|
201
|
+
const { offsetTop, scrollHeight } = highlightItem;
|
|
202
|
+
if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {
|
|
203
|
+
suggestion.scrollTop += scrollHeight;
|
|
204
|
+
}
|
|
205
|
+
if (offsetTop < scrollTop) {
|
|
206
|
+
suggestion.scrollTop -= scrollHeight;
|
|
207
|
+
}
|
|
208
|
+
highlightedIndex.value = index;
|
|
209
|
+
inputRef.value.ref.setAttribute("aria-activedescendant", `${listboxId.value}-item-${highlightedIndex.value}`);
|
|
210
|
+
};
|
|
211
|
+
core.onClickOutside(listboxRef, () => {
|
|
212
|
+
suggestionVisible.value && close();
|
|
213
|
+
});
|
|
214
|
+
vue.onMounted(() => {
|
|
215
|
+
;
|
|
216
|
+
inputRef.value.ref.setAttribute("role", "textbox");
|
|
217
|
+
inputRef.value.ref.setAttribute("aria-autocomplete", "list");
|
|
218
|
+
inputRef.value.ref.setAttribute("aria-controls", "id");
|
|
219
|
+
inputRef.value.ref.setAttribute("aria-activedescendant", `${listboxId.value}-item-${highlightedIndex.value}`);
|
|
220
|
+
readonly = inputRef.value.ref.hasAttribute("readonly");
|
|
221
|
+
});
|
|
222
|
+
expose({
|
|
223
|
+
highlightedIndex,
|
|
224
|
+
activated,
|
|
225
|
+
loading,
|
|
226
|
+
inputRef,
|
|
227
|
+
popperRef,
|
|
228
|
+
suggestions,
|
|
229
|
+
handleSelect,
|
|
230
|
+
handleKeyEnter,
|
|
231
|
+
focus,
|
|
232
|
+
blur,
|
|
233
|
+
close,
|
|
234
|
+
highlight
|
|
235
|
+
});
|
|
236
|
+
return (_ctx, _cache) => {
|
|
237
|
+
return vue.openBlock(), vue.createBlock(vue.unref(index$3.ElTooltip), {
|
|
238
|
+
ref_key: "popperRef",
|
|
239
|
+
ref: popperRef,
|
|
240
|
+
visible: vue.unref(suggestionVisible),
|
|
241
|
+
placement: _ctx.placement,
|
|
242
|
+
"fallback-placements": ["bottom-start", "top-start"],
|
|
243
|
+
"popper-class": [vue.unref(ns).e("popper"), _ctx.popperClass],
|
|
244
|
+
teleported: _ctx.teleported,
|
|
245
|
+
"gpu-acceleration": false,
|
|
246
|
+
pure: "",
|
|
247
|
+
"manual-mode": "",
|
|
248
|
+
effect: "light",
|
|
249
|
+
trigger: "click",
|
|
250
|
+
transition: `${vue.unref(ns).namespace.value}-zoom-in-top`,
|
|
251
|
+
persistent: "",
|
|
252
|
+
role: "listbox",
|
|
253
|
+
onBeforeShow: onSuggestionShow,
|
|
254
|
+
onHide
|
|
255
|
+
}, {
|
|
256
|
+
content: vue.withCtx(() => [
|
|
257
|
+
vue.createElementVNode("div", {
|
|
258
|
+
ref_key: "regionRef",
|
|
259
|
+
ref: regionRef,
|
|
260
|
+
class: vue.normalizeClass([vue.unref(ns).b("suggestion"), vue.unref(ns).is("loading", vue.unref(suggestionLoading))]),
|
|
261
|
+
style: vue.normalizeStyle({
|
|
262
|
+
[_ctx.fitInputWidth ? "width" : "minWidth"]: dropdownWidth.value,
|
|
263
|
+
outline: "none"
|
|
264
|
+
}),
|
|
265
|
+
role: "region"
|
|
266
|
+
}, [
|
|
267
|
+
vue.createVNode(vue.unref(index$4.ElScrollbar), {
|
|
268
|
+
id: vue.unref(listboxId),
|
|
269
|
+
tag: "ul",
|
|
270
|
+
"wrap-class": vue.unref(ns).be("suggestion", "wrap"),
|
|
271
|
+
"view-class": vue.unref(ns).be("suggestion", "list"),
|
|
272
|
+
role: "listbox"
|
|
273
|
+
}, {
|
|
274
|
+
default: vue.withCtx(() => [
|
|
275
|
+
vue.unref(suggestionLoading) ? (vue.openBlock(), vue.createElementBlock("li", _hoisted_2, [
|
|
276
|
+
vue.renderSlot(_ctx.$slots, "loading", {}, () => [
|
|
277
|
+
vue.createVNode(vue.unref(index$5.ElIcon), {
|
|
278
|
+
class: vue.normalizeClass(vue.unref(ns).is("loading"))
|
|
279
|
+
}, {
|
|
280
|
+
default: vue.withCtx(() => [
|
|
281
|
+
vue.createVNode(vue.unref(iconsVue.Loading))
|
|
282
|
+
]),
|
|
283
|
+
_: 1
|
|
284
|
+
}, 8, ["class"])
|
|
285
|
+
])
|
|
286
|
+
])) : (vue.openBlock(true), vue.createElementBlock(vue.Fragment, { key: 1 }, vue.renderList(suggestions.value, (item, index) => {
|
|
287
|
+
return vue.openBlock(), vue.createElementBlock("li", {
|
|
288
|
+
id: `${vue.unref(listboxId)}-item-${index}`,
|
|
289
|
+
key: index,
|
|
290
|
+
class: vue.normalizeClass({ highlighted: highlightedIndex.value === index }),
|
|
291
|
+
role: "option",
|
|
292
|
+
"aria-selected": highlightedIndex.value === index,
|
|
293
|
+
onClick: ($event) => handleSelect(item)
|
|
294
|
+
}, [
|
|
295
|
+
vue.renderSlot(_ctx.$slots, "default", { item }, () => [
|
|
296
|
+
vue.createTextVNode(vue.toDisplayString(item[_ctx.valueKey]), 1)
|
|
297
|
+
])
|
|
298
|
+
], 10, _hoisted_3);
|
|
299
|
+
}), 128))
|
|
300
|
+
]),
|
|
301
|
+
_: 3
|
|
302
|
+
}, 8, ["id", "wrap-class", "view-class"])
|
|
303
|
+
], 6)
|
|
304
|
+
]),
|
|
305
|
+
default: vue.withCtx(() => [
|
|
306
|
+
vue.createElementVNode("div", {
|
|
307
|
+
ref_key: "listboxRef",
|
|
308
|
+
ref: listboxRef,
|
|
309
|
+
class: vue.normalizeClass([vue.unref(ns).b(), _ctx.$attrs.class]),
|
|
310
|
+
style: vue.normalizeStyle(vue.unref(styles)),
|
|
311
|
+
role: "combobox",
|
|
312
|
+
"aria-haspopup": "listbox",
|
|
313
|
+
"aria-expanded": vue.unref(suggestionVisible),
|
|
314
|
+
"aria-owns": vue.unref(listboxId)
|
|
315
|
+
}, [
|
|
316
|
+
vue.createVNode(vue.unref(index$6.ElInput), vue.mergeProps({
|
|
317
|
+
ref_key: "inputRef",
|
|
318
|
+
ref: inputRef
|
|
319
|
+
}, vue.unref(attrs), {
|
|
320
|
+
clearable: _ctx.clearable,
|
|
321
|
+
disabled: vue.unref(disabled),
|
|
322
|
+
name: _ctx.name,
|
|
323
|
+
"model-value": _ctx.modelValue,
|
|
324
|
+
"aria-label": _ctx.ariaLabel,
|
|
325
|
+
onInput: handleInput,
|
|
326
|
+
onChange: handleChange,
|
|
327
|
+
onFocus: handleFocus,
|
|
328
|
+
onBlur: handleBlur,
|
|
329
|
+
onClear: handleClear,
|
|
330
|
+
onKeydown: [
|
|
331
|
+
_cache[0] || (_cache[0] = vue.withKeys(vue.withModifiers(($event) => highlight(highlightedIndex.value - 1), ["prevent"]), ["up"])),
|
|
332
|
+
_cache[1] || (_cache[1] = vue.withKeys(vue.withModifiers(($event) => highlight(highlightedIndex.value + 1), ["prevent"]), ["down"])),
|
|
333
|
+
vue.withKeys(handleKeyEnter, ["enter"]),
|
|
334
|
+
vue.withKeys(close, ["tab"]),
|
|
335
|
+
vue.withKeys(handleKeyEscape, ["esc"])
|
|
336
|
+
],
|
|
337
|
+
onMousedown: handleMouseDown
|
|
338
|
+
}), vue.createSlots({ _: 2 }, [
|
|
339
|
+
_ctx.$slots.prepend ? {
|
|
340
|
+
name: "prepend",
|
|
341
|
+
fn: vue.withCtx(() => [
|
|
342
|
+
vue.renderSlot(_ctx.$slots, "prepend")
|
|
343
|
+
])
|
|
344
|
+
} : void 0,
|
|
345
|
+
_ctx.$slots.append ? {
|
|
346
|
+
name: "append",
|
|
347
|
+
fn: vue.withCtx(() => [
|
|
348
|
+
vue.renderSlot(_ctx.$slots, "append")
|
|
349
|
+
])
|
|
350
|
+
} : void 0,
|
|
351
|
+
_ctx.$slots.prefix ? {
|
|
352
|
+
name: "prefix",
|
|
353
|
+
fn: vue.withCtx(() => [
|
|
354
|
+
vue.renderSlot(_ctx.$slots, "prefix")
|
|
355
|
+
])
|
|
356
|
+
} : void 0,
|
|
357
|
+
_ctx.$slots.suffix ? {
|
|
358
|
+
name: "suffix",
|
|
359
|
+
fn: vue.withCtx(() => [
|
|
360
|
+
vue.renderSlot(_ctx.$slots, "suffix")
|
|
361
|
+
])
|
|
362
|
+
} : void 0
|
|
363
|
+
]), 1040, ["clearable", "disabled", "name", "model-value", "aria-label", "onKeydown"])
|
|
364
|
+
], 14, _hoisted_1)
|
|
365
|
+
]),
|
|
366
|
+
_: 3
|
|
367
|
+
}, 8, ["visible", "placement", "popper-class", "teleported", "transition"]);
|
|
368
|
+
};
|
|
369
|
+
}
|
|
79
370
|
});
|
|
80
|
-
|
|
81
|
-
[event.UPDATE_MODEL_EVENT]: (value) => shared.isString(value),
|
|
82
|
-
[event.INPUT_EVENT]: (value) => shared.isString(value),
|
|
83
|
-
[event.CHANGE_EVENT]: (value) => shared.isString(value),
|
|
84
|
-
focus: (evt) => evt instanceof FocusEvent,
|
|
85
|
-
blur: (evt) => evt instanceof FocusEvent,
|
|
86
|
-
clear: () => true,
|
|
87
|
-
select: (item) => shared.isObject(item)
|
|
88
|
-
};
|
|
371
|
+
var Autocomplete = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "autocomplete.vue"]]);
|
|
89
372
|
|
|
90
|
-
exports
|
|
91
|
-
exports.autocompleteProps = autocompleteProps;
|
|
373
|
+
exports["default"] = Autocomplete;
|
|
92
374
|
//# sourceMappingURL=autocomplete2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"autocomplete2.js","sources":["../../../../../../packages/components/autocomplete/src/autocomplete.ts"],"sourcesContent":["import { NOOP } from '@vue/shared'\nimport {\n buildProps,\n definePropType,\n isObject,\n isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { useAriaProps } from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\n\nexport type AutocompleteData = Record<string, any>[]\nexport type AutocompleteFetchSuggestionsCallback = (\n data: AutocompleteData\n) => void\nexport type AutocompleteFetchSuggestions =\n | ((\n queryString: string,\n cb: AutocompleteFetchSuggestionsCallback\n ) => Awaitable<AutocompleteData> | void)\n | AutocompleteData\n\nexport const autocompleteProps = buildProps({\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey: {\n type: String,\n default: 'value',\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description placement of the popup menu\n */\n placement: {\n type: definePropType<Placement>(String),\n values: [\n 'top',\n 'top-start',\n 'top-end',\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n ],\n default: 'bottom-start',\n },\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions: {\n type: definePropType<AutocompleteFetchSuggestions>([Function, Array]),\n default: NOOP,\n },\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass: {\n type: String,\n default: '',\n },\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading: {\n type: Boolean,\n default: false,\n },\n teleported: useTooltipContentProps.teleported,\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to show clear button\n */\n clearable: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to disable\n */\n disabled: {\n type: Boolean,\n default: false,\n },\n /**\n * @description same as `name` in native input\n */\n name: String,\n ...useAriaProps(['ariaLabel']),\n} as const)\nexport type AutocompleteProps = ExtractPropTypes<typeof autocompleteProps>\n\nexport const autocompleteEmits = {\n [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n [INPUT_EVENT]: (value: string) => isString(value),\n [CHANGE_EVENT]: (value: string) => isString(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n select: (item: Record<string, any>) => isObject(item),\n}\nexport type AutocompleteEmits = typeof autocompleteEmits\n\nexport type AutocompleteInstance = InstanceType<typeof Autocomplete>\n"],"names":["buildProps","definePropType","NOOP","useTooltipContentProps","useAriaProps","UPDATE_MODEL_EVENT","isString","INPUT_EVENT","CHANGE_EVENT","isObject"],"mappings":";;;;;;;;;;;;;;AAcY,MAAC,iBAAiB,GAAGA,kBAAU,CAAC;AAC5C,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEC,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,MAAM,EAAE;AACZ,MAAM,KAAK;AACX,MAAM,WAAW;AACjB,MAAM,SAAS;AACf,MAAM,QAAQ;AACd,MAAM,cAAc;AACpB,MAAM,YAAY;AAClB,KAAK;AACL,IAAI,OAAO,EAAE,cAAc;AAC3B,GAAG;AACH,EAAE,gBAAgB,EAAE;AACpB,IAAI,IAAI,EAAEA,sBAAc,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC3C,IAAI,OAAO,EAAEC,WAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,cAAc,EAAE;AAClB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,mBAAmB,EAAE;AACvB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,UAAU,EAAEC,8BAAsB,CAAC,UAAU;AAC/C,EAAE,kBAAkB,EAAE;AACtB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,IAAI,EAAE,MAAM;AACd,EAAE,GAAGC,kBAAY,CAAC,CAAC,WAAW,CAAC,CAAC;AAChC,CAAC,EAAE;AACS,MAAC,iBAAiB,GAAG;AACjC,EAAE,CAACC,wBAAkB,GAAG,CAAC,KAAK,KAAKC,eAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,CAACC,iBAAW,GAAG,CAAC,KAAK,KAAKD,eAAQ,CAAC,KAAK,CAAC;AAC3C,EAAE,CAACE,kBAAY,GAAG,CAAC,KAAK,KAAKF,eAAQ,CAAC,KAAK,CAAC;AAC5C,EAAE,KAAK,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC3C,EAAE,IAAI,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC1C,EAAE,KAAK,EAAE,MAAM,IAAI;AACnB,EAAE,MAAM,EAAE,CAAC,IAAI,KAAKG,eAAQ,CAAC,IAAI,CAAC;AAClC;;;;;"}
|
|
1
|
+
{"version":3,"file":"autocomplete2.js","sources":["../../../../../../packages/components/autocomplete/src/autocomplete.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"popperRef\"\n :visible=\"suggestionVisible\"\n :placement=\"placement\"\n :fallback-placements=\"['bottom-start', 'top-start']\"\n :popper-class=\"[ns.e('popper'), popperClass]\"\n :teleported=\"teleported\"\n :gpu-acceleration=\"false\"\n pure\n manual-mode\n effect=\"light\"\n trigger=\"click\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n persistent\n role=\"listbox\"\n @before-show=\"onSuggestionShow\"\n @hide=\"onHide\"\n >\n <div\n ref=\"listboxRef\"\n :class=\"[ns.b(), $attrs.class]\"\n :style=\"styles\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n :aria-expanded=\"suggestionVisible\"\n :aria-owns=\"listboxId\"\n >\n <el-input\n ref=\"inputRef\"\n v-bind=\"attrs\"\n :clearable=\"clearable\"\n :disabled=\"disabled\"\n :name=\"name\"\n :model-value=\"modelValue\"\n :aria-label=\"ariaLabel\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown.up.prevent=\"highlight(highlightedIndex - 1)\"\n @keydown.down.prevent=\"highlight(highlightedIndex + 1)\"\n @keydown.enter=\"handleKeyEnter\"\n @keydown.tab=\"close\"\n @keydown.esc=\"handleKeyEscape\"\n @mousedown=\"handleMouseDown\"\n >\n <template v-if=\"$slots.prepend\" #prepend>\n <slot name=\"prepend\" />\n </template>\n <template v-if=\"$slots.append\" #append>\n <slot name=\"append\" />\n </template>\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template v-if=\"$slots.suffix\" #suffix>\n <slot name=\"suffix\" />\n </template>\n </el-input>\n </div>\n <template #content>\n <div\n ref=\"regionRef\"\n :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n :style=\"{\n [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n outline: 'none',\n }\"\n role=\"region\"\n >\n <el-scrollbar\n :id=\"listboxId\"\n tag=\"ul\"\n :wrap-class=\"ns.be('suggestion', 'wrap')\"\n :view-class=\"ns.be('suggestion', 'list')\"\n role=\"listbox\"\n >\n <li v-if=\"suggestionLoading\">\n <slot name=\"loading\">\n <el-icon :class=\"ns.is('loading')\">\n <Loading />\n </el-icon>\n </slot>\n </li>\n <template v-else>\n <li\n v-for=\"(item, index) in suggestions\"\n :id=\"`${listboxId}-item-${index}`\"\n :key=\"index\"\n :class=\"{ highlighted: highlightedIndex === index }\"\n role=\"option\"\n :aria-selected=\"highlightedIndex === index\"\n @click=\"handleSelect(item)\"\n >\n <slot :item=\"item\">{{ item[valueKey] }}</slot>\n </li>\n </template>\n </el-scrollbar>\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, useAttrs as useRawAttrs } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { onClickOutside } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useAttrs, useId, useNamespace } from '@element-plus/hooks'\nimport { isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits, autocompleteProps } from './autocomplete'\nimport type { AutocompleteData } from './autocomplete'\n\nimport type { StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n name: COMPONENT_NAME,\n inheritAttrs: false,\n})\n\nconst props = defineProps(autocompleteProps)\nconst emit = defineEmits(autocompleteEmits)\n\nconst attrs = useAttrs()\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref<AutocompleteData>([])\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n const isValidData = suggestions.value.length > 0\n return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n if (inputRef.value) {\n return Array.from<HTMLInputElement>(\n inputRef.value.$el.querySelectorAll('input')\n )\n }\n return []\n})\n\nconst onSuggestionShow = () => {\n if (suggestionVisible.value) {\n dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n }\n}\n\nconst onHide = () => {\n highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n if (suggestionDisabled.value) return\n\n const cb = (suggestionList: AutocompleteData) => {\n loading.value = false\n if (suggestionDisabled.value) return\n\n if (isArray(suggestionList)) {\n suggestions.value = suggestionList\n highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n } else {\n throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n }\n }\n\n loading.value = true\n if (isArray(props.fetchSuggestions)) {\n cb(props.fetchSuggestions)\n } else {\n const result = await props.fetchSuggestions(queryString, cb)\n if (isArray(result)) cb(result)\n }\n}\nconst debouncedGetData = debounce(getData, props.debounce)\n\nconst handleInput = (value: string) => {\n const valuePresented = !!value\n\n emit(INPUT_EVENT, value)\n emit(UPDATE_MODEL_EVENT, value)\n\n suggestionDisabled.value = false\n activated.value ||= valuePresented\n\n if (!props.triggerOnFocus && !value) {\n suggestionDisabled.value = true\n suggestions.value = []\n return\n }\n\n debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n if (disabled.value) return\n if (\n (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n refInput.value.includes(document.activeElement as HTMLInputElement)\n ) {\n activated.value = true\n }\n}\n\nconst handleChange = (value: string) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(props.modelValue))\n }\n } else {\n ignoreFocusEvent = false\n }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n setTimeout(() => {\n // validate current focus event is inside el-tooltip-content\n // if so, ignore the blur event and the next focus event\n if (popperRef.value?.isFocusInsideContent()) {\n ignoreFocusEvent = true\n return\n }\n activated.value && close()\n emit('blur', evt)\n })\n}\n\nconst handleClear = () => {\n activated.value = false\n emit(UPDATE_MODEL_EVENT, '')\n emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n if (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\n }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n if (suggestionVisible.value) {\n evt.preventDefault()\n evt.stopPropagation()\n close()\n }\n}\n\nconst close = () => {\n activated.value = false\n}\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: any) => {\n emit(INPUT_EVENT, item[props.valueKey])\n emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n emit('select', item)\n suggestions.value = []\n highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n if (!suggestionVisible.value || loading.value) return\n\n if (index < 0) {\n highlightedIndex.value = -1\n return\n }\n\n if (index >= suggestions.value.length) {\n index = suggestions.value.length - 1\n }\n const suggestion = regionRef.value!.querySelector(\n `.${ns.be('suggestion', 'wrap')}`\n )!\n const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n `.${ns.be('suggestion', 'list')} li`\n )!\n const highlightItem = suggestionList[index]\n const scrollTop = suggestion.scrollTop\n const { offsetTop, scrollHeight } = highlightItem\n\n if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n suggestion.scrollTop += scrollHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop -= scrollHeight\n }\n highlightedIndex.value = index\n // TODO: use Volar generate dts to fix it.\n ;(inputRef.value as any).ref!.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\n\nonClickOutside(listboxRef, () => {\n suggestionVisible.value && close()\n})\n\nonMounted(() => {\n // TODO: use Volar generate dts to fix it.\n ;(inputRef.value as any).ref!.setAttribute('role', 'textbox')\n ;(inputRef.value as any).ref!.setAttribute('aria-autocomplete', 'list')\n ;(inputRef.value as any).ref!.setAttribute('aria-controls', 'id')\n ;(inputRef.value as any).ref!.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n // get readonly attr\n readonly = (inputRef.value as any).ref!.hasAttribute('readonly')\n})\n\ndefineExpose({\n /** @description the index of the currently highlighted item */\n highlightedIndex,\n /** @description autocomplete whether activated */\n activated,\n /** @description remote search loading status */\n loading,\n /** @description el-input component instance */\n inputRef,\n /** @description el-tooltip component instance */\n popperRef,\n /** @description fetch suggestions result */\n suggestions,\n /** @description triggers when a suggestion is clicked */\n handleSelect,\n /** @description handle keyboard enter event */\n handleKeyEnter,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n /** @description close suggestion */\n close,\n /** @description highlight an item in a suggestion */\n highlight,\n})\n</script>\n"],"names":["useAttrs","useRawAttrs","useFormDisabled","useNamespace","ref","useId","computed","isArray","throwError","debounce","INPUT_EVENT","UPDATE_MODEL_EVENT","CHANGE_EVENT","onClickOutside","onMounted"],"mappings":"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"}
|
package/lib/components/index.js
CHANGED
|
@@ -85,7 +85,7 @@ var index$1e = require('./notification/index.js');
|
|
|
85
85
|
var index$1f = require('./popover/index.js');
|
|
86
86
|
var affix = require('./affix/src/affix.js');
|
|
87
87
|
var alert = require('./alert/src/alert.js');
|
|
88
|
-
var autocomplete = require('./autocomplete/src/
|
|
88
|
+
var autocomplete = require('./autocomplete/src/autocomplete.js');
|
|
89
89
|
var avatar = require('./avatar/src/avatar.js');
|
|
90
90
|
var backtop = require('./backtop/src/backtop.js');
|
|
91
91
|
var badge = require('./badge/src/badge.js');
|