UNPKG

vxe-table-select-area

Version:

一个基于 vxe-table 的可区域选中复制、粘贴的组件

101 lines (99 loc) 3.4 kB
import { getFuncText } from '../../tools/utils' export default { name: 'VxeTableContextMenu', props: { ctxMenuStore: Object, ctxMenuOpts: Object }, mounted () { document.body.appendChild(this.$el) }, beforeDestroy () { const { $el } = this if ($el.parentNode) { $el.parentNode.removeChild($el) } }, render (h) { const $xetable = this.$parent const { _e, ctxMenuOpts, ctxMenuStore } = this return h('div', { class: ['vxe-table--context-menu-wrapper', ctxMenuOpts.className], style: ctxMenuStore.style }, ctxMenuStore.list.map((options, gIndex) => { return options.every(item => item.visible === false) ? _e() : h('ul', { class: 'vxe-context-menu--option-wrapper', key: gIndex }, options.map((item, index) => { const hasChildMenus = item.children && item.children.some((child) => child.visible !== false) return item.visible === false ? null : h('li', { class: [item.className, { 'link--disabled': item.disabled, 'link--active': item === ctxMenuStore.selected }], key: `${gIndex}_${index}` }, [ h('a', { class: 'vxe-context-menu--link', on: { click (evnt) { $xetable.ctxMenuLinkEvent(evnt, item) }, mouseover (evnt) { $xetable.ctxMenuMouseoverEvent(evnt, item) }, mouseout (evnt) { $xetable.ctxMenuMouseoutEvent(evnt, item) } } }, [ h('i', { class: ['vxe-context-menu--link-prefix', item.prefixIcon] }), h('span', { class: 'vxe-context-menu--link-content' }, getFuncText(item.name)), h('i', { class: ['vxe-context-menu--link-suffix', hasChildMenus ? item.suffixIcon || 'suffix--haschild' : item.suffixIcon] }) ]), hasChildMenus ? h('ul', { class: ['vxe-table--context-menu-clild-wrapper', { 'is--show': item === ctxMenuStore.selected && ctxMenuStore.showChild }] }, item.children.map((child, cIndex) => { return child.visible === false ? null : h('li', { class: [child.className, { 'link--disabled': child.disabled, 'link--active': child === ctxMenuStore.selectChild }], key: `${gIndex}_${index}_${cIndex}` }, [ h('a', { class: 'vxe-context-menu--link', on: { click (evnt) { $xetable.ctxMenuLinkEvent(evnt, child) }, mouseover (evnt) { $xetable.ctxMenuMouseoverEvent(evnt, item, child) }, mouseout (evnt) { $xetable.ctxMenuMouseoutEvent(evnt, item, child) } } }, [ h('i', { class: ['vxe-context-menu--link-prefix', child.prefixIcon] }), h('span', { class: 'vxe-context-menu--link-content' }, getFuncText(child.name)) ]) ]) })) : null ]) })) })) } }