import { ItemMenu, ItemsMenu, Menu } from '~/types/interfaces' import BaseMenu from '~/composables/layout/Menus/baseMenu' import {useAbility} from "@casl/vue"; /** * @category composables/layout/Menus * @class CommunicationMenu * Classe pour la construction du Menu Communication */ class CommunicationMenu extends BaseMenu implements Menu { /** * @constructor * Initialisation des services issues du context */ constructor () { const {$config} = useNuxtApp() super($config) } /** * Construit le menu Communication ou null si aucune page accessible * @return {ItemMenu | null} */ getMenu (): ItemMenu | null { const {can} = useAbility() const children: ItemsMenu = [] if (can('display', 'inbox_page')) { children.push(this.constructMenu('inbox', {name: 'fa-inbox'}, '/messages/list/', true)) } if (can('display', 'message_send_page')) { children.push(this.constructMenu('message_send', {name: 'fa-paper-plane'}, '/messagessends/list/', true)) } if (can('display', 'message_templates_page')) { children.push(this.constructMenu('message_templates', {name: 'fa-edit'}, '/templates/list/', true)) } if (children.length === 1) { return children[0] } else if (children.length > 0) { return this.constructMenu('communication', {name: 'fa-comments'}, undefined, undefined, children) } else { return null } } } export const getCommunicationMenu = () => new CommunicationMenu().getMenu()