matrix-react-sdk
Version:
SDK for matrix.org using React
338 lines (335 loc) • 62.2 kB
JavaScript
"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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