matrix-react-sdk
Version:
SDK for matrix.org using React
149 lines (124 loc) • 15.9 kB
JavaScript
;
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 _languageHandler = require("../../../languageHandler");
var _FormattingUtils = require("../../../utils/FormattingUtils");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _ReactionsRowButtonTooltip = _interopRequireDefault(require("./ReactionsRowButtonTooltip"));
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _dec, _class, _class2, _temp;
let ReactionsRowButton = (_dec = (0, _replaceableComponent.replaceableComponent)("views.messages.ReactionsRowButton"), _dec(_class = (_temp = _class2 = class ReactionsRowButton extends _react.default.PureComponent
/*:: <IProps, IState>*/
{
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "state", {
tooltipRendered: false,
tooltipVisible: false
});
(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(), "m.reaction", {
"m.relates_to": {
"rel_type": "m.annotation",
"event_id": mxEvent.getId(),
"key": content
}
});
_dispatcher.default.dispatch({
action: "message_sent"
});
}
});
(0, _defineProperty2.default)(this, "onMouseOver", () => {
this.setState({
// To avoid littering the DOM with a tooltip for every reaction,
// only render it on first use.
tooltipRendered: true,
tooltipVisible: true
});
});
(0, _defineProperty2.default)(this, "onMouseLeave", () => {
this.setState({
tooltipVisible: false
});
});
}
render() {
const {
mxEvent,
content,
count,
reactionEvents,
myReactionEvent
} = this.props;
const classes = (0, _classnames.default)({
mx_ReactionsRowButton: true,
mx_ReactionsRowButton_selected: !!myReactionEvent
});
let tooltip;
if (this.state.tooltipRendered) {
tooltip = /*#__PURE__*/_react.default.createElement(_ReactionsRowButtonTooltip.default, {
mxEvent: this.props.mxEvent,
content: content,
reactionEvents: reactionEvents,
visible: this.state.tooltipVisible
});
}
const room = this.context.getRoom(mxEvent.getRoomId());
let label;
if (room) {
const senders = [];
for (const reactionEvent of reactionEvents) {
const member = room.getMember(reactionEvent.getSender());
const name = member ? member.name : reactionEvent.getSender();
senders.push(name);
}
label = (0, _languageHandler._t)("<reactors/><reactedWith> reacted with %(content)s</reactedWith>", {
content
}, {
reactors: () => {
return (0, _FormattingUtils.formatCommaSeparatedList)(senders, 6);
},
reactedWith: sub => {
if (!content) {
return null;
}
return sub;
}
});
}
const isPeeking = room.getMyMembership() !== "join";
return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: classes,
"aria-label": label,
onClick: this.onClick,
disabled: isPeeking,
onMouseOver: this.onMouseOver,
onMouseLeave: this.onMouseLeave
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ReactionsRowButton_content",
"aria-hidden": "true"
}, content), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ReactionsRowButton_count",
"aria-hidden": "true"
}, count), tooltip);
}
}, (0, _defineProperty2.default)(_class2, "contextType", _MatrixClientContext.default), _temp)) || _class);
exports.default = ReactionsRowButton;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/messages/ReactionsRowButton.tsx"],"names":["ReactionsRowButton","React","PureComponent","tooltipRendered","tooltipVisible","mxEvent","myReactionEvent","content","props","context","redactEvent","getRoomId","getId","sendEvent","dis","dispatch","action","setState","render","count","reactionEvents","classes","mx_ReactionsRowButton","mx_ReactionsRowButton_selected","tooltip","state","room","getRoom","label","senders","reactionEvent","member","getMember","getSender","name","push","reactors","reactedWith","sub","isPeeking","getMyMembership","onClick","onMouseOver","onMouseLeave","MatrixClientContext"],"mappings":"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","sourcesContent":["/*\nCopyright 2019, 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React from \"react\";\nimport classNames from \"classnames\";\nimport { MatrixEvent } from \"matrix-js-sdk/src/models/event\";\n\nimport { _t } from '../../../languageHandler';\nimport { formatCommaSeparatedList } from '../../../utils/FormattingUtils';\nimport dis from \"../../../dispatcher/dispatcher\";\nimport { replaceableComponent } from \"../../../utils/replaceableComponent\";\nimport ReactionsRowButtonTooltip from \"./ReactionsRowButtonTooltip\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\n\ninterface 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 Set of Matrix reaction events for this key\n    reactionEvents: Set<MatrixEvent>;\n    // A possible Matrix event if the current user has voted for this type\n    myReactionEvent?: MatrixEvent;\n}\n\ninterface IState {\n    tooltipRendered: boolean;\n    tooltipVisible: boolean;\n}\n\n@replaceableComponent(\"views.messages.ReactionsRowButton\")\nexport default class ReactionsRowButton extends React.PureComponent<IProps, IState> {\n    static contextType = MatrixClientContext;\n\n    state = {\n        tooltipRendered: false,\n        tooltipVisible: false,\n    };\n\n    onClick = () => {\n        const { mxEvent, myReactionEvent, content } = this.props;\n        if (myReactionEvent) {\n            this.context.redactEvent(\n                mxEvent.getRoomId(),\n                myReactionEvent.getId(),\n            );\n        } else {\n            this.context.sendEvent(mxEvent.getRoomId(), \"m.reaction\", {\n                \"m.relates_to\": {\n                    \"rel_type\": \"m.annotation\",\n                    \"event_id\": mxEvent.getId(),\n                    \"key\": content,\n                },\n            });\n            dis.dispatch({action: \"message_sent\"});\n        }\n    };\n\n    onMouseOver = () => {\n        this.setState({\n            // To avoid littering the DOM with a tooltip for every reaction,\n            // only render it on first use.\n            tooltipRendered: true,\n            tooltipVisible: true,\n        });\n    }\n\n    onMouseLeave = () => {\n        this.setState({\n            tooltipVisible: false,\n        });\n    }\n\n    render() {\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        let tooltip;\n        if (this.state.tooltipRendered) {\n            tooltip = <ReactionsRowButtonTooltip\n                mxEvent={this.props.mxEvent}\n                content={content}\n                reactionEvents={reactionEvents}\n                visible={this.state.tooltipVisible}\n            />;\n        }\n\n        const room = this.context.getRoom(mxEvent.getRoomId());\n        let label;\n        if (room) {\n            const senders = [];\n            for (const reactionEvent of reactionEvents) {\n                const member = room.getMember(reactionEvent.getSender());\n                const name = member ? member.name : reactionEvent.getSender();\n                senders.push(name);\n            }\n            label = _t(\n                \"<reactors/><reactedWith> reacted with %(content)s</reactedWith>\",\n                {\n                    content,\n                },\n                {\n                    reactors: () => {\n                        return formatCommaSeparatedList(senders, 6);\n                    },\n                    reactedWith: (sub) => {\n                        if (!content) {\n                            return null;\n                        }\n                        return sub;\n                    },\n                },\n            );\n        }\n        const isPeeking = room.getMyMembership() !== \"join\";\n        return <AccessibleButton\n            className={classes}\n            aria-label={label}\n            onClick={this.onClick}\n            disabled={isPeeking}\n            onMouseOver={this.onMouseOver}\n            onMouseLeave={this.onMouseLeave}\n        >\n            <span className=\"mx_ReactionsRowButton_content\" aria-hidden=\"true\">\n                {content}\n            </span>\n            <span className=\"mx_ReactionsRowButton_count\" aria-hidden=\"true\">\n                {count}\n            </span>\n            {tooltip}\n        </AccessibleButton>;\n    }\n}\n"]}