1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- 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 items-center pl-1 pr-0.5 h-6 border border-transparent text-[#DD2590] rounded-[5px] hover:bg-[#FCE7F6]
- ${open ? 'bg-[#FCE7F6]' : 'bg-[#FDF2FA]'}
- ${isSelected && '!border-[#F670C7]'}
- `} ref={ref}>
- <MessageClockCircle className='mr-1 w-[14px] h-[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 items-center justify-center w-[18px] h-[18px] rounded cursor-pointer
- ${open ? 'bg-[#DD2590] text-white' : 'bg-white/50 group-hover:bg-white group-hover:shadow-xs'}
- `}>
- <RiMoreFill className='w-3 h-3' />
- </div>
- </PortalToFollowElemTrigger>
- <PortalToFollowElemContent style={{ zIndex: 100 }}>
- <div className='w-[360px] bg-white rounded-xl 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='px-4 py-3 text-xs text-[#155EEF] border-t border-black/5 rounded-b-xl cursor-pointer'
- onClick={onEditRole}
- >
- {t('common.promptEditor.history.modal.edit')}
- </div>
- </div>
- </PortalToFollowElemContent>
- </PortalToFollowElem>
- </div>
- )
- }
- export default HistoryBlockComponent
|