mirror of
https://github.com/immich-app/immich.git
synced 2025-07-09 09:12:57 +02:00
* no-misused-promises * no-floating-promises * format * revert for now * remove load function * require-await * revert a few no-floating-promises changes that would cause no-misused-promises failures * format * fix a few more * fix most remaining errors * executor-queue * executor-queue.spec * remove duplicate comments by grouping rules * upgrade sveltekit and enforce rules * oops. move await * try this * just ignore for now since it's only a test * run in parallel * Update web/src/routes/admin/jobs-status/+page.svelte Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> * remove Promise.resolve call * rename function * remove unnecessary warning silencing * make handleError sync * fix new errors from recently merged PR to main * extract method * use handlePromiseError --------- Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
64 lines
2.1 KiB
TypeScript
64 lines
2.1 KiB
TypeScript
import { createEventEmitter } from '$lib/utils/eventemitter';
|
|
import type { AssetResponseDto, ServerVersionResponseDto } from '@immich/sdk';
|
|
import { io, type Socket } from 'socket.io-client';
|
|
import { get, writable } from 'svelte/store';
|
|
import { user } from './user.store';
|
|
|
|
export interface ReleaseEvent {
|
|
isAvailable: boolean;
|
|
checkedAt: Date;
|
|
serverVersion: ServerVersionResponseDto;
|
|
releaseVersion: ServerVersionResponseDto;
|
|
}
|
|
export interface Events {
|
|
on_upload_success: (asset: AssetResponseDto) => void;
|
|
on_asset_delete: (assetId: string) => void;
|
|
on_asset_trash: (assetIds: string[]) => void;
|
|
on_asset_update: (asset: AssetResponseDto) => void;
|
|
on_asset_hidden: (assetId: string) => void;
|
|
on_asset_restore: (assetIds: string[]) => void;
|
|
on_asset_stack_update: (assetIds: string[]) => void;
|
|
on_person_thumbnail: (personId: string) => void;
|
|
on_server_version: (serverVersion: ServerVersionResponseDto) => void;
|
|
on_config_update: () => void;
|
|
on_new_release: (newRelase: ReleaseEvent) => void;
|
|
}
|
|
|
|
const websocket: Socket<Events> = io('', {
|
|
path: '/api/socket.io',
|
|
transports: ['websocket'],
|
|
reconnection: true,
|
|
forceNew: true,
|
|
autoConnect: false,
|
|
});
|
|
|
|
export const websocketStore = {
|
|
connected: writable<boolean>(false),
|
|
serverVersion: writable<ServerVersionResponseDto>(),
|
|
release: writable<ReleaseEvent>(),
|
|
};
|
|
|
|
export const websocketEvents = createEventEmitter(websocket);
|
|
|
|
websocket
|
|
.on('connect', () => websocketStore.connected.set(true))
|
|
.on('disconnect', () => websocketStore.connected.set(false))
|
|
.on('on_server_version', (serverVersion) => websocketStore.serverVersion.set(serverVersion))
|
|
.on('on_new_release', (releaseVersion) => websocketStore.release.set(releaseVersion))
|
|
.on('connect_error', (e) => console.log('Websocket Connect Error', e));
|
|
|
|
export const openWebsocketConnection = () => {
|
|
try {
|
|
if (!get(user)) {
|
|
return;
|
|
}
|
|
|
|
websocket.connect();
|
|
} catch (error) {
|
|
console.log('Cannot connect to websocket', error);
|
|
}
|
|
};
|
|
|
|
export const closeWebsocketConnection = () => {
|
|
websocket.disconnect();
|
|
};
|