matrix-react-sdk
Version:
SDK for matrix.org using React
117 lines (109 loc) • 19.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _logger = require("matrix-js-sdk/src/logger");
var _InlineSpinner = _interopRequireDefault(require("../elements/InlineSpinner"));
var _languageHandler = require("../../../languageHandler");
var _AudioPlayer = _interopRequireDefault(require("../audio_messages/AudioPlayer"));
var _MFileBody = _interopRequireDefault(require("./MFileBody"));
var _PlaybackManager = require("../../../audio/PlaybackManager");
var _EventUtils = require("../../../utils/EventUtils");
var _PlaybackQueue = require("../../../audio/PlaybackQueue");
var _RoomContext = _interopRequireWildcard(require("../../../contexts/RoomContext"));
var _MediaProcessingError = _interopRequireDefault(require("./shared/MediaProcessingError"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2021 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class MAudioBody extends _react.default.PureComponent {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "state", {});
}
async componentDidMount() {
let buffer;
try {
try {
const blob = await this.props.mediaEventHelper.sourceBlob.value;
buffer = await blob.arrayBuffer();
} catch (e) {
this.setState({
error: true
});
_logger.logger.warn("Unable to decrypt audio message", e);
return; // stop processing the audio file
}
} catch (e) {
this.setState({
error: true
});
_logger.logger.warn("Unable to decrypt/download audio message", e);
return; // stop processing the audio file
}
// We should have a buffer to work with now: let's set it up
// Note: we don't actually need a waveform to render an audio event, but voice messages do.
const content = this.props.mxEvent.getContent();
const waveform = content?.["org.matrix.msc1767.audio"]?.waveform?.map(p => p / 1024);
// We should have a buffer to work with now: let's set it up
const playback = _PlaybackManager.PlaybackManager.instance.createPlaybackInstance(buffer, waveform);
playback.clockInfo.populatePlaceholdersFrom(this.props.mxEvent);
this.setState({
playback
});
if ((0, _EventUtils.isVoiceMessage)(this.props.mxEvent)) {
_PlaybackQueue.PlaybackQueue.forRoom(this.props.mxEvent.getRoomId()).unsortedEnqueue(this.props.mxEvent, playback);
}
// Note: the components later on will handle preparing the Playback class for us.
}
componentWillUnmount() {
this.state.playback?.destroy();
}
get showFileBody() {
return this.context.timelineRenderingType !== _RoomContext.TimelineRenderingType.Room && this.context.timelineRenderingType !== _RoomContext.TimelineRenderingType.Pinned && this.context.timelineRenderingType !== _RoomContext.TimelineRenderingType.Search;
}
render() {
if (this.state.error) {
return /*#__PURE__*/_react.default.createElement(_MediaProcessingError.default, {
className: "mx_MAudioBody"
}, (0, _languageHandler._t)("timeline|m.audio|error_processing_audio"));
}
if (this.props.forExport) {
const content = this.props.mxEvent.getContent();
// During export, the content url will point to the MSC, which will later point to a local url
const contentUrl = content.file?.url || content.url;
return /*#__PURE__*/_react.default.createElement("span", {
className: "mx_MAudioBody"
}, /*#__PURE__*/_react.default.createElement("audio", {
src: contentUrl,
controls: true
}));
}
if (!this.state.playback) {
return /*#__PURE__*/_react.default.createElement("span", {
className: "mx_MAudioBody"
}, /*#__PURE__*/_react.default.createElement(_InlineSpinner.default, null));
}
// At this point we should have a playable state
return /*#__PURE__*/_react.default.createElement("span", {
className: "mx_MAudioBody"
}, /*#__PURE__*/_react.default.createElement(_AudioPlayer.default, {
playback: this.state.playback,
mediaName: this.props.mxEvent.getContent().body
}), this.showFileBody && /*#__PURE__*/_react.default.createElement(_MFileBody.default, (0, _extends2.default)({}, this.props, {
showGenericPlaceholder: false
})));
}
}
exports.default = MAudioBody;
(0, _defineProperty2.default)(MAudioBody, "contextType", _RoomContext.default);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_logger","_InlineSpinner","_languageHandler","_AudioPlayer","_MFileBody","_PlaybackManager","_EventUtils","_PlaybackQueue","_RoomContext","_interopRequireWildcard","_MediaProcessingError","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MAudioBody","React","PureComponent","constructor","args","_defineProperty2","componentDidMount","buffer","blob","props","mediaEventHelper","sourceBlob","value","arrayBuffer","setState","error","logger","warn","content","mxEvent","getContent","waveform","map","p","playback","PlaybackManager","instance","createPlaybackInstance","clockInfo","populatePlaceholdersFrom","isVoiceMessage","PlaybackQueue","forRoom","getRoomId","unsortedEnqueue","componentWillUnmount","state","destroy","showFileBody","context","timelineRenderingType","TimelineRenderingType","Room","Pinned","Search","render","createElement","className","_t","forExport","contentUrl","file","url","src","controls","mediaName","body","_extends2","showGenericPlaceholder","exports","RoomContext"],"sources":["../../../../src/components/views/messages/MAudioBody.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React from \"react\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { IContent } from \"matrix-js-sdk/src/matrix\";\nimport { MediaEventContent } from \"matrix-js-sdk/src/types\";\n\nimport { Playback } from \"../../../audio/Playback\";\nimport InlineSpinner from \"../elements/InlineSpinner\";\nimport { _t } from \"../../../languageHandler\";\nimport AudioPlayer from \"../audio_messages/AudioPlayer\";\nimport MFileBody from \"./MFileBody\";\nimport { IBodyProps } from \"./IBodyProps\";\nimport { PlaybackManager } from \"../../../audio/PlaybackManager\";\nimport { isVoiceMessage } from \"../../../utils/EventUtils\";\nimport { PlaybackQueue } from \"../../../audio/PlaybackQueue\";\nimport RoomContext, { TimelineRenderingType } from \"../../../contexts/RoomContext\";\nimport MediaProcessingError from \"./shared/MediaProcessingError\";\n\ninterface IState {\n    error?: boolean;\n    playback?: Playback;\n}\n\nexport default class MAudioBody extends React.PureComponent<IBodyProps, IState> {\n    public static contextType = RoomContext;\n    public declare context: React.ContextType<typeof RoomContext>;\n\n    public state: IState = {};\n\n    public async componentDidMount(): Promise<void> {\n        let buffer: ArrayBuffer;\n\n        try {\n            try {\n                const blob = await this.props.mediaEventHelper!.sourceBlob.value;\n                buffer = await blob.arrayBuffer();\n            } catch (e) {\n                this.setState({ error: true });\n                logger.warn(\"Unable to decrypt audio message\", e);\n                return; // stop processing the audio file\n            }\n        } catch (e) {\n            this.setState({ error: true });\n            logger.warn(\"Unable to decrypt/download audio message\", e);\n            return; // stop processing the audio file\n        }\n\n        // We should have a buffer to work with now: let's set it up\n\n        // Note: we don't actually need a waveform to render an audio event, but voice messages do.\n        const content = this.props.mxEvent.getContent<MediaEventContent & IContent>();\n        const waveform = content?.[\"org.matrix.msc1767.audio\"]?.waveform?.map((p: number) => p / 1024);\n\n        // We should have a buffer to work with now: let's set it up\n        const playback = PlaybackManager.instance.createPlaybackInstance(buffer, waveform);\n        playback.clockInfo.populatePlaceholdersFrom(this.props.mxEvent);\n        this.setState({ playback });\n\n        if (isVoiceMessage(this.props.mxEvent)) {\n            PlaybackQueue.forRoom(this.props.mxEvent.getRoomId()!).unsortedEnqueue(this.props.mxEvent, playback);\n        }\n\n        // Note: the components later on will handle preparing the Playback class for us.\n    }\n\n    public componentWillUnmount(): void {\n        this.state.playback?.destroy();\n    }\n\n    protected get showFileBody(): boolean {\n        return (\n            this.context.timelineRenderingType !== TimelineRenderingType.Room &&\n            this.context.timelineRenderingType !== TimelineRenderingType.Pinned &&\n            this.context.timelineRenderingType !== TimelineRenderingType.Search\n        );\n    }\n\n    public render(): React.ReactNode {\n        if (this.state.error) {\n            return (\n                <MediaProcessingError className=\"mx_MAudioBody\">\n                    {_t(\"timeline|m.audio|error_processing_audio\")}\n                </MediaProcessingError>\n            );\n        }\n\n        if (this.props.forExport) {\n            const content = this.props.mxEvent.getContent();\n            // During export, the content url will point to the MSC, which will later point to a local url\n            const contentUrl = content.file?.url || content.url;\n            return (\n                <span className=\"mx_MAudioBody\">\n                    <audio src={contentUrl} controls />\n                </span>\n            );\n        }\n\n        if (!this.state.playback) {\n            return (\n                <span className=\"mx_MAudioBody\">\n                    <InlineSpinner />\n                </span>\n            );\n        }\n\n        // At this point we should have a playable state\n        return (\n            <span className=\"mx_MAudioBody\">\n                <AudioPlayer playback={this.state.playback} mediaName={this.props.mxEvent.getContent().body} />\n                {this.showFileBody && <MFileBody {...this.props} showGenericPlaceholder={false} />}\n            </span>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}