UNPKG

element-plus

Version:

A Component Library for Vue 3

65 lines (62 loc) 2.5 kB
import { defineComponent, inject, openBlock, createElementBlock, normalizeStyle, normalizeClass, withModifiers, renderSlot, createElementVNode, toDisplayString } from 'vue'; import { useOption } from './useOption.mjs'; import { useProps } from './useProps.mjs'; import { optionV2Props, optionV2Emits } from './defaults.mjs'; import { selectV2InjectionKey } from './token.mjs'; import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs'; import { useNamespace } from '../../../hooks/use-namespace/index.mjs'; const _sfc_main = defineComponent({ props: optionV2Props, emits: optionV2Emits, setup(props, { emit }) { const select = inject(selectV2InjectionKey); const ns = useNamespace("select"); const { hoverItem, selectOptionClick } = useOption(props, { emit }); const { getLabel } = useProps(select.props); const contentId = select.contentId; return { ns, contentId, hoverItem, selectOptionClick, getLabel }; } }); const _hoisted_1 = ["id", "aria-selected", "aria-disabled"]; function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { return openBlock(), createElementBlock("li", { id: `${_ctx.contentId}-${_ctx.index}`, role: "option", "aria-selected": _ctx.selected, "aria-disabled": _ctx.disabled || void 0, style: normalizeStyle(_ctx.style), class: normalizeClass([ _ctx.ns.be("dropdown", "item"), _ctx.ns.is("selected", _ctx.selected), _ctx.ns.is("disabled", _ctx.disabled), _ctx.ns.is("created", _ctx.created), _ctx.ns.is("hovering", _ctx.hovering) ]), onMousemove: _cache[0] || (_cache[0] = (...args) => _ctx.hoverItem && _ctx.hoverItem(...args)), onClick: _cache[1] || (_cache[1] = withModifiers((...args) => _ctx.selectOptionClick && _ctx.selectOptionClick(...args), ["stop"])), onMousedown: _cache[2] || (_cache[2] = withModifiers(() => { }, ["prevent"])) }, [ renderSlot(_ctx.$slots, "default", { item: _ctx.item, index: _ctx.index, disabled: _ctx.disabled }, () => [ createElementVNode( "span", null, toDisplayString(_ctx.getLabel(_ctx.item)), 1 ) ]) ], 46, _hoisted_1); } var OptionItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/select-v2/src/option-item.vue"]]); export { OptionItem as default }; //# sourceMappingURL=option-item.mjs.map