12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- <!-- Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { TicketState } from '#shared/entities/ticket/types.ts'
- import { replaceTags } from '#shared/utils/formatter.ts'
- import CommonSectionMenu from '../CommonSectionMenu/CommonSectionMenu.vue'
- import CommonSectionMenuLink from '../CommonSectionMenu/CommonSectionMenuLink.vue'
- interface Props {
- createLink?: string
- createLabel?: string
- counts: Record<TicketState.Closed | TicketState.Open, number>
- ticketsLinkQuery: string
- }
- const props = defineProps<Props>()
- const getTicketsLink = (stateIds: number[]) => {
- const states = stateIds
- .map((stateId) => `state.state_type_id: ${stateId}`)
- .join(' OR ')
- return replaceTags(`/search/ticket?search=(${states}) AND #{query}`, {
- query: props.ticketsLinkQuery,
- })
- }
- </script>
- <template>
- <CommonSectionMenu header-label="Tickets">
- <div class="px-3">
- <slot name="before-fields" />
- </div>
- <CommonSectionMenuLink
- :icon="{
- name: 'check-circle-no',
- size: 'base',
- class: 'text-yellow',
- decorative: true,
- }"
- :information="counts[TicketState.Open]"
- :link="getTicketsLink([1, 2, 3, 4])"
- >
- {{ $t('open') }}
- </CommonSectionMenuLink>
- <CommonSectionMenuLink
- :icon="{
- name: 'check-circle-no',
- size: 'base',
- class: 'text-green',
- decorative: true,
- }"
- :information="counts[TicketState.Closed]"
- :link="getTicketsLink([5])"
- >
- {{ $t('closed') }}
- </CommonSectionMenuLink>
- <CommonLink
- v-if="createLink && createLabel"
- class="text-blue flex min-h-[54px] items-center justify-center gap-2"
- :link="createLink"
- >
- <CommonIcon name="add" size="tiny" decorative />
- {{ $t(createLabel) }}
- </CommonLink>
- </CommonSectionMenu>
- </template>
|