mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
49 lines
1.1 KiB
49 lines
1.1 KiB
2 years ago
|
import { useInjectionState, useToggle, watch } from '#imports'
|
||
|
|
||
|
interface UseSidebarProps {
|
||
|
hasSidebar?: boolean
|
||
|
isOpen?: boolean
|
||
|
}
|
||
|
|
||
|
const [setup, use] = useInjectionState((props: UseSidebarProps = {}) => {
|
||
|
const [isOpen, toggle] = useToggle(props.isOpen ?? false)
|
||
|
const [hasSidebar, toggleHasSidebar] = useToggle(props.hasSidebar ?? true)
|
||
|
|
||
|
watch(
|
||
|
hasSidebar,
|
||
|
(nextHasSidebar) => {
|
||
|
if (!nextHasSidebar) toggle(false)
|
||
|
},
|
||
|
{ immediate: true },
|
||
|
)
|
||
|
|
||
|
watch(
|
||
|
isOpen,
|
||
|
(nextIsOpen) => {
|
||
|
if (nextIsOpen && !hasSidebar.value) toggleHasSidebar(true)
|
||
|
},
|
||
|
{ immediate: true },
|
||
|
)
|
||
|
|
||
|
return {
|
||
|
isOpen,
|
||
|
toggle,
|
||
|
hasSidebar,
|
||
|
toggleHasSidebar,
|
||
|
}
|
||
|
}, 'useSidebar')
|
||
|
|
||
|
export function useSidebar(props: UseSidebarProps = {}) {
|
||
|
const state = use()
|
||
|
|
||
|
if (!state) {
|
||
|
return setup(props)
|
||
|
} else {
|
||
|
// set state if props were passed
|
||
|
if (typeof props.isOpen !== 'undefined') state.isOpen.value = props.isOpen
|
||
|
if (typeof props.hasSidebar !== 'undefined') state.hasSidebar.value = props.hasSidebar
|
||
|
}
|
||
|
|
||
|
return state
|
||
|
}
|