matrix-react-sdk
Version:
SDK for matrix.org using React
128 lines (104 loc) • 15.7 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 _event = require("matrix-js-sdk/src/models/event");
var sdk = _interopRequireWildcard(require("../../../index"));
var _languageHandler = require("../../../languageHandler");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _ErrorDialog = _interopRequireDefault(require("../dialogs/ErrorDialog"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _class2, _temp;
const GROUP_ID_REGEX = /\+\S+:\S+/;
let RelatedGroupSettings = (_dec = (0, _replaceableComponent.replaceableComponent)("views.room_settings.RelatedGroupSettings"), _dec(_class = (_temp = _class2 = class RelatedGroupSettings extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onNewGroupChanged", newGroupId => {
this.setState({
newGroupId
});
});
(0, _defineProperty2.default)(this, "onGroupAdded", groupId => {
if (groupId.length === 0 || !this.validateGroupId(groupId)) {
return;
}
const newGroupsList = [...this.state.newGroupsList, groupId];
this.setState({
newGroupsList: newGroupsList,
newGroupId: ''
});
this.updateGroups(newGroupsList);
});
(0, _defineProperty2.default)(this, "onGroupDeleted", index => {
const group = this.state.newGroupsList[index];
const newGroupsList = this.state.newGroupsList.filter(g => g !== group);
this.setState({
newGroupsList
});
this.updateGroups(newGroupsList);
});
this.state = {
newGroupId: "",
newGroupsList: props.relatedGroupsEvent ? props.relatedGroupsEvent.getContent().groups || [] : []
};
}
updateGroups(newGroupsList) {
this.context.sendStateEvent(this.props.roomId, 'm.room.related_groups', {
groups: newGroupsList
}, '').catch(err => {
console.error(err);
_Modal.default.createTrackedDialog('Error updating flair', '', _ErrorDialog.default, {
title: (0, _languageHandler._t)("Error updating flair"),
description: (0, _languageHandler._t)("There was an error updating the flair for this room. The server may not allow it or " + "a temporary error occurred.")
});
});
}
validateGroupId(groupId) {
if (!GROUP_ID_REGEX.test(groupId)) {
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
_Modal.default.createTrackedDialog('Invalid related community ID', '', ErrorDialog, {
title: (0, _languageHandler._t)('Invalid community ID'),
description: (0, _languageHandler._t)('\'%(groupId)s\' is not a valid community ID', {
groupId
})
});
return false;
}
return true;
}
render() {
const localDomain = this.context.getDomain();
const EditableItemList = sdk.getComponent('elements.EditableItemList');
return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(EditableItemList, {
id: "relatedGroups",
items: this.state.newGroupsList,
className: "mx_RelatedGroupSettings",
newItem: this.state.newGroupId,
canRemove: this.props.canSetRelatedGroups,
canEdit: this.props.canSetRelatedGroups,
onNewItemChanged: this.onNewGroupChanged,
onItemAdded: this.onGroupAdded,
onItemRemoved: this.onGroupDeleted,
itemsLabel: (0, _languageHandler._t)('Showing flair for these communities:'),
noItemsLabel: (0, _languageHandler._t)('This room is not showing flair for any communities'),
placeholder: (0, _languageHandler._t)('New community ID (e.g. +foo:%(localDomain)s)', {
localDomain
})
}));
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
roomId: _propTypes.default.string.isRequired,
canSetRelatedGroups: _propTypes.default.bool.isRequired,
relatedGroupsEvent: _propTypes.default.instanceOf(_event.MatrixEvent)
}), (0, _defineProperty2.default)(_class2, "contextType", _MatrixClientContext.default), (0, _defineProperty2.default)(_class2, "defaultProps", {
canSetRelatedGroups: false
}), _temp)) || _class);
exports.default = RelatedGroupSettings;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/room_settings/RelatedGroupSettings.js"],"names":["GROUP_ID_REGEX","RelatedGroupSettings","React","Component","constructor","props","newGroupId","setState","groupId","length","validateGroupId","newGroupsList","state","updateGroups","index","group","filter","g","relatedGroupsEvent","getContent","groups","context","sendStateEvent","roomId","catch","err","console","error","Modal","createTrackedDialog","ErrorDialog","title","description","test","sdk","getComponent","render","localDomain","getDomain","EditableItemList","canSetRelatedGroups","onNewGroupChanged","onGroupAdded","onGroupDeleted","PropTypes","string","isRequired","bool","instanceOf","MatrixEvent","MatrixClientContext"],"mappings":"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","sourcesContent":["/*\nCopyright 2017, 2019 New Vector Ltd.\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 {MatrixEvent} from 'matrix-js-sdk/src/models/event';\nimport * as sdk from '../../../index';\nimport { _t } from '../../../languageHandler';\nimport Modal from '../../../Modal';\nimport ErrorDialog from \"../dialogs/ErrorDialog\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nconst GROUP_ID_REGEX = /\\+\\S+:\\S+/;\n\n@replaceableComponent(\"views.room_settings.RelatedGroupSettings\")\nexport default class RelatedGroupSettings extends React.Component {\n    static propTypes = {\n        roomId: PropTypes.string.isRequired,\n        canSetRelatedGroups: PropTypes.bool.isRequired,\n        relatedGroupsEvent: PropTypes.instanceOf(MatrixEvent),\n    };\n\n    static contextType = MatrixClientContext;\n\n    static defaultProps = {\n        canSetRelatedGroups: false,\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            newGroupId: \"\",\n            newGroupsList: props.relatedGroupsEvent ? (props.relatedGroupsEvent.getContent().groups || []) : [],\n        };\n    }\n\n    updateGroups(newGroupsList) {\n        this.context.sendStateEvent(this.props.roomId, 'm.room.related_groups', {\n            groups: newGroupsList,\n        }, '').catch((err) => {\n            console.error(err);\n            Modal.createTrackedDialog('Error updating flair', '', ErrorDialog, {\n                title: _t(\"Error updating flair\"),\n                description: _t(\n                    \"There was an error updating the flair for this room. The server may not allow it or \" +\n                    \"a temporary error occurred.\",\n                ),\n            });\n        });\n    }\n\n    validateGroupId(groupId) {\n        if (!GROUP_ID_REGEX.test(groupId)) {\n            const ErrorDialog = sdk.getComponent(\"dialogs.ErrorDialog\");\n            Modal.createTrackedDialog('Invalid related community ID', '', ErrorDialog, {\n                title: _t('Invalid community ID'),\n                description: _t('\\'%(groupId)s\\' is not a valid community ID', { groupId }),\n            });\n            return false;\n        }\n        return true;\n    }\n\n    onNewGroupChanged = (newGroupId) => {\n        this.setState({ newGroupId });\n    };\n\n    onGroupAdded = (groupId) => {\n        if (groupId.length === 0 || !this.validateGroupId(groupId)) {\n            return;\n        }\n        const newGroupsList = [...this.state.newGroupsList, groupId];\n        this.setState({\n            newGroupsList: newGroupsList,\n            newGroupId: '',\n        });\n        this.updateGroups(newGroupsList);\n    };\n\n    onGroupDeleted = (index) => {\n        const group = this.state.newGroupsList[index];\n        const newGroupsList = this.state.newGroupsList.filter((g) => g !== group);\n        this.setState({ newGroupsList });\n        this.updateGroups(newGroupsList);\n    };\n\n    render() {\n        const localDomain = this.context.getDomain();\n        const EditableItemList = sdk.getComponent('elements.EditableItemList');\n        return <div>\n            <EditableItemList\n                id=\"relatedGroups\"\n                items={this.state.newGroupsList}\n                className={\"mx_RelatedGroupSettings\"}\n                newItem={this.state.newGroupId}\n                canRemove={this.props.canSetRelatedGroups}\n                canEdit={this.props.canSetRelatedGroups}\n                onNewItemChanged={this.onNewGroupChanged}\n                onItemAdded={this.onGroupAdded}\n                onItemRemoved={this.onGroupDeleted}\n                itemsLabel={_t('Showing flair for these communities:')}\n                noItemsLabel={_t('This room is not showing flair for any communities')}\n                placeholder={_t(\n                    'New community ID (e.g. +foo:%(localDomain)s)', {localDomain},\n                )}\n            />\n        </div>;\n    }\n}\n"]}