Extract createVoiceMessageContent (#9322)
This commit is contained in:
parent
3e076c8246
commit
7a33818bd7
5 changed files with 143 additions and 33 deletions
|
@ -16,7 +16,6 @@ limitations under the License.
|
||||||
|
|
||||||
import React, { ReactNode } from "react";
|
import React, { ReactNode } from "react";
|
||||||
import { Room } from "matrix-js-sdk/src/models/room";
|
import { Room } from "matrix-js-sdk/src/models/room";
|
||||||
import { MsgType } from "matrix-js-sdk/src/@types/event";
|
|
||||||
import { logger } from "matrix-js-sdk/src/logger";
|
import { logger } from "matrix-js-sdk/src/logger";
|
||||||
import { Optional } from "matrix-events-sdk";
|
import { Optional } from "matrix-events-sdk";
|
||||||
import { IEventRelation, MatrixEvent } from "matrix-js-sdk/src/models/event";
|
import { IEventRelation, MatrixEvent } from "matrix-js-sdk/src/models/event";
|
||||||
|
@ -45,6 +44,7 @@ import { addReplyToMessageContent } from "../../../utils/Reply";
|
||||||
import { RoomPermalinkCreator } from "../../../utils/permalinks/Permalinks";
|
import { RoomPermalinkCreator } from "../../../utils/permalinks/Permalinks";
|
||||||
import RoomContext from "../../../contexts/RoomContext";
|
import RoomContext from "../../../contexts/RoomContext";
|
||||||
import { IUpload, VoiceMessageRecording } from "../../../audio/VoiceMessageRecording";
|
import { IUpload, VoiceMessageRecording } from "../../../audio/VoiceMessageRecording";
|
||||||
|
import { createVoiceMessageContent } from "../../../utils/createVoiceMessageContent";
|
||||||
|
|
||||||
interface IProps {
|
interface IProps {
|
||||||
room: Room;
|
room: Room;
|
||||||
|
@ -122,36 +122,14 @@ export default class VoiceRecordComposerTile extends React.PureComponent<IProps,
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// noinspection ES6MissingAwait - we don't care if it fails, it'll get queued.
|
// noinspection ES6MissingAwait - we don't care if it fails, it'll get queued.
|
||||||
const content = {
|
const content = createVoiceMessageContent(
|
||||||
"body": "Voice message",
|
upload.mxc,
|
||||||
//"msgtype": "org.matrix.msc2516.voice",
|
this.state.recorder.contentType,
|
||||||
"msgtype": MsgType.Audio,
|
Math.round(this.state.recorder.durationSeconds * 1000),
|
||||||
"url": upload.mxc,
|
this.state.recorder.contentLength,
|
||||||
"file": upload.encrypted,
|
upload.encrypted,
|
||||||
"info": {
|
this.state.recorder.getPlayback().thumbnailWaveform.map(v => Math.round(v * 1024)),
|
||||||
duration: Math.round(this.state.recorder.durationSeconds * 1000),
|
);
|
||||||
mimetype: this.state.recorder.contentType,
|
|
||||||
size: this.state.recorder.contentLength,
|
|
||||||
},
|
|
||||||
|
|
||||||
// MSC1767 + Ideals of MSC2516 as MSC3245
|
|
||||||
// https://github.com/matrix-org/matrix-doc/pull/3245
|
|
||||||
"org.matrix.msc1767.text": "Voice message",
|
|
||||||
"org.matrix.msc1767.file": {
|
|
||||||
url: upload.mxc,
|
|
||||||
file: upload.encrypted,
|
|
||||||
name: "Voice message.ogg",
|
|
||||||
mimetype: this.state.recorder.contentType,
|
|
||||||
size: this.state.recorder.contentLength,
|
|
||||||
},
|
|
||||||
"org.matrix.msc1767.audio": {
|
|
||||||
duration: Math.round(this.state.recorder.durationSeconds * 1000),
|
|
||||||
|
|
||||||
// https://github.com/matrix-org/matrix-doc/pull/3246
|
|
||||||
waveform: this.state.recorder.getPlayback().thumbnailWaveform.map(v => Math.round(v * 1024)),
|
|
||||||
},
|
|
||||||
"org.matrix.msc3245.voice": {}, // No content, this is a rendering hint
|
|
||||||
};
|
|
||||||
|
|
||||||
attachRelation(content, relation);
|
attachRelation(content, relation);
|
||||||
if (replyToEvent) {
|
if (replyToEvent) {
|
||||||
|
|
64
src/utils/createVoiceMessageContent.ts
Normal file
64
src/utils/createVoiceMessageContent.ts
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
/*
|
||||||
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { IEncryptedFile, MsgType } from "matrix-js-sdk/src/matrix";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {string} mxc MXC URL of the file
|
||||||
|
* @param {string} mimetype
|
||||||
|
* @param {number} duration Duration in milliseconds
|
||||||
|
* @param {number} size
|
||||||
|
* @param {number[]} [waveform]
|
||||||
|
* @param {IEncryptedFile} [file] Encrypted file
|
||||||
|
*/
|
||||||
|
export const createVoiceMessageContent = (
|
||||||
|
mxc: string,
|
||||||
|
mimetype: string,
|
||||||
|
duration: number,
|
||||||
|
size: number,
|
||||||
|
file?: IEncryptedFile,
|
||||||
|
waveform?: number[],
|
||||||
|
) => {
|
||||||
|
return {
|
||||||
|
"body": "Voice message",
|
||||||
|
//"msgtype": "org.matrix.msc2516.voice",
|
||||||
|
"msgtype": MsgType.Audio,
|
||||||
|
"url": mxc,
|
||||||
|
"file": file,
|
||||||
|
"info": {
|
||||||
|
duration,
|
||||||
|
mimetype,
|
||||||
|
size,
|
||||||
|
},
|
||||||
|
|
||||||
|
// MSC1767 + Ideals of MSC2516 as MSC3245
|
||||||
|
// https://github.com/matrix-org/matrix-doc/pull/3245
|
||||||
|
"org.matrix.msc1767.text": "Voice message",
|
||||||
|
"org.matrix.msc1767.file": {
|
||||||
|
url: mxc,
|
||||||
|
file,
|
||||||
|
name: "Voice message.ogg",
|
||||||
|
mimetype,
|
||||||
|
size,
|
||||||
|
},
|
||||||
|
"org.matrix.msc1767.audio": {
|
||||||
|
duration,
|
||||||
|
// https://github.com/matrix-org/matrix-doc/pull/3246
|
||||||
|
waveform,
|
||||||
|
},
|
||||||
|
"org.matrix.msc3245.voice": {}, // No content, this is a rendering hint
|
||||||
|
};
|
||||||
|
};
|
|
@ -57,7 +57,7 @@ describe("<VoiceRecordComposerTile/>", () => {
|
||||||
durationSeconds: 1337,
|
durationSeconds: 1337,
|
||||||
contentType: "audio/ogg",
|
contentType: "audio/ogg",
|
||||||
getPlayback: () => ({
|
getPlayback: () => ({
|
||||||
thumbnailWaveform: [],
|
thumbnailWaveform: [1.4, 2.5, 3.6],
|
||||||
}),
|
}),
|
||||||
} as unknown as VoiceRecording;
|
} as unknown as VoiceRecording;
|
||||||
voiceRecordComposerTile = mount(<VoiceRecordComposerTile {...props} />);
|
voiceRecordComposerTile = mount(<VoiceRecordComposerTile {...props} />);
|
||||||
|
@ -88,7 +88,11 @@ describe("<VoiceRecordComposerTile/>", () => {
|
||||||
"msgtype": MsgType.Audio,
|
"msgtype": MsgType.Audio,
|
||||||
"org.matrix.msc1767.audio": {
|
"org.matrix.msc1767.audio": {
|
||||||
"duration": 1337000,
|
"duration": 1337000,
|
||||||
"waveform": [],
|
"waveform": [
|
||||||
|
1434,
|
||||||
|
2560,
|
||||||
|
3686,
|
||||||
|
],
|
||||||
},
|
},
|
||||||
"org.matrix.msc1767.file": {
|
"org.matrix.msc1767.file": {
|
||||||
"file": undefined,
|
"file": undefined,
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||||
|
|
||||||
|
exports[`createVoiceMessageContent should create a voice message content 1`] = `
|
||||||
|
Object {
|
||||||
|
"body": "Voice message",
|
||||||
|
"file": Object {},
|
||||||
|
"info": Object {
|
||||||
|
"duration": 23000,
|
||||||
|
"mimetype": "ogg/opus",
|
||||||
|
"size": 42000,
|
||||||
|
},
|
||||||
|
"msgtype": "m.audio",
|
||||||
|
"org.matrix.msc1767.audio": Object {
|
||||||
|
"duration": 23000,
|
||||||
|
"waveform": Array [
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
3,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
"org.matrix.msc1767.file": Object {
|
||||||
|
"file": Object {},
|
||||||
|
"mimetype": "ogg/opus",
|
||||||
|
"name": "Voice message.ogg",
|
||||||
|
"size": 42000,
|
||||||
|
"url": "mxc://example.com/file",
|
||||||
|
},
|
||||||
|
"org.matrix.msc1767.text": "Voice message",
|
||||||
|
"org.matrix.msc3245.voice": Object {},
|
||||||
|
"url": "mxc://example.com/file",
|
||||||
|
}
|
||||||
|
`;
|
32
test/utils/createVoiceMessageContent-test.ts
Normal file
32
test/utils/createVoiceMessageContent-test.ts
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
/*
|
||||||
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { IEncryptedFile } from "matrix-js-sdk/src/matrix";
|
||||||
|
|
||||||
|
import { createVoiceMessageContent } from "../../src/utils/createVoiceMessageContent";
|
||||||
|
|
||||||
|
describe("createVoiceMessageContent", () => {
|
||||||
|
it("should create a voice message content", () => {
|
||||||
|
expect(createVoiceMessageContent(
|
||||||
|
"mxc://example.com/file",
|
||||||
|
"ogg/opus",
|
||||||
|
23000,
|
||||||
|
42000,
|
||||||
|
{} as unknown as IEncryptedFile,
|
||||||
|
[1, 2, 3],
|
||||||
|
)).toMatchSnapshot();
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue