NavigationMenuList.vue 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <!-- Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ -->
  2. <script setup lang="ts">
  3. import { computed } from 'vue'
  4. import type { BadgeVariant } from '#shared/components/CommonBadge/types.ts'
  5. import type { Sizes } from '#shared/components/CommonLabel/types.ts'
  6. import {
  7. NavigationMenuDensity,
  8. type NavigationMenuEntry,
  9. } from '#desktop/components/NavigationMenu/types.ts'
  10. interface Props {
  11. items: NavigationMenuEntry[]
  12. density?: NavigationMenuDensity
  13. countVariant?: BadgeVariant
  14. countSize?: Sizes
  15. }
  16. const props = withDefaults(defineProps<Props>(), {
  17. density: NavigationMenuDensity.Comfortable,
  18. countVariant: 'info',
  19. countSize: 'xs',
  20. })
  21. const paddingClasses = computed(() =>
  22. props.density === NavigationMenuDensity.Dense ? 'px-2 py-1' : 'px-2 py-3',
  23. )
  24. </script>
  25. <template>
  26. <nav class="flex p-0">
  27. <ul class="m-0 flex basis-full flex-col gap-1 p-0">
  28. <li v-for="entry in items" :key="entry.label">
  29. <CommonLink
  30. class="flex items-center gap-2 rounded-md text-sm text-gray-100 hover:bg-blue-600 hover:text-black hover:no-underline focus:outline-none focus-visible:outline-1 focus-visible:outline-offset-1 focus-visible:outline-blue-800 dark:text-neutral-400 dark:hover:bg-blue-900 dark:hover:text-white"
  31. :class="[paddingClasses]"
  32. exact-active-class="!bg-blue-800 w-full !text-white"
  33. internal
  34. :link="entry.route"
  35. >
  36. <template #default="{ isActive }">
  37. <slot v-bind="entry">
  38. <CommonLabel
  39. class="line-clamp-1 grow text-current"
  40. :prefix-icon="entry.icon"
  41. :icon-color="entry.iconColor"
  42. >
  43. {{ $t(entry.label) }}
  44. </CommonLabel>
  45. <CommonBadge
  46. v-if="entry.count !== undefined"
  47. class="font-bold leading-snug"
  48. :size="countSize"
  49. :variant="countVariant"
  50. :class="{
  51. '!bg-transparent !text-white': isActive,
  52. }"
  53. rounded
  54. >
  55. {{ entry.count }}
  56. </CommonBadge>
  57. </slot>
  58. </template>
  59. </CommonLink>
  60. </li>
  61. </ul>
  62. </nav>
  63. </template>