| 
                        1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 | 
                        - 'use client'
 - import type { FC } from 'react'
 - import React from 'react'
 - import {
 -   PlayIcon,
 - } from '@heroicons/react/24/solid'
 - import { useTranslation } from 'react-i18next'
 - import cn from 'classnames'
 - import {
 -   RiLoader2Line,
 - } from '@remixicon/react'
 - import CSVReader from './csv-reader'
 - import CSVDownload from './csv-download'
 - import Button from '@/app/components/base/button'
 - export type IRunBatchProps = {
 -   vars: { name: string }[]
 -   onSend: (data: string[][]) => void
 -   isAllFinished: boolean
 - }
 - 
 - const RunBatch: FC<IRunBatchProps> = ({
 -   vars,
 -   onSend,
 -   isAllFinished,
 - }) => {
 -   const { t } = useTranslation()
 - 
 -   const [csvData, setCsvData] = React.useState<string[][]>([])
 -   const [isParsed, setIsParsed] = React.useState(false)
 -   const handleParsed = (data: string[][]) => {
 -     setCsvData(data)
 -     // console.log(data)
 -     setIsParsed(true)
 -   }
 - 
 -   const handleSend = () => {
 -     onSend(csvData)
 -   }
 -   const Icon = isAllFinished ? PlayIcon : RiLoader2Line
 -   return (
 -     <div className='pt-4'>
 -       <CSVReader onParsed={handleParsed} />
 -       <CSVDownload vars={vars} />
 -       <div className='mt-4 h-[1px] bg-gray-100'></div>
 -       <div className='flex justify-end'>
 -         <Button
 -           variant="primary"
 -           className='mt-4 pl-3 pr-4'
 -           onClick={handleSend}
 -           disabled={!isParsed || !isAllFinished}
 -         >
 -           <Icon className={cn(!isAllFinished && 'animate-spin', 'shrink-0 w-4 h-4 mr-1')} aria-hidden="true" />
 -           <span className='uppercase text-[13px]'>{t('share.generation.run')}</span>
 -         </Button>
 -       </div>
 -     </div>
 -   )
 - }
 - export default React.memo(RunBatch)
 
 
  |