// Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/ import { inject, computed, provide } from 'vue' import { useSessionStore } from '#shared/stores/session.ts' import type { ObjectLike } from '#shared/types/utils.ts' import type { MenuItem } from '#desktop/components/CommonPopoverMenu/types.ts' import type { ComputedRef, Ref } from 'vue' const POPOVER_MENU_SYMBOL = Symbol('popover-menu') interface UsePopoverMenuReturn { filteredMenuItems: ComputedRef singleMenuItemPresent: ComputedRef singleMenuItem: ComputedRef } export const usePopoverMenu = ( items: Ref, entity: Ref, options: { provides?: boolean } = {}, ) => { const injectPopoverMenu = inject>( POPOVER_MENU_SYMBOL, null, ) if (injectPopoverMenu) return injectPopoverMenu const { provides = false } = options const session = useSessionStore() const filterItems = () => { return items.value?.filter((item) => { if (item.permission && item.show) { return ( session.hasPermission(item.permission) && item.show(entity?.value) ) } if (item.permission) { return session.hasPermission(item.permission) } if (item.show) { return item.show(entity?.value) } return true }) } const filteredMenuItems = computed(() => { if (!items.value || !items.value.length) return return filterItems() }) const singleMenuItemPresent = computed(() => { return filteredMenuItems.value?.length === 1 }) const singleMenuItem = computed(() => { if (!singleMenuItemPresent.value) return return filterItems()?.at(0) }) const providePopoverMenu = { filteredMenuItems, singleMenuItemPresent, singleMenuItem, } if (provides) provide(POPOVER_MENU_SYMBOL, providePopoverMenu) return providePopoverMenu }