matrix-react-sdk
Version:
SDK for matrix.org using React
238 lines (199 loc) • 31.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
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 _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _Modal = _interopRequireDefault(require("../../../Modal"));
var sdk = _interopRequireWildcard(require("../../../index"));
var _languageHandler = require("../../../languageHandler");
var _GroupStore = _interopRequireDefault(require("../../../stores/GroupStore"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _AutoHideScrollbar = _interopRequireDefault(require("../../structures/AutoHideScrollbar"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _Media = require("../../../customisations/Media");
var _dec, _class, _class2, _temp;
let GroupRoomInfo = (_dec = (0, _replaceableComponent.replaceableComponent)("views.groups.GroupRoomInfo"), _dec(_class = (_temp = _class2 = class GroupRoomInfo extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "state", {
isUserPrivilegedInGroup: null,
groupRoom: null,
groupRoomPublicityLoading: false,
groupRoomRemoveLoading: false
});
(0, _defineProperty2.default)(this, "onGroupStoreUpdated", () => {
this.setState({
isUserPrivilegedInGroup: _GroupStore.default.isUserPrivileged(this.props.groupId)
});
this._updateGroupRoom();
});
(0, _defineProperty2.default)(this, "_onRemove", e => {
const groupId = this.props.groupId;
const roomName = this.state.groupRoom.displayname;
e.preventDefault();
e.stopPropagation();
const QuestionDialog = sdk.getComponent("dialogs.QuestionDialog");
_Modal.default.createTrackedDialog('Confirm removal of group from room', '', QuestionDialog, {
title: (0, _languageHandler._t)("Are you sure you want to remove '%(roomName)s' from %(groupId)s?", {
roomName,
groupId
}),
description: (0, _languageHandler._t)("Removing a room from the community will also remove it from the community page."),
button: (0, _languageHandler._t)("Remove"),
onFinished: proceed => {
if (!proceed) return;
this.setState({
groupRoomRemoveLoading: true
});
const groupId = this.props.groupId;
const roomId = this.props.groupRoomId;
_GroupStore.default.removeRoomFromGroup(this.props.groupId, roomId).then(() => {
_dispatcher.default.dispatch({
action: "view_group_room_list"
});
}).catch(err => {
console.error(`Error whilst removing ${roomId} from ${groupId}`, err);
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
_Modal.default.createTrackedDialog('Failed to remove room from group', '', ErrorDialog, {
title: (0, _languageHandler._t)("Failed to remove room from community"),
description: (0, _languageHandler._t)("Failed to remove '%(roomName)s' from %(groupId)s", {
groupId,
roomName
})
});
}).finally(() => {
this.setState({
groupRoomRemoveLoading: false
});
});
}
});
});
(0, _defineProperty2.default)(this, "_onCancel", e => {
_dispatcher.default.dispatch({
action: "view_group_room_list"
});
});
(0, _defineProperty2.default)(this, "_changeGroupRoomPublicity", e => {
const isPublic = e.target.value === "public";
this.setState({
groupRoomPublicityLoading: true
});
const groupId = this.props.groupId;
const roomId = this.props.groupRoomId;
const roomName = this.state.groupRoom.displayname;
_GroupStore.default.updateGroupRoomVisibility(this.props.groupId, roomId, isPublic).catch(err => {
console.error(`Error whilst changing visibility of ${roomId} in ${groupId} to ${isPublic}`, err);
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
_Modal.default.createTrackedDialog('Failed to remove room from group', '', ErrorDialog, {
title: (0, _languageHandler._t)("Something went wrong!"),
description: (0, _languageHandler._t)("The visibility of '%(roomName)s' in %(groupId)s could not be updated.", {
roomName,
groupId
})
});
}).finally(() => {
this.setState({
groupRoomPublicityLoading: false
});
});
});
}
componentDidMount() {
this._initGroupStore(this.props.groupId);
} // TODO: [REACT-WARNING] Replace with appropriate lifecycle event
// eslint-disable-next-line camelcase
UNSAFE_componentWillReceiveProps(newProps) {
if (newProps.groupId !== this.props.groupId) {
this._unregisterGroupStore(this.props.groupId);
this._initGroupStore(newProps.groupId);
}
}
componentWillUnmount() {
this._unregisterGroupStore(this.props.groupId);
}
_initGroupStore(groupId) {
_GroupStore.default.registerListener(groupId, this.onGroupStoreUpdated);
}
_unregisterGroupStore(groupId) {
_GroupStore.default.unregisterListener(this.onGroupStoreUpdated);
}
_updateGroupRoom() {
this.setState({
groupRoom: _GroupStore.default.getGroupRooms(this.props.groupId).find(r => r.roomId === this.props.groupRoomId)
});
}
render() {
const AccessibleButton = sdk.getComponent('elements.AccessibleButton');
const InlineSpinner = sdk.getComponent('elements.InlineSpinner');
if (this.state.groupRoomRemoveLoading || !this.state.groupRoom) {
const Spinner = sdk.getComponent("elements.Spinner");
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo"
}, /*#__PURE__*/_react.default.createElement(Spinner, null));
}
let adminTools;
if (this.state.isUserPrivilegedInGroup) {
adminTools = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_adminTools"
}, /*#__PURE__*/_react.default.createElement("h3", null, (0, _languageHandler._t)("Admin Tools")), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_buttons"
}, /*#__PURE__*/_react.default.createElement(AccessibleButton, {
className: "mx_MemberInfo_field",
onClick: this._onRemove
}, (0, _languageHandler._t)('Remove from community'))), /*#__PURE__*/_react.default.createElement("h3", null, (0, _languageHandler._t)('Visibility in Room List'), this.state.groupRoomPublicityLoading ? /*#__PURE__*/_react.default.createElement(InlineSpinner, null) : /*#__PURE__*/_react.default.createElement("div", null)), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("label", null, /*#__PURE__*/_react.default.createElement("input", {
type: "radio",
value: "public",
checked: this.state.groupRoom.isPublic,
onChange: this._changeGroupRoomPublicity
}), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_label_text"
}, (0, _languageHandler._t)('Visible to everyone')))), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("label", null, /*#__PURE__*/_react.default.createElement("input", {
type: "radio",
value: "private",
checked: !this.state.groupRoom.isPublic,
onChange: this._changeGroupRoomPublicity
}), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_label_text"
}, (0, _languageHandler._t)('Only visible to community members')))));
}
const avatarUrl = this.state.groupRoom.avatarUrl;
let avatarElement;
if (avatarUrl) {
const httpUrl = (0, _Media.mediaFromMxc)(avatarUrl).getSquareThumbnailHttp(800);
avatarElement = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_avatar"
}, /*#__PURE__*/_react.default.createElement("img", {
src: httpUrl
}));
}
const groupRoomName = this.state.groupRoom.displayname;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo",
role: "tabpanel"
}, /*#__PURE__*/_react.default.createElement(_AutoHideScrollbar.default, null, /*#__PURE__*/_react.default.createElement(AccessibleButton, {
className: "mx_MemberInfo_cancel",
onClick: this._onCancel
}, /*#__PURE__*/_react.default.createElement("img", {
src: require("../../../../res/img/cancel.svg"),
width: "18",
height: "18",
className: "mx_filterFlipColor"
})), avatarElement, /*#__PURE__*/_react.default.createElement("h2", null, groupRoomName), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_profile"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_profileField"
}, this.state.groupRoom.canonicalAlias)), adminTools));
}
}, (0, _defineProperty2.default)(_class2, "contextType", _MatrixClientContext.default), (0, _defineProperty2.default)(_class2, "propTypes", {
groupId: _propTypes.default.string,
groupRoomId: _propTypes.default.string
}), _temp)) || _class);
exports.default = GroupRoomInfo;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/groups/GroupRoomInfo.js"],"names":["GroupRoomInfo","React","Component","isUserPrivilegedInGroup","groupRoom","groupRoomPublicityLoading","groupRoomRemoveLoading","setState","GroupStore","isUserPrivileged","props","groupId","_updateGroupRoom","e","roomName","state","displayname","preventDefault","stopPropagation","QuestionDialog","sdk","getComponent","Modal","createTrackedDialog","title","description","button","onFinished","proceed","roomId","groupRoomId","removeRoomFromGroup","then","dis","dispatch","action","catch","err","console","error","ErrorDialog","finally","isPublic","target","value","updateGroupRoomVisibility","componentDidMount","_initGroupStore","UNSAFE_componentWillReceiveProps","newProps","_unregisterGroupStore","componentWillUnmount","registerListener","onGroupStoreUpdated","unregisterListener","getGroupRooms","find","r","render","AccessibleButton","InlineSpinner","Spinner","adminTools","_onRemove","_changeGroupRoomPublicity","avatarUrl","avatarElement","httpUrl","getSquareThumbnailHttp","groupRoomName","_onCancel","require","canonicalAlias","MatrixClientContext","PropTypes","string"],"mappings":"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","sourcesContent":["/*\nCopyright 2017 New Vector 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 dis from '../../../dispatcher/dispatcher';\nimport Modal from '../../../Modal';\nimport * as sdk from '../../../index';\nimport { _t } from '../../../languageHandler';\nimport GroupStore from '../../../stores/GroupStore';\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport AutoHideScrollbar from \"../../structures/AutoHideScrollbar\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\n@replaceableComponent(\"views.groups.GroupRoomInfo\")\nexport default class GroupRoomInfo extends React.Component {\n    static contextType = MatrixClientContext;\n\n    static propTypes = {\n        groupId: PropTypes.string,\n        groupRoomId: PropTypes.string,\n    };\n\n    state = {\n        isUserPrivilegedInGroup: null,\n        groupRoom: null,\n        groupRoomPublicityLoading: false,\n        groupRoomRemoveLoading: false,\n    };\n\n    componentDidMount() {\n        this._initGroupStore(this.props.groupId);\n    }\n\n    // TODO: [REACT-WARNING] Replace with appropriate lifecycle event\n    // eslint-disable-next-line camelcase\n    UNSAFE_componentWillReceiveProps(newProps) {\n        if (newProps.groupId !== this.props.groupId) {\n            this._unregisterGroupStore(this.props.groupId);\n            this._initGroupStore(newProps.groupId);\n        }\n    }\n\n    componentWillUnmount() {\n        this._unregisterGroupStore(this.props.groupId);\n    }\n\n    _initGroupStore(groupId) {\n        GroupStore.registerListener(groupId, this.onGroupStoreUpdated);\n    }\n\n    _unregisterGroupStore(groupId) {\n        GroupStore.unregisterListener(this.onGroupStoreUpdated);\n    }\n\n    _updateGroupRoom() {\n        this.setState({\n            groupRoom: GroupStore.getGroupRooms(this.props.groupId).find(\n                (r) => r.roomId === this.props.groupRoomId,\n            ),\n        });\n    }\n\n    onGroupStoreUpdated = () => {\n        this.setState({\n            isUserPrivilegedInGroup: GroupStore.isUserPrivileged(this.props.groupId),\n        });\n        this._updateGroupRoom();\n    };\n\n    _onRemove = e => {\n        const groupId = this.props.groupId;\n        const roomName = this.state.groupRoom.displayname;\n        e.preventDefault();\n        e.stopPropagation();\n        const QuestionDialog = sdk.getComponent(\"dialogs.QuestionDialog\");\n        Modal.createTrackedDialog('Confirm removal of group from room', '', QuestionDialog, {\n            title: _t(\"Are you sure you want to remove '%(roomName)s' from %(groupId)s?\", {roomName, groupId}),\n            description: _t(\"Removing a room from the community will also remove it from the community page.\"),\n            button: _t(\"Remove\"),\n            onFinished: (proceed) => {\n                if (!proceed) return;\n                this.setState({groupRoomRemoveLoading: true});\n                const groupId = this.props.groupId;\n                const roomId = this.props.groupRoomId;\n                GroupStore.removeRoomFromGroup(this.props.groupId, roomId).then(() => {\n                    dis.dispatch({\n                        action: \"view_group_room_list\",\n                    });\n                }).catch((err) => {\n                    console.error(`Error whilst removing ${roomId} from ${groupId}`, err);\n                    const ErrorDialog = sdk.getComponent(\"dialogs.ErrorDialog\");\n                    Modal.createTrackedDialog('Failed to remove room from group', '', ErrorDialog, {\n                        title: _t(\"Failed to remove room from community\"),\n                        description: _t(\n                            \"Failed to remove '%(roomName)s' from %(groupId)s\", {groupId, roomName},\n                        ),\n                    });\n                }).finally(() => {\n                    this.setState({groupRoomRemoveLoading: false});\n                });\n            },\n        });\n    };\n\n    _onCancel = e => {\n        dis.dispatch({\n            action: \"view_group_room_list\",\n        });\n    };\n\n    _changeGroupRoomPublicity = e => {\n        const isPublic = e.target.value === \"public\";\n        this.setState({\n            groupRoomPublicityLoading: true,\n        });\n        const groupId = this.props.groupId;\n        const roomId = this.props.groupRoomId;\n        const roomName = this.state.groupRoom.displayname;\n        GroupStore.updateGroupRoomVisibility(this.props.groupId, roomId, isPublic).catch((err) => {\n            console.error(`Error whilst changing visibility of ${roomId} in ${groupId} to ${isPublic}`, err);\n            const ErrorDialog = sdk.getComponent(\"dialogs.ErrorDialog\");\n            Modal.createTrackedDialog('Failed to remove room from group', '', ErrorDialog, {\n                title: _t(\"Something went wrong!\"),\n                description: _t(\n                    \"The visibility of '%(roomName)s' in %(groupId)s could not be updated.\",\n                    {roomName, groupId},\n                ),\n            });\n        }).finally(() => {\n            this.setState({\n                groupRoomPublicityLoading: false,\n            });\n        });\n    };\n\n    render() {\n        const AccessibleButton = sdk.getComponent('elements.AccessibleButton');\n        const InlineSpinner = sdk.getComponent('elements.InlineSpinner');\n        if (this.state.groupRoomRemoveLoading || !this.state.groupRoom) {\n            const Spinner = sdk.getComponent(\"elements.Spinner\");\n            return <div className=\"mx_MemberInfo\">\n                <Spinner />\n            </div>;\n        }\n\n        let adminTools;\n        if (this.state.isUserPrivilegedInGroup) {\n            adminTools =\n                <div className=\"mx_MemberInfo_adminTools\">\n                    <h3>{ _t(\"Admin Tools\") }</h3>\n                    <div className=\"mx_MemberInfo_buttons\">\n                        <AccessibleButton className=\"mx_MemberInfo_field\" onClick={this._onRemove}>\n                            { _t('Remove from community') }\n                        </AccessibleButton>\n                    </div>\n                    <h3>\n                        { _t('Visibility in Room List') }\n                        { this.state.groupRoomPublicityLoading ?\n                            <InlineSpinner /> : <div />\n                        }\n                    </h3>\n                    <div>\n                        <label>\n                            <input type=\"radio\"\n                                value=\"public\"\n                                checked={this.state.groupRoom.isPublic}\n                                onChange={this._changeGroupRoomPublicity}\n                            />\n                            <div className=\"mx_MemberInfo_label_text\">\n                                { _t('Visible to everyone') }\n                            </div>\n                        </label>\n                    </div>\n                    <div>\n                        <label>\n                            <input type=\"radio\"\n                                value=\"private\"\n                                checked={!this.state.groupRoom.isPublic}\n                                onChange={this._changeGroupRoomPublicity}\n                            />\n                            <div className=\"mx_MemberInfo_label_text\">\n                                { _t('Only visible to community members') }\n                            </div>\n                        </label>\n                    </div>\n                </div>;\n        }\n\n        const avatarUrl = this.state.groupRoom.avatarUrl;\n        let avatarElement;\n        if (avatarUrl) {\n            const httpUrl = mediaFromMxc(avatarUrl).getSquareThumbnailHttp(800);\n            avatarElement = <div className=\"mx_MemberInfo_avatar\"><img src={httpUrl} /></div>;\n        }\n\n        const groupRoomName = this.state.groupRoom.displayname;\n        return (\n            <div className=\"mx_MemberInfo\" role=\"tabpanel\">\n                <AutoHideScrollbar>\n                    <AccessibleButton className=\"mx_MemberInfo_cancel\" onClick={this._onCancel}>\n                        <img src={require(\"../../../../res/img/cancel.svg\")} width=\"18\" height=\"18\" className=\"mx_filterFlipColor\" />\n                    </AccessibleButton>\n                    { avatarElement }\n\n                    <h2>{ groupRoomName }</h2>\n\n                    <div className=\"mx_MemberInfo_profile\">\n                        <div className=\"mx_MemberInfo_profileField\">\n                            { this.state.groupRoom.canonicalAlias }\n                        </div>\n                    </div>\n\n                    { adminTools }\n                </AutoHideScrollbar>\n            </div>\n        );\n    }\n}\n"]}