Files
colanode/packages/ui/src/components/files/file-container.tsx

36 lines
1.3 KiB
TypeScript
Raw Normal View History

Web version (#43) * Create client package * Create the UI package * Init web app * Use isomorphic 'ws' for web sockets * File and asset implementations * Use Opfs SAH version of sqlite in browser * Generate Svg sprites for emojis and icons * Include emojis sprite * Improve and refactor assets * More assets improvements * Implement emoji and icons db import as readonly * Improve import paths * Handle concurrency limits for sqlite * Fix event broadcast in web * Pass windowId for subscribe and unsubscribe queries in desktop * Remove asset context * Implement avatar upload/download with the new structure * Improve file handlings * Move the necessary dependencies to client and ui packages * Update packages * Improve open file dialog * Make sure database files are deleted in browser * Improve avatar loading * Improve file loading * Fix some assets * Implement asset caching for offline access * Small fixes and improvements * Use server instead of pre signed urls for file upload/download * Cleanup some client related metadata * Switch Axios with ky * Refactor mutation results * Minor concurrency fix * Refactor web sockets * Improve file uploading * Handle connection close on server * Use stream for downloading the file * Add config options for cors * Update document in all tabs on local change * Include necessary icons for web * Update docker compose * Implement server upgrade required component * Use correct client type and platform in web and desktop * Improve service worker * Improve versioning * Fix an import * Minor fixes * Update some user endpoints * Minor endpoint changes * Enable app badge for desktop * Add error handling in some database operations * Update mutation naming convention * Update query naming convention * Update event and some metadata naming conventions * Update event and job naming conventions in server * Update Github workflow files * Restructure assets directory * Update packages * Upgrade to Zod v4 * Upgrade to react 19 * Upgrade to tailwind v4 * Minor ui improvements * Fix some cursor pointers * Add browser not supported message in web * Enhance server create flow, allow insecure connections and custom api paths * Execute electron-rebuild as postinstall command * Update docker compose
2025-06-11 00:14:17 +02:00
import { LocalFileNode } from '@colanode/client/types';
2025-11-18 11:07:58 -08:00
import { FileNoPreview } from '@colanode/ui/components/files/file-no-preview';
import { FilePreview } from '@colanode/ui/components/files/file-preview';
import { FileSaveButton } from '@colanode/ui/components/files/file-save-button';
import { FileSidebar } from '@colanode/ui/components/files/file-sidebar';
import { canPreviewFile } from '@colanode/ui/lib/files';
interface FileContainerProps {
2025-11-18 11:07:58 -08:00
file: LocalFileNode;
}
2025-11-18 11:07:58 -08:00
export const FileContainer = ({ file }: FileContainerProps) => {
const canPreview = canPreviewFile(file.attributes.subtype);
2025-11-18 11:07:58 -08:00
return (
<div className="flex h-full max-h-full w-full flex-row items-center gap-2">
<div className="flex flex-col w-full max-w-full h-full grow overflow-hidden">
<div className="flex flex-row w-full items-center justify-end p-4 gap-4">
<FileSaveButton file={file} />
</div>
2024-12-30 21:50:08 +01:00
2025-11-18 11:07:58 -08:00
<div className="flex flex-col grow items-center justify-center overflow-hidden p-10">
{canPreview ? (
<FilePreview file={file} />
) : (
<FileNoPreview mimeType={file.attributes.mimeType} />
)}
</div>
</div>
<div className="h-full w-72 min-w-72 overflow-hidden border-l border-border p-2 pl-3">
<FileSidebar file={file} />
</div>
</div>
);
};