mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-09-28 19:59:59 +02:00
integrate deletion to collab sessions
This commit is contained in:
@@ -72,6 +72,7 @@ import {
|
||||
} from "../data/FileManager";
|
||||
import { LocalData } from "../data/LocalData";
|
||||
import {
|
||||
deleteRoomFromFirebase,
|
||||
isSavedToFirebase,
|
||||
loadFilesFromFirebase,
|
||||
loadFromFirebase,
|
||||
@@ -115,6 +116,7 @@ export interface CollabAPI {
|
||||
onPointerUpdate: CollabInstance["onPointerUpdate"];
|
||||
startCollaboration: CollabInstance["startCollaboration"];
|
||||
stopCollaboration: CollabInstance["stopCollaboration"];
|
||||
deleteRoom: CollabInstance["deleteRoom"];
|
||||
syncElements: CollabInstance["syncElements"];
|
||||
fetchImageFilesFromFirebase: CollabInstance["fetchImageFilesFromFirebase"];
|
||||
setUsername: CollabInstance["setUsername"];
|
||||
@@ -228,6 +230,7 @@ class Collab extends PureComponent<CollabProps, CollabState> {
|
||||
isCollaborating: this.isCollaborating,
|
||||
onPointerUpdate: this.onPointerUpdate,
|
||||
startCollaboration: this.startCollaboration,
|
||||
deleteRoom: this.deleteRoom,
|
||||
syncElements: this.syncElements,
|
||||
fetchImageFilesFromFirebase: this.fetchImageFilesFromFirebase,
|
||||
stopCollaboration: this.stopCollaboration,
|
||||
@@ -675,6 +678,18 @@ class Collab extends PureComponent<CollabProps, CollabState> {
|
||||
break;
|
||||
}
|
||||
|
||||
case WS_SUBTYPES.DELETE: {
|
||||
const { roomId } = decryptedData.payload;
|
||||
if (this.portal.roomId === roomId) {
|
||||
this.destroySocketClient({ isUnload: true });
|
||||
this.setIsCollaborating(false);
|
||||
this.setActiveRoomLink(null);
|
||||
this.setErrorDialog(t("alerts.collabRoomDeleted"));
|
||||
window.history.pushState({}, APP_NAME, window.location.origin);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
default: {
|
||||
assertNever(decryptedData, null);
|
||||
}
|
||||
@@ -894,6 +909,42 @@ class Collab extends PureComponent<CollabProps, CollabState> {
|
||||
});
|
||||
};
|
||||
|
||||
deleteRoom = async (): Promise<void> => {
|
||||
if (!this.portal.socket || !this.portal.roomId) {
|
||||
return;
|
||||
}
|
||||
|
||||
const { roomId, roomKey } = this.portal;
|
||||
if (!roomId || !roomKey) {
|
||||
return;
|
||||
}
|
||||
|
||||
const link = this.getActiveRoomLink();
|
||||
if (!link) {
|
||||
return;
|
||||
}
|
||||
|
||||
// check if the room belongs to the current user
|
||||
const isOwner = await roomManager.isRoomOwnedByUser(link);
|
||||
|
||||
if (!isOwner) {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
this.portal.broadcastRoomDeletion();
|
||||
await deleteRoomFromFirebase(roomId, roomKey);
|
||||
await roomManager.deleteRoom(roomId);
|
||||
this.stopCollaboration(false);
|
||||
this.setActiveRoomLink(null);
|
||||
window.history.pushState({}, APP_NAME, window.location.origin);
|
||||
} catch (error) {
|
||||
console.error("Failed to delete room:", error);
|
||||
this.setErrorDialog(t("errors.roomDeletionFailed"));
|
||||
throw error;
|
||||
}
|
||||
};
|
||||
|
||||
public setLastBroadcastedOrReceivedSceneVersion = (version: number) => {
|
||||
this.lastBroadcastedOrReceivedSceneVersion = version;
|
||||
};
|
||||
|
Reference in New Issue
Block a user