diff --git a/src/i18n/strings/en_EN.json b/src/i18n/strings/en_EN.json index 7fbcac9569..3aa40c62e6 100644 --- a/src/i18n/strings/en_EN.json +++ b/src/i18n/strings/en_EN.json @@ -831,6 +831,8 @@ "The person who invited you has already left.": "The person who invited you has already left.", "The person who invited you has already left, or their server is offline.": "The person who invited you has already left, or their server is offline.", "Failed to join": "Failed to join", + "Connection lost": "Connection lost", + "You were disconnected from the call. (Error: %(message)s)": "You were disconnected from the call. (Error: %(message)s)", "All rooms": "All rooms", "Home": "Home", "Favourites": "Favourites", diff --git a/src/stores/widgets/ElementWidgetActions.ts b/src/stores/widgets/ElementWidgetActions.ts index df82bf3b1f..7ad41885be 100644 --- a/src/stores/widgets/ElementWidgetActions.ts +++ b/src/stores/widgets/ElementWidgetActions.ts @@ -36,6 +36,12 @@ export enum ElementWidgetActions { ViewRoom = "io.element.view_room", } +export interface IHangupCallApiRequest extends IWidgetApiRequest { + data: { + errorMessage?: string; + }; +} + /** * @deprecated Use MSC2931 instead */ diff --git a/src/stores/widgets/StopGapWidget.ts b/src/stores/widgets/StopGapWidget.ts index 33395b7942..8d40a89ef8 100644 --- a/src/stores/widgets/StopGapWidget.ts +++ b/src/stores/widgets/StopGapWidget.ts @@ -37,6 +37,7 @@ import { MatrixEvent, MatrixEventEvent } from "matrix-js-sdk/src/models/event"; import { logger } from "matrix-js-sdk/src/logger"; import { ClientEvent } from "matrix-js-sdk/src/client"; +import { _t } from "../../languageHandler"; import { StopGapWidgetDriver } from "./StopGapWidgetDriver"; import { WidgetMessagingStore } from "./WidgetMessagingStore"; import { RoomViewStore } from "../RoomViewStore"; @@ -50,7 +51,7 @@ import ActiveWidgetStore from "../ActiveWidgetStore"; import { objectShallowClone } from "../../utils/objects"; import defaultDispatcher from "../../dispatcher/dispatcher"; import { Action } from "../../dispatcher/actions"; -import { ElementWidgetActions, IViewRoomApiRequest } from "./ElementWidgetActions"; +import { ElementWidgetActions, IHangupCallApiRequest, IViewRoomApiRequest } from "./ElementWidgetActions"; import { ModalWidgetStore } from "../ModalWidgetStore"; import ThemeWatcher from "../../settings/watchers/ThemeWatcher"; import { getCustomTheme } from "../../theme"; @@ -60,6 +61,8 @@ import { getUserLanguage } from "../../languageHandler"; import { WidgetVariableCustomisations } from "../../customisations/WidgetVariables"; import { arrayFastClone } from "../../utils/arrays"; import { ViewRoomPayload } from "../../dispatcher/payloads/ViewRoomPayload"; +import Modal from "../../Modal"; +import ErrorDialog from "../../components/views/dialogs/ErrorDialog"; // TODO: Destroy all of this code @@ -367,6 +370,21 @@ export class StopGapWidget extends EventEmitter { }, ); } + + if (WidgetType.JITSI.matches(this.mockWidget.type)) { + this.messaging.on(`action:${ElementWidgetActions.HangupCall}`, + (ev: CustomEvent) => { + if (ev.detail.data?.errorMessage) { + Modal.createTrackedDialog("Connection lost", "", ErrorDialog, { + title: _t("Connection lost"), + description: _t("You were disconnected from the call. (Error: %(message)s)", { + message: ev.detail.data.errorMessage, + }), + }); + } + }, + ); + } } public async prepare(): Promise {