Mute broadcast chunk notifications
This commit is contained in:
parent
6d6adc8c02
commit
cb4e444a60
3 changed files with 50 additions and 0 deletions
|
@ -50,6 +50,7 @@ import { localNotificationsAreSilenced, createLocalNotificationSettingsIfNeeded
|
||||||
import { getIncomingCallToastKey, IncomingCallToast } from "./toasts/IncomingCallToast";
|
import { getIncomingCallToastKey, IncomingCallToast } from "./toasts/IncomingCallToast";
|
||||||
import ToastStore from "./stores/ToastStore";
|
import ToastStore from "./stores/ToastStore";
|
||||||
import { ElementCall } from "./models/Call";
|
import { ElementCall } from "./models/Call";
|
||||||
|
import { VoiceBroadcastChunkEventType } from "./voice-broadcast";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Dispatches:
|
* Dispatches:
|
||||||
|
@ -77,6 +78,13 @@ const msgTypeHandlers = {
|
||||||
[M_LOCATION.altName]: (event: MatrixEvent) => {
|
[M_LOCATION.altName]: (event: MatrixEvent) => {
|
||||||
return TextForEvent.textForLocationEvent(event)();
|
return TextForEvent.textForLocationEvent(event)();
|
||||||
},
|
},
|
||||||
|
[MsgType.Audio]: (event: MatrixEvent): string | null => {
|
||||||
|
if (event.getContent()?.[VoiceBroadcastChunkEventType]) {
|
||||||
|
// mute broadcast chunks
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return TextForEvent.textForEvent(event);
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export const Notifier = {
|
export const Notifier = {
|
||||||
|
|
|
@ -20,6 +20,7 @@ import { Room, RoomEvent } from "matrix-js-sdk/src/models/room";
|
||||||
import { IContent, MatrixEvent } from "matrix-js-sdk/src/models/event";
|
import { IContent, MatrixEvent } from "matrix-js-sdk/src/models/event";
|
||||||
import { SyncState } from "matrix-js-sdk/src/sync";
|
import { SyncState } from "matrix-js-sdk/src/sync";
|
||||||
import { waitFor } from "@testing-library/react";
|
import { waitFor } from "@testing-library/react";
|
||||||
|
import { EventType, MsgType } from "matrix-js-sdk/src/matrix";
|
||||||
|
|
||||||
import BasePlatform from "../src/BasePlatform";
|
import BasePlatform from "../src/BasePlatform";
|
||||||
import { ElementCall } from "../src/models/Call";
|
import { ElementCall } from "../src/models/Call";
|
||||||
|
@ -39,6 +40,7 @@ import { mkThread } from "./test-utils/threads";
|
||||||
import dis from "../src/dispatcher/dispatcher";
|
import dis from "../src/dispatcher/dispatcher";
|
||||||
import { ThreadPayload } from "../src/dispatcher/payloads/ThreadPayload";
|
import { ThreadPayload } from "../src/dispatcher/payloads/ThreadPayload";
|
||||||
import { Action } from "../src/dispatcher/actions";
|
import { Action } from "../src/dispatcher/actions";
|
||||||
|
import { VoiceBroadcastChunkEventType } from "../src/voice-broadcast";
|
||||||
|
|
||||||
jest.mock("../src/utils/notifications", () => ({
|
jest.mock("../src/utils/notifications", () => ({
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
@ -73,6 +75,22 @@ describe("Notifier", () => {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const mkAudioEvent = (broadcastChunk = false): MatrixEvent => {
|
||||||
|
const chunkContent = broadcastChunk ? { [VoiceBroadcastChunkEventType]: {} } : {};
|
||||||
|
|
||||||
|
return mkEvent({
|
||||||
|
event: true,
|
||||||
|
type: EventType.RoomMessage,
|
||||||
|
user: "@user:example.com",
|
||||||
|
room: "!room:example.com",
|
||||||
|
content: {
|
||||||
|
...chunkContent,
|
||||||
|
msgtype: MsgType.Audio,
|
||||||
|
body: "test audio message",
|
||||||
|
},
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
accountDataStore = {};
|
accountDataStore = {};
|
||||||
mockClient = getMockClientWithEventEmitter({
|
mockClient = getMockClientWithEventEmitter({
|
||||||
|
@ -256,6 +274,24 @@ describe("Notifier", () => {
|
||||||
Notifier._displayPopupNotification(testEvent, testRoom);
|
Notifier._displayPopupNotification(testEvent, testRoom);
|
||||||
expect(MockPlatform.displayNotification).toHaveBeenCalledTimes(count);
|
expect(MockPlatform.displayNotification).toHaveBeenCalledTimes(count);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("should display a notification for a voice message", () => {
|
||||||
|
const audioEvent = mkAudioEvent();
|
||||||
|
Notifier._displayPopupNotification(audioEvent, testRoom);
|
||||||
|
expect(MockPlatform.displayNotification).toHaveBeenCalledWith(
|
||||||
|
"@user:example.com (!room1:server)",
|
||||||
|
"@user:example.com: test audio message",
|
||||||
|
"",
|
||||||
|
testRoom,
|
||||||
|
audioEvent,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not display a notification for a broadcast chunk", () => {
|
||||||
|
const audioEvent = mkAudioEvent(true);
|
||||||
|
Notifier._displayPopupNotification(audioEvent, testRoom);
|
||||||
|
expect(MockPlatform.displayNotification).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("getSoundForRoom", () => {
|
describe("getSoundForRoom", () => {
|
||||||
|
@ -456,6 +492,11 @@ describe("Notifier", () => {
|
||||||
Notifier._evaluateEvent(events[1]);
|
Notifier._evaluateEvent(events[1]);
|
||||||
expect(Notifier._displayPopupNotification).toHaveBeenCalledTimes(1);
|
expect(Notifier._displayPopupNotification).toHaveBeenCalledTimes(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("should show a pop-up for an audio message", () => {
|
||||||
|
Notifier._evaluateEvent(mkAudioEvent());
|
||||||
|
expect(Notifier._displayPopupNotification).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("setPromptHidden", () => {
|
describe("setPromptHidden", () => {
|
||||||
|
|
|
@ -92,6 +92,7 @@ export const unmockClientPeg = () => jest.spyOn(MatrixClientPeg, "get").mockRest
|
||||||
*/
|
*/
|
||||||
export const mockClientMethodsUser = (userId = "@alice:domain") => ({
|
export const mockClientMethodsUser = (userId = "@alice:domain") => ({
|
||||||
getUserId: jest.fn().mockReturnValue(userId),
|
getUserId: jest.fn().mockReturnValue(userId),
|
||||||
|
getSafeUserId: jest.fn().mockReturnValue(userId),
|
||||||
getUser: jest.fn().mockReturnValue(new User(userId)),
|
getUser: jest.fn().mockReturnValue(new User(userId)),
|
||||||
isGuest: jest.fn().mockReturnValue(false),
|
isGuest: jest.fn().mockReturnValue(false),
|
||||||
mxcUrlToHttp: jest.fn().mockReturnValue("mock-mxcUrlToHttp"),
|
mxcUrlToHttp: jest.fn().mockReturnValue("mock-mxcUrlToHttp"),
|
||||||
|
|
Loading…
Reference in a new issue