123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- <!-- Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { computed } from 'vue'
- import { useCopyToClipboard } from '#shared/composables/useCopyToClipboard.ts'
- import { useTicketView } from '#shared/entities/ticket/composables/useTicketView.ts'
- import CommonBreadcrumb from '#desktop/components/CommonBreadcrumb/CommonBreadcrumb.vue'
- import HighlightMenu from '#desktop/pages/ticket/components/TicketDetailView/TicketDetailTopBar/TopBarHeader/HighlightMenu.vue'
- import TicketInformation from '#desktop/pages/ticket/components/TicketDetailView/TicketDetailTopBar/TopBarHeader/TicketInformation.vue'
- import { useTicketInformation } from '#desktop/pages/ticket/composables/useTicketInformation.ts'
- import { useTicketNumber } from '#desktop/pages/ticket/composables/useTicketNumber.ts'
- interface Props {
- hideDetails: boolean
- }
- const props = defineProps<Props>()
- const { ticket } = useTicketInformation()
- const { isTicketAgent, isTicketEditable } = useTicketView(ticket)
- const { copyToClipboard } = useCopyToClipboard()
- const { ticketNumber, ticketNumberWithTicketHook } = useTicketNumber(ticket)
- const items = computed(() => [
- // :TODO Adjust navigations currently two h1 are present
- {
- label: 'Tickets',
- to: { name: 'ticket-list' },
- },
- {
- label: ticketNumberWithTicketHook.value || '',
- noOptionLabelTranslation: true,
- to: { name: 'ticket-list' },
- },
- ])
- const detailViewActiveClasses = computed(() => {
- if (props.hideDetails)
- return [
- 'ticket-detail-grid-compact gap-x-2 grid-cols-[1fr_max-content] items-center p-2 px-10',
- ]
- return [' ticket-detail-grid-full grid-cols-2 gap-y-2.5']
- })
- </script>
- <template>
- <header
- class="-:p-3 -:relative z-10 grid border-b border-neutral-100 bg-neutral-50 dark:border-gray-900 dark:bg-gray-500"
- :class="detailViewActiveClasses"
- >
- <CommonBreadcrumb
- v-if="!hideDetails"
- emphasize-last-item
- size="small"
- :style="{ gridTemplate: 'breadcrumbs' }"
- :items="items"
- class="flex"
- >
- <template #trailing>
- <CommonIcon
- v-if="ticketNumber"
- v-tooltip="$t('Copy ticket number')"
- :aria-label="$t('Copy ticket number')"
- role="button"
- name="files"
- size="xs"
- class="cursor-pointer text-blue-800 ltr:ml-2 rtl:mr-2"
- @click="copyToClipboard(ticketNumberWithTicketHook)"
- />
- </template>
- </CommonBreadcrumb>
- <HighlightMenu
- v-if="isTicketAgent && isTicketEditable"
- class="justify-self-end"
- :style="{ gridTemplate: 'actions' }"
- />
- <TicketInformation
- :hide-details="hideDetails"
- :style="{ gridArea: hideDetails ? 'breadcrumbs' : 'info' }"
- :class="{ 'mx-10': !hideDetails }"
- />
- </header>
- </template>
- <style scoped>
- .ticket-detail-grid-full {
- grid-template-areas:
- 'breadcrumbs actions'
- 'info info';
- }
- .ticket-detail-grid-compact {
- grid-template-areas: 'breadcrumbs actions';
- }
- </style>
|