communicationMenuBuilder.ts 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. import AbstractMenuBuilder from '~/services/layout/menuBuilder/abstractMenuBuilder'
  2. import type {MenuGroup, MenuItem, MenuItems} from "~/types/layout";
  3. import {MENU_LINK_TYPE} from "~/types/enum/layout";
  4. /**
  5. * Menu Communication
  6. */
  7. export default class CommunicationMenuBuilder extends AbstractMenuBuilder {
  8. static readonly menuName = "Communication"
  9. /**
  10. * Construit le menu Communication ou null si aucune page accessible
  11. */
  12. build (): MenuItem | MenuGroup | null {
  13. const children: MenuItems = []
  14. if (this.ability.can('display', 'inbox_page')) {
  15. children.push(this.createItem('inbox', {name: 'fas fa-inbox'}, '/messages/list/', MENU_LINK_TYPE.V1))
  16. }
  17. if (this.ability.can('display', 'message_send_page')) {
  18. children.push(this.createItem('message_send', {name: 'fas fa-paper-plane'}, '/messagessends/list/', MENU_LINK_TYPE.V1))
  19. }
  20. if (this.ability.can('display', 'message_templates_page')) {
  21. children.push(this.createItem('message_templates', {name: 'fas fa-edit'}, '/templates/list/', MENU_LINK_TYPE.V1))
  22. }
  23. if (children.length > 1) {
  24. // Plusieurs éléments, on retourne un groupe
  25. return this.createGroup('communication', {name: 'fas fa-comments'}, children)
  26. }
  27. else if (children.length === 1) {
  28. // Un seul élément, on retourne cet élément seul
  29. return children[0]
  30. }
  31. return null
  32. }
  33. }