1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { injectLocal, provideLocal } from '@vueuse/shared'
- import { isEqual } from 'lodash-es'
- import { computed, ref, type InjectionKey, type Ref } from 'vue'
- import { useTicketSidebarPlugins } from '../components/TicketSidebar/plugins/index.ts'
- import type { TicketSidebarPlugin } from '../components/TicketSidebar/plugins/types.ts'
- import type {
- TicketSidebarContext,
- TicketSidebarInformation,
- } from '../types/sidebar.ts'
- export const TICKET_SIDEBAR_SYMBOL = Symbol(
- 'ticket-sidebar',
- ) as InjectionKey<TicketSidebarInformation>
- export const useProvideTicketSidebar = (context: Ref<TicketSidebarContext>) => {
- const shownSidebars = ref<Record<string, boolean>>({})
- const switchedSidebar = ref<string>()
- const showSidebar = (sidebar: string) => {
- shownSidebars.value[sidebar] = true
- }
- const hideSidebar = (sidebar: string) => {
- shownSidebars.value[sidebar] = false
- }
- const switchSidebar = (newSidebar: string) => {
- switchedSidebar.value = newSidebar
- }
- const sidebarPlugins = useTicketSidebarPlugins(context.value.screenType)
- const availableSidebarPlugins = computed<Record<string, TicketSidebarPlugin>>(
- (currentAvailableSidebarPlugins) => {
- const newCurrentSidebarPlugins = Object.fromEntries(
- Object.entries(sidebarPlugins).filter(([, sidebarPlugin]) =>
- typeof sidebarPlugin.available === 'function'
- ? sidebarPlugin.available(context.value)
- : true,
- ),
- )
- if (
- currentAvailableSidebarPlugins &&
- isEqual(currentAvailableSidebarPlugins, newCurrentSidebarPlugins)
- )
- return currentAvailableSidebarPlugins
- return newCurrentSidebarPlugins
- },
- )
- const activeSidebar = computed<string | null>(() => {
- if (!Object.keys(availableSidebarPlugins.value)?.length) return null
- if (
- switchedSidebar.value &&
- availableSidebarPlugins.value[switchedSidebar.value] &&
- shownSidebars.value[switchedSidebar.value]
- )
- return switchedSidebar.value
- const sidebar = Object.entries(availableSidebarPlugins.value).filter(
- ([sidebar]) => shownSidebars.value[sidebar],
- )?.[0]?.[0]
- return sidebar === undefined ? ' ' : sidebar // ' ' is a fallback value for a non-selectable sidebar to prevent flickering if sidebar is loading
- })
- const hasSidebar = computed(() => Boolean(activeSidebar.value))
- provideLocal(TICKET_SIDEBAR_SYMBOL, {
- shownSidebars,
- activeSidebar,
- availableSidebarPlugins,
- sidebarPlugins,
- hasSidebar,
- showSidebar,
- hideSidebar,
- switchSidebar,
- })
- }
- export const useTicketSidebar = () => {
- return injectLocal(TICKET_SIDEBAR_SYMBOL) as TicketSidebarInformation
- }
|