12345678910111213141516171819202122232425262728293031323334353637383940 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { onBeforeUnmount, onBeforeMount, ref, watch } from 'vue'
- import useMetaTitle from '#shared/composables/useMetaTitle.ts'
- import type { ComputedRef, Ref, UnwrapRef } from 'vue'
- import type { RouteLocationRaw } from 'vue-router'
- export interface HeaderOptions {
- title?: string | ComputedRef<string>
- titleClass?: string | ComputedRef<string>
- backTitle?: string | ComputedRef<string>
- backUrl?: RouteLocationRaw | ComputedRef<RouteLocationRaw>
- backAvoidHomeButton?: boolean
- backIgnore?: string[]
- refetch?: ComputedRef<boolean>
- actionTitle?: string | ComputedRef<string>
- actionHidden?: boolean | ComputedRef<boolean> | Ref<boolean>
- onAction?(): void
- }
- export const headerOptions = ref<HeaderOptions>({})
- const { setViewTitle } = useMetaTitle()
- watch(
- () => headerOptions.value.title,
- (title) => title && setViewTitle(title),
- )
- export const useHeader = (options: HeaderOptions) => {
- onBeforeMount(() => {
- headerOptions.value = options as UnwrapRef<HeaderOptions>
- })
- onBeforeUnmount(() => {
- headerOptions.value = {}
- })
- }
|