1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- <!-- Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { useTicketSidebar } from '../composables/useTicketSidebar.ts'
- import type { TicketSidebarContext } from '../types/sidebar.ts'
- interface Props {
- context: TicketSidebarContext
- isCollapsed: boolean
- toggleCollapse: () => void
- }
- const props = defineProps<Props>()
- const {
- activeSidebar,
- availableSidebarPlugins,
- shownSidebars,
- showSidebar,
- hideSidebar,
- switchSidebar,
- } = useTicketSidebar()
- const maybeToggleAndSwitchSidebar = (newSidebar: string) => {
- if (props.isCollapsed) props.toggleCollapse()
- switchSidebar(newSidebar)
- }
- </script>
- <template>
- <div class="flex h-full justify-end">
- <div v-show="!isCollapsed" id="ticketSidebar" class="flex grow flex-col" />
- <div
- class="flex max-w-12 flex-col items-center gap-2.5 border-neutral-100 px-2.5 py-3 transition-[border] dark:border-gray-900"
- :class="{ 'border-s': !isCollapsed }"
- >
- <component
- :is="sidebarPlugin.component"
- v-for="(sidebarPlugin, sidebar) of availableSidebarPlugins"
- v-show="shownSidebars[sidebar]"
- :key="sidebar"
- :selected="activeSidebar === sidebar"
- :sidebar="sidebar"
- :sidebar-plugin="sidebarPlugin"
- :context="context"
- @click="maybeToggleAndSwitchSidebar"
- @show="showSidebar(sidebar as string)"
- @hide="hideSidebar(sidebar as string)"
- />
- </div>
- </div>
- </template>
|