| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 | 'use client'import type { FC } from 'react'import React, { useCallback } from 'react'import { useTranslation } from 'react-i18next'import CheckboxWithLabel from './checkbox-with-label'import CrawledResultItem from './crawled-result-item'import cn from '@/utils/classnames'import type { CrawlResultItem } from '@/models/datasets'const I18N_PREFIX = 'datasetCreation.stepOne.website'type Props = {  className?: string  list: CrawlResultItem[]  checkedList: CrawlResultItem[]  onSelectedChange: (selected: CrawlResultItem[]) => void  onPreview: (payload: CrawlResultItem) => void  usedTime: number}const CrawledResult: FC<Props> = ({  className = '',  list,  checkedList,  onSelectedChange,  onPreview,  usedTime,}) => {  const { t } = useTranslation()  const isCheckAll = checkedList.length === list.length  const handleCheckedAll = useCallback(() => {    if (!isCheckAll)      onSelectedChange(list)    else      onSelectedChange([])  }, [isCheckAll, list, onSelectedChange])  const handleItemCheckChange = useCallback((item: CrawlResultItem) => {    return (checked: boolean) => {      if (checked)        onSelectedChange([...checkedList, item])      else        onSelectedChange(checkedList.filter(checkedItem => checkedItem.source_url !== item.source_url))    }  }, [checkedList, onSelectedChange])  const [previewIndex, setPreviewIndex] = React.useState<number>(-1)  const handlePreview = useCallback((index: number) => {    return () => {      setPreviewIndex(index)      onPreview(list[index])    }  }, [list, onPreview])  return (    <div className={cn(className, 'border-t border-gray-200')}>      <div className='flex items-center justify-between h-[34px] px-4 bg-gray-50 shadow-xs border-b-[0.5px] border-black/8 text-xs font-normal text-gray-700'>        <CheckboxWithLabel          isChecked={isCheckAll}          onChange={handleCheckedAll} label={isCheckAll ? t(`${I18N_PREFIX}.resetAll`) : t(`${I18N_PREFIX}.selectAll`)}          labelClassName='!font-medium'        />        <div>{t(`${I18N_PREFIX}.scrapTimeInfo`, {          total: list.length,          time: usedTime.toFixed(1),        })}</div>      </div>      <div className='p-2'>        {list.map((item, index) => (          <CrawledResultItem            key={item.source_url}            isPreview={index === previewIndex}            onPreview={handlePreview(index)}            payload={item}            isChecked={checkedList.some(checkedItem => checkedItem.source_url === item.source_url)}            onCheckChange={handleItemCheckChange(item)}          />        ))}      </div>    </div>  )}export default React.memo(CrawledResult)
 |