| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 | import type { FC } from 'react'import { useState } from 'react'import { useTranslation } from 'react-i18next'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 { DotsHorizontal } from '@/app/components/base/icons/src/vender/line/general'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'}          `}>            <DotsHorizontal 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
 |