matrix-react-sdk
Version:
SDK for matrix.org using React
208 lines (196 loc) • 33.8 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PinnedEventTile = PinnedEventTile;
var _react = _interopRequireWildcard(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _compoundWeb = require("@vector-im/compound-web");
var _visibilityOn = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/visibility-on"));
var _unpin = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/unpin"));
var _forward = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/forward"));
var _overflowHorizontal = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/overflow-horizontal"));
var _delete = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/delete"));
var _threads = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/threads"));
var _classnames = _interopRequireDefault(require("classnames"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _actions = require("../../../dispatcher/actions");
var _MessageEvent = _interopRequireDefault(require("../messages/MessageEvent"));
var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar"));
var _languageHandler = require("../../../languageHandler");
var _FormattingUtils = require("../../../utils/FormattingUtils");
var _MatrixClientContext = require("../../../contexts/MatrixClientContext");
var _useRoomState = require("../../../hooks/useRoomState");
var _EventUtils = require("../../../utils/EventUtils");
var _events = require("../../../events");
var _ConfirmRedactDialog = require("../dialogs/ConfirmRedactDialog");
var _PinningUtils = _interopRequireDefault(require("../../../utils/PinningUtils.ts"));
var _PosthogTrackers = _interopRequireDefault(require("../../../PosthogTrackers.ts"));
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.
Copyright 2017 Travis Ralston
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const AVATAR_SIZE = "32px";
/**
* Properties for {@link PinnedEventTile}.
*/
/**
* A pinned event tile.
*/
function PinnedEventTile({
event,
room,
permalinkCreator
}) {
const sender = event.getSender();
if (!sender) {
throw new Error("Pinned event unexpectedly has no sender");
}
const isInThread = Boolean(event.threadRootId);
const displayThreadInfo = !event.isThreadRoot && isInThread;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PinnedEventTile",
role: "listitem"
}, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, {
className: "mx_PinnedEventTile_senderAvatar",
member: event.sender,
size: AVATAR_SIZE,
fallbackUserId: sender
})), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PinnedEventTile_wrapper"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PinnedEventTile_top"
}, /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, {
label: event.sender?.name || sender
}, /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)("mx_PinnedEventTile_sender", (0, _FormattingUtils.getUserNameColorClass)(sender))
}, event.sender?.name || sender)), /*#__PURE__*/_react.default.createElement(PinMenu, {
event: event,
room: room,
permalinkCreator: permalinkCreator
})), /*#__PURE__*/_react.default.createElement(_MessageEvent.default, {
mxEvent: event,
maxImageHeight: 150,
onHeightChanged: () => {} // we need to give this, apparently
,
permalinkCreator: permalinkCreator,
replacingEventId: event.replacingEventId()
}), displayThreadInfo && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PinnedEventTile_thread"
}, /*#__PURE__*/_react.default.createElement(_threads.default, null), (0, _languageHandler._t)("right_panel|pinned_messages|reply_thread", {}, {
link: sub => /*#__PURE__*/_react.default.createElement("button", {
type: "button",
onClick: () => {
if (!event.threadRootId) return;
const rootEvent = room.findEventById(event.threadRootId);
if (!rootEvent) return;
_dispatcher.default.dispatch({
action: _actions.Action.ShowThread,
rootEvent: rootEvent,
push: true
});
}
}, sub)
}))));
}
/**
* Properties for {@link PinMenu}.
*/
/**
* A popover menu with actions on the pinned event
*/
function PinMenu({
event,
room,
permalinkCreator
}) {
const [open, setOpen] = (0, _react.useState)(false);
const matrixClient = (0, _MatrixClientContext.useMatrixClientContext)();
/**
* View the event in the timeline.
*/
const onViewInTimeline = (0, _react.useCallback)(() => {
_PosthogTrackers.default.trackInteraction("PinnedMessageListViewTimeline");
_dispatcher.default.dispatch({
action: _actions.Action.ViewRoom,
event_id: event.getId(),
highlighted: true,
room_id: event.getRoomId(),
metricsTrigger: undefined // room doesn't change
});
}, [event]);
/**
* Whether the client can unpin the event.
* If the room state change, we want to check again the permission
*/
const canUnpin = (0, _useRoomState.useRoomState)(room, () => _PinningUtils.default.canUnpin(matrixClient, event));
/**
* Unpin the event.
* @param event
*/
const onUnpin = (0, _react.useCallback)(async () => {
await _PinningUtils.default.pinOrUnpinEvent(matrixClient, event);
_PosthogTrackers.default.trackPinUnpinMessage("Unpin", "MessagePinningList");
}, [event, matrixClient]);
const contentActionable = (0, _EventUtils.isContentActionable)(event);
// Get the forwardable event for the given event
const forwardableEvent = contentActionable && (0, _events.getForwardableEvent)(event, matrixClient);
/**
* Open the forward dialog.
*/
const onForward = (0, _react.useCallback)(() => {
if (forwardableEvent) {
_dispatcher.default.dispatch({
action: _actions.Action.OpenForwardDialog,
event: forwardableEvent,
permalinkCreator: permalinkCreator
});
}
}, [forwardableEvent, permalinkCreator]);
/**
* Whether the client can redact the event.
*/
const canRedact = room.getLiveTimeline().getState(_matrix.EventTimeline.FORWARDS)?.maySendRedactionForEvent(event, matrixClient.getSafeUserId()) && event.getType() !== _matrix.EventType.RoomServerAcl && event.getType() !== _matrix.EventType.RoomEncryption;
/**
* Redact the event.
*/
const onRedact = (0, _react.useCallback)(() => (0, _ConfirmRedactDialog.createRedactEventDialog)({
mxEvent: event
}), [event]);
return /*#__PURE__*/_react.default.createElement(_compoundWeb.Menu, {
open: open,
onOpenChange: setOpen,
showTitle: false,
title: (0, _languageHandler._t)("right_panel|pinned_messages|menu"),
side: "right",
align: "start",
trigger: /*#__PURE__*/_react.default.createElement(_compoundWeb.IconButton, {
size: "24px",
"aria-label": (0, _languageHandler._t)("right_panel|pinned_messages|menu")
}, /*#__PURE__*/_react.default.createElement(_overflowHorizontal.default, null))
}, /*#__PURE__*/_react.default.createElement(_compoundWeb.MenuItem, {
Icon: _visibilityOn.default,
label: (0, _languageHandler._t)("right_panel|pinned_messages|view"),
onSelect: onViewInTimeline
}), canUnpin && /*#__PURE__*/_react.default.createElement(_compoundWeb.MenuItem, {
Icon: _unpin.default,
label: (0, _languageHandler._t)("action|unpin"),
onSelect: onUnpin
}), forwardableEvent && /*#__PURE__*/_react.default.createElement(_compoundWeb.MenuItem, {
Icon: _forward.default,
label: (0, _languageHandler._t)("action|forward"),
onSelect: onForward
}), canRedact && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_compoundWeb.Separator, null), /*#__PURE__*/_react.default.createElement(_compoundWeb.MenuItem, {
kind: "critical",
Icon: _delete.default,
label: (0, _languageHandler._t)("action|delete"),
onSelect: onRedact
})));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_compoundWeb","_visibilityOn","_interopRequireDefault","_unpin","_forward","_overflowHorizontal","_delete","_threads","_classnames","_dispatcher","_actions","_MessageEvent","_MemberAvatar","_languageHandler","_FormattingUtils","_MatrixClientContext","_useRoomState","_EventUtils","_events","_ConfirmRedactDialog","_PinningUtils","_PosthogTrackers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AVATAR_SIZE","PinnedEventTile","event","room","permalinkCreator","sender","getSender","Error","isInThread","Boolean","threadRootId","displayThreadInfo","isThreadRoot","createElement","className","role","member","size","fallbackUserId","Tooltip","label","name","classNames","getUserNameColorClass","PinMenu","mxEvent","maxImageHeight","onHeightChanged","replacingEventId","_t","link","sub","type","onClick","rootEvent","findEventById","dis","dispatch","action","Action","ShowThread","push","open","setOpen","useState","matrixClient","useMatrixClientContext","onViewInTimeline","useCallback","PosthogTrackers","trackInteraction","ViewRoom","event_id","getId","highlighted","room_id","getRoomId","metricsTrigger","undefined","canUnpin","useRoomState","PinningUtils","onUnpin","pinOrUnpinEvent","trackPinUnpinMessage","contentActionable","isContentActionable","forwardableEvent","getForwardableEvent","onForward","OpenForwardDialog","canRedact","getLiveTimeline","getState","EventTimeline","FORWARDS","maySendRedactionForEvent","getSafeUserId","getType","EventType","RoomServerAcl","RoomEncryption","onRedact","createRedactEventDialog","Menu","onOpenChange","showTitle","title","side","align","trigger","IconButton","MenuItem","Icon","ViewIcon","onSelect","UnpinIcon","ForwardIcon","Fragment","Separator","kind","DeleteIcon"],"sources":["../../../../src/components/views/rooms/PinnedEventTile.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 The Matrix.org Foundation C.I.C.\nCopyright 2017 Travis Ralston\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, { JSX, useCallback, useState } from \"react\";\nimport { EventTimeline, EventType, MatrixEvent, Room } from \"matrix-js-sdk/src/matrix\";\nimport { IconButton, Menu, MenuItem, Separator, Tooltip } from \"@vector-im/compound-web\";\nimport ViewIcon from \"@vector-im/compound-design-tokens/assets/web/icons/visibility-on\";\nimport UnpinIcon from \"@vector-im/compound-design-tokens/assets/web/icons/unpin\";\nimport ForwardIcon from \"@vector-im/compound-design-tokens/assets/web/icons/forward\";\nimport TriggerIcon from \"@vector-im/compound-design-tokens/assets/web/icons/overflow-horizontal\";\nimport DeleteIcon from \"@vector-im/compound-design-tokens/assets/web/icons/delete\";\nimport ThreadIcon from \"@vector-im/compound-design-tokens/assets/web/icons/threads\";\nimport classNames from \"classnames\";\n\nimport dis from \"../../../dispatcher/dispatcher\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport MessageEvent from \"../messages/MessageEvent\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport { _t } from \"../../../languageHandler\";\nimport { getUserNameColorClass } from \"../../../utils/FormattingUtils\";\nimport { ViewRoomPayload } from \"../../../dispatcher/payloads/ViewRoomPayload\";\nimport { RoomPermalinkCreator } from \"../../../utils/permalinks/Permalinks\";\nimport { useMatrixClientContext } from \"../../../contexts/MatrixClientContext\";\nimport { useRoomState } from \"../../../hooks/useRoomState\";\nimport { isContentActionable } from \"../../../utils/EventUtils\";\nimport { getForwardableEvent } from \"../../../events\";\nimport { OpenForwardDialogPayload } from \"../../../dispatcher/payloads/OpenForwardDialogPayload\";\nimport { createRedactEventDialog } from \"../dialogs/ConfirmRedactDialog\";\nimport { ShowThreadPayload } from \"../../../dispatcher/payloads/ShowThreadPayload\";\nimport PinningUtils from \"../../../utils/PinningUtils.ts\";\nimport PosthogTrackers from \"../../../PosthogTrackers.ts\";\n\nconst AVATAR_SIZE = \"32px\";\n\n/**\n * Properties for {@link PinnedEventTile}.\n */\ninterface PinnedEventTileProps {\n    /**\n     * The event to display.\n     */\n    event: MatrixEvent;\n    /**\n     * The permalink creator to use.\n     */\n    permalinkCreator: RoomPermalinkCreator;\n    /**\n     * The room the event is in.\n     */\n    room: Room;\n}\n\n/**\n * A pinned event tile.\n */\nexport function PinnedEventTile({ event, room, permalinkCreator }: PinnedEventTileProps): JSX.Element {\n    const sender = event.getSender();\n    if (!sender) {\n        throw new Error(\"Pinned event unexpectedly has no sender\");\n    }\n\n    const isInThread = Boolean(event.threadRootId);\n    const displayThreadInfo = !event.isThreadRoot && isInThread;\n\n    return (\n        <div className=\"mx_PinnedEventTile\" role=\"listitem\">\n            <div>\n                <MemberAvatar\n                    className=\"mx_PinnedEventTile_senderAvatar\"\n                    member={event.sender}\n                    size={AVATAR_SIZE}\n                    fallbackUserId={sender}\n                />\n            </div>\n            <div className=\"mx_PinnedEventTile_wrapper\">\n                <div className=\"mx_PinnedEventTile_top\">\n                    <Tooltip label={event.sender?.name || sender}>\n                        <span className={classNames(\"mx_PinnedEventTile_sender\", getUserNameColorClass(sender))}>\n                            {event.sender?.name || sender}\n                        </span>\n                    </Tooltip>\n                    <PinMenu event={event} room={room} permalinkCreator={permalinkCreator} />\n                </div>\n                <MessageEvent\n                    mxEvent={event}\n                    maxImageHeight={150}\n                    onHeightChanged={() => {}} // we need to give this, apparently\n                    permalinkCreator={permalinkCreator}\n                    replacingEventId={event.replacingEventId()}\n                />\n                {displayThreadInfo && (\n                    <div className=\"mx_PinnedEventTile_thread\">\n                        <ThreadIcon />\n                        {_t(\n                            \"right_panel|pinned_messages|reply_thread\",\n                            {},\n                            {\n                                link: (sub) => (\n                                    <button\n                                        type=\"button\"\n                                        onClick={() => {\n                                            if (!event.threadRootId) return;\n\n                                            const rootEvent = room.findEventById(event.threadRootId);\n                                            if (!rootEvent) return;\n\n                                            dis.dispatch<ShowThreadPayload>({\n                                                action: Action.ShowThread,\n                                                rootEvent: rootEvent,\n                                                push: true,\n                                            });\n                                        }}\n                                    >\n                                        {sub}\n                                    </button>\n                                ),\n                            },\n                        )}\n                    </div>\n                )}\n            </div>\n        </div>\n    );\n}\n\n/**\n * Properties for {@link PinMenu}.\n */\ninterface PinMenuProps extends PinnedEventTileProps {}\n\n/**\n * A popover menu with actions on the pinned event\n */\nfunction PinMenu({ event, room, permalinkCreator }: PinMenuProps): JSX.Element {\n    const [open, setOpen] = useState(false);\n    const matrixClient = useMatrixClientContext();\n\n    /**\n     * View the event in the timeline.\n     */\n    const onViewInTimeline = useCallback(() => {\n        PosthogTrackers.trackInteraction(\"PinnedMessageListViewTimeline\");\n\n        dis.dispatch<ViewRoomPayload>({\n            action: Action.ViewRoom,\n            event_id: event.getId(),\n            highlighted: true,\n            room_id: event.getRoomId(),\n            metricsTrigger: undefined, // room doesn't change\n        });\n    }, [event]);\n\n    /**\n     * Whether the client can unpin the event.\n     * If the room state change, we want to check again the permission\n     */\n    const canUnpin = useRoomState(room, () => PinningUtils.canUnpin(matrixClient, event));\n\n    /**\n     * Unpin the event.\n     * @param event\n     */\n    const onUnpin = useCallback(async (): Promise<void> => {\n        await PinningUtils.pinOrUnpinEvent(matrixClient, event);\n        PosthogTrackers.trackPinUnpinMessage(\"Unpin\", \"MessagePinningList\");\n    }, [event, matrixClient]);\n\n    const contentActionable = isContentActionable(event);\n    // Get the forwardable event for the given event\n    const forwardableEvent = contentActionable && getForwardableEvent(event, matrixClient);\n    /**\n     * Open the forward dialog.\n     */\n    const onForward = useCallback(() => {\n        if (forwardableEvent) {\n            dis.dispatch<OpenForwardDialogPayload>({\n                action: Action.OpenForwardDialog,\n                event: forwardableEvent,\n                permalinkCreator: permalinkCreator,\n            });\n        }\n    }, [forwardableEvent, permalinkCreator]);\n\n    /**\n     * Whether the client can redact the event.\n     */\n    const canRedact =\n        room\n            .getLiveTimeline()\n            .getState(EventTimeline.FORWARDS)\n            ?.maySendRedactionForEvent(event, matrixClient.getSafeUserId()) &&\n        event.getType() !== EventType.RoomServerAcl &&\n        event.getType() !== EventType.RoomEncryption;\n\n    /**\n     * Redact the event.\n     */\n    const onRedact = useCallback(\n        (): void =>\n            createRedactEventDialog({\n                mxEvent: event,\n            }),\n        [event],\n    );\n\n    return (\n        <Menu\n            open={open}\n            onOpenChange={setOpen}\n            showTitle={false}\n            title={_t(\"right_panel|pinned_messages|menu\")}\n            side=\"right\"\n            align=\"start\"\n            trigger={\n                <IconButton size=\"24px\" aria-label={_t(\"right_panel|pinned_messages|menu\")}>\n                    <TriggerIcon />\n                </IconButton>\n            }\n        >\n            <MenuItem Icon={ViewIcon} label={_t(\"right_panel|pinned_messages|view\")} onSelect={onViewInTimeline} />\n            {canUnpin && <MenuItem Icon={UnpinIcon} label={_t(\"action|unpin\")} onSelect={onUnpin} />}\n            {forwardableEvent && <MenuItem Icon={ForwardIcon} label={_t(\"action|forward\")} onSelect={onForward} />}\n            {canRedact && (\n                <>\n                    <Separator />\n                    <MenuItem kind=\"critical\" Icon={DeleteIcon} label={_t(\"action|delete\")} onSelect={onRedact} />\n                </>\n            )}\n        </Menu>\n    );\n}\n"],"mappings":"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","ignoreList":[]}