agendaMenu.ts 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import { ItemMenu, ItemsMenu, Menu } from '~/types/interfaces'
  2. import BaseMenu from '~/composables/layout/Menus/baseMenu'
  3. import {useAbility} from "@casl/vue";
  4. /**
  5. * @category composables/layout/Menus
  6. * @class AgendaMenu
  7. * Classe pour la construction du Menu agenda
  8. */
  9. class AgendaMenu extends BaseMenu implements Menu {
  10. /**
  11. * @constructor
  12. * Initialisation des services issues du context
  13. */
  14. constructor () {
  15. const {$config} = useNuxtApp()
  16. super($config)
  17. }
  18. /**
  19. * Construit le menu Agenda ou null si aucune page accessible
  20. * @return {ItemMenu | null}
  21. */
  22. getMenu (): ItemMenu | null {
  23. const {can} = useAbility()
  24. const children: ItemsMenu = []
  25. if (can('display', 'agenda_page')) {
  26. children.push(this.constructMenu('schedule', {name: 'fa-calendar-alt'}, '/calendar', true))
  27. }
  28. if (can('display', 'attendance_page')) {
  29. children.push(this.constructMenu('attendances', {name: 'fa-calendar-check'}, '/attendances/list/', true))
  30. }
  31. if (children.length === 1) {
  32. return children[0]
  33. }
  34. return children.length > 0 ? this.constructMenu('schedule', {name: 'fa-calendar-alt'}, undefined, undefined, children) : null
  35. }
  36. }
  37. export const getAgendaMenu = () => new AgendaMenu().getMenu()