jan/web/screens/Settings/ImportingModelModal/ImportingModelItem.tsx
Faisal Amir 635435fbb8
Revert feat: temporary remove dark mode (#2221)
* Revert "feat: temporary remove dark mode :(  (#2168)"

This reverts commit 222b4ad897c275dab0eaec3c8a8472bf3df7afc4.

* fix: revert darkmode and fix darkmode for import model

* fix: prettier format import model

---------

Co-authored-by: Louis <louis@jan.ai>
2024-03-04 14:46:10 +07:00

61 lines
1.8 KiB
TypeScript

import { useCallback, useMemo } from 'react'
import { ImportingModel } from '@janhq/core/.'
import { useSetAtom } from 'jotai'
import { AlertCircle } from 'lucide-react'
import { setImportModelStageAtom } from '@/hooks/useImportModel'
import { toGibibytes } from '@/utils/converter'
import { editingModelIdAtom } from '../EditModelInfoModal'
import ImportInProgressIcon from '../ImportInProgressIcon'
import ImportSuccessIcon from '../ImportSuccessIcon'
type Props = {
model: ImportingModel
}
const ImportingModelItem: React.FC<Props> = ({ model }) => {
const setImportModelStage = useSetAtom(setImportModelStageAtom)
const setEditingModelId = useSetAtom(editingModelIdAtom)
const onEditModelInfoClick = useCallback(() => {
setEditingModelId(model.importId)
setImportModelStage('EDIT_MODEL_INFO')
}, [setImportModelStage, setEditingModelId, model.importId])
const onDeleteModelClick = useCallback(() => {}, [])
const displayStatus = useMemo(() => {
if (model.status === 'FAILED') {
return 'Failed'
} else {
return toGibibytes(model.size)
}
}, [model.status, model.size])
return (
<div className="flex w-full flex-row items-center space-x-3 rounded-lg border border-border px-4 py-3">
<p className="line-clamp-1 flex-1 font-semibold text-muted-foreground">
{model.name}
</p>
<p className="text-muted-foreground">{displayStatus}</p>
{model.status === 'IMPORTED' && (
<ImportSuccessIcon onEditModelClick={onEditModelInfoClick} />
)}
{(model.status === 'IMPORTING' || model.status === 'PREPARING') && (
<ImportInProgressIcon
percentage={model.percentage ?? 0}
onDeleteModelClick={onDeleteModelClick}
/>
)}
{model.status === 'FAILED' && <AlertCircle size={24} color="#F00" />}
</div>
)
}
export default ImportingModelItem