option-item.js 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var useOption = require('./useOption.js');
  5. var useProps = require('./useProps.js');
  6. var defaults = require('./defaults.js');
  7. var token = require('./token.js');
  8. var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
  9. var index = require('../../../hooks/use-namespace/index.js');
  10. const _sfc_main = vue.defineComponent({
  11. props: defaults.OptionProps,
  12. emits: defaults.optionEmits,
  13. setup(props, { emit }) {
  14. const select = vue.inject(token.selectV2InjectionKey);
  15. const ns = index.useNamespace("select");
  16. const { hoverItem, selectOptionClick } = useOption.useOption(props, { emit });
  17. const { getLabel } = useProps.useProps(select.props);
  18. return {
  19. ns,
  20. hoverItem,
  21. selectOptionClick,
  22. getLabel
  23. };
  24. }
  25. });
  26. function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
  27. return vue.openBlock(), vue.createElementBlock("li", {
  28. "aria-selected": _ctx.selected,
  29. style: vue.normalizeStyle(_ctx.style),
  30. class: vue.normalizeClass([
  31. _ctx.ns.be("dropdown", "item"),
  32. _ctx.ns.is("selected", _ctx.selected),
  33. _ctx.ns.is("disabled", _ctx.disabled),
  34. _ctx.ns.is("created", _ctx.created),
  35. _ctx.ns.is("hovering", _ctx.hovering)
  36. ]),
  37. onMousemove: _ctx.hoverItem,
  38. onClick: vue.withModifiers(_ctx.selectOptionClick, ["stop"])
  39. }, [
  40. vue.renderSlot(_ctx.$slots, "default", {
  41. item: _ctx.item,
  42. index: _ctx.index,
  43. disabled: _ctx.disabled
  44. }, () => [
  45. vue.createElementVNode("span", null, vue.toDisplayString(_ctx.getLabel(_ctx.item)), 1)
  46. ])
  47. ], 46, ["aria-selected", "onMousemove", "onClick"]);
  48. }
  49. var OptionItem = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["render", _sfc_render], ["__file", "option-item.vue"]]);
  50. exports["default"] = OptionItem;
  51. //# sourceMappingURL=option-item.js.map