UNPKG

matrix-react-sdk

Version:
127 lines (102 loc) 16.1 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 _propTypes = _interopRequireDefault(require("prop-types")); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _MessageEvent = _interopRequireDefault(require("../messages/MessageEvent")); var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar")); var _languageHandler = require("../../../languageHandler"); var _DateUtils = require("../../../DateUtils"); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; let PinnedEventTile = (_dec = (0, _replaceableComponent.replaceableComponent)("views.rooms.PinnedEventTile"), _dec(_class = (_temp = _class2 = class PinnedEventTile extends _react.default.Component { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "onTileClicked", () => { _dispatcher.default.dispatch({ action: 'view_room', event_id: this.props.mxEvent.getId(), highlighted: true, room_id: this.props.mxEvent.getRoomId() }); }); (0, _defineProperty2.default)(this, "onUnpinClicked", () => { const pinnedEvents = this.props.mxRoom.currentState.getStateEvents("m.room.pinned_events", ""); if (!pinnedEvents || !pinnedEvents.getContent().pinned) { // Nothing to do: already unpinned if (this.props.onUnpinned) this.props.onUnpinned(); } else { const pinned = pinnedEvents.getContent().pinned; const index = pinned.indexOf(this.props.mxEvent.getId()); if (index !== -1) { pinned.splice(index, 1); _MatrixClientPeg.MatrixClientPeg.get().sendStateEvent(this.props.mxRoom.roomId, 'm.room.pinned_events', { pinned }, '').then(() => { if (this.props.onUnpinned) this.props.onUnpinned(); }); } else if (this.props.onUnpinned) this.props.onUnpinned(); } }); } _canUnpin() { return this.props.mxRoom.currentState.mayClientSendStateEvent('m.room.pinned_events', _MatrixClientPeg.MatrixClientPeg.get()); } render() { const sender = this.props.mxEvent.getSender(); // Get the latest sender profile rather than historical const senderProfile = this.props.mxRoom.getMember(sender); const avatarSize = 40; let unpinButton = null; if (this._canUnpin()) { unpinButton = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onUnpinClicked, className: "mx_PinnedEventTile_unpinButton" }, /*#__PURE__*/_react.default.createElement("img", { src: require("../../../../res/img/cancel-red.svg"), width: "8", height: "8", alt: (0, _languageHandler._t)('Unpin Message'), title: (0, _languageHandler._t)('Unpin Message') })); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_PinnedEventTile" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_PinnedEventTile_actions" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_PinnedEventTile_gotoButton mx_textButton", onClick: this.onTileClicked }, (0, _languageHandler._t)("Jump to message")), unpinButton), /*#__PURE__*/_react.default.createElement("span", { className: "mx_PinnedEventTile_senderAvatar" }, /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, { member: senderProfile, width: avatarSize, height: avatarSize, fallbackUserId: sender })), /*#__PURE__*/_react.default.createElement("span", { className: "mx_PinnedEventTile_sender" }, senderProfile ? senderProfile.name : sender), /*#__PURE__*/_react.default.createElement("span", { className: "mx_PinnedEventTile_timestamp" }, (0, _DateUtils.formatFullDate)(new Date(this.props.mxEvent.getTs()))), /*#__PURE__*/_react.default.createElement("div", { className: "mx_PinnedEventTile_message" }, /*#__PURE__*/_react.default.createElement(_MessageEvent.default, { mxEvent: this.props.mxEvent, className: "mx_PinnedEventTile_body", maxImageHeight: 150, onHeightChanged: () => {} // we need to give this, apparently }))); } }, (0, _defineProperty2.default)(_class2, "propTypes", { mxRoom: _propTypes.default.object.isRequired, mxEvent: _propTypes.default.object.isRequired, onUnpinned: _propTypes.default.func }), _temp)) || _class); exports.default = PinnedEventTile; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/rooms/PinnedEventTile.js"],"names":["PinnedEventTile","React","Component","dis","dispatch","action","event_id","props","mxEvent","getId","highlighted","room_id","getRoomId","pinnedEvents","mxRoom","currentState","getStateEvents","getContent","pinned","onUnpinned","index","indexOf","splice","MatrixClientPeg","get","sendStateEvent","roomId","then","_canUnpin","mayClientSendStateEvent","render","sender","getSender","senderProfile","getMember","avatarSize","unpinButton","onUnpinClicked","require","onTileClicked","name","Date","getTs","PropTypes","object","isRequired","func"],"mappings":"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","sourcesContent":["/*\nCopyright 2017 Travis Ralston\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 PropTypes from 'prop-types';\nimport {MatrixClientPeg} from \"../../../MatrixClientPeg\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport MessageEvent from \"../messages/MessageEvent\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport { _t } from '../../../languageHandler';\nimport {formatFullDate} from '../../../DateUtils';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.rooms.PinnedEventTile\")\nexport default class PinnedEventTile extends React.Component {\n    static propTypes = {\n        mxRoom: PropTypes.object.isRequired,\n        mxEvent: PropTypes.object.isRequired,\n        onUnpinned: PropTypes.func,\n    };\n\n    onTileClicked = () => {\n        dis.dispatch({\n            action: 'view_room',\n            event_id: this.props.mxEvent.getId(),\n            highlighted: true,\n            room_id: this.props.mxEvent.getRoomId(),\n        });\n    };\n\n    onUnpinClicked = () => {\n        const pinnedEvents = this.props.mxRoom.currentState.getStateEvents(\"m.room.pinned_events\", \"\");\n        if (!pinnedEvents || !pinnedEvents.getContent().pinned) {\n            // Nothing to do: already unpinned\n            if (this.props.onUnpinned) this.props.onUnpinned();\n        } else {\n            const pinned = pinnedEvents.getContent().pinned;\n            const index = pinned.indexOf(this.props.mxEvent.getId());\n            if (index !== -1) {\n                pinned.splice(index, 1);\n                MatrixClientPeg.get().sendStateEvent(this.props.mxRoom.roomId, 'm.room.pinned_events', {pinned}, '')\n                    .then(() => {\n                        if (this.props.onUnpinned) this.props.onUnpinned();\n                    });\n            } else if (this.props.onUnpinned) this.props.onUnpinned();\n        }\n    };\n\n    _canUnpin() {\n        return this.props.mxRoom.currentState.mayClientSendStateEvent('m.room.pinned_events', MatrixClientPeg.get());\n    }\n\n    render() {\n        const sender = this.props.mxEvent.getSender();\n        // Get the latest sender profile rather than historical\n        const senderProfile = this.props.mxRoom.getMember(sender);\n        const avatarSize = 40;\n\n        let unpinButton = null;\n        if (this._canUnpin()) {\n            unpinButton = (\n                <AccessibleButton onClick={this.onUnpinClicked} className=\"mx_PinnedEventTile_unpinButton\">\n                    <img src={require(\"../../../../res/img/cancel-red.svg\")} width=\"8\" height=\"8\" alt={_t('Unpin Message')} title={_t('Unpin Message')} />\n                </AccessibleButton>\n            );\n        }\n\n        return (\n            <div className=\"mx_PinnedEventTile\">\n                <div className=\"mx_PinnedEventTile_actions\">\n                    <AccessibleButton className=\"mx_PinnedEventTile_gotoButton mx_textButton\" onClick={this.onTileClicked}>\n                        { _t(\"Jump to message\") }\n                    </AccessibleButton>\n                    { unpinButton }\n                </div>\n\n                <span className=\"mx_PinnedEventTile_senderAvatar\">\n                    <MemberAvatar member={senderProfile} width={avatarSize} height={avatarSize} fallbackUserId={sender} />\n                </span>\n                <span className=\"mx_PinnedEventTile_sender\">\n                    { senderProfile ? senderProfile.name : sender }\n                </span>\n                <span className=\"mx_PinnedEventTile_timestamp\">\n                    { formatFullDate(new Date(this.props.mxEvent.getTs())) }\n                </span>\n                <div className=\"mx_PinnedEventTile_message\">\n                    <MessageEvent\n                        mxEvent={this.props.mxEvent}\n                        className=\"mx_PinnedEventTile_body\"\n                        maxImageHeight={150}\n                        onHeightChanged={() => {}} // we need to give this, apparently\n                    />\n                </div>\n            </div>\n        );\n    }\n}\n"]}