matrix-react-sdk
Version:
SDK for matrix.org using React
78 lines (75 loc) • 11.7 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 _MatrixClientPeg = require("../../../MatrixClientPeg");
var _languageHandler = require("../../../languageHandler");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _Media = require("../../../customisations/Media");
var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar"));
var _ImageView = _interopRequireDefault(require("../elements/ImageView"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2019 Michael Telatynski <7t3chguy@gmail.com>
Copyright 2019 The Matrix.org Foundation C.I.C.
Copyright 2017 Vector Creations Ltd
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class RoomAvatarEvent extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onAvatarClick", () => {
const cli = _MatrixClientPeg.MatrixClientPeg.safeGet();
const ev = this.props.mxEvent;
const httpUrl = (0, _Media.mediaFromMxc)(ev.getContent().url).srcHttp;
if (!httpUrl) return;
const room = cli.getRoom(this.props.mxEvent.getRoomId());
const text = (0, _languageHandler._t)("timeline|m.room.avatar|lightbox_title", {
senderDisplayName: ev.sender && ev.sender.name ? ev.sender.name : ev.getSender(),
roomName: room ? room.name : ""
});
const params = {
src: httpUrl,
name: text
};
_Modal.default.createDialog(_ImageView.default, params, "mx_Dialog_lightbox", undefined, true);
});
}
render() {
const ev = this.props.mxEvent;
const senderDisplayName = ev.sender && ev.sender.name ? ev.sender.name : ev.getSender();
if (!ev.getContent().url || ev.getContent().url.trim().length === 0) {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TextualEvent"
}, (0, _languageHandler._t)("timeline|m.room.avatar|removed", {
senderDisplayName
}));
}
const room = _MatrixClientPeg.MatrixClientPeg.safeGet().getRoom(ev.getRoomId());
// Provide all arguments to RoomAvatar via oobData because the avatar is historic
const oobData = {
avatarUrl: ev.getContent().url,
name: room ? room.name : ""
};
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _languageHandler._t)("timeline|m.room.avatar|changed_img", {
senderDisplayName: senderDisplayName
}, {
img: () => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
key: "avatar",
className: "mx_RoomAvatarEvent_avatar",
onClick: this.onAvatarClick
}, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
size: "14px",
oobData: oobData
}))
}));
}
}
exports.default = RoomAvatarEvent;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_MatrixClientPeg","_languageHandler","_Modal","_AccessibleButton","_Media","_RoomAvatar","_ImageView","RoomAvatarEvent","React","Component","constructor","args","_defineProperty2","default","cli","MatrixClientPeg","safeGet","ev","props","mxEvent","httpUrl","mediaFromMxc","getContent","url","srcHttp","room","getRoom","getRoomId","text","_t","senderDisplayName","sender","name","getSender","roomName","params","src","Modal","createDialog","ImageView","undefined","render","trim","length","createElement","className","oobData","avatarUrl","Fragment","img","key","onClick","onAvatarClick","size","exports"],"sources":["../../../../src/components/views/messages/RoomAvatarEvent.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 Michael Telatynski <7t3chguy@gmail.com>\nCopyright 2019 The Matrix.org Foundation C.I.C.\nCopyright 2017 Vector Creations Ltd\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 { MatrixEvent } from \"matrix-js-sdk/src/matrix\";\n\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { _t } from \"../../../languageHandler\";\nimport Modal from \"../../../Modal\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { mediaFromMxc } from \"../../../customisations/Media\";\nimport RoomAvatar from \"../avatars/RoomAvatar\";\nimport ImageView from \"../elements/ImageView\";\ninterface IProps {\n    /* the MatrixEvent to show */\n    mxEvent: MatrixEvent;\n}\n\nexport default class RoomAvatarEvent extends React.Component<IProps> {\n    private onAvatarClick = (): void => {\n        const cli = MatrixClientPeg.safeGet();\n        const ev = this.props.mxEvent;\n        const httpUrl = mediaFromMxc(ev.getContent().url).srcHttp;\n        if (!httpUrl) return;\n\n        const room = cli.getRoom(this.props.mxEvent.getRoomId());\n        const text = _t(\"timeline|m.room.avatar|lightbox_title\", {\n            senderDisplayName: ev.sender && ev.sender.name ? ev.sender.name : ev.getSender(),\n            roomName: room ? room.name : \"\",\n        });\n\n        const params = {\n            src: httpUrl,\n            name: text,\n        };\n        Modal.createDialog(ImageView, params, \"mx_Dialog_lightbox\", undefined, true);\n    };\n\n    public render(): React.ReactNode {\n        const ev = this.props.mxEvent;\n        const senderDisplayName = ev.sender && ev.sender.name ? ev.sender.name : ev.getSender();\n\n        if (!ev.getContent().url || ev.getContent().url.trim().length === 0) {\n            return <div className=\"mx_TextualEvent\">{_t(\"timeline|m.room.avatar|removed\", { senderDisplayName })}</div>;\n        }\n\n        const room = MatrixClientPeg.safeGet().getRoom(ev.getRoomId());\n        // Provide all arguments to RoomAvatar via oobData because the avatar is historic\n        const oobData = {\n            avatarUrl: ev.getContent().url,\n            name: room ? room.name : \"\",\n        };\n\n        return (\n            <>\n                {_t(\n                    \"timeline|m.room.avatar|changed_img\",\n                    { senderDisplayName: senderDisplayName },\n                    {\n                        img: () => (\n                            <AccessibleButton\n                                key=\"avatar\"\n                                className=\"mx_RoomAvatarEvent_avatar\"\n                                onClick={this.onAvatarClick}\n                            >\n                                <RoomAvatar size=\"14px\" oobData={oobData} />\n                            </AccessibleButton>\n                        ),\n                    },\n                )}\n            </>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}