UNPKG

matrix-react-sdk

Version:
188 lines (162 loc) 21.9 kB
"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 sdk = _interopRequireWildcard(require("../../../index")); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _languageHandler = require("../../../languageHandler"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; let CreateGroupDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.CreateGroupDialog"), _dec(_class = (_temp = _class2 = class CreateGroupDialog extends _react.default.Component { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "state", { groupName: '', groupId: '', groupError: null, creating: false, createError: null }); (0, _defineProperty2.default)(this, "_onGroupNameChange", e => { this.setState({ groupName: e.target.value }); }); (0, _defineProperty2.default)(this, "_onGroupIdChange", e => { this.setState({ groupId: e.target.value }); }); (0, _defineProperty2.default)(this, "_onGroupIdBlur", e => { this._checkGroupId(); }); (0, _defineProperty2.default)(this, "_onFormSubmit", e => { e.preventDefault(); if (this._checkGroupId()) return; const profile = {}; if (this.state.groupName !== '') { profile.name = this.state.groupName; } this.setState({ creating: true }); _MatrixClientPeg.MatrixClientPeg.get().createGroup({ localpart: this.state.groupId, profile: profile }).then(result => { _dispatcher.default.dispatch({ action: 'view_group', group_id: result.group_id, group_is_new: true }); this.props.onFinished(true); }).catch(e => { this.setState({ createError: e }); }).finally(() => { this.setState({ creating: false }); }); }); (0, _defineProperty2.default)(this, "_onCancel", () => { this.props.onFinished(false); }); } _checkGroupId(e) { let error = null; if (!this.state.groupId) { error = (0, _languageHandler._t)("Community IDs cannot be empty."); } else if (!/^[a-z0-9=_\-./]*$/.test(this.state.groupId)) { error = (0, _languageHandler._t)("Community IDs may only contain characters a-z, 0-9, or '=_-./'"); } this.setState({ groupIdError: error, // Reset createError to get rid of now stale error message createError: null }); return error; } render() { const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog'); const Spinner = sdk.getComponent('elements.Spinner'); if (this.state.creating) { return /*#__PURE__*/_react.default.createElement(Spinner, null); } let createErrorNode; if (this.state.createError) { // XXX: We should catch errcodes and give sensible i18ned messages for them, // rather than displaying what the server gives us, but synapse doesn't give // any yet. createErrorNode = /*#__PURE__*/_react.default.createElement("div", { className: "error", role: "alert" }, /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)('Something went wrong whilst creating your community')), /*#__PURE__*/_react.default.createElement("div", null, this.state.createError.message)); } return /*#__PURE__*/_react.default.createElement(BaseDialog, { className: "mx_CreateGroupDialog", onFinished: this.props.onFinished, title: (0, _languageHandler._t)('Create Community') }, /*#__PURE__*/_react.default.createElement("form", { onSubmit: this._onFormSubmit }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateGroupDialog_inputRow" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateGroupDialog_label" }, /*#__PURE__*/_react.default.createElement("label", { htmlFor: "groupname" }, (0, _languageHandler._t)('Community Name'))), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("input", { id: "groupname", className: "mx_CreateGroupDialog_input", autoFocus: true, size: "64", placeholder: (0, _languageHandler._t)('Example'), onChange: this._onGroupNameChange, value: this.state.groupName }))), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateGroupDialog_inputRow" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateGroupDialog_label" }, /*#__PURE__*/_react.default.createElement("label", { htmlFor: "groupid" }, (0, _languageHandler._t)('Community ID'))), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateGroupDialog_input_group" }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_CreateGroupDialog_prefix" }, "+"), /*#__PURE__*/_react.default.createElement("input", { id: "groupid", className: "mx_CreateGroupDialog_input mx_CreateGroupDialog_input_hasPrefixAndSuffix", size: "32", placeholder: (0, _languageHandler._t)('example'), onChange: this._onGroupIdChange, onBlur: this._onGroupIdBlur, value: this.state.groupId }), /*#__PURE__*/_react.default.createElement("span", { className: "mx_CreateGroupDialog_suffix" }, ":", _MatrixClientPeg.MatrixClientPeg.get().getDomain()))), /*#__PURE__*/_react.default.createElement("div", { className: "error" }, this.state.groupIdError), createErrorNode), /*#__PURE__*/_react.default.createElement("div", { className: "mx_Dialog_buttons" }, /*#__PURE__*/_react.default.createElement("input", { type: "submit", value: (0, _languageHandler._t)('Create'), className: "mx_Dialog_primary" }), /*#__PURE__*/_react.default.createElement("button", { onClick: this._onCancel }, (0, _languageHandler._t)("Cancel"))))); } }, (0, _defineProperty2.default)(_class2, "propTypes", { onFinished: _propTypes.default.func.isRequired }), _temp)) || _class); exports.default = CreateGroupDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/CreateGroupDialog.js"],"names":["CreateGroupDialog","React","Component","groupName","groupId","groupError","creating","createError","e","setState","target","value","_checkGroupId","preventDefault","profile","state","name","MatrixClientPeg","get","createGroup","localpart","then","result","dis","dispatch","action","group_id","group_is_new","props","onFinished","catch","finally","error","test","groupIdError","render","BaseDialog","sdk","getComponent","Spinner","createErrorNode","message","_onFormSubmit","_onGroupNameChange","_onGroupIdChange","_onGroupIdBlur","getDomain","_onCancel","PropTypes","func","isRequired"],"mappings":"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","sourcesContent":["/*\nCopyright 2017 Vector Creations 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 * as sdk from '../../../index';\nimport dis from '../../../dispatcher/dispatcher';\nimport { _t } from '../../../languageHandler';\nimport {MatrixClientPeg} from '../../../MatrixClientPeg';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.dialogs.CreateGroupDialog\")\nexport default class CreateGroupDialog extends React.Component {\n    static propTypes = {\n        onFinished: PropTypes.func.isRequired,\n    };\n\n    state = {\n        groupName: '',\n        groupId: '',\n        groupError: null,\n        creating: false,\n        createError: null,\n    };\n\n    _onGroupNameChange = e => {\n        this.setState({\n            groupName: e.target.value,\n        });\n    };\n\n    _onGroupIdChange = e => {\n        this.setState({\n            groupId: e.target.value,\n        });\n    };\n\n    _onGroupIdBlur = e => {\n        this._checkGroupId();\n    };\n\n    _checkGroupId(e) {\n        let error = null;\n        if (!this.state.groupId) {\n            error = _t(\"Community IDs cannot be empty.\");\n        } else if (!/^[a-z0-9=_\\-./]*$/.test(this.state.groupId)) {\n            error = _t(\"Community IDs may only contain characters a-z, 0-9, or '=_-./'\");\n        }\n        this.setState({\n            groupIdError: error,\n            // Reset createError to get rid of now stale error message\n            createError: null,\n        });\n        return error;\n    }\n\n    _onFormSubmit = e => {\n        e.preventDefault();\n\n        if (this._checkGroupId()) return;\n\n        const profile = {};\n        if (this.state.groupName !== '') {\n            profile.name = this.state.groupName;\n        }\n        this.setState({creating: true});\n        MatrixClientPeg.get().createGroup({\n            localpart: this.state.groupId,\n            profile: profile,\n        }).then((result) => {\n            dis.dispatch({\n                action: 'view_group',\n                group_id: result.group_id,\n                group_is_new: true,\n            });\n            this.props.onFinished(true);\n        }).catch((e) => {\n            this.setState({createError: e});\n        }).finally(() => {\n            this.setState({creating: false});\n        });\n    };\n\n    _onCancel = () => {\n        this.props.onFinished(false);\n    };\n\n    render() {\n        const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog');\n        const Spinner = sdk.getComponent('elements.Spinner');\n\n        if (this.state.creating) {\n            return <Spinner />;\n        }\n\n        let createErrorNode;\n        if (this.state.createError) {\n            // XXX: We should catch errcodes and give sensible i18ned messages for them,\n            // rather than displaying what the server gives us, but synapse doesn't give\n            // any yet.\n            createErrorNode = <div className=\"error\" role=\"alert\">\n                <div>{ _t('Something went wrong whilst creating your community') }</div>\n                <div>{ this.state.createError.message }</div>\n            </div>;\n        }\n\n        return (\n            <BaseDialog className=\"mx_CreateGroupDialog\" onFinished={this.props.onFinished}\n                title={_t('Create Community')}\n            >\n                <form onSubmit={this._onFormSubmit}>\n                    <div className=\"mx_Dialog_content\">\n                        <div className=\"mx_CreateGroupDialog_inputRow\">\n                            <div className=\"mx_CreateGroupDialog_label\">\n                                <label htmlFor=\"groupname\">{ _t('Community Name') }</label>\n                            </div>\n                            <div>\n                                <input id=\"groupname\" className=\"mx_CreateGroupDialog_input\"\n                                    autoFocus={true} size=\"64\"\n                                    placeholder={_t('Example')}\n                                    onChange={this._onGroupNameChange}\n                                    value={this.state.groupName}\n                                />\n                            </div>\n                        </div>\n                        <div className=\"mx_CreateGroupDialog_inputRow\">\n                            <div className=\"mx_CreateGroupDialog_label\">\n                                <label htmlFor=\"groupid\">{ _t('Community ID') }</label>\n                            </div>\n                            <div className=\"mx_CreateGroupDialog_input_group\">\n                                <span className=\"mx_CreateGroupDialog_prefix\">+</span>\n                                <input id=\"groupid\"\n                                    className=\"mx_CreateGroupDialog_input mx_CreateGroupDialog_input_hasPrefixAndSuffix\"\n                                    size=\"32\"\n                                    placeholder={_t('example')}\n                                    onChange={this._onGroupIdChange}\n                                    onBlur={this._onGroupIdBlur}\n                                    value={this.state.groupId}\n                                />\n                                <span className=\"mx_CreateGroupDialog_suffix\">\n                                    :{ MatrixClientPeg.get().getDomain() }\n                                </span>\n                            </div>\n                        </div>\n                        <div className=\"error\">\n                            { this.state.groupIdError }\n                        </div>\n                        { createErrorNode }\n                    </div>\n                    <div className=\"mx_Dialog_buttons\">\n                        <input type=\"submit\" value={_t('Create')} className=\"mx_Dialog_primary\" />\n                        <button onClick={this._onCancel}>\n                            { _t(\"Cancel\") }\n                        </button>\n                    </div>\n                </form>\n            </BaseDialog>\n        );\n    }\n}\n"]}