matrix-react-sdk
Version:
SDK for matrix.org using React
125 lines (122 loc) • 23.8 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.ThreadMessagePreview = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = _interopRequireWildcard(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _compoundWeb = require("@vector-im/compound-web");
var _threadsSolid = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/threads-solid"));
var _languageHandler = require("../../../languageHandler");
var _context = require("../right_panel/context");
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _PosthogTrackers = _interopRequireDefault(require("../../../PosthogTrackers"));
var _useEventEmitter = require("../../../hooks/useEventEmitter");
var _RoomContext = _interopRequireDefault(require("../../../contexts/RoomContext"));
var _MessagePreviewStore = require("../../../stores/room-list/MessagePreviewStore");
var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar"));
var _useAsyncMemo = require("../../../hooks/useAsyncMemo");
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _actions = require("../../../dispatcher/actions");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _useUnreadNotifications = require("../../../hooks/useUnreadNotifications");
var _notifications = require("../../../utils/notifications");
const _excluded = ["mxEvent", "thread"];
/*
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.
*/
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; }
const ThreadSummary = _ref => {
let {
mxEvent,
thread
} = _ref,
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
const roomContext = (0, _react.useContext)(_RoomContext.default);
const cardContext = (0, _react.useContext)(_context.CardContext);
const count = (0, _useEventEmitter.useTypedEventEmitterState)(thread, _matrix.ThreadEvent.Update, () => thread.length);
const {
level
} = (0, _useUnreadNotifications.useUnreadNotifications)(thread.room, thread.id);
if (!count) return null; // We don't want to show a thread summary if the thread doesn't have replies yet
let countSection = count;
if (!roomContext.narrow) {
countSection = (0, _languageHandler._t)("threads|count_of_reply", {
count
});
}
return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, (0, _extends2.default)({}, props, {
className: "mx_ThreadSummary",
onClick: ev => {
_dispatcher.default.dispatch({
action: _actions.Action.ShowThread,
rootEvent: mxEvent,
push: cardContext.isCard
});
_PosthogTrackers.default.trackInteraction("WebRoomTimelineThreadSummaryButton", ev);
},
"aria-label": (0, _languageHandler._t)("threads|open_thread")
}), /*#__PURE__*/_react.default.createElement(_compoundWeb.IndicatorIcon, {
size: "24px",
indicator: (0, _notifications.notificationLevelToIndicator)(level)
}, /*#__PURE__*/_react.default.createElement(_threadsSolid.default, null)), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ThreadSummary_replies_amount"
}, countSection), /*#__PURE__*/_react.default.createElement(ThreadMessagePreview, {
thread: thread,
showDisplayname: !roomContext.narrow
}), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadSummary_chevron"
}));
};
const ThreadMessagePreview = ({
thread,
showDisplayname = false
}) => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
const lastReply = (0, _useEventEmitter.useTypedEventEmitterState)(thread, _matrix.ThreadEvent.Update, () => thread.replyToEvent) ?? undefined;
// track the content as a means to regenerate the thread message preview upon edits & decryption
const [content, setContent] = (0, _react.useState)(lastReply?.getContent());
(0, _useEventEmitter.useTypedEventEmitter)(lastReply, _matrix.MatrixEventEvent.Replaced, () => {
setContent(lastReply.getContent());
});
const awaitDecryption = lastReply?.shouldAttemptDecryption() || lastReply?.isBeingDecrypted();
(0, _useEventEmitter.useTypedEventEmitter)(awaitDecryption ? lastReply : undefined, _matrix.MatrixEventEvent.Decrypted, () => {
setContent(lastReply.getContent());
});
const preview = (0, _useAsyncMemo.useAsyncMemo)(async () => {
if (!lastReply) return;
await cli.decryptEventIfNeeded(lastReply);
return _MessagePreviewStore.MessagePreviewStore.instance.generatePreviewForEvent(lastReply);
}, [lastReply, content]);
if (!preview || !lastReply) {
return null;
}
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, {
member: lastReply.sender,
fallbackUserId: lastReply.getSender(),
size: "24px",
className: "mx_ThreadSummary_avatar"
}), showDisplayname && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadSummary_sender"
}, lastReply.sender?.name ?? lastReply.getSender()), lastReply.isDecryptionFailure() ? /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadSummary_content mx_DecryptionFailureBody",
title: (0, _languageHandler._t)("timeline|decryption_failure|unable_to_decrypt")
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ThreadSummary_message-preview"
}, (0, _languageHandler._t)("timeline|decryption_failure|unable_to_decrypt"))) : /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadSummary_content",
title: preview
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ThreadSummary_message-preview"
}, preview)));
};
exports.ThreadMessagePreview = ThreadMessagePreview;
var _default = exports.default = ThreadSummary;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_compoundWeb","_threadsSolid","_interopRequireDefault","_languageHandler","_context","_AccessibleButton","_PosthogTrackers","_useEventEmitter","_RoomContext","_MessagePreviewStore","_MemberAvatar","_useAsyncMemo","_MatrixClientContext","_actions","_dispatcher","_useUnreadNotifications","_notifications","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ThreadSummary","_ref","mxEvent","thread","props","_objectWithoutProperties2","roomContext","useContext","RoomContext","cardContext","CardContext","count","useTypedEventEmitterState","ThreadEvent","Update","length","level","useUnreadNotifications","room","id","countSection","narrow","_t","createElement","_extends2","className","onClick","ev","defaultDispatcher","dispatch","action","Action","ShowThread","rootEvent","push","isCard","PosthogTrackers","trackInteraction","IndicatorIcon","size","indicator","notificationLevelToIndicator","ThreadMessagePreview","showDisplayname","cli","MatrixClientContext","lastReply","replyToEvent","undefined","content","setContent","useState","getContent","useTypedEventEmitter","MatrixEventEvent","Replaced","awaitDecryption","shouldAttemptDecryption","isBeingDecrypted","Decrypted","preview","useAsyncMemo","decryptEventIfNeeded","MessagePreviewStore","instance","generatePreviewForEvent","Fragment","member","sender","fallbackUserId","getSender","name","isDecryptionFailure","title","exports","_default"],"sources":["../../../../src/components/views/rooms/ThreadSummary.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, { useContext, useState } from \"react\";\nimport { Thread, ThreadEvent, IContent, MatrixEvent, MatrixEventEvent } from \"matrix-js-sdk/src/matrix\";\nimport { IndicatorIcon } from \"@vector-im/compound-web\";\nimport ThreadIconSolid from \"@vector-im/compound-design-tokens/assets/web/icons/threads-solid\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { CardContext } from \"../right_panel/context\";\nimport AccessibleButton, { ButtonEvent } from \"../elements/AccessibleButton\";\nimport PosthogTrackers from \"../../../PosthogTrackers\";\nimport { useTypedEventEmitter, useTypedEventEmitterState } from \"../../../hooks/useEventEmitter\";\nimport RoomContext from \"../../../contexts/RoomContext\";\nimport { MessagePreviewStore } from \"../../../stores/room-list/MessagePreviewStore\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport { useAsyncMemo } from \"../../../hooks/useAsyncMemo\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport { ShowThreadPayload } from \"../../../dispatcher/payloads/ShowThreadPayload\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport { useUnreadNotifications } from \"../../../hooks/useUnreadNotifications\";\nimport { notificationLevelToIndicator } from \"../../../utils/notifications\";\n\ninterface IProps {\n    mxEvent: MatrixEvent;\n    thread: Thread;\n}\n\nconst ThreadSummary: React.FC<IProps> = ({ mxEvent, thread, ...props }) => {\n    const roomContext = useContext(RoomContext);\n    const cardContext = useContext(CardContext);\n    const count = useTypedEventEmitterState(thread, ThreadEvent.Update, () => thread.length);\n    const { level } = useUnreadNotifications(thread.room, thread.id);\n\n    if (!count) return null; // We don't want to show a thread summary if the thread doesn't have replies yet\n\n    let countSection: string | number = count;\n    if (!roomContext.narrow) {\n        countSection = _t(\"threads|count_of_reply\", { count });\n    }\n\n    return (\n        <AccessibleButton\n            {...props}\n            className=\"mx_ThreadSummary\"\n            onClick={(ev: ButtonEvent) => {\n                defaultDispatcher.dispatch<ShowThreadPayload>({\n                    action: Action.ShowThread,\n                    rootEvent: mxEvent,\n                    push: cardContext.isCard,\n                });\n                PosthogTrackers.trackInteraction(\"WebRoomTimelineThreadSummaryButton\", ev);\n            }}\n            aria-label={_t(\"threads|open_thread\")}\n        >\n            <IndicatorIcon size=\"24px\" indicator={notificationLevelToIndicator(level)}>\n                <ThreadIconSolid />\n            </IndicatorIcon>\n            <span className=\"mx_ThreadSummary_replies_amount\">{countSection}</span>\n            <ThreadMessagePreview thread={thread} showDisplayname={!roomContext.narrow} />\n            <div className=\"mx_ThreadSummary_chevron\" />\n        </AccessibleButton>\n    );\n};\n\ninterface IPreviewProps {\n    thread: Thread;\n    showDisplayname?: boolean;\n}\n\nexport const ThreadMessagePreview: React.FC<IPreviewProps> = ({ thread, showDisplayname = false }) => {\n    const cli = useContext(MatrixClientContext);\n\n    const lastReply = useTypedEventEmitterState(thread, ThreadEvent.Update, () => thread.replyToEvent) ?? undefined;\n    // track the content as a means to regenerate the thread message preview upon edits & decryption\n    const [content, setContent] = useState<IContent | undefined>(lastReply?.getContent());\n    useTypedEventEmitter(lastReply, MatrixEventEvent.Replaced, () => {\n        setContent(lastReply!.getContent());\n    });\n    const awaitDecryption = lastReply?.shouldAttemptDecryption() || lastReply?.isBeingDecrypted();\n    useTypedEventEmitter(awaitDecryption ? lastReply : undefined, MatrixEventEvent.Decrypted, () => {\n        setContent(lastReply!.getContent());\n    });\n\n    const preview = useAsyncMemo(async (): Promise<string | undefined> => {\n        if (!lastReply) return;\n        await cli.decryptEventIfNeeded(lastReply);\n        return MessagePreviewStore.instance.generatePreviewForEvent(lastReply);\n    }, [lastReply, content]);\n    if (!preview || !lastReply) {\n        return null;\n    }\n\n    return (\n        <>\n            <MemberAvatar\n                member={lastReply.sender}\n                fallbackUserId={lastReply.getSender()}\n                size=\"24px\"\n                className=\"mx_ThreadSummary_avatar\"\n            />\n            {showDisplayname && (\n                <div className=\"mx_ThreadSummary_sender\">{lastReply.sender?.name ?? lastReply.getSender()}</div>\n            )}\n\n            {lastReply.isDecryptionFailure() ? (\n                <div\n                    className=\"mx_ThreadSummary_content mx_DecryptionFailureBody\"\n                    title={_t(\"timeline|decryption_failure|unable_to_decrypt\")}\n                >\n                    <span className=\"mx_ThreadSummary_message-preview\">\n                        {_t(\"timeline|decryption_failure|unable_to_decrypt\")}\n                    </span>\n                </div>\n            ) : (\n                <div className=\"mx_ThreadSummary_content\" title={preview}>\n                    <span className=\"mx_ThreadSummary_message-preview\">{preview}</span>\n                </div>\n            )}\n        </>\n    );\n};\n\nexport default ThreadSummary;\n"],"mappings":"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","ignoreList":[]}