| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 'use client' | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  | import React, { useMemo, useState } from 'react' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  | import cn from 'classnames' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | import FilePreview from '../file-preview' | 
					
						
							|  |  |  | import FileUploader from '../file-uploader' | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  | import NotionPagePreview from '../notion-page-preview' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | import EmptyDatasetCreationModal from '../empty-dataset-creation-modal' | 
					
						
							|  |  |  | import s from './index.module.css' | 
					
						
							| 
									
										
										
										
											2023-08-16 23:14:27 +08:00
										 |  |  | import type { FileItem } from '@/models/datasets' | 
					
						
							| 
									
										
										
										
											2023-08-28 19:48:53 +08:00
										 |  |  | import type { NotionPage } from '@/models/common' | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  | import { DataSourceType } from '@/models/datasets' | 
					
						
							|  |  |  | import Button from '@/app/components/base/button' | 
					
						
							|  |  |  | import { NotionPageSelector } from '@/app/components/base/notion-page-selector' | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  | import { useDatasetDetailContext } from '@/context/dataset-detail' | 
					
						
							| 
									
										
										
										
											2023-12-03 22:10:16 +08:00
										 |  |  | import { useProviderContext } from '@/context/provider-context' | 
					
						
							|  |  |  | import VectorSpaceFull from '@/app/components/billing/vector-space-full' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | type IStepOneProps = { | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |   datasetId?: string | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |   dataSourceType?: DataSourceType | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |   dataSourceTypeDisable: Boolean | 
					
						
							|  |  |  |   hasConnection: boolean | 
					
						
							|  |  |  |   onSetting: () => void | 
					
						
							| 
									
										
										
										
											2023-08-16 23:14:27 +08:00
										 |  |  |   files: FileItem[] | 
					
						
							|  |  |  |   updateFileList: (files: FileItem[]) => void | 
					
						
							|  |  |  |   updateFile: (fileItem: FileItem, progress: number, list: FileItem[]) => void | 
					
						
							| 
									
										
										
										
											2023-08-28 19:48:53 +08:00
										 |  |  |   notionPages?: NotionPage[] | 
					
						
							|  |  |  |   updateNotionPages: (value: NotionPage[]) => void | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |   onStepChange: () => void | 
					
						
							|  |  |  |   changeType: (type: DataSourceType) => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type NotionConnectorProps = { | 
					
						
							|  |  |  |   onSetting: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | export const NotionConnector = ({ onSetting }: NotionConnectorProps) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <div className={s.notionConnectionTip}> | 
					
						
							|  |  |  |       <span className={s.notionIcon}/> | 
					
						
							|  |  |  |       <div className={s.title}>{t('datasetCreation.stepOne.notionSyncTitle')}</div> | 
					
						
							|  |  |  |       <div className={s.tip}>{t('datasetCreation.stepOne.notionSyncTip')}</div> | 
					
						
							|  |  |  |       <Button className='h-8' type='primary' onClick={onSetting}>{t('datasetCreation.stepOne.connect')}</Button> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const StepOne = ({ | 
					
						
							|  |  |  |   datasetId, | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |   dataSourceType, | 
					
						
							|  |  |  |   dataSourceTypeDisable, | 
					
						
							|  |  |  |   changeType, | 
					
						
							|  |  |  |   hasConnection, | 
					
						
							|  |  |  |   onSetting, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   onStepChange, | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |   files, | 
					
						
							|  |  |  |   updateFileList, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   updateFile, | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |   notionPages = [], | 
					
						
							|  |  |  |   updateNotionPages, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | }: IStepOneProps) => { | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |   const { dataset } = useDatasetDetailContext() | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   const [showModal, setShowModal] = useState(false) | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |   const [currentFile, setCurrentFile] = useState<File | undefined>() | 
					
						
							| 
									
										
										
										
											2023-09-10 15:17:22 +08:00
										 |  |  |   const [currentNotionPage, setCurrentNotionPage] = useState<NotionPage | undefined>() | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const modalShowHandle = () => setShowModal(true) | 
					
						
							|  |  |  |   const modalCloseHandle = () => setShowModal(false) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |   const updateCurrentFile = (file: File) => { | 
					
						
							|  |  |  |     setCurrentFile(file) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   const hideFilePreview = () => { | 
					
						
							| 
									
										
										
										
											2023-07-06 10:51:30 +08:00
										 |  |  |     setCurrentFile(undefined) | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-10 15:17:22 +08:00
										 |  |  |   const updateCurrentPage = (page: NotionPage) => { | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |     setCurrentNotionPage(page) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const hideNotionPagePreview = () => { | 
					
						
							|  |  |  |     setCurrentNotionPage(undefined) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |   const shouldShowDataSourceTypeList = !datasetId || (datasetId && !dataset?.data_source_type) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-03 22:10:16 +08:00
										 |  |  |   const { plan, enableBilling } = useProviderContext() | 
					
						
							|  |  |  |   const allFileLoaded = (files.length > 0 && files.every(file => file.file.id)) | 
					
						
							|  |  |  |   const hasNotin = notionPages.length > 0 | 
					
						
							|  |  |  |   const isVectorSpaceFull = plan.usage.vectorSpace >= plan.total.vectorSpace | 
					
						
							|  |  |  |   const isShowVectorSpaceFull = (allFileLoaded || hasNotin) && isVectorSpaceFull && enableBilling | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |   const nextDisabled = useMemo(() => { | 
					
						
							|  |  |  |     if (!files.length) | 
					
						
							|  |  |  |       return true | 
					
						
							|  |  |  |     if (files.some(file => !file.file.id)) | 
					
						
							|  |  |  |       return true | 
					
						
							| 
									
										
										
										
											2023-12-03 22:10:16 +08:00
										 |  |  |     if (isShowVectorSpaceFull) | 
					
						
							|  |  |  |       return true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |     return false | 
					
						
							|  |  |  |   }, [files]) | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <div className='flex w-full h-full'> | 
					
						
							|  |  |  |       <div className='grow overflow-y-auto relative'> | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |         { | 
					
						
							|  |  |  |           shouldShowDataSourceTypeList && ( | 
					
						
							|  |  |  |             <div className={s.stepHeader}>{t('datasetCreation.steps.one')}</div> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         <div className={s.form}> | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |           { | 
					
						
							|  |  |  |             shouldShowDataSourceTypeList && ( | 
					
						
							| 
									
										
										
										
											2023-11-27 11:47:48 +08:00
										 |  |  |               <div className='flex items-center mb-8 flex-wrap gap-y-4'> | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |                 <div | 
					
						
							|  |  |  |                   className={cn( | 
					
						
							|  |  |  |                     s.dataSourceItem, | 
					
						
							|  |  |  |                     dataSourceType === DataSourceType.FILE && s.active, | 
					
						
							|  |  |  |                     dataSourceTypeDisable && dataSourceType !== DataSourceType.FILE && s.disabled, | 
					
						
							|  |  |  |                   )} | 
					
						
							|  |  |  |                   onClick={() => { | 
					
						
							|  |  |  |                     if (dataSourceTypeDisable) | 
					
						
							|  |  |  |                       return | 
					
						
							|  |  |  |                     changeType(DataSourceType.FILE) | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |                     hideFilePreview() | 
					
						
							|  |  |  |                     hideNotionPagePreview() | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |                   }} | 
					
						
							|  |  |  |                 > | 
					
						
							|  |  |  |                   <span className={cn(s.datasetIcon)} /> | 
					
						
							|  |  |  |                   {t('datasetCreation.stepOne.dataSourceType.file')} | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                 <div | 
					
						
							|  |  |  |                   className={cn( | 
					
						
							|  |  |  |                     s.dataSourceItem, | 
					
						
							|  |  |  |                     dataSourceType === DataSourceType.NOTION && s.active, | 
					
						
							|  |  |  |                     dataSourceTypeDisable && dataSourceType !== DataSourceType.NOTION && s.disabled, | 
					
						
							|  |  |  |                   )} | 
					
						
							|  |  |  |                   onClick={() => { | 
					
						
							|  |  |  |                     if (dataSourceTypeDisable) | 
					
						
							|  |  |  |                       return | 
					
						
							|  |  |  |                     changeType(DataSourceType.NOTION) | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |                     hideFilePreview() | 
					
						
							|  |  |  |                     hideNotionPagePreview() | 
					
						
							| 
									
										
										
										
											2023-06-19 16:32:25 +08:00
										 |  |  |                   }} | 
					
						
							|  |  |  |                 > | 
					
						
							|  |  |  |                   <span className={cn(s.datasetIcon, s.notion)} /> | 
					
						
							|  |  |  |                   {t('datasetCreation.stepOne.dataSourceType.notion')} | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                 <div | 
					
						
							|  |  |  |                   className={cn(s.dataSourceItem, s.disabled, dataSourceType === DataSourceType.WEB && s.active)} | 
					
						
							|  |  |  |                 // onClick={() => changeType(DataSourceType.WEB)}
 | 
					
						
							|  |  |  |                 > | 
					
						
							|  |  |  |                   <span className={s.comingTag}>Coming soon</span> | 
					
						
							|  |  |  |                   <span className={cn(s.datasetIcon, s.web)} /> | 
					
						
							|  |  |  |                   {t('datasetCreation.stepOne.dataSourceType.web')} | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |               </div> | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2023-12-05 16:53:40 +08:00
										 |  |  |           {dataSourceType === DataSourceType.FILE && ( | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |             <> | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |               <FileUploader | 
					
						
							|  |  |  |                 fileList={files} | 
					
						
							|  |  |  |                 titleClassName={!shouldShowDataSourceTypeList ? 'mt-[30px] !mb-[44px] !text-lg !font-semibold !text-gray-900' : undefined} | 
					
						
							|  |  |  |                 prepareFileList={updateFileList} | 
					
						
							|  |  |  |                 onFileListUpdate={updateFileList} | 
					
						
							|  |  |  |                 onFileUpdate={updateFile} | 
					
						
							|  |  |  |                 onPreview={updateCurrentFile} | 
					
						
							|  |  |  |               /> | 
					
						
							| 
									
										
										
										
											2023-12-03 22:10:16 +08:00
										 |  |  |               {isShowVectorSpaceFull && ( | 
					
						
							|  |  |  |                 <div className='max-w-[640px] mb-4'> | 
					
						
							|  |  |  |                   <VectorSpaceFull /> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |               )} | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |               <Button disabled={nextDisabled} className={s.submitButton} type='primary' onClick={onStepChange}>{t('datasetCreation.stepOne.button')}</Button> | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |             </> | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |           {dataSourceType === DataSourceType.NOTION && ( | 
					
						
							|  |  |  |             <> | 
					
						
							|  |  |  |               {!hasConnection && <NotionConnector onSetting={onSetting} />} | 
					
						
							| 
									
										
										
										
											2023-12-05 16:53:40 +08:00
										 |  |  |               {hasConnection && ( | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |                 <> | 
					
						
							|  |  |  |                   <div className='mb-8 w-[640px]'> | 
					
						
							| 
									
										
										
										
											2023-08-28 10:53:45 +08:00
										 |  |  |                     <NotionPageSelector | 
					
						
							|  |  |  |                       value={notionPages.map(page => page.page_id)} | 
					
						
							|  |  |  |                       onSelect={updateNotionPages} | 
					
						
							|  |  |  |                       onPreview={updateCurrentPage} | 
					
						
							|  |  |  |                     /> | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |                   </div> | 
					
						
							| 
									
										
										
										
											2023-12-03 22:10:16 +08:00
										 |  |  |                   {isShowVectorSpaceFull && ( | 
					
						
							|  |  |  |                     <div className='max-w-[640px] mb-4'> | 
					
						
							|  |  |  |                       <VectorSpaceFull /> | 
					
						
							|  |  |  |                     </div> | 
					
						
							|  |  |  |                   )} | 
					
						
							|  |  |  |                   <Button disabled={isShowVectorSpaceFull || !notionPages.length} className={s.submitButton} type='primary' onClick={onStepChange}>{t('datasetCreation.stepOne.button')}</Button> | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |                 </> | 
					
						
							|  |  |  |               )} | 
					
						
							|  |  |  |             </> | 
					
						
							|  |  |  |           )} | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |           {!datasetId && ( | 
					
						
							|  |  |  |             <> | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |               <div className={s.dividerLine} /> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |               <div onClick={modalShowHandle} className={s.OtherCreationOption}>{t('datasetCreation.stepOne.emptyDatasetCreation')}</div> | 
					
						
							|  |  |  |             </> | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |         <EmptyDatasetCreationModal show={showModal} onHide={modalCloseHandle} /> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2023-06-21 09:44:01 +08:00
										 |  |  |       {currentFile && <FilePreview file={currentFile} hidePreview={hideFilePreview} />} | 
					
						
							| 
									
										
										
										
											2023-06-16 21:47:51 +08:00
										 |  |  |       {currentNotionPage && <NotionPagePreview currentPage={currentNotionPage} hidePreview={hideNotionPagePreview} />} | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default StepOne |