matrix-react-sdk
Version:
SDK for matrix.org using React
299 lines (233 loc) • 37.2 kB
JavaScript
"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 _classnames = _interopRequireDefault(require("classnames"));
var _languageHandler = require("../../../languageHandler");
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _ratelimitedfunc = _interopRequireDefault(require("../../../ratelimitedfunc"));
var _SimpleRoomHeader = require("./SimpleRoomHeader");
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _RoomHeaderButtons = _interopRequireDefault(require("../right_panel/RoomHeaderButtons"));
var _E2EIcon = _interopRequireDefault(require("./E2EIcon"));
var _DecoratedRoomAvatar = _interopRequireDefault(require("../avatars/DecoratedRoomAvatar"));
var _AccessibleTooltipButton = _interopRequireDefault(require("../elements/AccessibleTooltipButton"));
var _RoomTopic = _interopRequireDefault(require("../elements/RoomTopic"));
var _RoomName = _interopRequireDefault(require("../elements/RoomName"));
var _CallHandler = require("../../../CallHandler");
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _class2, _temp;
let RoomHeader = (_dec = (0, _replaceableComponent.replaceableComponent)("views.rooms.RoomHeader"), _dec(_class = (_temp = _class2 = class RoomHeader extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "_onRoomStateEvents", (event, state) => {
if (!this.props.room || event.getRoomId() !== this.props.room.roomId) {
return;
} // redisplay the room name, topic, etc.
this._rateLimitedUpdate();
});
(0, _defineProperty2.default)(this, "_onRoomAccountData", (event, room) => {
if (!this.props.room || room.roomId !== this.props.room.roomId) return;
if (event.getType() !== "im.vector.room.read_pins") return;
this._rateLimitedUpdate();
});
(0, _defineProperty2.default)(this, "_rateLimitedUpdate", new _ratelimitedfunc.default(function () {
/* eslint-disable babel/no-invalid-this */
this.forceUpdate();
}, 500));
}
componentDidMount() {
const cli = _MatrixClientPeg.MatrixClientPeg.get();
cli.on("RoomState.events", this._onRoomStateEvents);
cli.on("Room.accountData", this._onRoomAccountData);
}
componentWillUnmount() {
const cli = _MatrixClientPeg.MatrixClientPeg.get();
if (cli) {
cli.removeListener("RoomState.events", this._onRoomStateEvents);
cli.removeListener("Room.accountData", this._onRoomAccountData);
}
}
_hasUnreadPins() {
const currentPinEvent = this.props.room.currentState.getStateEvents("m.room.pinned_events", '');
if (!currentPinEvent) return false;
if (currentPinEvent.getContent().pinned && currentPinEvent.getContent().pinned.length <= 0) {
return false; // no pins == nothing to read
}
const readPinsEvent = this.props.room.getAccountData("im.vector.room.read_pins");
if (readPinsEvent && readPinsEvent.getContent()) {
const readStateEvents = readPinsEvent.getContent().event_ids || [];
if (readStateEvents) {
return !readStateEvents.includes(currentPinEvent.getId());
}
} // There's pins, and we haven't read any of them
return true;
}
_hasPins() {
const currentPinEvent = this.props.room.currentState.getStateEvents("m.room.pinned_events", '');
if (!currentPinEvent) return false;
return !(currentPinEvent.getContent().pinned && currentPinEvent.getContent().pinned.length <= 0);
}
render() {
let searchStatus = null;
let cancelButton = null;
let pinnedEventsButton = null;
if (this.props.onCancelClick) {
cancelButton = /*#__PURE__*/_react.default.createElement(_SimpleRoomHeader.CancelButton, {
onClick: this.props.onCancelClick
});
} // don't display the search count until the search completes and
// gives us a valid (possibly zero) searchCount.
if (this.props.searchInfo && this.props.searchInfo.searchCount !== undefined && this.props.searchInfo.searchCount !== null) {
searchStatus = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_searchStatus"
}, "\xA0", (0, _languageHandler._t)("(~%(count)s results)", {
count: this.props.searchInfo.searchCount
}));
} // XXX: this is a bit inefficient - we could just compare room.name for 'Empty room'...
let settingsHint = false;
const members = this.props.room ? this.props.room.getJoinedMembers() : undefined;
if (members) {
if (members.length === 1 && members[0].userId === _MatrixClientPeg.MatrixClientPeg.get().credentials.userId) {
const nameEvent = this.props.room.currentState.getStateEvents('m.room.name', '');
if (!nameEvent || !nameEvent.getContent().name) {
settingsHint = true;
}
}
}
let oobName = (0, _languageHandler._t)("Join Room");
if (this.props.oobData && this.props.oobData.name) {
oobName = this.props.oobData.name;
}
const textClasses = (0, _classnames.default)('mx_RoomHeader_nametext', {
mx_RoomHeader_settingsHint: settingsHint
});
const name = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_name",
onClick: this.props.onSettingsClick
}, /*#__PURE__*/_react.default.createElement(_RoomName.default, {
room: this.props.room
}, name => {
const roomName = name || oobName;
return /*#__PURE__*/_react.default.createElement("div", {
dir: "auto",
className: textClasses,
title: roomName
}, roomName);
}), searchStatus);
const topicElement = /*#__PURE__*/_react.default.createElement(_RoomTopic.default, {
room: this.props.room
}, (topic, ref) => /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_topic",
ref: ref,
title: topic,
dir: "auto"
}, topic));
let roomAvatar;
if (this.props.room) {
roomAvatar = /*#__PURE__*/_react.default.createElement(_DecoratedRoomAvatar.default, {
room: this.props.room,
avatarSize: 32,
oobData: this.props.oobData,
viewAvatarOnClick: true
});
}
if (this.props.onPinnedClick && _SettingsStore.default.getValue('feature_pinning')) {
let pinsIndicator = null;
if (this._hasUnreadPins()) {
pinsIndicator = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_pinsIndicator mx_RoomHeader_pinsIndicatorUnread"
});
} else if (this._hasPins()) {
pinsIndicator = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_pinsIndicator"
});
}
pinnedEventsButton = /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, {
className: "mx_RoomHeader_button mx_RoomHeader_pinnedButton",
onClick: this.props.onPinnedClick,
title: (0, _languageHandler._t)("Pinned Messages")
}, pinsIndicator);
}
let forgetButton;
if (this.props.onForgetClick) {
forgetButton = /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, {
className: "mx_RoomHeader_button mx_RoomHeader_forgetButton",
onClick: this.props.onForgetClick,
title: (0, _languageHandler._t)("Forget room")
});
}
let appsButton;
if (this.props.onAppsClick) {
appsButton = /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, {
className: (0, _classnames.default)("mx_RoomHeader_button mx_RoomHeader_appsButton", {
mx_RoomHeader_appsButton_highlight: this.props.appsShown
}),
onClick: this.props.onAppsClick,
title: this.props.appsShown ? (0, _languageHandler._t)("Hide Widgets") : (0, _languageHandler._t)("Show Widgets")
});
}
let searchButton;
if (this.props.onSearchClick && this.props.inRoom) {
searchButton = /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, {
className: "mx_RoomHeader_button mx_RoomHeader_searchButton",
onClick: this.props.onSearchClick,
title: (0, _languageHandler._t)("Search")
});
}
let voiceCallButton;
let videoCallButton;
if (this.props.inRoom && _SettingsStore.default.getValue("showCallButtonsInComposer")) {
voiceCallButton = /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, {
className: "mx_RoomHeader_button mx_RoomHeader_voiceCallButton",
onClick: () => this.props.onCallPlaced(_CallHandler.PlaceCallType.Voice),
title: (0, _languageHandler._t)("Voice call")
});
videoCallButton = /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, {
className: "mx_RoomHeader_button mx_RoomHeader_videoCallButton",
onClick: ev => this.props.onCallPlaced(ev.shiftKey ? _CallHandler.PlaceCallType.ScreenSharing : _CallHandler.PlaceCallType.Video),
title: (0, _languageHandler._t)("Video call")
});
}
const rightRow = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_buttons"
}, videoCallButton, voiceCallButton, pinnedEventsButton, forgetButton, appsButton, searchButton);
const e2eIcon = this.props.e2eStatus ? /*#__PURE__*/_react.default.createElement(_E2EIcon.default, {
status: this.props.e2eStatus
}) : undefined;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader light-panel"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_wrapper",
"aria-owns": "mx_RightPanel"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_avatar"
}, roomAvatar), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomHeader_e2eIcon"
}, e2eIcon), name, topicElement, cancelButton, rightRow, /*#__PURE__*/_react.default.createElement(_RoomHeaderButtons.default, null)));
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
room: _propTypes.default.object,
oobData: _propTypes.default.object,
inRoom: _propTypes.default.bool,
onSettingsClick: _propTypes.default.func,
onPinnedClick: _propTypes.default.func,
onSearchClick: _propTypes.default.func,
onLeaveClick: _propTypes.default.func,
onCancelClick: _propTypes.default.func,
e2eStatus: _propTypes.default.string,
onAppsClick: _propTypes.default.func,
appsShown: _propTypes.default.bool,
onCallPlaced: _propTypes.default.func // (PlaceCallType) => void;
}), (0, _defineProperty2.default)(_class2, "defaultProps", {
editing: false,
inRoom: false,
onCancelClick: null
}), _temp)) || _class);
exports.default = RoomHeader;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/rooms/RoomHeader.js"],"names":["RoomHeader","React","Component","event","state","props","room","getRoomId","roomId","_rateLimitedUpdate","getType","RateLimitedFunc","forceUpdate","componentDidMount","cli","MatrixClientPeg","get","on","_onRoomStateEvents","_onRoomAccountData","componentWillUnmount","removeListener","_hasUnreadPins","currentPinEvent","currentState","getStateEvents","getContent","pinned","length","readPinsEvent","getAccountData","readStateEvents","event_ids","includes","getId","_hasPins","render","searchStatus","cancelButton","pinnedEventsButton","onCancelClick","searchInfo","searchCount","undefined","count","settingsHint","members","getJoinedMembers","userId","credentials","nameEvent","name","oobName","oobData","textClasses","mx_RoomHeader_settingsHint","onSettingsClick","roomName","topicElement","topic","ref","roomAvatar","onPinnedClick","SettingsStore","getValue","pinsIndicator","forgetButton","onForgetClick","appsButton","onAppsClick","mx_RoomHeader_appsButton_highlight","appsShown","searchButton","onSearchClick","inRoom","voiceCallButton","videoCallButton","onCallPlaced","PlaceCallType","Voice","ev","shiftKey","ScreenSharing","Video","rightRow","e2eIcon","e2eStatus","PropTypes","object","bool","func","onLeaveClick","string","editing"],"mappings":"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","sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\nCopyright 2019 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 PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { _t } from '../../../languageHandler';\nimport {MatrixClientPeg} from '../../../MatrixClientPeg';\nimport RateLimitedFunc from '../../../ratelimitedfunc';\n\nimport {CancelButton} from './SimpleRoomHeader';\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport RoomHeaderButtons from '../right_panel/RoomHeaderButtons';\nimport E2EIcon from './E2EIcon';\nimport DecoratedRoomAvatar from \"../avatars/DecoratedRoomAvatar\";\nimport AccessibleTooltipButton from \"../elements/AccessibleTooltipButton\";\nimport RoomTopic from \"../elements/RoomTopic\";\nimport RoomName from \"../elements/RoomName\";\nimport {PlaceCallType} from \"../../../CallHandler\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.rooms.RoomHeader\")\nexport default class RoomHeader extends React.Component {\n    static propTypes = {\n        room: PropTypes.object,\n        oobData: PropTypes.object,\n        inRoom: PropTypes.bool,\n        onSettingsClick: PropTypes.func,\n        onPinnedClick: PropTypes.func,\n        onSearchClick: PropTypes.func,\n        onLeaveClick: PropTypes.func,\n        onCancelClick: PropTypes.func,\n        e2eStatus: PropTypes.string,\n        onAppsClick: PropTypes.func,\n        appsShown: PropTypes.bool,\n        onCallPlaced: PropTypes.func, // (PlaceCallType) => void;\n    };\n\n    static defaultProps = {\n        editing: false,\n        inRoom: false,\n        onCancelClick: null,\n    };\n\n    componentDidMount() {\n        const cli = MatrixClientPeg.get();\n        cli.on(\"RoomState.events\", this._onRoomStateEvents);\n        cli.on(\"Room.accountData\", this._onRoomAccountData);\n    }\n\n    componentWillUnmount() {\n        const cli = MatrixClientPeg.get();\n        if (cli) {\n            cli.removeListener(\"RoomState.events\", this._onRoomStateEvents);\n            cli.removeListener(\"Room.accountData\", this._onRoomAccountData);\n        }\n    }\n\n    _onRoomStateEvents = (event, state) => {\n        if (!this.props.room || event.getRoomId() !== this.props.room.roomId) {\n            return;\n        }\n\n        // redisplay the room name, topic, etc.\n        this._rateLimitedUpdate();\n    };\n\n    _onRoomAccountData = (event, room) => {\n        if (!this.props.room || room.roomId !== this.props.room.roomId) return;\n        if (event.getType() !== \"im.vector.room.read_pins\") return;\n\n        this._rateLimitedUpdate();\n    };\n\n    _rateLimitedUpdate = new RateLimitedFunc(function() {\n        /* eslint-disable babel/no-invalid-this */\n        this.forceUpdate();\n    }, 500);\n\n    _hasUnreadPins() {\n        const currentPinEvent = this.props.room.currentState.getStateEvents(\"m.room.pinned_events\", '');\n        if (!currentPinEvent) return false;\n        if (currentPinEvent.getContent().pinned && currentPinEvent.getContent().pinned.length <= 0) {\n            return false; // no pins == nothing to read\n        }\n\n        const readPinsEvent = this.props.room.getAccountData(\"im.vector.room.read_pins\");\n        if (readPinsEvent && readPinsEvent.getContent()) {\n            const readStateEvents = readPinsEvent.getContent().event_ids || [];\n            if (readStateEvents) {\n                return !readStateEvents.includes(currentPinEvent.getId());\n            }\n        }\n\n        // There's pins, and we haven't read any of them\n        return true;\n    }\n\n    _hasPins() {\n        const currentPinEvent = this.props.room.currentState.getStateEvents(\"m.room.pinned_events\", '');\n        if (!currentPinEvent) return false;\n\n        return !(currentPinEvent.getContent().pinned && currentPinEvent.getContent().pinned.length <= 0);\n    }\n\n    render() {\n        let searchStatus = null;\n        let cancelButton = null;\n        let pinnedEventsButton = null;\n\n        if (this.props.onCancelClick) {\n            cancelButton = <CancelButton onClick={this.props.onCancelClick} />;\n        }\n\n        // don't display the search count until the search completes and\n        // gives us a valid (possibly zero) searchCount.\n        if (this.props.searchInfo &&\n            this.props.searchInfo.searchCount !== undefined &&\n            this.props.searchInfo.searchCount !== null) {\n            searchStatus = <div className=\"mx_RoomHeader_searchStatus\">&nbsp;\n                { _t(\"(~%(count)s results)\", { count: this.props.searchInfo.searchCount }) }\n            </div>;\n        }\n\n        // XXX: this is a bit inefficient - we could just compare room.name for 'Empty room'...\n        let settingsHint = false;\n        const members = this.props.room ? this.props.room.getJoinedMembers() : undefined;\n        if (members) {\n            if (members.length === 1 && members[0].userId === MatrixClientPeg.get().credentials.userId) {\n                const nameEvent = this.props.room.currentState.getStateEvents('m.room.name', '');\n                if (!nameEvent || !nameEvent.getContent().name) {\n                    settingsHint = true;\n                }\n            }\n        }\n\n        let oobName = _t(\"Join Room\");\n        if (this.props.oobData && this.props.oobData.name) {\n            oobName = this.props.oobData.name;\n        }\n\n        const textClasses = classNames('mx_RoomHeader_nametext', { mx_RoomHeader_settingsHint: settingsHint });\n        const name =\n            <div className=\"mx_RoomHeader_name\" onClick={this.props.onSettingsClick}>\n                <RoomName room={this.props.room}>\n                    {(name) => {\n                        const roomName = name || oobName;\n                        return <div dir=\"auto\" className={textClasses} title={roomName}>{ roomName }</div>;\n                    }}\n                </RoomName>\n                { searchStatus }\n            </div>;\n\n        const topicElement = <RoomTopic room={this.props.room}>\n            {(topic, ref) => <div className=\"mx_RoomHeader_topic\" ref={ref} title={topic} dir=\"auto\">\n                { topic }\n            </div>}\n        </RoomTopic>;\n\n        let roomAvatar;\n        if (this.props.room) {\n            roomAvatar = <DecoratedRoomAvatar\n                room={this.props.room}\n                avatarSize={32}\n                oobData={this.props.oobData}\n                viewAvatarOnClick={true}\n            />;\n        }\n\n        if (this.props.onPinnedClick && SettingsStore.getValue('feature_pinning')) {\n            let pinsIndicator = null;\n            if (this._hasUnreadPins()) {\n                pinsIndicator = (<div className=\"mx_RoomHeader_pinsIndicator mx_RoomHeader_pinsIndicatorUnread\" />);\n            } else if (this._hasPins()) {\n                pinsIndicator = (<div className=\"mx_RoomHeader_pinsIndicator\" />);\n            }\n\n            pinnedEventsButton =\n                <AccessibleTooltipButton\n                    className=\"mx_RoomHeader_button mx_RoomHeader_pinnedButton\"\n                    onClick={this.props.onPinnedClick}\n                    title={_t(\"Pinned Messages\")}\n                >\n                    { pinsIndicator }\n                </AccessibleTooltipButton>;\n        }\n\n        let forgetButton;\n        if (this.props.onForgetClick) {\n            forgetButton =\n                <AccessibleTooltipButton\n                    className=\"mx_RoomHeader_button mx_RoomHeader_forgetButton\"\n                    onClick={this.props.onForgetClick}\n                    title={_t(\"Forget room\")} />;\n        }\n\n        let appsButton;\n        if (this.props.onAppsClick) {\n            appsButton =\n                <AccessibleTooltipButton\n                    className={classNames(\"mx_RoomHeader_button mx_RoomHeader_appsButton\", {\n                        mx_RoomHeader_appsButton_highlight: this.props.appsShown,\n                    })}\n                    onClick={this.props.onAppsClick}\n                    title={this.props.appsShown ? _t(\"Hide Widgets\") : _t(\"Show Widgets\")} />;\n        }\n\n        let searchButton;\n        if (this.props.onSearchClick && this.props.inRoom) {\n            searchButton =\n                <AccessibleTooltipButton\n                    className=\"mx_RoomHeader_button mx_RoomHeader_searchButton\"\n                    onClick={this.props.onSearchClick}\n                    title={_t(\"Search\")} />;\n        }\n\n        let voiceCallButton;\n        let videoCallButton;\n        if (this.props.inRoom && SettingsStore.getValue(\"showCallButtonsInComposer\")) {\n            voiceCallButton =\n                <AccessibleTooltipButton\n                    className=\"mx_RoomHeader_button mx_RoomHeader_voiceCallButton\"\n                    onClick={() => this.props.onCallPlaced(PlaceCallType.Voice)}\n                    title={_t(\"Voice call\")} />;\n            videoCallButton =\n                <AccessibleTooltipButton\n                    className=\"mx_RoomHeader_button mx_RoomHeader_videoCallButton\"\n                    onClick={(ev) => this.props.onCallPlaced(\n                        ev.shiftKey ? PlaceCallType.ScreenSharing : PlaceCallType.Video)}\n                    title={_t(\"Video call\")} />;\n        }\n\n        const rightRow =\n            <div className=\"mx_RoomHeader_buttons\">\n                { videoCallButton }\n                { voiceCallButton }\n                { pinnedEventsButton }\n                { forgetButton }\n                { appsButton }\n                { searchButton }\n            </div>;\n\n        const e2eIcon = this.props.e2eStatus ? <E2EIcon status={this.props.e2eStatus} /> : undefined;\n\n        return (\n            <div className=\"mx_RoomHeader light-panel\">\n                <div className=\"mx_RoomHeader_wrapper\" aria-owns=\"mx_RightPanel\">\n                    <div className=\"mx_RoomHeader_avatar\">{ roomAvatar }</div>\n                    <div className=\"mx_RoomHeader_e2eIcon\">{ e2eIcon }</div>\n                    { name }\n                    { topicElement }\n                    { cancelButton }\n                    { rightRow }\n                    <RoomHeaderButtons />\n                </div>\n            </div>\n        );\n    }\n}\n"]}