UNPKG

matrix-react-sdk

Version:
245 lines (212 loc) 32.7 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 = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _languageHandler = require("../../../languageHandler"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _Field = _interopRequireDefault(require("../elements/Field")); var sdk = _interopRequireWildcard(require("../../../index")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _Media = require("../../../customisations/Media"); var _dec, _class, _class2, _temp; let RoomProfileSettings = ( // TODO: Merge with ProfileSettings? _dec = (0, _replaceableComponent.replaceableComponent)("views.room_settings.RoomProfileSettings"), _dec(_class = (_temp = _class2 = class RoomProfileSettings extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "_uploadAvatar", () => { this._avatarUpload.current.click(); }); (0, _defineProperty2.default)(this, "_removeAvatar", () => { // clear file upload field so same file can be selected this._avatarUpload.current.value = ""; this.setState({ avatarUrl: null, avatarFile: null, enableProfileSave: true }); }); (0, _defineProperty2.default)(this, "_cancelProfileChanges", async e => { e.stopPropagation(); e.preventDefault(); if (!this.state.enableProfileSave) return; this.setState({ enableProfileSave: false, displayName: this.state.originalDisplayName, topic: this.state.originalTopic, avatarUrl: this.state.originalAvatarUrl, avatarFile: null }); }); (0, _defineProperty2.default)(this, "_saveProfile", async e => { e.stopPropagation(); e.preventDefault(); if (!this.state.enableProfileSave) return; this.setState({ enableProfileSave: false }); const client = _MatrixClientPeg.MatrixClientPeg.get(); const newState = {}; // TODO: What do we do about errors? const displayName = this.state.displayName.trim(); if (this.state.originalDisplayName !== this.state.displayName) { await client.setRoomName(this.props.roomId, displayName); newState.originalDisplayName = displayName; newState.displayName = displayName; } if (this.state.avatarFile) { const uri = await client.uploadContent(this.state.avatarFile); await client.sendStateEvent(this.props.roomId, 'm.room.avatar', { url: uri }, ''); newState.avatarUrl = (0, _Media.mediaFromMxc)(uri).getSquareThumbnailHttp(96); newState.originalAvatarUrl = newState.avatarUrl; newState.avatarFile = null; } else if (this.state.originalAvatarUrl !== this.state.avatarUrl) { await client.sendStateEvent(this.props.roomId, 'm.room.avatar', {}, ''); } if (this.state.originalTopic !== this.state.topic) { await client.setRoomTopic(this.props.roomId, this.state.topic); newState.originalTopic = this.state.topic; } this.setState(newState); }); (0, _defineProperty2.default)(this, "_onDisplayNameChanged", e => { this.setState({ displayName: e.target.value }); if (this.state.originalDisplayName === e.target.value) { this.setState({ enableProfileSave: false }); } else { this.setState({ enableProfileSave: true }); } }); (0, _defineProperty2.default)(this, "_onTopicChanged", e => { this.setState({ topic: e.target.value }); if (this.state.originalTopic === e.target.value) { this.setState({ enableProfileSave: false }); } else { this.setState({ enableProfileSave: true }); } }); (0, _defineProperty2.default)(this, "_onAvatarChanged", e => { if (!e.target.files || !e.target.files.length) { this.setState({ avatarUrl: this.state.originalAvatarUrl, avatarFile: null, enableProfileSave: false }); return; } const file = e.target.files[0]; const reader = new FileReader(); reader.onload = ev => { this.setState({ avatarUrl: ev.target.result, avatarFile: file, enableProfileSave: true }); }; reader.readAsDataURL(file); }); const _client = _MatrixClientPeg.MatrixClientPeg.get(); const room = _client.getRoom(props.roomId); if (!room) throw new Error("Expected a room for ID: ", props.roomId); const avatarEvent = room.currentState.getStateEvents("m.room.avatar", ""); let avatarUrl = avatarEvent && avatarEvent.getContent() ? avatarEvent.getContent()["url"] : null; if (avatarUrl) avatarUrl = (0, _Media.mediaFromMxc)(avatarUrl).getSquareThumbnailHttp(96); const topicEvent = room.currentState.getStateEvents("m.room.topic", ""); const topic = topicEvent && topicEvent.getContent() ? topicEvent.getContent()['topic'] : ''; const nameEvent = room.currentState.getStateEvents('m.room.name', ''); const name = nameEvent && nameEvent.getContent() ? nameEvent.getContent()['name'] : ''; this.state = { originalDisplayName: name, displayName: name, originalAvatarUrl: avatarUrl, avatarUrl: avatarUrl, avatarFile: null, originalTopic: topic, topic: topic, enableProfileSave: false, canSetName: room.currentState.maySendStateEvent('m.room.name', _client.getUserId()), canSetTopic: room.currentState.maySendStateEvent('m.room.topic', _client.getUserId()), canSetAvatar: room.currentState.maySendStateEvent('m.room.avatar', _client.getUserId()) }; this._avatarUpload = /*#__PURE__*/(0, _react.createRef)(); } render() { const AccessibleButton = sdk.getComponent('elements.AccessibleButton'); const AvatarSetting = sdk.getComponent('settings.AvatarSetting'); let profileSettingsButtons; if (this.state.canSetName || this.state.canSetTopic || this.state.canSetAvatar) { profileSettingsButtons = /*#__PURE__*/_react.default.createElement("div", { className: "mx_ProfileSettings_buttons" }, /*#__PURE__*/_react.default.createElement(AccessibleButton, { onClick: this._cancelProfileChanges, kind: "link", disabled: !this.state.enableProfileSave }, (0, _languageHandler._t)("Cancel")), /*#__PURE__*/_react.default.createElement(AccessibleButton, { onClick: this._saveProfile, kind: "primary", disabled: !this.state.enableProfileSave }, (0, _languageHandler._t)("Save"))); } return /*#__PURE__*/_react.default.createElement("form", { onSubmit: this._saveProfile, autoComplete: "off", noValidate: true, className: "mx_ProfileSettings_profileForm" }, /*#__PURE__*/_react.default.createElement("input", { type: "file", ref: this._avatarUpload, className: "mx_ProfileSettings_avatarUpload", onChange: this._onAvatarChanged, accept: "image/*" }), /*#__PURE__*/_react.default.createElement("div", { className: "mx_ProfileSettings_profile" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_ProfileSettings_controls" }, /*#__PURE__*/_react.default.createElement(_Field.default, { label: (0, _languageHandler._t)("Room Name"), type: "text", value: this.state.displayName, autoComplete: "off", onChange: this._onDisplayNameChanged, disabled: !this.state.canSetName }), /*#__PURE__*/_react.default.createElement(_Field.default, { className: "mx_ProfileSettings_controls_topic", id: "profileTopic", label: (0, _languageHandler._t)("Room Topic"), disabled: !this.state.canSetTopic, type: "text", value: this.state.topic, autoComplete: "off", onChange: this._onTopicChanged, element: "textarea" })), /*#__PURE__*/_react.default.createElement(AvatarSetting, { avatarUrl: this.state.avatarUrl, avatarName: this.state.displayName || this.props.roomId, avatarAltText: (0, _languageHandler._t)("Room avatar"), uploadAvatar: this.state.canSetAvatar ? this._uploadAvatar : undefined, removeAvatar: this.state.canSetAvatar ? this._removeAvatar : undefined })), profileSettingsButtons); } }, (0, _defineProperty2.default)(_class2, "propTypes", { roomId: _propTypes.default.string.isRequired }), _temp)) || _class); exports.default = RoomProfileSettings; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/room_settings/RoomProfileSettings.js"],"names":["RoomProfileSettings","React","Component","constructor","props","_avatarUpload","current","click","value","setState","avatarUrl","avatarFile","enableProfileSave","e","stopPropagation","preventDefault","state","displayName","originalDisplayName","topic","originalTopic","originalAvatarUrl","client","MatrixClientPeg","get","newState","trim","setRoomName","roomId","uri","uploadContent","sendStateEvent","url","getSquareThumbnailHttp","setRoomTopic","target","files","length","file","reader","FileReader","onload","ev","result","readAsDataURL","room","getRoom","Error","avatarEvent","currentState","getStateEvents","getContent","topicEvent","nameEvent","name","canSetName","maySendStateEvent","getUserId","canSetTopic","canSetAvatar","render","AccessibleButton","sdk","getComponent","AvatarSetting","profileSettingsButtons","_cancelProfileChanges","_saveProfile","_onAvatarChanged","_onDisplayNameChanged","_onTopicChanged","_uploadAvatar","undefined","_removeAvatar","PropTypes","string","isRequired"],"mappings":"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","sourcesContent":["/*\nCopyright 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, {createRef} from 'react';\nimport PropTypes from 'prop-types';\nimport {_t} from \"../../../languageHandler\";\nimport {MatrixClientPeg} from \"../../../MatrixClientPeg\";\nimport Field from \"../elements/Field\";\nimport * as sdk from \"../../../index\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\n// TODO: Merge with ProfileSettings?\n@replaceableComponent(\"views.room_settings.RoomProfileSettings\")\nexport default class RoomProfileSettings extends React.Component {\n    static propTypes = {\n        roomId: PropTypes.string.isRequired,\n    };\n\n    constructor(props) {\n        super(props);\n\n        const client = MatrixClientPeg.get();\n        const room = client.getRoom(props.roomId);\n        if (!room) throw new Error(\"Expected a room for ID: \", props.roomId);\n\n        const avatarEvent = room.currentState.getStateEvents(\"m.room.avatar\", \"\");\n        let avatarUrl = avatarEvent && avatarEvent.getContent() ? avatarEvent.getContent()[\"url\"] : null;\n        if (avatarUrl) avatarUrl = mediaFromMxc(avatarUrl).getSquareThumbnailHttp(96);\n\n        const topicEvent = room.currentState.getStateEvents(\"m.room.topic\", \"\");\n        const topic = topicEvent && topicEvent.getContent() ? topicEvent.getContent()['topic'] : '';\n\n        const nameEvent = room.currentState.getStateEvents('m.room.name', '');\n        const name = nameEvent && nameEvent.getContent() ? nameEvent.getContent()['name'] : '';\n\n        this.state = {\n            originalDisplayName: name,\n            displayName: name,\n            originalAvatarUrl: avatarUrl,\n            avatarUrl: avatarUrl,\n            avatarFile: null,\n            originalTopic: topic,\n            topic: topic,\n            enableProfileSave: false,\n            canSetName: room.currentState.maySendStateEvent('m.room.name', client.getUserId()),\n            canSetTopic: room.currentState.maySendStateEvent('m.room.topic', client.getUserId()),\n            canSetAvatar: room.currentState.maySendStateEvent('m.room.avatar', client.getUserId()),\n        };\n\n        this._avatarUpload = createRef();\n    }\n\n    _uploadAvatar = () => {\n        this._avatarUpload.current.click();\n    };\n\n    _removeAvatar = () => {\n        // clear file upload field so same file can be selected\n        this._avatarUpload.current.value = \"\";\n        this.setState({\n            avatarUrl: null,\n            avatarFile: null,\n            enableProfileSave: true,\n        });\n    };\n\n    _cancelProfileChanges = async (e) => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        if (!this.state.enableProfileSave) return;\n        this.setState({\n            enableProfileSave: false,\n            displayName: this.state.originalDisplayName,\n            topic: this.state.originalTopic,\n            avatarUrl: this.state.originalAvatarUrl,\n            avatarFile: null,\n        });\n    };\n\n    _saveProfile = async (e) => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        if (!this.state.enableProfileSave) return;\n        this.setState({enableProfileSave: false});\n\n        const client = MatrixClientPeg.get();\n        const newState = {};\n\n        // TODO: What do we do about errors?\n        const displayName = this.state.displayName.trim();\n        if (this.state.originalDisplayName !== this.state.displayName) {\n            await client.setRoomName(this.props.roomId, displayName);\n            newState.originalDisplayName = displayName;\n            newState.displayName = displayName;\n        }\n\n        if (this.state.avatarFile) {\n            const uri = await client.uploadContent(this.state.avatarFile);\n            await client.sendStateEvent(this.props.roomId, 'm.room.avatar', {url: uri}, '');\n            newState.avatarUrl = mediaFromMxc(uri).getSquareThumbnailHttp(96);\n            newState.originalAvatarUrl = newState.avatarUrl;\n            newState.avatarFile = null;\n        } else if (this.state.originalAvatarUrl !== this.state.avatarUrl) {\n            await client.sendStateEvent(this.props.roomId, 'm.room.avatar', {}, '');\n        }\n\n        if (this.state.originalTopic !== this.state.topic) {\n            await client.setRoomTopic(this.props.roomId, this.state.topic);\n            newState.originalTopic = this.state.topic;\n        }\n\n        this.setState(newState);\n    };\n\n    _onDisplayNameChanged = (e) => {\n        this.setState({displayName: e.target.value});\n        if (this.state.originalDisplayName === e.target.value) {\n            this.setState({enableProfileSave: false});\n        } else {\n            this.setState({enableProfileSave: true});\n        }\n    };\n\n    _onTopicChanged = (e) => {\n        this.setState({topic: e.target.value});\n        if (this.state.originalTopic === e.target.value) {\n            this.setState({enableProfileSave: false});\n        } else {\n            this.setState({enableProfileSave: true});\n        }\n    };\n\n    _onAvatarChanged = (e) => {\n        if (!e.target.files || !e.target.files.length) {\n            this.setState({\n                avatarUrl: this.state.originalAvatarUrl,\n                avatarFile: null,\n                enableProfileSave: false,\n            });\n            return;\n        }\n\n        const file = e.target.files[0];\n        const reader = new FileReader();\n        reader.onload = (ev) => {\n            this.setState({\n                avatarUrl: ev.target.result,\n                avatarFile: file,\n                enableProfileSave: true,\n            });\n        };\n        reader.readAsDataURL(file);\n    };\n\n    render() {\n        const AccessibleButton = sdk.getComponent('elements.AccessibleButton');\n        const AvatarSetting = sdk.getComponent('settings.AvatarSetting');\n\n        let profileSettingsButtons;\n        if (\n            this.state.canSetName ||\n            this.state.canSetTopic ||\n            this.state.canSetAvatar\n        ) {\n            profileSettingsButtons = (\n                <div className=\"mx_ProfileSettings_buttons\">\n                    <AccessibleButton\n                        onClick={this._cancelProfileChanges}\n                        kind=\"link\"\n                        disabled={!this.state.enableProfileSave}\n                    >\n                        {_t(\"Cancel\")}\n                    </AccessibleButton>\n                    <AccessibleButton\n                        onClick={this._saveProfile}\n                        kind=\"primary\"\n                        disabled={!this.state.enableProfileSave}\n                    >\n                        {_t(\"Save\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        return (\n            <form\n                onSubmit={this._saveProfile}\n                autoComplete=\"off\"\n                noValidate={true}\n                className=\"mx_ProfileSettings_profileForm\"\n            >\n                <input\n                    type=\"file\"\n                    ref={this._avatarUpload}\n                    className=\"mx_ProfileSettings_avatarUpload\"\n                    onChange={this._onAvatarChanged}\n                    accept=\"image/*\"\n                />\n                <div className=\"mx_ProfileSettings_profile\">\n                    <div className=\"mx_ProfileSettings_controls\">\n                        <Field\n                            label={_t(\"Room Name\")}\n                            type=\"text\"\n                            value={this.state.displayName}\n                            autoComplete=\"off\"\n                            onChange={this._onDisplayNameChanged}\n                            disabled={!this.state.canSetName}\n                        />\n                        <Field\n                            className=\"mx_ProfileSettings_controls_topic\"\n                            id=\"profileTopic\"\n                            label={_t(\"Room Topic\")}\n                            disabled={!this.state.canSetTopic}\n                            type=\"text\"\n                            value={this.state.topic}\n                            autoComplete=\"off\"\n                            onChange={this._onTopicChanged}\n                            element=\"textarea\"\n                        />\n                    </div>\n                    <AvatarSetting\n                        avatarUrl={this.state.avatarUrl}\n                        avatarName={this.state.displayName || this.props.roomId}\n                        avatarAltText={_t(\"Room avatar\")}\n                        uploadAvatar={this.state.canSetAvatar ? this._uploadAvatar : undefined}\n                        removeAvatar={this.state.canSetAvatar ? this._removeAvatar : undefined} />\n                </div>\n                { profileSettingsButtons }\n            </form>\n        );\n    }\n}\n"]}