UNPKG

matrix-react-sdk

Version:
338 lines (335 loc) 62.2 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 = _interopRequireWildcard(require("react")); var _matrix = require("matrix-js-sdk/src/matrix"); var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig")); var _Validation = _interopRequireDefault(require("../elements/Validation")); var _languageHandler = require("../../../languageHandler"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _createRoom = require("../../../createRoom"); var _Field = _interopRequireDefault(require("../elements/Field")); var _RoomAliasField = _interopRequireDefault(require("../elements/RoomAliasField")); var _LabelledToggleSwitch = _interopRequireDefault(require("../elements/LabelledToggleSwitch")); var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons")); var _BaseDialog = _interopRequireDefault(require("../dialogs/BaseDialog")); var _JoinRuleDropdown = _interopRequireDefault(require("../elements/JoinRuleDropdown")); var _KeyBindingsManager = require("../../../KeyBindingsManager"); var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts"); var _rooms = require("../../../utils/rooms"); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _LabelledCheckbox = _interopRequireDefault(require("../elements/LabelledCheckbox")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /* Copyright 2024 New Vector Ltd. Copyright 2020, 2021 The Matrix.org Foundation C.I.C. Copyright 2017 Michael Telatynski <7t3chguy@gmail.com> SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ class CreateRoomDialog extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "askToJoinEnabled", void 0); (0, _defineProperty2.default)(this, "supportsRestricted", void 0); (0, _defineProperty2.default)(this, "nameField", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "aliasField", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "onKeyDown", event => { const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(event); switch (action) { case _KeyboardShortcuts.KeyBindingAction.Enter: this.onOk(); event.preventDefault(); event.stopPropagation(); break; } }); (0, _defineProperty2.default)(this, "onOk", async () => { if (!this.nameField.current) return; const activeElement = document.activeElement; activeElement?.blur(); await this.nameField.current.validate({ allowEmpty: false }); if (this.aliasField.current) { await this.aliasField.current.validate({ allowEmpty: false }); } // Validation and state updates are async, so we need to wait for them to complete // first. Queue a `setState` callback and wait for it to resolve. await new Promise(resolve => this.setState({}, resolve)); if (this.state.nameIsValid && (!this.aliasField.current || this.aliasField.current.isValid)) { this.props.onFinished(true, this.roomCreateOptions()); } else { let field = null; if (!this.state.nameIsValid) { field = this.nameField.current; } else if (this.aliasField.current && !this.aliasField.current.isValid) { field = this.aliasField.current; } if (field) { field.focus(); await field.validate({ allowEmpty: false, focused: true }); } } }); (0, _defineProperty2.default)(this, "onCancel", () => { this.props.onFinished(false); }); (0, _defineProperty2.default)(this, "onNameChange", ev => { this.setState({ name: ev.target.value }); }); (0, _defineProperty2.default)(this, "onTopicChange", ev => { this.setState({ topic: ev.target.value }); }); (0, _defineProperty2.default)(this, "onJoinRuleChange", joinRule => { this.setState({ joinRule }); }); (0, _defineProperty2.default)(this, "onEncryptedChange", isEncrypted => { this.setState({ isEncrypted }); }); (0, _defineProperty2.default)(this, "onAliasChange", alias => { this.setState({ alias }); }); (0, _defineProperty2.default)(this, "onDetailsToggled", ev => { this.setState({ detailsOpen: ev.target.open }); }); (0, _defineProperty2.default)(this, "onNoFederateChange", noFederate => { this.setState({ noFederate }); }); (0, _defineProperty2.default)(this, "onNameValidate", async fieldState => { const result = await CreateRoomDialog.validateRoomName(fieldState); this.setState({ nameIsValid: !!result.valid }); return result; }); (0, _defineProperty2.default)(this, "onIsPublicKnockRoomChange", isPublicKnockRoom => { this.setState({ isPublicKnockRoom }); }); this.askToJoinEnabled = _SettingsStore.default.getValue("feature_ask_to_join"); this.supportsRestricted = !!this.props.parentSpace; let _joinRule = _matrix.JoinRule.Invite; if (this.props.defaultPublic) { _joinRule = _matrix.JoinRule.Public; } else if (this.supportsRestricted) { _joinRule = _matrix.JoinRule.Restricted; } const cli = _MatrixClientPeg.MatrixClientPeg.safeGet(); this.state = { isPublicKnockRoom: this.props.defaultPublic || false, isEncrypted: this.props.defaultEncrypted ?? (0, _rooms.privateShouldBeEncrypted)(cli), joinRule: _joinRule, name: this.props.defaultName || "", topic: "", alias: "", detailsOpen: false, noFederate: _SdkConfig.default.get().default_federate === false, nameIsValid: false, canChangeEncryption: false }; (0, _createRoom.checkUserIsAllowedToChangeEncryption)(cli, _matrix.Preset.PrivateChat).then(({ allowChange, forcedValue }) => this.setState(state => ({ canChangeEncryption: allowChange, // override with forcedValue if it is set isEncrypted: forcedValue ?? state.isEncrypted }))); } roomCreateOptions() { const opts = {}; const createOpts = opts.createOpts = {}; opts.roomType = this.props.type; createOpts.name = this.state.name; if (this.state.joinRule === _matrix.JoinRule.Public) { createOpts.visibility = _matrix.Visibility.Public; createOpts.preset = _matrix.Preset.PublicChat; opts.guestAccess = false; const { alias } = this.state; createOpts.room_alias_name = alias.substring(1, alias.indexOf(":")); } else { opts.encryption = this.state.isEncrypted; } if (this.state.topic) { createOpts.topic = this.state.topic; } if (this.state.noFederate) { createOpts.creation_content = { "m.federate": false }; } opts.parentSpace = this.props.parentSpace; if (this.props.parentSpace && this.state.joinRule === _matrix.JoinRule.Restricted) { opts.joinRule = _matrix.JoinRule.Restricted; } if (this.state.joinRule === _matrix.JoinRule.Knock) { opts.joinRule = _matrix.JoinRule.Knock; createOpts.visibility = this.state.isPublicKnockRoom ? _matrix.Visibility.Public : _matrix.Visibility.Private; } return opts; } componentDidMount() { // move focus to first field when showing dialog this.nameField.current?.focus(); } render() { const isVideoRoom = this.props.type === _matrix.RoomType.ElementVideo; let aliasField; if (this.state.joinRule === _matrix.JoinRule.Public) { const domain = _MatrixClientPeg.MatrixClientPeg.safeGet().getDomain(); aliasField = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CreateRoomDialog_aliasContainer" }, /*#__PURE__*/_react.default.createElement(_RoomAliasField.default, { ref: this.aliasField, onChange: this.onAliasChange, domain: domain, value: this.state.alias })); } let publicPrivateLabel; if (this.state.joinRule === _matrix.JoinRule.Restricted) { publicPrivateLabel = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("create_room|join_rule_restricted_label", {}, { SpaceName: () => /*#__PURE__*/_react.default.createElement("strong", null, this.props.parentSpace?.name ?? (0, _languageHandler._t)("common|unnamed_space")) }), "\xA0", (0, _languageHandler._t)("create_room|join_rule_change_notice")); } else if (this.state.joinRule === _matrix.JoinRule.Public && this.props.parentSpace) { publicPrivateLabel = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("create_room|join_rule_public_parent_space_label", {}, { SpaceName: () => /*#__PURE__*/_react.default.createElement("strong", null, this.props.parentSpace?.name ?? (0, _languageHandler._t)("common|unnamed_space")) }), "\xA0", (0, _languageHandler._t)("create_room|join_rule_change_notice")); } else if (this.state.joinRule === _matrix.JoinRule.Public) { publicPrivateLabel = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("create_room|join_rule_public_label"), "\xA0", (0, _languageHandler._t)("create_room|join_rule_change_notice")); } else if (this.state.joinRule === _matrix.JoinRule.Invite) { publicPrivateLabel = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("create_room|join_rule_invite_label"), "\xA0", (0, _languageHandler._t)("create_room|join_rule_change_notice")); } else if (this.state.joinRule === _matrix.JoinRule.Knock) { publicPrivateLabel = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("create_room|join_rule_knock_label")); } let visibilitySection; if (this.state.joinRule === _matrix.JoinRule.Knock) { visibilitySection = /*#__PURE__*/_react.default.createElement(_LabelledCheckbox.default, { className: "mx_CreateRoomDialog_labelledCheckbox", label: (0, _languageHandler._t)("room_settings|security|publish_room"), onChange: this.onIsPublicKnockRoomChange, value: this.state.isPublicKnockRoom }); } let e2eeSection; if (this.state.joinRule !== _matrix.JoinRule.Public) { let microcopy; if ((0, _rooms.privateShouldBeEncrypted)(_MatrixClientPeg.MatrixClientPeg.safeGet())) { if (this.state.canChangeEncryption) { microcopy = isVideoRoom ? (0, _languageHandler._t)("create_room|encrypted_video_room_warning") : (0, _languageHandler._t)("create_room|encrypted_warning"); } else { microcopy = (0, _languageHandler._t)("create_room|encryption_forced"); } } else { microcopy = (0, _languageHandler._t)("settings|security|e2ee_default_disabled_warning"); } e2eeSection = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { label: (0, _languageHandler._t)("create_room|encryption_label"), onChange: this.onEncryptedChange, value: this.state.isEncrypted, className: "mx_CreateRoomDialog_e2eSwitch" // for end-to-end tests , disabled: !this.state.canChangeEncryption }), /*#__PURE__*/_react.default.createElement("p", null, microcopy)); } let federateLabel = (0, _languageHandler._t)("create_room|unfederated_label_default_off"); if (_SdkConfig.default.get().default_federate === false) { // We only change the label if the default setting is different to avoid jarring text changes to the // user. They will have read the implications of turning this off/on, so no need to rephrase for them. federateLabel = (0, _languageHandler._t)("create_room|unfederated_label_default_on"); } let title; if (isVideoRoom) { title = (0, _languageHandler._t)("create_room|title_video_room"); } else if (this.props.parentSpace || this.state.joinRule === _matrix.JoinRule.Knock) { title = (0, _languageHandler._t)("action|create_a_room"); } else { title = this.state.joinRule === _matrix.JoinRule.Public ? (0, _languageHandler._t)("create_room|title_public_room") : (0, _languageHandler._t)("create_room|title_private_room"); } return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, { className: "mx_CreateRoomDialog", onFinished: this.props.onFinished, title: title, screenName: "CreateRoom" }, /*#__PURE__*/_react.default.createElement("form", { onSubmit: this.onOk, onKeyDown: this.onKeyDown }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement(_Field.default, { ref: this.nameField, label: (0, _languageHandler._t)("common|name"), onChange: this.onNameChange, onValidate: this.onNameValidate, value: this.state.name, className: "mx_CreateRoomDialog_name" }), /*#__PURE__*/_react.default.createElement(_Field.default, { label: (0, _languageHandler._t)("create_room|topic_label"), onChange: this.onTopicChange, value: this.state.topic, className: "mx_CreateRoomDialog_topic" }), /*#__PURE__*/_react.default.createElement(_JoinRuleDropdown.default, { label: (0, _languageHandler._t)("create_room|room_visibility_label"), labelInvite: (0, _languageHandler._t)("create_room|join_rule_invite"), labelKnock: this.askToJoinEnabled ? (0, _languageHandler._t)("room_settings|security|join_rule_knock") : undefined, labelPublic: (0, _languageHandler._t)("common|public_room"), labelRestricted: this.supportsRestricted ? (0, _languageHandler._t)("create_room|join_rule_restricted") : undefined, value: this.state.joinRule, onChange: this.onJoinRuleChange }), publicPrivateLabel, visibilitySection, e2eeSection, aliasField, /*#__PURE__*/_react.default.createElement("details", { onToggle: this.onDetailsToggled, className: "mx_CreateRoomDialog_details" }, /*#__PURE__*/_react.default.createElement("summary", { className: "mx_CreateRoomDialog_details_summary" }, this.state.detailsOpen ? (0, _languageHandler._t)("action|hide_advanced") : (0, _languageHandler._t)("action|show_advanced")), /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { label: (0, _languageHandler._t)("create_room|unfederated", { serverName: _MatrixClientPeg.MatrixClientPeg.safeGet().getDomain() }), onChange: this.onNoFederateChange, value: this.state.noFederate }), /*#__PURE__*/_react.default.createElement("p", null, federateLabel)))), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: isVideoRoom ? (0, _languageHandler._t)("create_room|action_create_video_room") : (0, _languageHandler._t)("create_room|action_create_room"), onPrimaryButtonClick: this.onOk, onCancel: this.onCancel })); } } exports.default = CreateRoomDialog; (0, _defineProperty2.default)(CreateRoomDialog, "validateRoomName", (0, _Validation.default)({ rules: [{ key: "required", test: async ({ value }) => !!value, invalid: () => (0, _languageHandler._t)("create_room|name_validation_required") }] })); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_SdkConfig","_interopRequireDefault","_Validation","_languageHandler","_MatrixClientPeg","_createRoom","_Field","_RoomAliasField","_LabelledToggleSwitch","_DialogButtons","_BaseDialog","_JoinRuleDropdown","_KeyBindingsManager","_KeyboardShortcuts","_rooms","_SettingsStore","_LabelledCheckbox","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","CreateRoomDialog","React","Component","constructor","props","_defineProperty2","createRef","event","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","Enter","onOk","preventDefault","stopPropagation","nameField","current","activeElement","document","blur","validate","allowEmpty","aliasField","Promise","resolve","setState","state","nameIsValid","isValid","onFinished","roomCreateOptions","field","focus","focused","ev","name","target","value","topic","joinRule","isEncrypted","alias","detailsOpen","open","noFederate","fieldState","result","validateRoomName","valid","isPublicKnockRoom","askToJoinEnabled","SettingsStore","getValue","supportsRestricted","parentSpace","JoinRule","Invite","defaultPublic","Public","Restricted","cli","MatrixClientPeg","safeGet","defaultEncrypted","privateShouldBeEncrypted","defaultName","SdkConfig","default_federate","canChangeEncryption","checkUserIsAllowedToChangeEncryption","Preset","PrivateChat","then","allowChange","forcedValue","opts","createOpts","roomType","type","visibility","Visibility","preset","PublicChat","guestAccess","room_alias_name","substring","indexOf","encryption","creation_content","Knock","Private","componentDidMount","render","isVideoRoom","RoomType","ElementVideo","domain","getDomain","createElement","className","ref","onChange","onAliasChange","publicPrivateLabel","_t","SpaceName","visibilitySection","label","onIsPublicKnockRoomChange","e2eeSection","microcopy","Fragment","onEncryptedChange","disabled","federateLabel","title","screenName","onSubmit","onKeyDown","onNameChange","onValidate","onNameValidate","onTopicChange","labelInvite","labelKnock","undefined","labelPublic","labelRestricted","onJoinRuleChange","onToggle","onDetailsToggled","serverName","onNoFederateChange","primaryButton","onPrimaryButtonClick","onCancel","exports","withValidation","rules","key","test","invalid"],"sources":["../../../../src/components/views/dialogs/CreateRoomDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020, 2021 The Matrix.org Foundation C.I.C.\nCopyright 2017 Michael Telatynski <7t3chguy@gmail.com>\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { ChangeEvent, createRef, KeyboardEvent, SyntheticEvent } from \"react\";\nimport { Room, RoomType, JoinRule, Preset, Visibility } from \"matrix-js-sdk/src/matrix\";\n\nimport SdkConfig from \"../../../SdkConfig\";\nimport withValidation, { IFieldState, IValidationResult } from \"../elements/Validation\";\nimport { _t } from \"../../../languageHandler\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { checkUserIsAllowedToChangeEncryption, IOpts } from \"../../../createRoom\";\nimport Field from \"../elements/Field\";\nimport RoomAliasField from \"../elements/RoomAliasField\";\nimport LabelledToggleSwitch from \"../elements/LabelledToggleSwitch\";\nimport DialogButtons from \"../elements/DialogButtons\";\nimport BaseDialog from \"../dialogs/BaseDialog\";\nimport JoinRuleDropdown from \"../elements/JoinRuleDropdown\";\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\nimport { privateShouldBeEncrypted } from \"../../../utils/rooms\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport LabelledCheckbox from \"../elements/LabelledCheckbox\";\n\ninterface IProps {\n    type?: RoomType;\n    defaultPublic?: boolean;\n    defaultName?: string;\n    parentSpace?: Room;\n    defaultEncrypted?: boolean;\n    onFinished(proceed?: false): void;\n    onFinished(proceed: true, opts: IOpts): void;\n}\n\ninterface IState {\n    /**\n     * The selected room join rule.\n     */\n    joinRule: JoinRule;\n    /**\n     * Indicates whether the created room should have public visibility (ie, it should be\n     * shown in the public room list). Only applicable if `joinRule` == `JoinRule.Knock`.\n     */\n    isPublicKnockRoom: boolean;\n    /**\n     * Indicates whether end-to-end encryption is enabled for the room.\n     */\n    isEncrypted: boolean;\n    /**\n     * The room name.\n     */\n    name: string;\n    /**\n     * The room topic.\n     */\n    topic: string;\n    /**\n     * The room alias.\n     */\n    alias: string;\n    /**\n     * Indicates whether the details section is open.\n     */\n    detailsOpen: boolean;\n    /**\n     * Indicates whether federation is disabled for the room.\n     */\n    noFederate: boolean;\n    /**\n     * Indicates whether the room name is valid.\n     */\n    nameIsValid: boolean;\n    /**\n     * Indicates whether the user can change encryption settings for the room.\n     */\n    canChangeEncryption: boolean;\n}\n\nexport default class CreateRoomDialog extends React.Component<IProps, IState> {\n    private readonly askToJoinEnabled: boolean;\n    private readonly supportsRestricted: boolean;\n    private nameField = createRef<Field>();\n    private aliasField = createRef<RoomAliasField>();\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.askToJoinEnabled = SettingsStore.getValue(\"feature_ask_to_join\");\n        this.supportsRestricted = !!this.props.parentSpace;\n\n        let joinRule = JoinRule.Invite;\n        if (this.props.defaultPublic) {\n            joinRule = JoinRule.Public;\n        } else if (this.supportsRestricted) {\n            joinRule = JoinRule.Restricted;\n        }\n\n        const cli = MatrixClientPeg.safeGet();\n        this.state = {\n            isPublicKnockRoom: this.props.defaultPublic || false,\n            isEncrypted: this.props.defaultEncrypted ?? privateShouldBeEncrypted(cli),\n            joinRule,\n            name: this.props.defaultName || \"\",\n            topic: \"\",\n            alias: \"\",\n            detailsOpen: false,\n            noFederate: SdkConfig.get().default_federate === false,\n            nameIsValid: false,\n            canChangeEncryption: false,\n        };\n\n        checkUserIsAllowedToChangeEncryption(cli, Preset.PrivateChat).then(({ allowChange, forcedValue }) =>\n            this.setState((state) => ({\n                canChangeEncryption: allowChange,\n                // override with forcedValue if it is set\n                isEncrypted: forcedValue ?? state.isEncrypted,\n            })),\n        );\n    }\n\n    private roomCreateOptions(): IOpts {\n        const opts: IOpts = {};\n        const createOpts: IOpts[\"createOpts\"] = (opts.createOpts = {});\n        opts.roomType = this.props.type;\n        createOpts.name = this.state.name;\n\n        if (this.state.joinRule === JoinRule.Public) {\n            createOpts.visibility = Visibility.Public;\n            createOpts.preset = Preset.PublicChat;\n            opts.guestAccess = false;\n            const { alias } = this.state;\n            createOpts.room_alias_name = alias.substring(1, alias.indexOf(\":\"));\n        } else {\n            opts.encryption = this.state.isEncrypted;\n        }\n\n        if (this.state.topic) {\n            createOpts.topic = this.state.topic;\n        }\n        if (this.state.noFederate) {\n            createOpts.creation_content = { \"m.federate\": false };\n        }\n\n        opts.parentSpace = this.props.parentSpace;\n        if (this.props.parentSpace && this.state.joinRule === JoinRule.Restricted) {\n            opts.joinRule = JoinRule.Restricted;\n        }\n\n        if (this.state.joinRule === JoinRule.Knock) {\n            opts.joinRule = JoinRule.Knock;\n            createOpts.visibility = this.state.isPublicKnockRoom ? Visibility.Public : Visibility.Private;\n        }\n\n        return opts;\n    }\n\n    public componentDidMount(): void {\n        // move focus to first field when showing dialog\n        this.nameField.current?.focus();\n    }\n\n    private onKeyDown = (event: KeyboardEvent): void => {\n        const action = getKeyBindingsManager().getAccessibilityAction(event);\n        switch (action) {\n            case KeyBindingAction.Enter:\n                this.onOk();\n                event.preventDefault();\n                event.stopPropagation();\n                break;\n        }\n    };\n\n    private onOk = async (): Promise<void> => {\n        if (!this.nameField.current) return;\n        const activeElement = document.activeElement as HTMLElement;\n        activeElement?.blur();\n        await this.nameField.current.validate({ allowEmpty: false });\n        if (this.aliasField.current) {\n            await this.aliasField.current.validate({ allowEmpty: false });\n        }\n        // Validation and state updates are async, so we need to wait for them to complete\n        // first. Queue a `setState` callback and wait for it to resolve.\n        await new Promise<void>((resolve) => this.setState({}, resolve));\n        if (this.state.nameIsValid && (!this.aliasField.current || this.aliasField.current.isValid)) {\n            this.props.onFinished(true, this.roomCreateOptions());\n        } else {\n            let field: RoomAliasField | Field | null = null;\n            if (!this.state.nameIsValid) {\n                field = this.nameField.current;\n            } else if (this.aliasField.current && !this.aliasField.current.isValid) {\n                field = this.aliasField.current;\n            }\n            if (field) {\n                field.focus();\n                await field.validate({ allowEmpty: false, focused: true });\n            }\n        }\n    };\n\n    private onCancel = (): void => {\n        this.props.onFinished(false);\n    };\n\n    private onNameChange = (ev: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({ name: ev.target.value });\n    };\n\n    private onTopicChange = (ev: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({ topic: ev.target.value });\n    };\n\n    private onJoinRuleChange = (joinRule: JoinRule): void => {\n        this.setState({ joinRule });\n    };\n\n    private onEncryptedChange = (isEncrypted: boolean): void => {\n        this.setState({ isEncrypted });\n    };\n\n    private onAliasChange = (alias: string): void => {\n        this.setState({ alias });\n    };\n\n    private onDetailsToggled = (ev: SyntheticEvent<HTMLDetailsElement>): void => {\n        this.setState({ detailsOpen: (ev.target as HTMLDetailsElement).open });\n    };\n\n    private onNoFederateChange = (noFederate: boolean): void => {\n        this.setState({ noFederate });\n    };\n\n    private onNameValidate = async (fieldState: IFieldState): Promise<IValidationResult> => {\n        const result = await CreateRoomDialog.validateRoomName(fieldState);\n        this.setState({ nameIsValid: !!result.valid });\n        return result;\n    };\n\n    private onIsPublicKnockRoomChange = (isPublicKnockRoom: boolean): void => {\n        this.setState({ isPublicKnockRoom });\n    };\n\n    private static validateRoomName = withValidation({\n        rules: [\n            {\n                key: \"required\",\n                test: async ({ value }) => !!value,\n                invalid: () => _t(\"create_room|name_validation_required\"),\n            },\n        ],\n    });\n\n    public render(): React.ReactNode {\n        const isVideoRoom = this.props.type === RoomType.ElementVideo;\n\n        let aliasField: JSX.Element | undefined;\n        if (this.state.joinRule === JoinRule.Public) {\n            const domain = MatrixClientPeg.safeGet().getDomain()!;\n            aliasField = (\n                <div className=\"mx_CreateRoomDialog_aliasContainer\">\n                    <RoomAliasField\n                        ref={this.aliasField}\n                        onChange={this.onAliasChange}\n                        domain={domain}\n                        value={this.state.alias}\n                    />\n                </div>\n            );\n        }\n\n        let publicPrivateLabel: JSX.Element | undefined;\n        if (this.state.joinRule === JoinRule.Restricted) {\n            publicPrivateLabel = (\n                <p>\n                    {_t(\n                        \"create_room|join_rule_restricted_label\",\n                        {},\n                        {\n                            SpaceName: () => (\n                                <strong>{this.props.parentSpace?.name ?? _t(\"common|unnamed_space\")}</strong>\n                            ),\n                        },\n                    )}\n                    &nbsp;\n                    {_t(\"create_room|join_rule_change_notice\")}\n                </p>\n            );\n        } else if (this.state.joinRule === JoinRule.Public && this.props.parentSpace) {\n            publicPrivateLabel = (\n                <p>\n                    {_t(\n                        \"create_room|join_rule_public_parent_space_label\",\n                        {},\n                        {\n                            SpaceName: () => (\n                                <strong>{this.props.parentSpace?.name ?? _t(\"common|unnamed_space\")}</strong>\n                            ),\n                        },\n                    )}\n                    &nbsp;\n                    {_t(\"create_room|join_rule_change_notice\")}\n                </p>\n            );\n        } else if (this.state.joinRule === JoinRule.Public) {\n            publicPrivateLabel = (\n                <p>\n                    {_t(\"create_room|join_rule_public_label\")}\n                    &nbsp;\n                    {_t(\"create_room|join_rule_change_notice\")}\n                </p>\n            );\n        } else if (this.state.joinRule === JoinRule.Invite) {\n            publicPrivateLabel = (\n                <p>\n                    {_t(\"create_room|join_rule_invite_label\")}\n                    &nbsp;\n                    {_t(\"create_room|join_rule_change_notice\")}\n                </p>\n            );\n        } else if (this.state.joinRule === JoinRule.Knock) {\n            publicPrivateLabel = <p>{_t(\"create_room|join_rule_knock_label\")}</p>;\n        }\n\n        let visibilitySection: JSX.Element | undefined;\n        if (this.state.joinRule === JoinRule.Knock) {\n            visibilitySection = (\n                <LabelledCheckbox\n                    className=\"mx_CreateRoomDialog_labelledCheckbox\"\n                    label={_t(\"room_settings|security|publish_room\")}\n                    onChange={this.onIsPublicKnockRoomChange}\n                    value={this.state.isPublicKnockRoom}\n                />\n            );\n        }\n\n        let e2eeSection: JSX.Element | undefined;\n        if (this.state.joinRule !== JoinRule.Public) {\n            let microcopy: string;\n            if (privateShouldBeEncrypted(MatrixClientPeg.safeGet())) {\n                if (this.state.canChangeEncryption) {\n                    microcopy = isVideoRoom\n                        ? _t(\"create_room|encrypted_video_room_warning\")\n                        : _t(\"create_room|encrypted_warning\");\n                } else {\n                    microcopy = _t(\"create_room|encryption_forced\");\n                }\n            } else {\n                microcopy = _t(\"settings|security|e2ee_default_disabled_warning\");\n            }\n            e2eeSection = (\n                <React.Fragment>\n                    <LabelledToggleSwitch\n                        label={_t(\"create_room|encryption_label\")}\n                        onChange={this.onEncryptedChange}\n                        value={this.state.isEncrypted}\n                        className=\"mx_CreateRoomDialog_e2eSwitch\" // for end-to-end tests\n                        disabled={!this.state.canChangeEncryption}\n                    />\n                    <p>{microcopy}</p>\n                </React.Fragment>\n            );\n        }\n\n        let federateLabel = _t(\"create_room|unfederated_label_default_off\");\n        if (SdkConfig.get().default_federate === false) {\n            // We only change the label if the default setting is different to avoid jarring text changes to the\n            // user. They will have read the implications of turning this off/on, so no need to rephrase for them.\n            federateLabel = _t(\"create_room|unfederated_label_default_on\");\n        }\n\n        let title: string;\n        if (isVideoRoom) {\n            title = _t(\"create_room|title_video_room\");\n        } else if (this.props.parentSpace || this.state.joinRule === JoinRule.Knock) {\n            title = _t(\"action|create_a_room\");\n        } else {\n            title =\n                this.state.joinRule === JoinRule.Public\n                    ? _t(\"create_room|title_public_room\")\n                    : _t(\"create_room|title_private_room\");\n        }\n\n        return (\n            <BaseDialog\n                className=\"mx_CreateRoomDialog\"\n                onFinished={this.props.onFinished}\n                title={title}\n                screenName=\"CreateRoom\"\n            >\n                <form onSubmit={this.onOk} onKeyDown={this.onKeyDown}>\n                    <div className=\"mx_Dialog_content\">\n                        <Field\n                            ref={this.nameField}\n                            label={_t(\"common|name\")}\n                            onChange={this.onNameChange}\n                            onValidate={this.onNameValidate}\n                            value={this.state.name}\n                            className=\"mx_CreateRoomDialog_name\"\n                        />\n                        <Field\n                            label={_t(\"create_room|topic_label\")}\n                            onChange={this.onTopicChange}\n                            value={this.state.topic}\n                            className=\"mx_CreateRoomDialog_topic\"\n                        />\n\n                        <JoinRuleDropdown\n                            label={_t(\"create_room|room_visibility_label\")}\n                            labelInvite={_t(\"create_room|join_rule_invite\")}\n                            labelKnock={\n                                this.askToJoinEnabled ? _t(\"room_settings|security|join_rule_knock\") : undefined\n                            }\n                            labelPublic={_t(\"common|public_room\")}\n                            labelRestricted={\n                                this.supportsRestricted ? _t(\"create_room|join_rule_restricted\") : undefined\n                            }\n                            value={this.state.joinRule}\n                            onChange={this.onJoinRuleChange}\n                        />\n\n                        {publicPrivateLabel}\n                        {visibilitySection}\n                        {e2eeSection}\n                        {aliasField}\n                        <details onToggle={this.onDetailsToggled} className=\"mx_CreateRoomDialog_details\">\n                            <summary className=\"mx_CreateRoomDialog_details_summary\">\n                                {this.state.detailsOpen ? _t(\"action|hide_advanced\") : _t(\"action|show_advanced\")}\n                            </summary>\n                            <LabelledToggleSwitch\n                                label={_t(\"create_room|unfederated\", {\n                                    serverName: MatrixClientPeg.safeGet().getDomain(),\n                                })}\n                                onChange={this.onNoFederateChange}\n                                value={this.state.noFederate}\n                            />\n                            <p>{federateLabel}</p>\n                        </details>\n                    </div>\n                </form>\n                <DialogButtons\n                    primaryButton={\n                        isVideoRoom ? _t(\"create_room|action_create_video_room\") : _t(\"create_room|action_create_room\")\n                    }\n                    onPrimaryButtonClick={this.onOk}\n                    onCancel={this.onCancel}\n                />\n            </BaseDialog>\n        );\n    }\n}\n"],"mappings":"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