matrix-react-sdk
Version:
SDK for matrix.org using React
117 lines (115 loc) • 18.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useDmMember = exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _compoundWeb = require("@vector-im/compound-web");
var _presence = require("../../../utils/presence");
var _languageHandler = require("../../../languageHandler");
var _DMRoomMap = _interopRequireDefault(require("../../../utils/DMRoomMap"));
var _getJoinedNonFunctionalMembers = require("../../../utils/room/getJoinedNonFunctionalMembers");
var _useEventEmitter = require("../../../hooks/useEventEmitter");
var _PresenceLabel = require("../rooms/PresenceLabel");
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 2024 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.
*/
var Presence = /*#__PURE__*/function (Presence) {
Presence["Online"] = "ONLINE";
Presence["Away"] = "AWAY";
Presence["Offline"] = "OFFLINE";
Presence["Busy"] = "BUSY";
return Presence;
}(Presence || {});
function tooltipText(variant) {
switch (variant) {
case Presence.Online:
return (0, _languageHandler._t)("presence|online");
case Presence.Away:
return (0, _languageHandler._t)("presence|away");
case Presence.Offline:
return (0, _languageHandler._t)("presence|offline");
case Presence.Busy:
return (0, _languageHandler._t)("presence|busy");
}
}
function getDmMember(room) {
const otherUserId = _DMRoomMap.default.shared().getUserIdForRoomId(room.roomId);
return otherUserId ? room.getMember(otherUserId) : null;
}
const useDmMember = room => {
const [dmMember, setDmMember] = (0, _react.useState)(getDmMember(room));
const updateDmMember = () => {
setDmMember(getDmMember(room));
};
(0, _useEventEmitter.useEventEmitter)(room.currentState, _matrix.RoomStateEvent.Members, updateDmMember);
(0, _useEventEmitter.useEventEmitter)(room.client, _matrix.ClientEvent.AccountData, updateDmMember);
(0, _react.useEffect)(updateDmMember, [room]);
return dmMember;
};
exports.useDmMember = useDmMember;
function getPresence(member) {
if (!member?.user) return null;
const presence = member.user.presence;
const isOnline = member.user.currentlyActive || presence === "online";
if (_PresenceLabel.BUSY_PRESENCE_NAME.matches(member.user.presence)) {
return Presence.Busy;
}
if (isOnline) {
return Presence.Online;
}
if (presence === "offline") {
return Presence.Offline;
}
if (presence === "unavailable") {
return Presence.Away;
}
return null;
}
const usePresence = (room, member) => {
const [presence, setPresence] = (0, _react.useState)(getPresence(member));
const updatePresence = () => {
setPresence(getPresence(member));
};
(0, _useEventEmitter.useEventEmitter)(member?.user, _matrix.UserEvent.Presence, updatePresence);
(0, _useEventEmitter.useEventEmitter)(member?.user, _matrix.UserEvent.CurrentlyActive, updatePresence);
(0, _react.useEffect)(updatePresence, [member]);
if ((0, _getJoinedNonFunctionalMembers.getJoinedNonFunctionalMembers)(room).length !== 2 || !(0, _presence.isPresenceEnabled)(room.client)) return null;
return presence;
};
const WithPresenceIndicator = ({
room,
size,
tooltipProps,
children
}) => {
const dmMember = useDmMember(room);
const presence = usePresence(room, dmMember);
let icon;
if (presence) {
icon = /*#__PURE__*/_react.default.createElement("div", {
tabIndex: tooltipProps?.tabIndex ?? 0,
className: `mx_WithPresenceIndicator_icon mx_WithPresenceIndicator_icon_${presence.toLowerCase()}`,
style: {
width: size,
height: size
}
});
}
if (!presence) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, children);
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_WithPresenceIndicator"
}, children, /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, {
label: tooltipText(presence),
placement: "bottom"
}, icon));
};
var _default = exports.default = WithPresenceIndicator;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_compoundWeb","_presence","_languageHandler","_DMRoomMap","_interopRequireDefault","_getJoinedNonFunctionalMembers","_useEventEmitter","_PresenceLabel","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Presence","tooltipText","variant","Online","_t","Away","Offline","Busy","getDmMember","room","otherUserId","DMRoomMap","shared","getUserIdForRoomId","roomId","getMember","useDmMember","dmMember","setDmMember","useState","updateDmMember","useEventEmitter","currentState","RoomStateEvent","Members","client","ClientEvent","AccountData","useEffect","exports","getPresence","member","user","presence","isOnline","currentlyActive","BUSY_PRESENCE_NAME","matches","usePresence","setPresence","updatePresence","UserEvent","CurrentlyActive","getJoinedNonFunctionalMembers","length","isPresenceEnabled","WithPresenceIndicator","size","tooltipProps","children","icon","createElement","tabIndex","className","toLowerCase","style","width","height","Fragment","Tooltip","label","placement","_default"],"sources":["../../../../src/components/views/avatars/WithPresenceIndicator.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2024 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, { ReactNode, useEffect, useState } from \"react\";\nimport { ClientEvent, Room, RoomMember, RoomStateEvent, UserEvent } from \"matrix-js-sdk/src/matrix\";\nimport { Tooltip } from \"@vector-im/compound-web\";\n\nimport { isPresenceEnabled } from \"../../../utils/presence\";\nimport { _t } from \"../../../languageHandler\";\nimport DMRoomMap from \"../../../utils/DMRoomMap\";\nimport { getJoinedNonFunctionalMembers } from \"../../../utils/room/getJoinedNonFunctionalMembers\";\nimport { useEventEmitter } from \"../../../hooks/useEventEmitter\";\nimport { BUSY_PRESENCE_NAME } from \"../rooms/PresenceLabel\";\n\ninterface Props {\n    room: Room;\n    size: string; // CSS size\n    tooltipProps?: {\n        tabIndex?: number;\n    };\n    children: ReactNode;\n}\n\nenum Presence {\n    // Note: the names here are used in CSS class names\n    Online = \"ONLINE\",\n    Away = \"AWAY\",\n    Offline = \"OFFLINE\",\n    Busy = \"BUSY\",\n}\n\nfunction tooltipText(variant: Presence): string {\n    switch (variant) {\n        case Presence.Online:\n            return _t(\"presence|online\");\n        case Presence.Away:\n            return _t(\"presence|away\");\n        case Presence.Offline:\n            return _t(\"presence|offline\");\n        case Presence.Busy:\n            return _t(\"presence|busy\");\n    }\n}\n\nfunction getDmMember(room: Room): RoomMember | null {\n    const otherUserId = DMRoomMap.shared().getUserIdForRoomId(room.roomId);\n    return otherUserId ? room.getMember(otherUserId) : null;\n}\n\nexport const useDmMember = (room: Room): RoomMember | null => {\n    const [dmMember, setDmMember] = useState<RoomMember | null>(getDmMember(room));\n    const updateDmMember = (): void => {\n        setDmMember(getDmMember(room));\n    };\n\n    useEventEmitter(room.currentState, RoomStateEvent.Members, updateDmMember);\n    useEventEmitter(room.client, ClientEvent.AccountData, updateDmMember);\n    useEffect(updateDmMember, [room]);\n\n    return dmMember;\n};\n\nfunction getPresence(member: RoomMember | null): Presence | null {\n    if (!member?.user) return null;\n\n    const presence = member.user.presence;\n    const isOnline = member.user.currentlyActive || presence === \"online\";\n    if (BUSY_PRESENCE_NAME.matches(member.user.presence)) {\n        return Presence.Busy;\n    }\n    if (isOnline) {\n        return Presence.Online;\n    }\n    if (presence === \"offline\") {\n        return Presence.Offline;\n    }\n    if (presence === \"unavailable\") {\n        return Presence.Away;\n    }\n\n    return null;\n}\n\nconst usePresence = (room: Room, member: RoomMember | null): Presence | null => {\n    const [presence, setPresence] = useState<Presence | null>(getPresence(member));\n    const updatePresence = (): void => {\n        setPresence(getPresence(member));\n    };\n\n    useEventEmitter(member?.user, UserEvent.Presence, updatePresence);\n    useEventEmitter(member?.user, UserEvent.CurrentlyActive, updatePresence);\n    useEffect(updatePresence, [member]);\n\n    if (getJoinedNonFunctionalMembers(room).length !== 2 || !isPresenceEnabled(room.client)) return null;\n    return presence;\n};\n\nconst WithPresenceIndicator: React.FC<Props> = ({ room, size, tooltipProps, children }) => {\n    const dmMember = useDmMember(room);\n    const presence = usePresence(room, dmMember);\n\n    let icon: JSX.Element | undefined;\n    if (presence) {\n        icon = (\n            <div\n                tabIndex={tooltipProps?.tabIndex ?? 0}\n                className={`mx_WithPresenceIndicator_icon mx_WithPresenceIndicator_icon_${presence.toLowerCase()}`}\n                style={{\n                    width: size,\n                    height: size,\n                }}\n            />\n        );\n    }\n\n    if (!presence) return <>{children}</>;\n\n    return (\n        <div className=\"mx_WithPresenceIndicator\">\n            {children}\n            <Tooltip label={tooltipText(presence)} placement=\"bottom\">\n                {icon}\n            </Tooltip>\n        </div>\n    );\n};\n\nexport default WithPresenceIndicator;\n"],"mappings":"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","ignoreList":[]}