dify/web/app/components/workflow/run/agent-log/agent-log-nav-more.tsx

62 lines
1.8 KiB
TypeScript
Raw Normal View History

2024-12-27 16:17:44 +08:00
import { useState } from 'react'
import { RiMoreLine } from '@remixicon/react'
import {
PortalToFollowElem,
PortalToFollowElemContent,
PortalToFollowElemTrigger,
} from '@/app/components/base/portal-to-follow-elem'
import Button from '@/app/components/base/button'
2024-12-30 11:14:28 +08:00
import type { AgentLogItemWithChildren } from '@/types/workflow'
2024-12-27 16:17:44 +08:00
type AgentLogNavMoreProps = {
options: { id: string; label: string }[]
2024-12-30 11:14:28 +08:00
onShowAgentOrToolLog: (detail?: AgentLogItemWithChildren) => void
2024-12-27 16:17:44 +08:00
}
const AgentLogNavMore = ({
options,
2024-12-30 11:14:28 +08:00
onShowAgentOrToolLog,
2024-12-27 16:17:44 +08:00
}: AgentLogNavMoreProps) => {
const [open, setOpen] = useState(false)
return (
<PortalToFollowElem
placement='bottom-start'
offset={{
mainAxis: 2,
crossAxis: -54,
}}
open={open}
onOpenChange={setOpen}
>
<PortalToFollowElemTrigger>
<Button
className='w-6 h-6'
variant='ghost-accent'
>
<RiMoreLine className='w-4 h-4' />
</Button>
</PortalToFollowElemTrigger>
<PortalToFollowElemContent>
<div className='p-1 w-[136px] bg-components-panel-bg-blur border-[0.5px] border-components-panel-border rounded-xl shadow-lg'>
{
options.map(option => (
<div
key={option.id}
className='flex items-center px-2 h-8 rounded-lg system-md-regular text-text-secondary hover:bg-state-base-hover cursor-pointer'
2024-12-30 11:14:28 +08:00
onClick={() => {
onShowAgentOrToolLog(option as AgentLogItemWithChildren)
setOpen(false)
}}
2024-12-27 16:17:44 +08:00
>
{option.label}
</div>
))
}
</div>
</PortalToFollowElemContent>
</PortalToFollowElem>
)
}
export default AgentLogNavMore