| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 | import type { FC } from 'react'import { memo } from 'react'import { useTranslation } from 'react-i18next'import {  RiLoader2Line,  RiPlayLargeLine,} from '@remixicon/react'import { useStore } from '../store'import {  useIsChatMode,  useNodesReadOnly,  useWorkflowRun,  useWorkflowStartRun,} from '../hooks'import { WorkflowRunningStatus } from '../types'import ViewHistory from './view-history'import Checklist from './checklist'import cn from '@/utils/classnames'import {  StopCircle,} from '@/app/components/base/icons/src/vender/line/mediaAndDevices'const RunMode = memo(() => {  const { t } = useTranslation()  const { handleWorkflowStartRunInWorkflow } = useWorkflowStartRun()  const { handleStopRun } = useWorkflowRun()  const workflowRunningData = useStore(s => s.workflowRunningData)  const isRunning = workflowRunningData?.result.status === WorkflowRunningStatus.Running  return (    <>      <div        className={cn(          'flex items-center px-2.5 h-7 rounded-md text-[13px] font-medium text-components-button-secondary-accent-text',          'hover:bg-state-accent-hover cursor-pointer',          isRunning && 'bg-state-accent-hover !cursor-not-allowed',        )}        onClick={() => {          handleWorkflowStartRunInWorkflow()        }}      >        {          isRunning            ? (              <>                <RiLoader2Line className='mr-1 w-4 h-4 animate-spin' />                {t('workflow.common.running')}              </>            )            : (              <>                <RiPlayLargeLine className='mr-1 w-4 h-4' />                {t('workflow.common.run')}              </>            )        }      </div>      {        isRunning && (          <div            className='flex items-center justify-center ml-0.5 w-7 h-7 cursor-pointer hover:bg-black/5 rounded-md'            onClick={() => handleStopRun(workflowRunningData?.task_id || '')}          >            <StopCircle className='w-4 h-4 text-components-button-ghost-text' />          </div>        )      }    </>  )})RunMode.displayName = 'RunMode'const PreviewMode = memo(() => {  const { t } = useTranslation()  const { handleWorkflowStartRunInChatflow } = useWorkflowStartRun()  return (    <div      className={cn(        'flex items-center px-2.5 h-7 rounded-md text-[13px] font-medium text-components-button-secondary-accent-text',        'hover:bg-state-accent-hover cursor-pointer',      )}      onClick={() => handleWorkflowStartRunInChatflow()}    >      <RiPlayLargeLine className='mr-1 w-4 h-4' />      {t('workflow.common.debugAndPreview')}    </div>  )})PreviewMode.displayName = 'PreviewMode'const RunAndHistory: FC = () => {  const isChatMode = useIsChatMode()  const { nodesReadOnly } = useNodesReadOnly()  return (    <div className='flex items-center px-0.5 h-8 rounded-lg border-[0.5px] border-components-button-secondary-border bg-components-button-secondary-bg shadow-xs'>      {        !isChatMode && <RunMode />      }      {        isChatMode && <PreviewMode />      }      <div className='mx-0.5 w-[1px] h-3.5 bg-divider-regular'></div>      <ViewHistory />      <Checklist disabled={nodesReadOnly} />    </div>  )}export default memo(RunAndHistory)
 |