communicationMenuBuilder.ts 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import AbstractMenuBuilder from '~/services/menuBuilder/abstractMenuBuilder'
  2. import {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. name() {
  9. return 'Communication'
  10. }
  11. /**
  12. * Construit le menu Communication ou null si aucune page accessible
  13. */
  14. build (): MenuItem | MenuGroup | null {
  15. const children: MenuItems = []
  16. if (this.ability.can('display', 'inbox_page')) {
  17. children.push(this.createItem('inbox', {name: 'fas fa-inbox'}, '/messages/list/', MENU_LINK_TYPE.V1))
  18. }
  19. if (this.ability.can('display', 'message_send_page')) {
  20. children.push(this.createItem('message_send', {name: 'fas fa-paper-plane'}, '/messagessends/list/', MENU_LINK_TYPE.V1))
  21. }
  22. if (this.ability.can('display', 'message_templates_page')) {
  23. children.push(this.createItem('message_templates', {name: 'fas fa-edit'}, '/templates/list/', MENU_LINK_TYPE.V1))
  24. }
  25. if (children.length > 1) {
  26. // Plusieurs éléments, on retourne un groupe
  27. return this.createGroup('communication', {name: 'fas fa-comments'}, children)
  28. }
  29. else if (children.length === 1) {
  30. // Un seul élément, on retourne cet élément seul
  31. return children[0]
  32. }
  33. return null
  34. }
  35. }