import { createNamespace } from '../utils'; import { BLUE } from '../utils/color'; import { ParentMixin } from '../mixins/relation'; import { ClickOutsideMixin } from '../mixins/click-outside'; const [createComponent, bem] = createNamespace('dropdown-menu'); export default createComponent({ mixins: [ ParentMixin('vanDropdownMenu'), ClickOutsideMixin({ event: 'click', method: 'onClickOutside' }) ], props: { overlay: { type: Boolean, default: true }, zIndex: { type: Number, default: 10 }, duration: { type: Number, default: 0.2 }, direction: { type: String, default: 'down' }, activeColor: { type: String, default: BLUE }, closeOnClickOverlay: { type: Boolean, default: true } }, data() { return { offset: 0 }; }, methods: { updateOffset() { const { menu } = this.$refs; const rect = menu.getBoundingClientRect(); if (this.direction === 'down') { this.offset = rect.bottom; } else { this.offset = window.innerHeight - rect.top; } }, toggleItem(active) { this.children.forEach((item, index) => { if (index === active) { item.toggle(); } else if (item.showPopup) { item.toggle(false, { immediate: true }); } }); }, onClickOutside() { this.children.forEach(item => { item.toggle(false); }); } }, render() { const Titles = this.children.map((item, index) => (
{ if (!item.disabled) { this.toggleItem(index); } }} >
{item.displayTitle}
)); return (
{Titles} {this.slots('default')}
); } });