123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { useLocalStorage, useWindowSize } from '@vueuse/core'
- import { shallowRef, computed, type Ref } from 'vue'
- import { SidebarPosition } from '#desktop/components/layout/types.ts'
- export const DEFAULT_START_SIDEBAR_WIDTH = 260
- export const DEFAULT_END_SIDEBAR_WIDTH = 360
- export const MINIMUM_START_SIDEBAR_WIDTH = 200
- export const MINIMUM_END_SIDEBAR_WIDTH = 300
- export const SIDEBAR_COLLAPSED_WIDTH = 48
- export const useResizeGridColumns = (
- storageKey?: string,
- position: SidebarPosition = SidebarPosition.Start,
- ) => {
- const defaultSidebarWidth =
- position === SidebarPosition.Start
- ? DEFAULT_START_SIDEBAR_WIDTH
- : DEFAULT_END_SIDEBAR_WIDTH
- const minSidebarWidth =
- position === SidebarPosition.Start
- ? MINIMUM_START_SIDEBAR_WIDTH
- : MINIMUM_END_SIDEBAR_WIDTH
- const isSidebarCollapsed = shallowRef(false)
- let currentSidebarWidth: Ref<number>
- const storageId = `${storageKey}-sidebar-width`
- if (storageKey) {
- currentSidebarWidth = useLocalStorage(storageId, defaultSidebarWidth)
- } else {
- currentSidebarWidth = shallowRef(defaultSidebarWidth)
- }
- const { width: screenWidth } = useWindowSize()
- const maxWidth = computed(() => screenWidth.value / 3)
- const gridColumns = computed(() => {
- const width = isSidebarCollapsed.value
- ? SIDEBAR_COLLAPSED_WIDTH
- : currentSidebarWidth.value
- if (position === SidebarPosition.End)
- return {
- gridTemplateColumns: `1fr ${width}px`,
- }
- return {
- gridTemplateColumns: `${width}px 1fr`,
- }
- })
- const resizeSidebar = (width: number) => {
- if (width <= minSidebarWidth || width >= maxWidth.value) return
- currentSidebarWidth.value = width
- }
- const collapseSidebar = () => {
- isSidebarCollapsed.value = true
- }
- const expandSidebar = () => {
- isSidebarCollapsed.value = false
- }
- const resetSidebarWidth = () => {
- currentSidebarWidth.value = defaultSidebarWidth
- }
- return {
- currentSidebarWidth,
- maxSidebarWidth: maxWidth,
- minSidebarWidth,
- gridColumns,
- isSidebarCollapsed,
- resizeSidebar,
- collapseSidebar,
- expandSidebar,
- resetSidebarWidth,
- }
- }
|