matrix-react-sdk
Version:
SDK for matrix.org using React
167 lines (164 loc) • 28.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.CallEvent = void 0;
var _react = _interopRequireWildcard(require("react"));
var _Call = require("../../../models/Call");
var _languageHandler = require("../../../languageHandler");
var _useCall = require("../../../hooks/useCall");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _actions = require("../../../dispatcher/actions");
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar"));
var _LiveContentSummary = require("../rooms/LiveContentSummary");
var _FacePile = _interopRequireDefault(require("../elements/FacePile"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _CallDuration = require("../voip/CallDuration");
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 2022 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.
*/
const MAX_FACES = 8;
const ActiveCallEvent = /*#__PURE__*/(0, _react.forwardRef)(({
mxEvent,
call,
participatingMembers,
buttonText,
buttonKind,
buttonDisabledTooltip,
onButtonClick
}, ref) => {
const senderName = (0, _react.useMemo)(() => mxEvent.sender?.name ?? mxEvent.getSender(), [mxEvent]);
const facePileMembers = (0, _react.useMemo)(() => participatingMembers.slice(0, MAX_FACES), [participatingMembers]);
const facePileOverflow = participatingMembers.length > facePileMembers.length;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent_wrapper",
ref: ref
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent mx_CallEvent_active"
}, /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, {
member: mxEvent.sender,
fallbackUserId: mxEvent.getSender(),
viewUserOnClick: true,
size: "24px"
}), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent_columns"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent_details"
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CallEvent_title"
}, (0, _languageHandler._t)("timeline|m.call|video_call_started_text", {
name: senderName
})), /*#__PURE__*/_react.default.createElement(_LiveContentSummary.LiveContentSummary, {
type: _LiveContentSummary.LiveContentType.Video,
text: (0, _languageHandler._t)("voip|video_call"),
active: false,
participantCount: participatingMembers.length
}), /*#__PURE__*/_react.default.createElement(_FacePile.default, {
members: facePileMembers,
size: "24px",
overflow: facePileOverflow
})), call && /*#__PURE__*/_react.default.createElement(_CallDuration.SessionDuration, {
session: call.session
}), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_CallEvent_button",
kind: buttonKind,
disabled: onButtonClick === null || buttonDisabledTooltip !== undefined,
onClick: onButtonClick,
title: buttonDisabledTooltip
}, buttonText))));
});
const ActiveLoadedCallEvent = /*#__PURE__*/(0, _react.forwardRef)(({
mxEvent,
call
}, ref) => {
const connectionState = (0, _useCall.useConnectionState)(call);
const participatingMembers = (0, _useCall.useParticipatingMembers)(call);
const joinCallButtonDisabledTooltip = (0, _useCall.useJoinCallButtonDisabledTooltip)(call);
const connect = (0, _react.useCallback)(ev => {
ev.preventDefault();
_dispatcher.default.dispatch({
action: _actions.Action.ViewRoom,
room_id: mxEvent.getRoomId(),
view_call: true,
metricsTrigger: undefined
});
}, [mxEvent]);
const disconnect = (0, _react.useCallback)(ev => {
ev.preventDefault();
call.disconnect();
}, [call]);
const [buttonText, buttonKind, onButtonClick] = (0, _react.useMemo)(() => {
switch (connectionState) {
case _Call.ConnectionState.Disconnected:
return [(0, _languageHandler._t)("action|join"), "primary", connect];
case _Call.ConnectionState.Connected:
return [(0, _languageHandler._t)("action|leave"), "danger", disconnect];
case _Call.ConnectionState.Disconnecting:
return [(0, _languageHandler._t)("action|leave"), "danger", null];
case _Call.ConnectionState.Connecting:
case _Call.ConnectionState.Lobby:
case _Call.ConnectionState.WidgetLoading:
return [(0, _languageHandler._t)("action|join"), "primary", null];
}
}, [connectionState, connect, disconnect]);
return /*#__PURE__*/_react.default.createElement(ActiveCallEvent, {
ref: ref,
mxEvent: mxEvent,
call: call,
participatingMembers: participatingMembers,
buttonText: buttonText,
buttonKind: buttonKind,
buttonDisabledTooltip: joinCallButtonDisabledTooltip ?? undefined,
onButtonClick: onButtonClick
});
});
/**
* An event tile representing an active or historical Element call.
*/
const CallEvent = exports.CallEvent = /*#__PURE__*/(0, _react.forwardRef)(({
mxEvent
}, ref) => {
const client = (0, _react.useContext)(_MatrixClientContext.default);
const call = (0, _useCall.useCall)(mxEvent.getRoomId());
const latestEvent = client.getRoom(mxEvent.getRoomId()).currentState.getStateEvents(mxEvent.getType(), mxEvent.getStateKey());
if ("m.terminated" in latestEvent.getContent() || latestEvent.isRedacted()) {
// The call is terminated
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent_wrapper",
ref: ref
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent mx_CallEvent_inactive"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallEvent_columns"
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CallEvent_title"
}, (0, _languageHandler._t)("timeline|m.call|video_call_ended")), /*#__PURE__*/_react.default.createElement(_CallDuration.CallDuration, {
delta: latestEvent.getTs() - mxEvent.getTs()
}))));
}
if (call === null) {
// There should be a call, but it hasn't loaded yet
return /*#__PURE__*/_react.default.createElement(ActiveCallEvent, {
ref: ref,
mxEvent: mxEvent,
call: null,
participatingMembers: [],
buttonText: (0, _languageHandler._t)("action|join"),
buttonKind: "primary",
onButtonClick: null
});
}
return /*#__PURE__*/_react.default.createElement(ActiveLoadedCallEvent, {
mxEvent: mxEvent,
call: call,
ref: ref
});
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Call","_languageHandler","_useCall","_dispatcher","_interopRequireDefault","_actions","_AccessibleButton","_MemberAvatar","_LiveContentSummary","_FacePile","_MatrixClientContext","_CallDuration","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MAX_FACES","ActiveCallEvent","forwardRef","mxEvent","participatingMembers","buttonText","buttonKind","buttonDisabledTooltip","onButtonClick","ref","senderName","useMemo","sender","name","getSender","facePileMembers","slice","facePileOverflow","length","createElement","className","member","fallbackUserId","viewUserOnClick","size","_t","LiveContentSummary","type","LiveContentType","Video","text","active","participantCount","members","overflow","SessionDuration","session","kind","disabled","undefined","onClick","title","ActiveLoadedCallEvent","connectionState","useConnectionState","useParticipatingMembers","joinCallButtonDisabledTooltip","useJoinCallButtonDisabledTooltip","connect","useCallback","ev","preventDefault","defaultDispatcher","dispatch","action","Action","ViewRoom","room_id","getRoomId","view_call","metricsTrigger","disconnect","ConnectionState","Disconnected","Connected","Disconnecting","Connecting","Lobby","WidgetLoading","CallEvent","exports","client","useContext","MatrixClientContext","useCall","latestEvent","getRoom","currentState","getStateEvents","getType","getStateKey","getContent","isRedacted","CallDuration","delta","getTs"],"sources":["../../../../src/components/views/messages/CallEvent.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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, { forwardRef, useCallback, useContext, useMemo } from \"react\";\n\nimport type { MatrixEvent, RoomMember } from \"matrix-js-sdk/src/matrix\";\nimport { ConnectionState, ElementCall } from \"../../../models/Call\";\nimport { _t } from \"../../../languageHandler\";\nimport {\n    useCall,\n    useConnectionState,\n    useJoinCallButtonDisabledTooltip,\n    useParticipatingMembers,\n} from \"../../../hooks/useCall\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport type { ViewRoomPayload } from \"../../../dispatcher/payloads/ViewRoomPayload\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport AccessibleButton, { AccessibleButtonKind, ButtonEvent } from \"../elements/AccessibleButton\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport { LiveContentSummary, LiveContentType } from \"../rooms/LiveContentSummary\";\nimport FacePile from \"../elements/FacePile\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { CallDuration, SessionDuration } from \"../voip/CallDuration\";\n\nconst MAX_FACES = 8;\n\ninterface ActiveCallEventProps {\n    mxEvent: MatrixEvent;\n    call: ElementCall | null;\n    participatingMembers: RoomMember[];\n    buttonText: string;\n    buttonKind: AccessibleButtonKind;\n    buttonDisabledTooltip?: string;\n    onButtonClick: ((ev: ButtonEvent) => void) | null;\n}\n\nconst ActiveCallEvent = forwardRef<any, ActiveCallEventProps>(\n    ({ mxEvent, call, participatingMembers, buttonText, buttonKind, buttonDisabledTooltip, onButtonClick }, ref) => {\n        const senderName = useMemo(() => mxEvent.sender?.name ?? mxEvent.getSender(), [mxEvent]);\n\n        const facePileMembers = useMemo(() => participatingMembers.slice(0, MAX_FACES), [participatingMembers]);\n        const facePileOverflow = participatingMembers.length > facePileMembers.length;\n\n        return (\n            <div className=\"mx_CallEvent_wrapper\" ref={ref}>\n                <div className=\"mx_CallEvent mx_CallEvent_active\">\n                    <MemberAvatar\n                        member={mxEvent.sender}\n                        fallbackUserId={mxEvent.getSender()}\n                        viewUserOnClick\n                        size=\"24px\"\n                    />\n                    <div className=\"mx_CallEvent_columns\">\n                        <div className=\"mx_CallEvent_details\">\n                            <span className=\"mx_CallEvent_title\">\n                                {_t(\"timeline|m.call|video_call_started_text\", { name: senderName })}\n                            </span>\n                            <LiveContentSummary\n                                type={LiveContentType.Video}\n                                text={_t(\"voip|video_call\")}\n                                active={false}\n                                participantCount={participatingMembers.length}\n                            />\n                            <FacePile members={facePileMembers} size=\"24px\" overflow={facePileOverflow} />\n                        </div>\n                        {call && <SessionDuration session={call.session} />}\n                        <AccessibleButton\n                            className=\"mx_CallEvent_button\"\n                            kind={buttonKind}\n                            disabled={onButtonClick === null || buttonDisabledTooltip !== undefined}\n                            onClick={onButtonClick}\n                            title={buttonDisabledTooltip}\n                        >\n                            {buttonText}\n                        </AccessibleButton>\n                    </div>\n                </div>\n            </div>\n        );\n    },\n);\n\ninterface ActiveLoadedCallEventProps {\n    mxEvent: MatrixEvent;\n    call: ElementCall;\n}\n\nconst ActiveLoadedCallEvent = forwardRef<any, ActiveLoadedCallEventProps>(({ mxEvent, call }, ref) => {\n    const connectionState = useConnectionState(call);\n    const participatingMembers = useParticipatingMembers(call);\n    const joinCallButtonDisabledTooltip = useJoinCallButtonDisabledTooltip(call);\n\n    const connect = useCallback(\n        (ev: ButtonEvent) => {\n            ev.preventDefault();\n            defaultDispatcher.dispatch<ViewRoomPayload>({\n                action: Action.ViewRoom,\n                room_id: mxEvent.getRoomId()!,\n                view_call: true,\n                metricsTrigger: undefined,\n            });\n        },\n        [mxEvent],\n    );\n\n    const disconnect = useCallback(\n        (ev: ButtonEvent) => {\n            ev.preventDefault();\n            call.disconnect();\n        },\n        [call],\n    );\n\n    const [buttonText, buttonKind, onButtonClick] = useMemo<\n        [string, AccessibleButtonKind, null | ((ev: ButtonEvent) => void)]\n    >(() => {\n        switch (connectionState) {\n            case ConnectionState.Disconnected:\n                return [_t(\"action|join\"), \"primary\", connect];\n            case ConnectionState.Connected:\n                return [_t(\"action|leave\"), \"danger\", disconnect];\n            case ConnectionState.Disconnecting:\n                return [_t(\"action|leave\"), \"danger\", null];\n            case ConnectionState.Connecting:\n            case ConnectionState.Lobby:\n            case ConnectionState.WidgetLoading:\n                return [_t(\"action|join\"), \"primary\", null];\n        }\n    }, [connectionState, connect, disconnect]);\n\n    return (\n        <ActiveCallEvent\n            ref={ref}\n            mxEvent={mxEvent}\n            call={call}\n            participatingMembers={participatingMembers}\n            buttonText={buttonText}\n            buttonKind={buttonKind}\n            buttonDisabledTooltip={joinCallButtonDisabledTooltip ?? undefined}\n            onButtonClick={onButtonClick}\n        />\n    );\n});\n\ninterface CallEventProps {\n    mxEvent: MatrixEvent;\n}\n\n/**\n * An event tile representing an active or historical Element call.\n */\nexport const CallEvent = forwardRef<any, CallEventProps>(({ mxEvent }, ref) => {\n    const client = useContext(MatrixClientContext);\n    const call = useCall(mxEvent.getRoomId()!);\n    const latestEvent = client\n        .getRoom(mxEvent.getRoomId())!\n        .currentState.getStateEvents(mxEvent.getType(), mxEvent.getStateKey()!)!;\n\n    if (\"m.terminated\" in latestEvent.getContent() || latestEvent.isRedacted()) {\n        // The call is terminated\n        return (\n            <div className=\"mx_CallEvent_wrapper\" ref={ref}>\n                <div className=\"mx_CallEvent mx_CallEvent_inactive\">\n                    <div className=\"mx_CallEvent_columns\">\n                        <span className=\"mx_CallEvent_title\">{_t(\"timeline|m.call|video_call_ended\")}</span>\n                        <CallDuration delta={latestEvent.getTs() - mxEvent.getTs()} />\n                    </div>\n                </div>\n            </div>\n        );\n    }\n\n    if (call === null) {\n        // There should be a call, but it hasn't loaded yet\n        return (\n            <ActiveCallEvent\n                ref={ref}\n                mxEvent={mxEvent}\n                call={null}\n                participatingMembers={[]}\n                buttonText={_t(\"action|join\")}\n                buttonKind=\"primary\"\n                onButtonClick={null}\n            />\n        );\n    }\n\n    return <ActiveLoadedCallEvent mxEvent={mxEvent} call={call as ElementCall} ref={ref} />;\n});\n"],"mappings":"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","ignoreList":[]}