all
This commit is contained in:
83
Downloads/Voltaserve/ui/src/components/common/path.tsx
Normal file
83
Downloads/Voltaserve/ui/src/components/common/path.tsx
Normal file
@@ -0,0 +1,83 @@
|
||||
import { useMemo } from 'react'
|
||||
import {
|
||||
Breadcrumb,
|
||||
BreadcrumbItem,
|
||||
BreadcrumbLink,
|
||||
Skeleton,
|
||||
} from '@chakra-ui/react'
|
||||
import cx from 'classnames'
|
||||
import FileAPI from '@/client/api/file'
|
||||
import { Text } from '@/lib'
|
||||
|
||||
export type PathProps = {
|
||||
rootId: string
|
||||
fileId: string
|
||||
maxCharacters?: number
|
||||
onClick?: (fileId: string) => void
|
||||
}
|
||||
|
||||
const Path = ({ rootId, fileId, maxCharacters, onClick }: PathProps) => {
|
||||
const { data: path, error, isLoading } = FileAPI.useGetPath(fileId)
|
||||
const hasMore = path && path.length > 3
|
||||
const shortPath = useMemo(() => {
|
||||
if (!path) {
|
||||
return []
|
||||
}
|
||||
return hasMore ? path.slice(1).slice(-3) : path.slice(1)
|
||||
}, [hasMore, path])
|
||||
|
||||
return (
|
||||
<>
|
||||
{path && !error ? (
|
||||
<Breadcrumb className={cx('overflow-hidden', 'shrink-0')}>
|
||||
<BreadcrumbItem>
|
||||
<BreadcrumbLink
|
||||
className={cx('nowrap')}
|
||||
onClick={() => onClick?.(rootId)}
|
||||
>
|
||||
Home
|
||||
</BreadcrumbLink>
|
||||
</BreadcrumbItem>
|
||||
{hasMore ? (
|
||||
<BreadcrumbItem>
|
||||
<BreadcrumbLink>…</BreadcrumbLink>
|
||||
</BreadcrumbItem>
|
||||
) : null}
|
||||
{shortPath.map((file) => (
|
||||
<BreadcrumbItem key={file.id}>
|
||||
<BreadcrumbLink
|
||||
isCurrentPage={fileId === file.id}
|
||||
onClick={() => onClick?.(file.id)}
|
||||
>
|
||||
{maxCharacters ? (
|
||||
<Text maxCharacters={maxCharacters}>{file.name}</Text>
|
||||
) : (
|
||||
file.name
|
||||
)}
|
||||
</BreadcrumbLink>
|
||||
</BreadcrumbItem>
|
||||
))}
|
||||
</Breadcrumb>
|
||||
) : null}
|
||||
{isLoading ? (
|
||||
<div
|
||||
className={cx(
|
||||
'flex',
|
||||
'flex-row',
|
||||
'items-center',
|
||||
'gap-0.5',
|
||||
'flex-shrink-0',
|
||||
)}
|
||||
>
|
||||
<Skeleton className={cx('w-[100px]', 'h-[20px]', 'rounded-[20px]')} />
|
||||
<span>/</span>
|
||||
<Skeleton className={cx('w-[100px]', 'h-[20px]', 'rounded-[20px]')} />
|
||||
<span>/</span>
|
||||
<Skeleton className={cx('w-[100px]', 'h-[20px]', 'rounded-[20px]')} />
|
||||
</div>
|
||||
) : null}
|
||||
</>
|
||||
)
|
||||
}
|
||||
|
||||
export default Path
|
Reference in New Issue
Block a user