mirror of
https://github.com/colanode/colanode.git
synced 2025-12-16 19:57:46 +01:00
39 lines
1.2 KiB
TypeScript
39 lines
1.2 KiB
TypeScript
import { LocalFileNode } from '@colanode/client/types';
|
|
import { FileBody } from '@colanode/ui/components/files/file-body';
|
|
import { FileNotFound } from '@colanode/ui/components/files/file-not-found';
|
|
import { FileSettings } from '@colanode/ui/components/files/file-settings';
|
|
import { Breadcrumb } from '@colanode/ui/components/layouts/breadcrumbs/breadcrumb';
|
|
import { ContainerSettings } from '@colanode/ui/components/layouts/containers/container-settings';
|
|
import { NodeBreadcrumb } from '@colanode/ui/components/nodes/node-breadcrumb';
|
|
import { useNodeContainer } from '@colanode/ui/hooks/use-node-container';
|
|
import { useNodeRadar } from '@colanode/ui/hooks/use-node-radar';
|
|
|
|
interface FileContainerProps {
|
|
fileId: string;
|
|
}
|
|
|
|
export const FileContainer = ({ fileId }: FileContainerProps) => {
|
|
const data = useNodeContainer<LocalFileNode>(fileId);
|
|
useNodeRadar(data.node);
|
|
|
|
if (data.isPending) {
|
|
return null;
|
|
}
|
|
|
|
if (!data.node) {
|
|
return <FileNotFound />;
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<Breadcrumb>
|
|
<NodeBreadcrumb breadcrumb={data.breadcrumb} />
|
|
</Breadcrumb>
|
|
<ContainerSettings>
|
|
<FileSettings file={data.node} role={data.role} />
|
|
</ContainerSettings>
|
|
<FileBody file={data.node} />
|
|
</>
|
|
);
|
|
};
|