mirror of
https://github.com/colanode/colanode.git
synced 2025-12-16 11:47:47 +01:00
* 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
110 lines
2.5 KiB
TypeScript
110 lines
2.5 KiB
TypeScript
import { ChangeCheckResult, QueryHandler } from '@colanode/client/lib/types';
|
|
import {
|
|
FileUrlGetQueryInput,
|
|
FileUrlGetQueryOutput,
|
|
} from '@colanode/client/queries/files/file-url-get';
|
|
import { AppService } from '@colanode/client/services';
|
|
import { Event } from '@colanode/client/types/events';
|
|
|
|
export class FileUrlGetQueryHandler
|
|
implements QueryHandler<FileUrlGetQueryInput>
|
|
{
|
|
private readonly app: AppService;
|
|
|
|
constructor(app: AppService) {
|
|
this.app = app;
|
|
}
|
|
|
|
public async handleQuery(
|
|
input: FileUrlGetQueryInput
|
|
): Promise<FileUrlGetQueryOutput> {
|
|
return await this.buildFileUrl(input);
|
|
}
|
|
|
|
public async checkForChanges(
|
|
event: Event,
|
|
input: FileUrlGetQueryInput,
|
|
_: FileUrlGetQueryOutput
|
|
): Promise<ChangeCheckResult<FileUrlGetQueryInput>> {
|
|
if (
|
|
event.type === 'workspace.deleted' &&
|
|
event.workspace.accountId === input.accountId &&
|
|
event.workspace.id === input.workspaceId
|
|
) {
|
|
return {
|
|
hasChanges: true,
|
|
result: {
|
|
url: null,
|
|
},
|
|
};
|
|
}
|
|
|
|
if (
|
|
event.type === 'file.state.updated' &&
|
|
event.accountId === input.accountId &&
|
|
event.workspaceId === input.workspaceId &&
|
|
event.fileState.id === input.id
|
|
) {
|
|
const output = await this.handleQuery(input);
|
|
return {
|
|
hasChanges: true,
|
|
result: output,
|
|
};
|
|
}
|
|
|
|
if (
|
|
event.type === 'node.deleted' &&
|
|
event.accountId === input.accountId &&
|
|
event.workspaceId === input.workspaceId &&
|
|
event.node.id === input.id
|
|
) {
|
|
return {
|
|
hasChanges: true,
|
|
result: {
|
|
url: null,
|
|
},
|
|
};
|
|
}
|
|
|
|
if (
|
|
event.type === 'node.created' &&
|
|
event.accountId === input.accountId &&
|
|
event.workspaceId === input.workspaceId &&
|
|
event.node.id === input.id
|
|
) {
|
|
const newOutput = await this.handleQuery(input);
|
|
return {
|
|
hasChanges: true,
|
|
result: newOutput,
|
|
};
|
|
}
|
|
|
|
return {
|
|
hasChanges: false,
|
|
};
|
|
}
|
|
|
|
private async buildFileUrl(
|
|
input: FileUrlGetQueryInput
|
|
): Promise<FileUrlGetQueryOutput> {
|
|
const filePath = this.app.path.workspaceFile(
|
|
input.accountId,
|
|
input.workspaceId,
|
|
input.id,
|
|
input.extension
|
|
);
|
|
|
|
const exists = await this.app.fs.exists(filePath);
|
|
if (!exists) {
|
|
return {
|
|
url: null,
|
|
};
|
|
}
|
|
|
|
const url = await this.app.fs.url(filePath);
|
|
return {
|
|
url,
|
|
};
|
|
}
|
|
}
|