* chore: rebase and clean-up
* feat: sync description, add e2e tests
* feat: simplify web code
* chore: unit tests
* fix: linting
* Bug fix with the arrows key
* timezone typeahead filter
timezone typeahead filter
* small stlying
* format fix
* Bug fix in the map selection
Bug fix in the map selection
* Websocket basic
Websocket basic
* Update metadata visualisation through the websocket
* Update timeline
* fix merge
* fix web
* fix web
* maplibre system
* format fix
* format fix
* refactor: clean up
* Fix small bug in the hour/timezone
* Don't diplay modify for readOnly asset
* Add log in case of failure
* Formater + try/catch error
* Remove everything related to websocket
* Revert "Remove everything related to websocket"
This reverts commit 14bcb9e1e4.
* remove notification
* fix test
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
62 lines
2.0 KiB
TypeScript
62 lines
2.0 KiB
TypeScript
import type { AssetResponseDto, ServerVersionResponseDto } from '@api';
|
|
import { Socket, io } from 'socket.io-client';
|
|
import { writable } from 'svelte/store';
|
|
import { loadConfig } from './server-config.store';
|
|
|
|
export interface ReleaseEvent {
|
|
isAvailable: boolean;
|
|
checkedAt: Date;
|
|
serverVersion: ServerVersionResponseDto;
|
|
releaseVersion: ServerVersionResponseDto;
|
|
}
|
|
|
|
export const websocketStore = {
|
|
onUploadSuccess: writable<AssetResponseDto>(),
|
|
onAssetDelete: writable<string>(),
|
|
onAssetTrash: writable<string[]>(),
|
|
onAssetUpdate: writable<AssetResponseDto>(),
|
|
onPersonThumbnail: writable<string>(),
|
|
serverVersion: writable<ServerVersionResponseDto>(),
|
|
connected: writable<boolean>(false),
|
|
onRelease: writable<ReleaseEvent>(),
|
|
};
|
|
|
|
let websocket: Socket | null = null;
|
|
|
|
export const openWebsocketConnection = () => {
|
|
try {
|
|
if (websocket) {
|
|
return;
|
|
}
|
|
|
|
websocket = io('', {
|
|
path: '/api/socket.io',
|
|
reconnection: true,
|
|
forceNew: true,
|
|
autoConnect: true,
|
|
});
|
|
|
|
websocket
|
|
.on('connect', () => websocketStore.connected.set(true))
|
|
.on('disconnect', () => websocketStore.connected.set(false))
|
|
// .on('on_upload_success', (data) => websocketStore.onUploadSuccess.set(data))
|
|
.on('on_asset_delete', (data) => websocketStore.onAssetDelete.set(data))
|
|
.on('on_asset_trash', (data) => websocketStore.onAssetTrash.set(data))
|
|
.on('on_asset_update', (data) => websocketStore.onAssetUpdate.set(data))
|
|
.on('on_person_thumbnail', (data) => websocketStore.onPersonThumbnail.set(data))
|
|
.on('on_server_version', (data) => websocketStore.serverVersion.set(data))
|
|
.on('on_config_update', () => loadConfig())
|
|
.on('on_new_release', (data) => websocketStore.onRelease.set(data))
|
|
.on('error', (e) => console.log('Websocket Error', e));
|
|
} catch (e) {
|
|
console.log('Cannot connect to websocket ', e);
|
|
}
|
|
};
|
|
|
|
export const closeWebsocketConnection = () => {
|
|
if (websocket) {
|
|
websocket.close();
|
|
}
|
|
websocket = null;
|
|
};
|