UNPKG

matrix-react-sdk

Version:
238 lines (235 loc) 47 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _call = require("matrix-js-sdk/src/webrtc/call"); var _classnames = _interopRequireDefault(require("classnames")); var _languageHandler = require("../../../languageHandler"); var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar")); var _LegacyCallEventGrouper = require("../../structures/LegacyCallEventGrouper"); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _InfoTooltip = _interopRequireWildcard(require("../elements/InfoTooltip")); var _DateUtils = require("../../../DateUtils"); var _Clock = _interopRequireDefault(require("../audio_messages/Clock")); 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 Šimon Brandner <simon.bra.ag@gmail.com> SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ const MAX_NON_NARROW_WIDTH = 450 / 70 * 100; class LegacyCallEvent extends _react.default.PureComponent { constructor(props) { super(props); (0, _defineProperty2.default)(this, "wrapperElement", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "resizeObserver", void 0); (0, _defineProperty2.default)(this, "onLengthChanged", length => { this.setState({ length }); }); (0, _defineProperty2.default)(this, "resizeObserverCallback", entries => { const wrapperElementEntry = entries.find(entry => entry.target === this.wrapperElement.current); if (!wrapperElementEntry) return; this.setState({ narrow: wrapperElementEntry.contentRect.width < MAX_NON_NARROW_WIDTH }); }); (0, _defineProperty2.default)(this, "onSilencedChanged", newState => { this.setState({ silenced: newState }); }); (0, _defineProperty2.default)(this, "onStateChanged", newState => { this.setState({ callState: newState }); }); this.state = { callState: this.props.callEventGrouper.state, silenced: false, narrow: false, length: 0 }; } componentDidMount() { this.props.callEventGrouper.addListener(_LegacyCallEventGrouper.LegacyCallEventGrouperEvent.StateChanged, this.onStateChanged); this.props.callEventGrouper.addListener(_LegacyCallEventGrouper.LegacyCallEventGrouperEvent.SilencedChanged, this.onSilencedChanged); this.props.callEventGrouper.addListener(_LegacyCallEventGrouper.LegacyCallEventGrouperEvent.LengthChanged, this.onLengthChanged); this.resizeObserver = new ResizeObserver(this.resizeObserverCallback); this.wrapperElement.current && this.resizeObserver.observe(this.wrapperElement.current); } componentWillUnmount() { this.props.callEventGrouper.removeListener(_LegacyCallEventGrouper.LegacyCallEventGrouperEvent.StateChanged, this.onStateChanged); this.props.callEventGrouper.removeListener(_LegacyCallEventGrouper.LegacyCallEventGrouperEvent.SilencedChanged, this.onSilencedChanged); this.props.callEventGrouper.removeListener(_LegacyCallEventGrouper.LegacyCallEventGrouperEvent.LengthChanged, this.onLengthChanged); this.resizeObserver?.disconnect(); } renderCallBackButton(text) { return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_LegacyCallEvent_content_button mx_LegacyCallEvent_content_button_callBack", onClick: this.props.callEventGrouper.callBack, kind: "primary" }, /*#__PURE__*/_react.default.createElement("span", null, " ", text, " ")); } renderSilenceIcon() { const silenceClass = (0, _classnames.default)({ mx_LegacyCallEvent_iconButton: true, mx_LegacyCallEvent_unSilence: this.state.silenced, mx_LegacyCallEvent_silence: !this.state.silenced }); return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: silenceClass, onClick: this.props.callEventGrouper.toggleSilenced, title: this.state.silenced ? (0, _languageHandler._t)("voip|unsilence") : (0, _languageHandler._t)("voip|silence") }); } renderContent() { if (this.state.callState === _call.CallState.Ringing) { let silenceIcon; if (!this.state.narrow) { silenceIcon = this.renderSilenceIcon(); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, silenceIcon, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_LegacyCallEvent_content_button mx_LegacyCallEvent_content_button_reject", onClick: this.props.callEventGrouper.rejectCall, kind: "danger" }, /*#__PURE__*/_react.default.createElement("span", null, " ", (0, _languageHandler._t)("action|decline"), " ")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_LegacyCallEvent_content_button mx_LegacyCallEvent_content_button_answer", onClick: this.props.callEventGrouper.answerCall, kind: "primary" }, /*#__PURE__*/_react.default.createElement("span", null, " ", (0, _languageHandler._t)("action|accept"), " ")), this.props.timestamp); } if (this.state.callState === _call.CallState.Ended) { const hangupReason = this.props.callEventGrouper.hangupReason; const gotRejected = this.props.callEventGrouper.gotRejected; if (gotRejected) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, (0, _languageHandler._t)("timeline|m.call.invite|declined"), this.renderCallBackButton((0, _languageHandler._t)("timeline|m.call.invite|call_back_prompt")), this.props.timestamp); } else if (hangupReason === _call.CallErrorCode.AnsweredElsewhere) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, (0, _languageHandler._t)("timeline|m.call.invite|answered_elsewhere"), this.props.timestamp); } else if (this.props.callEventGrouper.callWasMissed) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, (0, _languageHandler._t)("timeline|m.call.invite|missed_call"), this.renderCallBackButton((0, _languageHandler._t)("timeline|m.call.invite|call_back_prompt")), this.props.timestamp); } else if (!hangupReason || [_call.CallErrorCode.UserHangup, "user hangup"].includes(hangupReason)) { // workaround for https://github.com/vector-im/element-web/issues/5178 // it seems Android randomly sets a reason of "user hangup" which is // interpreted as an error code :( // https://github.com/vector-im/riot-android/issues/2623 // Also the correct hangup code as of VoIP v1 (with underscore) // Also, if we don't have a reason const duration = this.props.callEventGrouper.duration; let text = (0, _languageHandler._t)("timeline|m.call.hangup|dm"); if (duration) { text += " • " + (0, _DateUtils.formatPreciseDuration)(duration); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, text, this.props.timestamp); } else if (hangupReason === _call.CallErrorCode.InviteTimeout) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, (0, _languageHandler._t)("timeline|m.call.invite|no_answer"), this.renderCallBackButton((0, _languageHandler._t)("timeline|m.call.invite|call_back_prompt")), this.props.timestamp); } let reason; if (hangupReason === _call.CallErrorCode.IceFailed) { // We couldn't establish a connection at all reason = (0, _languageHandler._t)("timeline|m.call.invite|failed_connect_media"); } else if (hangupReason === "ice_timeout") { // We established a connection but it died reason = (0, _languageHandler._t)("timeline|m.call.invite|failed_connection"); } else if (hangupReason === _call.CallErrorCode.NoUserMedia) { // The other side couldn't open capture devices reason = (0, _languageHandler._t)("timeline|m.call.invite|failed_opponent_media"); } else if (hangupReason === "unknown_error") { // An error code the other side doesn't have a way to express // (as opposed to an error code they gave but we don't know about, // in which case we show the error code) reason = (0, _languageHandler._t)("timeline|m.call.invite|unknown_error"); } else if (hangupReason === _call.CallErrorCode.UserBusy) { reason = (0, _languageHandler._t)("voip|user_busy_description"); } else { reason = (0, _languageHandler._t)("timeline|m.call.invite|unknown_failure", { reason: hangupReason }); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, /*#__PURE__*/_react.default.createElement(_InfoTooltip.default, { tooltip: reason, className: "mx_LegacyCallEvent_content_tooltip", kind: _InfoTooltip.InfoTooltipKind.Warning }), (0, _languageHandler._t)("timeline|m.call.invite|failed_connection"), this.renderCallBackButton((0, _languageHandler._t)("action|retry")), this.props.timestamp); } if (this.state.callState === _call.CallState.Connected) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, /*#__PURE__*/_react.default.createElement(_Clock.default, { seconds: this.state.length, "aria-live": "off" }), this.props.timestamp); } if (this.state.callState === _call.CallState.Connecting) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, (0, _languageHandler._t)("voip|connecting"), this.props.timestamp); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_content" }, (0, _languageHandler._t)("timeline|m.call.invite|unknown_state"), this.props.timestamp); } render() { const event = this.props.mxEvent; const sender = event.sender ? event.sender.name : event.getSender(); const isVoice = this.props.callEventGrouper.isVoice; const callType = isVoice ? (0, _languageHandler._t)("voip|voice_call") : (0, _languageHandler._t)("voip|video_call"); const callState = this.state.callState; const hangupReason = this.props.callEventGrouper.hangupReason; const content = this.renderContent(); const className = (0, _classnames.default)("mx_LegacyCallEvent", { mx_LegacyCallEvent_voice: isVoice, mx_LegacyCallEvent_video: !isVoice, mx_LegacyCallEvent_narrow: this.state.narrow, mx_LegacyCallEvent_missed: this.props.callEventGrouper.callWasMissed, mx_LegacyCallEvent_noAnswer: callState === _call.CallState.Ended && hangupReason === _call.CallErrorCode.InviteTimeout, mx_LegacyCallEvent_rejected: callState === _call.CallState.Ended && this.props.callEventGrouper.gotRejected }); let silenceIcon; if (this.state.narrow && this.state.callState === _call.CallState.Ringing) { silenceIcon = this.renderSilenceIcon(); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_wrapper", ref: this.wrapperElement }, /*#__PURE__*/_react.default.createElement("div", { className: className }, silenceIcon, /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_info" }, /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, { member: event.sender, size: "32px" }), /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_info_basic" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_sender" }, sender), /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_type" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_LegacyCallEvent_type_icon" }), callType))), content)); } } exports.default = LegacyCallEvent; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_call","_classnames","_interopRequireDefault","_languageHandler","_MemberAvatar","_LegacyCallEventGrouper","_AccessibleButton","_InfoTooltip","_DateUtils","_Clock","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MAX_NON_NARROW_WIDTH","LegacyCallEvent","React","PureComponent","constructor","props","_defineProperty2","createRef","length","setState","entries","wrapperElementEntry","find","entry","target","wrapperElement","current","narrow","contentRect","width","newState","silenced","callState","state","callEventGrouper","componentDidMount","addListener","LegacyCallEventGrouperEvent","StateChanged","onStateChanged","SilencedChanged","onSilencedChanged","LengthChanged","onLengthChanged","resizeObserver","ResizeObserver","resizeObserverCallback","observe","componentWillUnmount","removeListener","disconnect","renderCallBackButton","text","createElement","className","onClick","callBack","kind","renderSilenceIcon","silenceClass","classNames","mx_LegacyCallEvent_iconButton","mx_LegacyCallEvent_unSilence","mx_LegacyCallEvent_silence","toggleSilenced","title","_t","renderContent","CallState","Ringing","silenceIcon","rejectCall","answerCall","timestamp","Ended","hangupReason","gotRejected","CallErrorCode","AnsweredElsewhere","callWasMissed","UserHangup","includes","duration","formatPreciseDuration","InviteTimeout","reason","IceFailed","NoUserMedia","UserBusy","tooltip","InfoTooltipKind","Warning","Connected","seconds","Connecting","render","event","mxEvent","sender","name","getSender","isVoice","callType","content","mx_LegacyCallEvent_voice","mx_LegacyCallEvent_video","mx_LegacyCallEvent_narrow","mx_LegacyCallEvent_missed","mx_LegacyCallEvent_noAnswer","mx_LegacyCallEvent_rejected","ref","member","size","exports"],"sources":["../../../../src/components/views/messages/LegacyCallEvent.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>\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, { createRef } from \"react\";\nimport { MatrixEvent } from \"matrix-js-sdk/src/matrix\";\nimport { CallErrorCode, CallState } from \"matrix-js-sdk/src/webrtc/call\";\nimport classNames from \"classnames\";\n\nimport { _t } from \"../../../languageHandler\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport LegacyCallEventGrouper, { LegacyCallEventGrouperEvent } from \"../../structures/LegacyCallEventGrouper\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport InfoTooltip, { InfoTooltipKind } from \"../elements/InfoTooltip\";\nimport { formatPreciseDuration } from \"../../../DateUtils\";\nimport Clock from \"../audio_messages/Clock\";\n\nconst MAX_NON_NARROW_WIDTH = (450 / 70) * 100;\n\ninterface IProps {\n    mxEvent: MatrixEvent;\n    callEventGrouper: LegacyCallEventGrouper;\n    timestamp?: JSX.Element;\n}\n\ninterface IState {\n    callState?: CallState;\n    silenced: boolean;\n    narrow: boolean;\n    length: number;\n}\n\nexport default class LegacyCallEvent extends React.PureComponent<IProps, IState> {\n    private wrapperElement = createRef<HTMLDivElement>();\n    private resizeObserver?: ResizeObserver;\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            callState: this.props.callEventGrouper.state,\n            silenced: false,\n            narrow: false,\n            length: 0,\n        };\n    }\n\n    public componentDidMount(): void {\n        this.props.callEventGrouper.addListener(LegacyCallEventGrouperEvent.StateChanged, this.onStateChanged);\n        this.props.callEventGrouper.addListener(LegacyCallEventGrouperEvent.SilencedChanged, this.onSilencedChanged);\n        this.props.callEventGrouper.addListener(LegacyCallEventGrouperEvent.LengthChanged, this.onLengthChanged);\n\n        this.resizeObserver = new ResizeObserver(this.resizeObserverCallback);\n        this.wrapperElement.current && this.resizeObserver.observe(this.wrapperElement.current);\n    }\n\n    public componentWillUnmount(): void {\n        this.props.callEventGrouper.removeListener(LegacyCallEventGrouperEvent.StateChanged, this.onStateChanged);\n        this.props.callEventGrouper.removeListener(LegacyCallEventGrouperEvent.SilencedChanged, this.onSilencedChanged);\n        this.props.callEventGrouper.removeListener(LegacyCallEventGrouperEvent.LengthChanged, this.onLengthChanged);\n\n        this.resizeObserver?.disconnect();\n    }\n\n    private onLengthChanged = (length: number): void => {\n        this.setState({ length });\n    };\n\n    private resizeObserverCallback = (entries: ResizeObserverEntry[]): void => {\n        const wrapperElementEntry = entries.find((entry) => entry.target === this.wrapperElement.current);\n        if (!wrapperElementEntry) return;\n\n        this.setState({ narrow: wrapperElementEntry.contentRect.width < MAX_NON_NARROW_WIDTH });\n    };\n\n    private onSilencedChanged = (newState: boolean): void => {\n        this.setState({ silenced: newState });\n    };\n\n    private onStateChanged = (newState: CallState): void => {\n        this.setState({ callState: newState });\n    };\n\n    private renderCallBackButton(text: string): JSX.Element {\n        return (\n            <AccessibleButton\n                className=\"mx_LegacyCallEvent_content_button mx_LegacyCallEvent_content_button_callBack\"\n                onClick={this.props.callEventGrouper.callBack}\n                kind=\"primary\"\n            >\n                <span> {text} </span>\n            </AccessibleButton>\n        );\n    }\n\n    private renderSilenceIcon(): JSX.Element {\n        const silenceClass = classNames({\n            mx_LegacyCallEvent_iconButton: true,\n            mx_LegacyCallEvent_unSilence: this.state.silenced,\n            mx_LegacyCallEvent_silence: !this.state.silenced,\n        });\n\n        return (\n            <AccessibleButton\n                className={silenceClass}\n                onClick={this.props.callEventGrouper.toggleSilenced}\n                title={this.state.silenced ? _t(\"voip|unsilence\") : _t(\"voip|silence\")}\n            />\n        );\n    }\n\n    private renderContent(): JSX.Element {\n        if (this.state.callState === CallState.Ringing) {\n            let silenceIcon;\n            if (!this.state.narrow) {\n                silenceIcon = this.renderSilenceIcon();\n            }\n\n            return (\n                <div className=\"mx_LegacyCallEvent_content\">\n                    {silenceIcon}\n                    <AccessibleButton\n                        className=\"mx_LegacyCallEvent_content_button mx_LegacyCallEvent_content_button_reject\"\n                        onClick={this.props.callEventGrouper.rejectCall}\n                        kind=\"danger\"\n                    >\n                        <span> {_t(\"action|decline\")} </span>\n                    </AccessibleButton>\n                    <AccessibleButton\n                        className=\"mx_LegacyCallEvent_content_button mx_LegacyCallEvent_content_button_answer\"\n                        onClick={this.props.callEventGrouper.answerCall}\n                        kind=\"primary\"\n                    >\n                        <span> {_t(\"action|accept\")} </span>\n                    </AccessibleButton>\n                    {this.props.timestamp}\n                </div>\n            );\n        }\n        if (this.state.callState === CallState.Ended) {\n            const hangupReason = this.props.callEventGrouper.hangupReason;\n            const gotRejected = this.props.callEventGrouper.gotRejected;\n\n            if (gotRejected) {\n                return (\n                    <div className=\"mx_LegacyCallEvent_content\">\n                        {_t(\"timeline|m.call.invite|declined\")}\n                        {this.renderCallBackButton(_t(\"timeline|m.call.invite|call_back_prompt\"))}\n                        {this.props.timestamp}\n                    </div>\n                );\n            } else if (hangupReason === CallErrorCode.AnsweredElsewhere) {\n                return (\n                    <div className=\"mx_LegacyCallEvent_content\">\n                        {_t(\"timeline|m.call.invite|answered_elsewhere\")}\n                        {this.props.timestamp}\n                    </div>\n                );\n            } else if (this.props.callEventGrouper.callWasMissed) {\n                return (\n                    <div className=\"mx_LegacyCallEvent_content\">\n                        {_t(\"timeline|m.call.invite|missed_call\")}\n                        {this.renderCallBackButton(_t(\"timeline|m.call.invite|call_back_prompt\"))}\n                        {this.props.timestamp}\n                    </div>\n                );\n            } else if (!hangupReason || [CallErrorCode.UserHangup, \"user hangup\"].includes(hangupReason)) {\n                // workaround for https://github.com/vector-im/element-web/issues/5178\n                // it seems Android randomly sets a reason of \"user hangup\" which is\n                // interpreted as an error code :(\n                // https://github.com/vector-im/riot-android/issues/2623\n                // Also the correct hangup code as of VoIP v1 (with underscore)\n                // Also, if we don't have a reason\n                const duration = this.props.callEventGrouper.duration!;\n                let text = _t(\"timeline|m.call.hangup|dm\");\n                if (duration) {\n                    text += \" • \" + formatPreciseDuration(duration);\n                }\n                return (\n                    <div className=\"mx_LegacyCallEvent_content\">\n                        {text}\n                        {this.props.timestamp}\n                    </div>\n                );\n            } else if (hangupReason === CallErrorCode.InviteTimeout) {\n                return (\n                    <div className=\"mx_LegacyCallEvent_content\">\n                        {_t(\"timeline|m.call.invite|no_answer\")}\n                        {this.renderCallBackButton(_t(\"timeline|m.call.invite|call_back_prompt\"))}\n                        {this.props.timestamp}\n                    </div>\n                );\n            }\n\n            let reason;\n            if (hangupReason === CallErrorCode.IceFailed) {\n                // We couldn't establish a connection at all\n                reason = _t(\"timeline|m.call.invite|failed_connect_media\");\n            } else if (hangupReason === \"ice_timeout\") {\n                // We established a connection but it died\n                reason = _t(\"timeline|m.call.invite|failed_connection\");\n            } else if (hangupReason === CallErrorCode.NoUserMedia) {\n                // The other side couldn't open capture devices\n                reason = _t(\"timeline|m.call.invite|failed_opponent_media\");\n            } else if (hangupReason === \"unknown_error\") {\n                // An error code the other side doesn't have a way to express\n                // (as opposed to an error code they gave but we don't know about,\n                // in which case we show the error code)\n                reason = _t(\"timeline|m.call.invite|unknown_error\");\n            } else if (hangupReason === CallErrorCode.UserBusy) {\n                reason = _t(\"voip|user_busy_description\");\n            } else {\n                reason = _t(\"timeline|m.call.invite|unknown_failure\", { reason: hangupReason });\n            }\n\n            return (\n                <div className=\"mx_LegacyCallEvent_content\">\n                    <InfoTooltip\n                        tooltip={reason}\n                        className=\"mx_LegacyCallEvent_content_tooltip\"\n                        kind={InfoTooltipKind.Warning}\n                    />\n                    {_t(\"timeline|m.call.invite|failed_connection\")}\n                    {this.renderCallBackButton(_t(\"action|retry\"))}\n                    {this.props.timestamp}\n                </div>\n            );\n        }\n        if (this.state.callState === CallState.Connected) {\n            return (\n                <div className=\"mx_LegacyCallEvent_content\">\n                    <Clock seconds={this.state.length} aria-live=\"off\" />\n                    {this.props.timestamp}\n                </div>\n            );\n        }\n        if (this.state.callState === CallState.Connecting) {\n            return (\n                <div className=\"mx_LegacyCallEvent_content\">\n                    {_t(\"voip|connecting\")}\n                    {this.props.timestamp}\n                </div>\n            );\n        }\n\n        return (\n            <div className=\"mx_LegacyCallEvent_content\">\n                {_t(\"timeline|m.call.invite|unknown_state\")}\n                {this.props.timestamp}\n            </div>\n        );\n    }\n\n    public render(): React.ReactNode {\n        const event = this.props.mxEvent;\n        const sender = event.sender ? event.sender.name : event.getSender();\n        const isVoice = this.props.callEventGrouper.isVoice;\n        const callType = isVoice ? _t(\"voip|voice_call\") : _t(\"voip|video_call\");\n        const callState = this.state.callState;\n        const hangupReason = this.props.callEventGrouper.hangupReason;\n        const content = this.renderContent();\n        const className = classNames(\"mx_LegacyCallEvent\", {\n            mx_LegacyCallEvent_voice: isVoice,\n            mx_LegacyCallEvent_video: !isVoice,\n            mx_LegacyCallEvent_narrow: this.state.narrow,\n            mx_LegacyCallEvent_missed: this.props.callEventGrouper.callWasMissed,\n            mx_LegacyCallEvent_noAnswer: callState === CallState.Ended && hangupReason === CallErrorCode.InviteTimeout,\n            mx_LegacyCallEvent_rejected: callState === CallState.Ended && this.props.callEventGrouper.gotRejected,\n        });\n        let silenceIcon;\n        if (this.state.narrow && this.state.callState === CallState.Ringing) {\n            silenceIcon = this.renderSilenceIcon();\n        }\n\n        return (\n            <div className=\"mx_LegacyCallEvent_wrapper\" ref={this.wrapperElement}>\n                <div className={className}>\n                    {silenceIcon}\n                    <div className=\"mx_LegacyCallEvent_info\">\n                        <MemberAvatar member={event.sender} size=\"32px\" />\n                        <div className=\"mx_LegacyCallEvent_info_basic\">\n                            <div className=\"mx_LegacyCallEvent_sender\">{sender}</div>\n                            <div className=\"mx_LegacyCallEvent_type\">\n                                <div className=\"mx_LegacyCallEvent_type_icon\" />\n                                {callType}\n                            </div>\n                        </div>\n                    </div>\n                    {content}\n                </div>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}