mirror of
https://github.com/langgenius/dify.git
synced 2025-07-14 04:31:07 +00:00
62 lines
1.6 KiB
TypeScript
62 lines
1.6 KiB
TypeScript
import { usePathname } from 'next/navigation'
|
|
import {
|
|
useWorkflowMode,
|
|
} from '../hooks'
|
|
import type { HeaderInNormalProps } from './header-in-normal'
|
|
import HeaderInNormal from './header-in-normal'
|
|
import type { HeaderInHistoryProps } from './header-in-view-history'
|
|
import HeaderInHistory from './header-in-view-history'
|
|
import type { HeaderInRestoringProps } from './header-in-restoring'
|
|
import HeaderInRestoring from './header-in-restoring'
|
|
import { useStore } from '../store'
|
|
export type HeaderProps = {
|
|
normal?: HeaderInNormalProps
|
|
viewHistory?: HeaderInHistoryProps
|
|
restoring?: HeaderInRestoringProps
|
|
}
|
|
const Header = ({
|
|
normal: normalProps,
|
|
viewHistory: viewHistoryProps,
|
|
restoring: restoringProps,
|
|
}: HeaderProps) => {
|
|
const pathname = usePathname()
|
|
const inWorkflowCanvas = pathname.endsWith('/workflow')
|
|
const {
|
|
normal,
|
|
restoring,
|
|
viewHistory,
|
|
} = useWorkflowMode()
|
|
const maximizeCanvas = useStore(s => s.maximizeCanvas)
|
|
|
|
return (
|
|
<div
|
|
className='absolute left-0 top-0 z-10 flex h-14 w-full items-center justify-between bg-mask-top2bottom-gray-50-to-transparent px-3'
|
|
>
|
|
{inWorkflowCanvas && maximizeCanvas && <div className='h-14 w-[52px]' />}
|
|
{
|
|
normal && (
|
|
<HeaderInNormal
|
|
{...normalProps}
|
|
/>
|
|
)
|
|
}
|
|
{
|
|
viewHistory && (
|
|
<HeaderInHistory
|
|
{...viewHistoryProps}
|
|
/>
|
|
)
|
|
}
|
|
{
|
|
restoring && (
|
|
<HeaderInRestoring
|
|
{...restoringProps}
|
|
/>
|
|
)
|
|
}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default Header
|