UNPKG

element-plus

Version:

A Component Library for Vue3.0

65 lines (55 loc) 1.94 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var vue = require('vue'); const selectGroupKey = 'ElSelectGroup'; const selectKey = 'ElSelect'; const selectEvents = { queryChange: 'elOptionQueryChange', groupQueryChange: 'elOptionGroupQueryChange', }; var script = vue.defineComponent({ name: 'ElOptionGroup', componentName: 'ElOptionGroup', props: { label: String, disabled: { type: Boolean, default: false, }, }, setup(props) { const visible = vue.ref(true); vue.provide(selectGroupKey, vue.reactive(Object.assign({}, vue.toRefs(props)))); const select = vue.inject(selectKey); const queryChange = () => { var _a; visible.value = (_a = select === null || select === void 0 ? void 0 : select.options) === null || _a === void 0 ? void 0 : _a.some(option => option.visible === true); }; select.selectEmitter.on(selectEvents.groupQueryChange, queryChange); return { visible, }; }, }); const _hoisted_1 = { class: "el-select-group__wrap" }; const _hoisted_2 = { class: "el-select-group__title" }; const _hoisted_3 = { class: "el-select-group" }; function render(_ctx, _cache, $props, $setup, $data, $options) { return vue.withDirectives((vue.openBlock(), vue.createBlock("ul", _hoisted_1, [ vue.createVNode("li", _hoisted_2, vue.toDisplayString(_ctx.label), 1 /* TEXT */), vue.createVNode("li", null, [ vue.createVNode("ul", _hoisted_3, [ vue.renderSlot(_ctx.$slots, "default") ]) ]) ], 512 /* NEED_PATCH */)), [ [vue.vShow, _ctx.visible] ]) } script.render = render; script.__file = "packages/select/src/option-group.vue"; script.install = (app) => { app.component(script.name, script); }; const _OptionGroup = script; exports.default = _OptionGroup;