UNPKG

matrix-react-sdk

Version:
233 lines (196 loc) 28.6 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 _BaseDialog = _interopRequireDefault(require("./BaseDialog")); var _languageHandler = require("../../../languageHandler"); var _Field = _interopRequireDefault(require("../elements/Field")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _InfoTooltip = _interopRequireDefault(require("../elements/InfoTooltip")); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _RoomInvite = require("../../../RoomInvite"); var _GroupStore = _interopRequireDefault(require("../../../stores/GroupStore")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _temp; let CreateCommunityPrototypeDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.CreateCommunityPrototypeDialog"), _dec(_class = (_temp = class CreateCommunityPrototypeDialog extends _react.default.PureComponent /*:: <IProps, IState>*/ { constructor(props /*: IProps*/ ) { super(props); (0, _defineProperty2.default)(this, "avatarUploadRef", /*#__PURE__*/_react.default.createRef()); (0, _defineProperty2.default)(this, "onNameChange", (ev /*: ChangeEvent<HTMLInputElement>*/ ) => { const localpart = (ev.target.value || "").toLowerCase().replace(/[^a-z0-9.\-_]/g, '-'); this.setState({ name: ev.target.value, localpart }); }); (0, _defineProperty2.default)(this, "onSubmit", async ev => { ev.preventDefault(); ev.stopPropagation(); if (this.state.busy) return; // We'll create the community now to see if it's taken, leaving it active in // the background for the user to look at while they invite people. this.setState({ busy: true }); try { let avatarUrl = ''; // must be a string for synapse to accept it if (this.state.avatarFile) { avatarUrl = await _MatrixClientPeg.MatrixClientPeg.get().uploadContent(this.state.avatarFile); } const result = await _MatrixClientPeg.MatrixClientPeg.get().createGroup({ localpart: this.state.localpart, profile: { name: this.state.name, avatar_url: avatarUrl } }); // Ensure the tag gets selected now that we've created it _dispatcher.default.dispatch({ action: 'deselect_tags' }, true); _dispatcher.default.dispatch({ action: 'select_tag', tag: result.group_id }); // Close our own dialog before moving much further this.props.onFinished(true); if (result.room_id) { // Force the group store to update as it might have missed the general chat await _GroupStore.default.refreshGroupRooms(result.group_id); _dispatcher.default.dispatch({ action: 'view_room', room_id: result.room_id }); (0, _RoomInvite.showCommunityRoomInviteDialog)(result.room_id, this.state.name); } else { _dispatcher.default.dispatch({ action: 'view_group', group_id: result.group_id, group_is_new: true }); } } catch (e) { console.error(e); this.setState({ busy: false, error: (0, _languageHandler._t)("There was an error creating your community. The name may be taken or the " + "server is unable to process your request.") }); } }); (0, _defineProperty2.default)(this, "onAvatarChanged", (e /*: ChangeEvent<HTMLInputElement>*/ ) => { if (!e.target.files || !e.target.files.length) { this.setState({ avatarFile: null }); } else { this.setState({ busy: true }); const file = e.target.files[0]; const reader = new FileReader(); reader.onload = (ev /*: ProgressEvent<FileReader>*/ ) => { this.setState({ avatarFile: file, busy: false, avatarPreview: ev.target.result }); }; reader.readAsDataURL(file); } }); (0, _defineProperty2.default)(this, "onChangeAvatar", () => { if (this.avatarUploadRef.current) this.avatarUploadRef.current.click(); }); this.state = { name: "", localpart: "", error: null, busy: false, avatarFile: null, avatarPreview: null }; } render() { let communityId = null; if (this.state.localpart) { communityId = /*#__PURE__*/_react.default.createElement("span", { className: "mx_CreateCommunityPrototypeDialog_communityId" }, (0, _languageHandler._t)("Community ID: +<localpart />:%(domain)s", { domain: _MatrixClientPeg.MatrixClientPeg.getHomeserverName() }, { localpart: () => /*#__PURE__*/_react.default.createElement("u", null, this.state.localpart) }), /*#__PURE__*/_react.default.createElement(_InfoTooltip.default, { tooltip: (0, _languageHandler._t)("Use this when referencing your community to others. The community ID " + "cannot be changed.") })); } let helpText = /*#__PURE__*/_react.default.createElement("span", { className: "mx_CreateCommunityPrototypeDialog_subtext" }, (0, _languageHandler._t)("You can change this later if needed.")); if (this.state.error) { const classes = "mx_CreateCommunityPrototypeDialog_subtext mx_CreateCommunityPrototypeDialog_subtext_error"; helpText = /*#__PURE__*/_react.default.createElement("span", { className: classes }, this.state.error); } let preview = /*#__PURE__*/_react.default.createElement("img", { src: this.state.avatarPreview, className: "mx_CreateCommunityPrototypeDialog_avatar" }); if (!this.state.avatarPreview) { preview = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateCommunityPrototypeDialog_placeholderAvatar" }); } return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, { className: "mx_CreateCommunityPrototypeDialog", onFinished: this.props.onFinished, title: (0, _languageHandler._t)("What's the name of your community or team?") }, /*#__PURE__*/_react.default.createElement("form", { onSubmit: this.onSubmit }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateCommunityPrototypeDialog_colName" }, /*#__PURE__*/_react.default.createElement(_Field.default, { value: this.state.name, onChange: this.onNameChange, placeholder: (0, _languageHandler._t)("Enter name"), label: (0, _languageHandler._t)("Enter name") }), helpText, /*#__PURE__*/_react.default.createElement("span", { className: "mx_CreateCommunityPrototypeDialog_subtext" }, "\xA0", communityId), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "primary", onClick: this.onSubmit, disabled: this.state.busy }, (0, _languageHandler._t)("Create"))), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateCommunityPrototypeDialog_colAvatar" }, /*#__PURE__*/_react.default.createElement("input", { type: "file", style: { display: "none" }, ref: this.avatarUploadRef, accept: "image/*", onChange: this.onAvatarChanged }), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onChangeAvatar, className: "mx_CreateCommunityPrototypeDialog_avatarContainer" }, preview), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateCommunityPrototypeDialog_tip" }, /*#__PURE__*/_react.default.createElement("b", null, (0, _languageHandler._t)("Add image (optional)")), /*#__PURE__*/_react.default.createElement("span", null, (0, _languageHandler._t)("An image will help people identify your community."))))))); } }, _temp)) || _class); exports.default = CreateCommunityPrototypeDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/CreateCommunityPrototypeDialog.tsx"],"names":["CreateCommunityPrototypeDialog","React","PureComponent","constructor","props","createRef","ev","localpart","target","value","toLowerCase","replace","setState","name","preventDefault","stopPropagation","state","busy","avatarUrl","avatarFile","MatrixClientPeg","get","uploadContent","result","createGroup","profile","avatar_url","dis","dispatch","action","tag","group_id","onFinished","room_id","GroupStore","refreshGroupRooms","group_is_new","e","console","error","files","length","file","reader","FileReader","onload","avatarPreview","readAsDataURL","avatarUploadRef","current","click","render","communityId","domain","getHomeserverName","helpText","classes","preview","onSubmit","onNameChange","display","onAvatarChanged","onChangeAvatar"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 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, { ChangeEvent } from 'react';\nimport BaseDialog from \"./BaseDialog\";\nimport { _t } from \"../../../languageHandler\";\nimport { IDialogProps } from \"./IDialogProps\";\nimport Field from \"../elements/Field\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport InfoTooltip from \"../elements/InfoTooltip\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport {showCommunityRoomInviteDialog} from \"../../../RoomInvite\";\nimport GroupStore from \"../../../stores/GroupStore\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\ninterface IProps extends IDialogProps {\n}\n\ninterface IState {\n    name: string;\n    localpart: string;\n    error: string;\n    busy: boolean;\n    avatarFile: File;\n    avatarPreview: string;\n}\n\n@replaceableComponent(\"views.dialogs.CreateCommunityPrototypeDialog\")\nexport default class CreateCommunityPrototypeDialog extends React.PureComponent<IProps, IState> {\n    private avatarUploadRef: React.RefObject<HTMLInputElement> = React.createRef();\n\n    constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            name: \"\",\n            localpart: \"\",\n            error: null,\n            busy: false,\n            avatarFile: null,\n            avatarPreview: null,\n        };\n    }\n\n    private onNameChange = (ev: ChangeEvent<HTMLInputElement>) => {\n        const localpart = (ev.target.value || \"\").toLowerCase().replace(/[^a-z0-9.\\-_]/g, '-');\n        this.setState({name: ev.target.value, localpart});\n    };\n\n    private onSubmit = async (ev) => {\n        ev.preventDefault();\n        ev.stopPropagation();\n\n        if (this.state.busy) return;\n\n        // We'll create the community now to see if it's taken, leaving it active in\n        // the background for the user to look at while they invite people.\n        this.setState({busy: true});\n        try {\n            let avatarUrl = ''; // must be a string for synapse to accept it\n            if (this.state.avatarFile) {\n                avatarUrl = await MatrixClientPeg.get().uploadContent(this.state.avatarFile);\n            }\n\n            const result = await MatrixClientPeg.get().createGroup({\n                localpart: this.state.localpart,\n                profile: {\n                    name: this.state.name,\n                    avatar_url: avatarUrl,\n                },\n            });\n\n            // Ensure the tag gets selected now that we've created it\n            dis.dispatch({action: 'deselect_tags'}, true);\n            dis.dispatch({\n                action: 'select_tag',\n                tag: result.group_id,\n            });\n\n            // Close our own dialog before moving much further\n            this.props.onFinished(true);\n\n            if (result.room_id) {\n                // Force the group store to update as it might have missed the general chat\n                await GroupStore.refreshGroupRooms(result.group_id);\n                dis.dispatch({\n                    action: 'view_room',\n                    room_id: result.room_id,\n                });\n                showCommunityRoomInviteDialog(result.room_id, this.state.name);\n            } else {\n                dis.dispatch({\n                    action: 'view_group',\n                    group_id: result.group_id,\n                    group_is_new: true,\n                });\n            }\n        } catch (e) {\n            console.error(e);\n            this.setState({\n                busy: false,\n                error: _t(\n                    \"There was an error creating your community. The name may be taken or the \" +\n                    \"server is unable to process your request.\",\n                ),\n            });\n        }\n    };\n\n    private onAvatarChanged = (e: ChangeEvent<HTMLInputElement>) => {\n        if (!e.target.files || !e.target.files.length) {\n            this.setState({avatarFile: null});\n        } else {\n            this.setState({busy: true});\n            const file = e.target.files[0];\n            const reader = new FileReader();\n            reader.onload = (ev: ProgressEvent<FileReader>) => {\n                this.setState({avatarFile: file, busy: false, avatarPreview: ev.target.result as string});\n            };\n            reader.readAsDataURL(file);\n        }\n    };\n\n    private onChangeAvatar = () => {\n        if (this.avatarUploadRef.current) this.avatarUploadRef.current.click();\n    };\n\n    public render() {\n        let communityId = null;\n        if (this.state.localpart) {\n            communityId = (\n                <span className=\"mx_CreateCommunityPrototypeDialog_communityId\">\n                    {_t(\"Community ID: +<localpart />:%(domain)s\", {\n                        domain: MatrixClientPeg.getHomeserverName(),\n                    }, {\n                        localpart: () => <u>{this.state.localpart}</u>,\n                    })}\n                    <InfoTooltip\n                        tooltip={_t(\n                            \"Use this when referencing your community to others. The community ID \" +\n                            \"cannot be changed.\",\n                        )}\n                    />\n                </span>\n            );\n        }\n\n        let helpText = (\n            <span className=\"mx_CreateCommunityPrototypeDialog_subtext\">\n                {_t(\"You can change this later if needed.\")}\n            </span>\n        );\n        if (this.state.error) {\n            const classes = \"mx_CreateCommunityPrototypeDialog_subtext mx_CreateCommunityPrototypeDialog_subtext_error\";\n            helpText = (\n                <span className={classes}>\n                    {this.state.error}\n                </span>\n            );\n        }\n\n        let preview = <img src={this.state.avatarPreview} className=\"mx_CreateCommunityPrototypeDialog_avatar\" />;\n        if (!this.state.avatarPreview) {\n            preview = <div className=\"mx_CreateCommunityPrototypeDialog_placeholderAvatar\" />\n        }\n\n        return (\n            <BaseDialog\n                className=\"mx_CreateCommunityPrototypeDialog\"\n                onFinished={this.props.onFinished}\n                title={_t(\"What's the name of your community or team?\")}\n            >\n                <form onSubmit={this.onSubmit}>\n                    <div className=\"mx_Dialog_content\">\n                        <div className=\"mx_CreateCommunityPrototypeDialog_colName\">\n                            <Field\n                                value={this.state.name}\n                                onChange={this.onNameChange}\n                                placeholder={_t(\"Enter name\")}\n                                label={_t(\"Enter name\")}\n                            />\n                            {helpText}\n                            <span className=\"mx_CreateCommunityPrototypeDialog_subtext\">\n                                {/*nbsp is to reserve the height of this element when there's nothing*/}\n                                &nbsp;{communityId}\n                            </span>\n                            <AccessibleButton kind=\"primary\" onClick={this.onSubmit} disabled={this.state.busy}>\n                                {_t(\"Create\")}\n                            </AccessibleButton>\n                        </div>\n                        <div className=\"mx_CreateCommunityPrototypeDialog_colAvatar\">\n                            <input\n                                type=\"file\" style={{display: \"none\"}}\n                                ref={this.avatarUploadRef} accept=\"image/*\"\n                                onChange={this.onAvatarChanged}\n                            />\n                            <AccessibleButton\n                                onClick={this.onChangeAvatar}\n                                className=\"mx_CreateCommunityPrototypeDialog_avatarContainer\"\n                            >\n                                {preview}\n                            </AccessibleButton>\n                            <div className=\"mx_CreateCommunityPrototypeDialog_tip\">\n                                <b>{_t(\"Add image (optional)\")}</b>\n                                <span>\n                                    {_t(\"An image will help people identify your community.\")}\n                                </span>\n                            </div>\n                        </div>\n                    </div>\n                </form>\n            </BaseDialog>\n        );\n    }\n}\n"]}