mirror of
https://github.com/langgenius/dify.git
synced 2025-11-18 04:13:35 +00:00
Signed-off-by: -LAN- <laipz8200@outlook.com> Co-authored-by: twwu <twwu@dify.ai> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: jyong <718720800@qq.com> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: lyzno1 <yuanyouhuilyz@gmail.com> Co-authored-by: quicksand <quicksandzn@gmail.com> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: lyzno1 <92089059+lyzno1@users.noreply.github.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: Hanqing Zhao <sherry9277@gmail.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Harry <xh001x@hotmail.com>
70 lines
1.8 KiB
TypeScript
70 lines
1.8 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 type { HeaderInRestoringProps } from './header-in-restoring'
|
|
import { useStore } from '../store'
|
|
import dynamic from 'next/dynamic'
|
|
|
|
const HeaderInHistory = dynamic(() => import('./header-in-view-history'), {
|
|
ssr: false,
|
|
})
|
|
const HeaderInRestoring = dynamic(() => import('./header-in-restoring'), {
|
|
ssr: false,
|
|
})
|
|
|
|
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 isPipelineCanvas = pathname.endsWith('/pipeline')
|
|
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 || isPipelineCanvas) && maximizeCanvas && <div className='h-14 w-[52px]' />}
|
|
{
|
|
normal && (
|
|
<HeaderInNormal
|
|
{...normalProps}
|
|
/>
|
|
)
|
|
}
|
|
{
|
|
viewHistory && (
|
|
<HeaderInHistory
|
|
{...viewHistoryProps}
|
|
/>
|
|
)
|
|
}
|
|
{
|
|
restoring && (
|
|
<HeaderInRestoring
|
|
{...restoringProps}
|
|
/>
|
|
)
|
|
}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default Header
|