63 lines
2.4 KiB
JavaScript
63 lines
2.4 KiB
JavaScript
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"]))
|
|
}, [
|
|
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
|