UNPKG

matrix-react-sdk

Version:
119 lines (116 loc) 17.4 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 = _interopRequireDefault(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _matrix = require("matrix-js-sdk/src/matrix"); var _Media = require("../../../customisations/Media"); var _languageHandler = require("../../../languageHandler"); var _FormattingUtils = require("../../../utils/FormattingUtils"); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _ReactionsRowButtonTooltip = _interopRequireDefault(require("./ReactionsRowButtonTooltip")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _ReactionsRow = require("./ReactionsRow"); /* Copyright 2024 New Vector Ltd. Copyright 2019-2021 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. */ class ReactionsRowButton extends _react.default.PureComponent { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "onClick", () => { const { mxEvent, myReactionEvent, content } = this.props; if (myReactionEvent) { this.context.redactEvent(mxEvent.getRoomId(), myReactionEvent.getId()); } else { this.context.sendEvent(mxEvent.getRoomId(), _matrix.EventType.Reaction, { "m.relates_to": { rel_type: _matrix.RelationType.Annotation, event_id: mxEvent.getId(), key: content } }); _dispatcher.default.dispatch({ action: "message_sent" }); } }); } render() { const { mxEvent, content, count, reactionEvents, myReactionEvent } = this.props; const classes = (0, _classnames.default)({ mx_ReactionsRowButton: true, mx_ReactionsRowButton_selected: !!myReactionEvent }); const room = this.context.getRoom(mxEvent.getRoomId()); let label; let customReactionName; if (room) { const senders = []; for (const reactionEvent of reactionEvents) { const member = room.getMember(reactionEvent.getSender()); senders.push(member?.name || reactionEvent.getSender()); customReactionName = this.props.customReactionImagesEnabled && _ReactionsRow.REACTION_SHORTCODE_KEY.findIn(reactionEvent.getContent()) || undefined; } const reactors = (0, _FormattingUtils.formatList)(senders, 6); if (content) { label = (0, _languageHandler._t)("timeline|reactions|label", { reactors, content: customReactionName || content }); } else { label = reactors; } } let reactionContent = /*#__PURE__*/_react.default.createElement("span", { className: "mx_ReactionsRowButton_content", "aria-hidden": "true" }, content); if (this.props.customReactionImagesEnabled && content.startsWith("mxc://")) { const imageSrc = (0, _Media.mediaFromMxc)(content).srcHttp; if (imageSrc) { reactionContent = /*#__PURE__*/_react.default.createElement("img", { className: "mx_ReactionsRowButton_content", alt: customReactionName || (0, _languageHandler._t)("timeline|reactions|custom_reaction_fallback_label"), src: imageSrc, width: "16", height: "16" }); } } return /*#__PURE__*/_react.default.createElement(_ReactionsRowButtonTooltip.default, { mxEvent: this.props.mxEvent, content: content, reactionEvents: reactionEvents, customReactionImagesEnabled: this.props.customReactionImagesEnabled }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: classes, "aria-label": label, onClick: this.onClick, disabled: this.props.disabled }, reactionContent, /*#__PURE__*/_react.default.createElement("span", { className: "mx_ReactionsRowButton_count", "aria-hidden": "true" }, count))); } } exports.default = ReactionsRowButton; (0, _defineProperty2.default)(ReactionsRowButton, "contextType", _MatrixClientContext.default); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_matrix","_Media","_languageHandler","_FormattingUtils","_dispatcher","_ReactionsRowButtonTooltip","_AccessibleButton","_MatrixClientContext","_ReactionsRow","ReactionsRowButton","React","PureComponent","constructor","args","_defineProperty2","default","mxEvent","myReactionEvent","content","props","context","redactEvent","getRoomId","getId","sendEvent","EventType","Reaction","rel_type","RelationType","Annotation","event_id","key","dis","dispatch","action","render","count","reactionEvents","classes","classNames","mx_ReactionsRowButton","mx_ReactionsRowButton_selected","room","getRoom","label","customReactionName","senders","reactionEvent","member","getMember","getSender","push","name","customReactionImagesEnabled","REACTION_SHORTCODE_KEY","findIn","getContent","undefined","reactors","formatList","_t","reactionContent","createElement","className","startsWith","imageSrc","mediaFromMxc","srcHttp","alt","src","width","height","onClick","disabled","exports","MatrixClientContext"],"sources":["../../../../src/components/views/messages/ReactionsRowButton.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019-2021 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 from \"react\";\nimport classNames from \"classnames\";\nimport { EventType, MatrixEvent, RelationType } from \"matrix-js-sdk/src/matrix\";\n\nimport { mediaFromMxc } from \"../../../customisations/Media\";\nimport { _t } from \"../../../languageHandler\";\nimport { formatList } from \"../../../utils/FormattingUtils\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport ReactionsRowButtonTooltip from \"./ReactionsRowButtonTooltip\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { REACTION_SHORTCODE_KEY } from \"./ReactionsRow\";\n\nexport interface IProps {\n    // The event we're displaying reactions for\n    mxEvent: MatrixEvent;\n    // The reaction content / key / emoji\n    content: string;\n    // The count of votes for this key\n    count: number;\n    // A list of Matrix reaction events for this key\n    reactionEvents: MatrixEvent[];\n    // A possible Matrix event if the current user has voted for this type\n    myReactionEvent?: MatrixEvent;\n    // Whether to prevent quick-reactions by clicking on this reaction\n    disabled?: boolean;\n    // Whether to render custom image reactions\n    customReactionImagesEnabled?: boolean;\n}\n\nexport default class ReactionsRowButton extends React.PureComponent<IProps> {\n    public static contextType = MatrixClientContext;\n    public declare context: React.ContextType<typeof MatrixClientContext>;\n\n    public onClick = (): void => {\n        const { mxEvent, myReactionEvent, content } = this.props;\n        if (myReactionEvent) {\n            this.context.redactEvent(mxEvent.getRoomId()!, myReactionEvent.getId()!);\n        } else {\n            this.context.sendEvent(mxEvent.getRoomId()!, EventType.Reaction, {\n                \"m.relates_to\": {\n                    rel_type: RelationType.Annotation,\n                    event_id: mxEvent.getId()!,\n                    key: content,\n                },\n            });\n            dis.dispatch({ action: \"message_sent\" });\n        }\n    };\n\n    public render(): React.ReactNode {\n        const { mxEvent, content, count, reactionEvents, myReactionEvent } = this.props;\n\n        const classes = classNames({\n            mx_ReactionsRowButton: true,\n            mx_ReactionsRowButton_selected: !!myReactionEvent,\n        });\n\n        const room = this.context.getRoom(mxEvent.getRoomId());\n        let label: string | undefined;\n        let customReactionName: string | undefined;\n        if (room) {\n            const senders: string[] = [];\n            for (const reactionEvent of reactionEvents) {\n                const member = room.getMember(reactionEvent.getSender()!);\n                senders.push(member?.name || reactionEvent.getSender()!);\n                customReactionName =\n                    (this.props.customReactionImagesEnabled &&\n                        REACTION_SHORTCODE_KEY.findIn(reactionEvent.getContent())) ||\n                    undefined;\n            }\n\n            const reactors = formatList(senders, 6);\n            if (content) {\n                label = _t(\"timeline|reactions|label\", {\n                    reactors,\n                    content: customReactionName || content,\n                });\n            } else {\n                label = reactors;\n            }\n        }\n\n        let reactionContent = (\n            <span className=\"mx_ReactionsRowButton_content\" aria-hidden=\"true\">\n                {content}\n            </span>\n        );\n        if (this.props.customReactionImagesEnabled && content.startsWith(\"mxc://\")) {\n            const imageSrc = mediaFromMxc(content).srcHttp;\n            if (imageSrc) {\n                reactionContent = (\n                    <img\n                        className=\"mx_ReactionsRowButton_content\"\n                        alt={customReactionName || _t(\"timeline|reactions|custom_reaction_fallback_label\")}\n                        src={imageSrc}\n                        width=\"16\"\n                        height=\"16\"\n                    />\n                );\n            }\n        }\n\n        return (\n            <ReactionsRowButtonTooltip\n                mxEvent={this.props.mxEvent}\n                content={content}\n                reactionEvents={reactionEvents}\n                customReactionImagesEnabled={this.props.customReactionImagesEnabled}\n            >\n                <AccessibleButton\n                    className={classes}\n                    aria-label={label}\n                    onClick={this.onClick}\n                    disabled={this.props.disabled}\n                >\n                    {reactionContent}\n                    <span className=\"mx_ReactionsRowButton_count\" aria-hidden=\"true\">\n                        {count}\n                    </span>\n                </AccessibleButton>\n            </ReactionsRowButtonTooltip>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}