import type { FC } from 'react'
|
import { useState } from 'react'
|
import { useTranslation } from 'react-i18next'
|
import {
|
RiMoreFill,
|
} from '@remixicon/react'
|
import { useSelectOrDelete, useTrigger } from '../../hooks'
|
import { UPDATE_HISTORY_EVENT_EMITTER } from '../../constants'
|
import type { RoleName } from './index'
|
import { DELETE_HISTORY_BLOCK_COMMAND } from './index'
|
import { MessageClockCircle } from '@/app/components/base/icons/src/vender/solid/general'
|
import {
|
PortalToFollowElem,
|
PortalToFollowElemContent,
|
PortalToFollowElemTrigger,
|
} from '@/app/components/base/portal-to-follow-elem'
|
import { useEventEmitterContextContext } from '@/context/event-emitter'
|
|
type HistoryBlockComponentProps = {
|
nodeKey: string
|
roleName?: RoleName
|
onEditRole: () => void
|
}
|
|
const HistoryBlockComponent: FC<HistoryBlockComponentProps> = ({
|
nodeKey,
|
roleName = { user: '', assistant: '' },
|
onEditRole,
|
}) => {
|
const { t } = useTranslation()
|
const [ref, isSelected] = useSelectOrDelete(nodeKey, DELETE_HISTORY_BLOCK_COMMAND)
|
const [triggerRef, open, setOpen] = useTrigger()
|
const { eventEmitter } = useEventEmitterContextContext()
|
const [localRoleName, setLocalRoleName] = useState<RoleName>(roleName)
|
|
eventEmitter?.useSubscription((v: any) => {
|
if (v?.type === UPDATE_HISTORY_EVENT_EMITTER)
|
setLocalRoleName(v.payload)
|
})
|
|
return (
|
<div className={`
|
group inline-flex h-6 items-center rounded-[5px] border border-transparent pl-1 pr-0.5 text-[#DD2590] hover:bg-[#FCE7F6]
|
${open ? 'bg-[#FCE7F6]' : 'bg-[#FDF2FA]'}
|
${isSelected && '!border-[#F670C7]'}
|
`} ref={ref}>
|
<MessageClockCircle className='mr-1 h-[14px] w-[14px]' />
|
<div className='mr-1 text-xs font-medium'>{t('common.promptEditor.history.item.title')}</div>
|
<PortalToFollowElem
|
open={open}
|
onOpenChange={setOpen}
|
placement='top-end'
|
offset={{
|
mainAxis: 4,
|
alignmentAxis: -148,
|
}}
|
>
|
<PortalToFollowElemTrigger ref={triggerRef}>
|
<div className={`
|
flex h-[18px] w-[18px] cursor-pointer items-center justify-center rounded
|
${open ? 'bg-[#DD2590] text-white' : 'bg-white/50 group-hover:bg-white group-hover:shadow-xs'}
|
`}>
|
<RiMoreFill className='h-3 w-3' />
|
</div>
|
</PortalToFollowElemTrigger>
|
<PortalToFollowElemContent style={{ zIndex: 100 }}>
|
<div className='w-[360px] rounded-xl bg-white shadow-lg'>
|
<div className='p-4'>
|
<div className='mb-2 text-xs font-medium text-gray-500'>{t('common.promptEditor.history.modal.title')}</div>
|
<div className='flex items-center text-sm text-gray-700'>
|
<div className='mr-1 w-20 text-xs font-semibold'>{localRoleName?.user}</div>
|
{t('common.promptEditor.history.modal.user')}
|
</div>
|
<div className='flex items-center text-sm text-gray-700'>
|
<div className='mr-1 w-20 text-xs font-semibold'>{localRoleName?.assistant}</div>
|
{t('common.promptEditor.history.modal.assistant')}
|
</div>
|
</div>
|
<div
|
className='cursor-pointer rounded-b-xl border-t border-black/5 px-4 py-3 text-xs text-[#155EEF]'
|
onClick={onEditRole}
|
>
|
{t('common.promptEditor.history.modal.edit')}
|
</div>
|
</div>
|
</PortalToFollowElemContent>
|
</PortalToFollowElem>
|
</div>
|
)
|
}
|
|
export default HistoryBlockComponent
|