| 
                        12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 | 
                        - 'use client'
 - import type { FC } from 'react'
 - import React, { useCallback } from 'react'
 - import { useBoolean } from 'ahooks'
 - import { RiArrowDownSLine } from '@remixicon/react'
 - import { useTranslation } from 'react-i18next'
 - import FileIcon from '../document-file-icon'
 - import DocumentList from './document-list'
 - import {
 -   PortalToFollowElem,
 -   PortalToFollowElemContent,
 -   PortalToFollowElemTrigger,
 - } from '@/app/components/base/portal-to-follow-elem'
 - import cn from '@/utils/classnames'
 - import Loading from '@/app/components/base/loading'
 - import type { DocumentItem } from '@/models/datasets'
 - 
 - type Props = {
 -   className?: string
 -   value: DocumentItem
 -   files: DocumentItem[]
 -   onChange: (value: DocumentItem) => void
 - }
 - 
 - const PreviewDocumentPicker: FC<Props> = ({
 -   className,
 -   value,
 -   files,
 -   onChange,
 - }) => {
 -   const { t } = useTranslation()
 -   const { name, extension } = value
 - 
 -   const [open, {
 -     set: setOpen,
 -     toggle: togglePopup,
 -   }] = useBoolean(false)
 -   const ArrowIcon = RiArrowDownSLine
 - 
 -   const handleChange = useCallback((item: DocumentItem) => {
 -     onChange(item)
 -     setOpen(false)
 -   }, [onChange, setOpen])
 - 
 -   return (
 -     <PortalToFollowElem
 -       open={open}
 -       onOpenChange={setOpen}
 -       placement='bottom-start'
 -       offset={4}
 -     >
 -       <PortalToFollowElemTrigger onClick={togglePopup}>
 -         <div className={cn('flex h-6 select-none items-center rounded-md px-1 hover:bg-state-base-hover', open && 'bg-state-base-hover', className)}>
 -           <FileIcon name={name} extension={extension} size='md' />
 -           <div className='ml-1 flex flex-col items-start'>
 -             <div className='flex items-center space-x-0.5'>
 -               <span className={cn('system-md-semibold max-w-[200px] truncate text-text-primary')}> {name || '--'}</span>
 -               <ArrowIcon className={'h-[18px] w-[18px] text-text-primary'} />
 -             </div>
 -           </div>
 -         </div>
 -       </PortalToFollowElemTrigger>
 -       <PortalToFollowElemContent className='z-[11]'>
 -         <div className='w-[392px] rounded-xl border-[0.5px] border-components-panel-border bg-components-panel-bg-blur p-1 shadow-lg backdrop-blur-[5px]'>
 -           {files?.length > 1 && <div className='system-xs-medium-uppercase flex h-8 items-center pl-2 text-text-tertiary'>{t('dataset.preprocessDocument', { num: files.length })}</div>}
 -           {files?.length > 0
 -             ? (
 -               <DocumentList
 -                 list={files}
 -                 onChange={handleChange}
 -               />
 -             )
 -             : (<div className='mt-2 flex h-[100px] w-[360px] items-center justify-center'>
 -               <Loading />
 -             </div>)}
 -         </div>
 - 
 -       </PortalToFollowElemContent>
 -     </PortalToFollowElem>
 -   )
 - }
 - export default React.memo(PreviewDocumentPicker)
 
 
  |