matrix-react-sdk
Version:
SDK for matrix.org using React
349 lines (298 loc) • 46.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.AddExistingToSpace = void 0;
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _languageHandler = require("../../../languageHandler");
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _Dropdown = _interopRequireDefault(require("../elements/Dropdown"));
var _SearchBox = _interopRequireDefault(require("../../structures/SearchBox"));
var _SpaceStore = _interopRequireDefault(require("../../../stores/SpaceStore"));
var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar"));
var _Rooms = require("../../../Rooms");
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _AutoHideScrollbar = _interopRequireDefault(require("../../structures/AutoHideScrollbar"));
var _promise = require("../../../utils/promise");
var _DMRoomMap = _interopRequireDefault(require("../../../utils/DMRoomMap"));
var _Permalinks = require("../../../utils/permalinks/Permalinks");
var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _RecentAlgorithm = require("../../../stores/room-list/algorithms/tag-sorting/RecentAlgorithm");
var _ProgressBar = _interopRequireDefault(require("../elements/ProgressBar"));
var _SpaceRoomView = require("../../structures/SpaceRoomView");
var _DecoratedRoomAvatar = _interopRequireDefault(require("../avatars/DecoratedRoomAvatar"));
var _QueryMatcher = _interopRequireDefault(require("../../../autocomplete/QueryMatcher"));
/*
Copyright 2021 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
const Entry = ({
room,
checked,
onChange
}) => {
return /*#__PURE__*/_react.default.createElement("label", {
className: "mx_AddExistingToSpace_entry"
}, room?.isSpaceRoom() ? /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
room: room,
height: 32,
width: 32
}) : /*#__PURE__*/_react.default.createElement(_DecoratedRoomAvatar.default, {
room: room,
avatarSize: 32
}), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_AddExistingToSpace_entry_name"
}, room.name), /*#__PURE__*/_react.default.createElement(_StyledCheckbox.default, {
onChange: onChange ? e => onChange(e.target.checked) : null,
checked: checked,
disabled: !onChange
}));
};
const AddExistingToSpace
/*: React.FC<IAddExistingToSpaceProps>*/
= ({
space,
footerPrompt,
emptySelectionButton,
onFinished
}) => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
const visibleRooms = (0, _react.useMemo)(() => cli.getVisibleRooms().filter(r => r.getMyMembership() === "join"), [cli]);
const [selectedToAdd, setSelectedToAdd] = (0, _react.useState)(new Set());
const [progress, setProgress] = (0, _react.useState)(null);
const [error, setError] = (0, _react.useState)(null);
const [query, setQuery] = (0, _react.useState)("");
const lcQuery = query.toLowerCase().trim();
const existingSubspacesSet = (0, _react.useMemo)(() => new Set(_SpaceStore.default.instance.getChildSpaces(space.roomId)), [space]);
const existingRoomsSet = (0, _react.useMemo)(() => new Set(_SpaceStore.default.instance.getChildRooms(space.roomId)), [space]);
const [spaces, rooms, dms] = (0, _react.useMemo)(() => {
let rooms = visibleRooms;
if (lcQuery) {
const matcher = new _QueryMatcher.default(visibleRooms, {
keys: ["name"],
funcs: [r => [r.getCanonicalAlias(), ...r.getAltAliases()].filter(Boolean)],
shouldMatchWordsOnly: false
});
rooms = matcher.match(lcQuery);
}
const joinRule = space.getJoinRule();
return (0, _RecentAlgorithm.sortRooms)(rooms).reduce((arr, room) => {
if (room.isSpaceRoom()) {
if (room !== space && !existingSubspacesSet.has(room)) {
arr[0].push(room);
}
} else if (!existingRoomsSet.has(room)) {
if (!_DMRoomMap.default.shared().getUserIdForRoomId(room.roomId)) {
arr[1].push(room);
} else if (joinRule !== "public") {
// Only show DMs for non-public spaces as they make very little sense in spaces other than "Just Me" ones.
arr[2].push(room);
}
}
return arr;
}, [[], [], []]);
}, [visibleRooms, space, lcQuery, existingRoomsSet, existingSubspacesSet]);
const addRooms = async () => {
setError(null);
setProgress(0);
let error;
for (const room of selectedToAdd) {
const via = (0, _Permalinks.calculateRoomVia)(room);
try {
await _SpaceStore.default.instance.addRoomToSpace(space, room.roomId, via).catch(async e => {
if (e.errcode === "M_LIMIT_EXCEEDED") {
await (0, _promise.sleep)(e.data.retry_after_ms);
return _SpaceStore.default.instance.addRoomToSpace(space, room.roomId, via); // retry
}
throw e;
});
setProgress(i => i + 1);
} catch (e) {
console.error("Failed to add rooms to space", e);
setError(error = e);
break;
}
}
if (!error) {
onFinished(true);
}
};
const busy = progress !== null;
let footer;
if (error) {
footer = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("img", {
src: require("../../../../res/img/element-icons/warning-badge.svg"),
height: "24",
width: "24",
alt: ""
}), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_AddExistingToSpaceDialog_error"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpaceDialog_errorHeading"
}, (0, _languageHandler._t)("Not all selected were added")), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpaceDialog_errorCaption"
}, (0, _languageHandler._t)("Try again"))), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_AddExistingToSpaceDialog_retryButton",
onClick: addRooms
}, (0, _languageHandler._t)("Retry")));
} else if (busy) {
footer = /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement(_ProgressBar.default, {
value: progress,
max: selectedToAdd.size
}), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpaceDialog_progressText"
}, (0, _languageHandler._t)("Adding rooms... (%(progress)s out of %(count)s)", {
count: selectedToAdd.size,
progress
})));
} else {
let button = emptySelectionButton;
if (!button || selectedToAdd.size > 0) {
button = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
kind: "primary",
disabled: selectedToAdd.size < 1,
onClick: addRooms
}, (0, _languageHandler._t)("Add"));
}
footer = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", null, footerPrompt), button);
}
const onChange = !busy && !error ? (checked, room) => {
if (checked) {
selectedToAdd.add(room);
} else {
selectedToAdd.delete(room);
}
setSelectedToAdd(new Set(selectedToAdd));
} : null;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpace"
}, /*#__PURE__*/_react.default.createElement(_SearchBox.default, {
className: "mx_textinput_icon mx_textinput_search",
placeholder: (0, _languageHandler._t)("Filter your rooms and spaces"),
onSearch: setQuery,
autoComplete: true,
autoFocus: true
}), /*#__PURE__*/_react.default.createElement(_AutoHideScrollbar.default, {
className: "mx_AddExistingToSpace_content",
id: "mx_AddExistingToSpace"
}, rooms.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpace_section"
}, /*#__PURE__*/_react.default.createElement("h3", null, (0, _languageHandler._t)("Rooms")), rooms.map(room => {
return /*#__PURE__*/_react.default.createElement(Entry, {
key: room.roomId,
room: room,
checked: selectedToAdd.has(room),
onChange: onChange ? checked => {
onChange(checked, room);
} : null
});
})) : undefined, spaces.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpace_section mx_AddExistingToSpace_section_spaces"
}, /*#__PURE__*/_react.default.createElement("h3", null, (0, _languageHandler._t)("Spaces")), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpace_section_experimental"
}, /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("Feeling experimental?")), /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("You can add existing spaces to a space."))), spaces.map(space => {
return /*#__PURE__*/_react.default.createElement(Entry, {
key: space.roomId,
room: space,
checked: selectedToAdd.has(space),
onChange: onChange ? checked => {
onChange(checked, space);
} : null
});
})) : null, dms.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpace_section"
}, /*#__PURE__*/_react.default.createElement("h3", null, (0, _languageHandler._t)("Direct Messages")), dms.map(room => {
return /*#__PURE__*/_react.default.createElement(Entry, {
key: room.roomId,
room: room,
checked: selectedToAdd.has(room),
onChange: onChange ? checked => {
onChange(checked, room);
} : null
});
})) : null, spaces.length + rooms.length + dms.length < 1 ? /*#__PURE__*/_react.default.createElement("span", {
className: "mx_AddExistingToSpace_noResults"
}, (0, _languageHandler._t)("No results")) : undefined), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpace_footer"
}, footer));
};
exports.AddExistingToSpace = AddExistingToSpace;
const AddExistingToSpaceDialog
/*: React.FC<IProps>*/
= ({
matrixClient: cli,
space,
onCreateRoomClick,
onFinished
}) => {
const [selectedSpace, setSelectedSpace] = (0, _react.useState)(space);
const existingSubspaces = _SpaceStore.default.instance.getChildSpaces(space.roomId);
let spaceOptionSection;
if (existingSubspaces.length > 0) {
const options = [space, ...existingSubspaces].map(space => {
const classes = (0, _classnames.default)("mx_AddExistingToSpaceDialog_dropdownOption", {
mx_AddExistingToSpaceDialog_dropdownOptionActive: space === selectedSpace
});
return /*#__PURE__*/_react.default.createElement("div", {
key: space.roomId,
className: classes
}, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
room: space,
width: 24,
height: 24
}), space.name || (0, _Rooms.getDisplayAliasForRoom)(space) || space.roomId);
});
spaceOptionSection = /*#__PURE__*/_react.default.createElement(_Dropdown.default, {
id: "mx_SpaceSelectDropdown",
onOptionChange: (key
/*: string*/
) => {
setSelectedSpace(existingSubspaces.find(space => space.roomId === key) || space);
},
value: selectedSpace.roomId,
label: (0, _languageHandler._t)("Space selection")
}, options);
} else {
spaceOptionSection = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddExistingToSpaceDialog_onlySpace"
}, space.name || (0, _Rooms.getDisplayAliasForRoom)(space) || space.roomId);
}
const title = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
room: selectedSpace,
height: 40,
width: 40
}), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("h1", null, (0, _languageHandler._t)("Add existing rooms")), spaceOptionSection));
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
title: title,
className: "mx_AddExistingToSpaceDialog",
contentId: "mx_AddExistingToSpace",
onFinished: onFinished,
fixedWidth: false
}, /*#__PURE__*/_react.default.createElement(_MatrixClientContext.default.Provider, {
value: cli
}, /*#__PURE__*/_react.default.createElement(AddExistingToSpace, {
space: space,
onFinished: onFinished,
footerPrompt: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("Want to add a new room instead?")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: () => onCreateRoomClick(cli, space),
kind: "link"
}, (0, _languageHandler._t)("Create a new room")))
})), /*#__PURE__*/_react.default.createElement(_SpaceRoomView.SpaceFeedbackPrompt, {
onClick: () => onFinished(false)
}));
};
var _default = AddExistingToSpaceDialog;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/AddExistingToSpaceDialog.tsx"],"names":["Entry","room","checked","onChange","isSpaceRoom","name","e","target","AddExistingToSpace","space","footerPrompt","emptySelectionButton","onFinished","cli","MatrixClientContext","visibleRooms","getVisibleRooms","filter","r","getMyMembership","selectedToAdd","setSelectedToAdd","Set","progress","setProgress","error","setError","query","setQuery","lcQuery","toLowerCase","trim","existingSubspacesSet","SpaceStore","instance","getChildSpaces","roomId","existingRoomsSet","getChildRooms","spaces","rooms","dms","matcher","QueryMatcher","keys","funcs","getCanonicalAlias","getAltAliases","Boolean","shouldMatchWordsOnly","match","joinRule","getJoinRule","reduce","arr","has","push","DMRoomMap","shared","getUserIdForRoomId","addRooms","via","addRoomToSpace","catch","errcode","data","retry_after_ms","i","console","busy","footer","require","size","count","button","add","delete","length","map","undefined","AddExistingToSpaceDialog","matrixClient","onCreateRoomClick","selectedSpace","setSelectedSpace","existingSubspaces","spaceOptionSection","options","classes","mx_AddExistingToSpaceDialog_dropdownOptionActive","key","find","title"],"mappings":"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","sourcesContent":["/*\nCopyright 2021 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, {ReactNode, useContext, useMemo, useState} from \"react\";\nimport classNames from \"classnames\";\nimport {Room} from \"matrix-js-sdk/src/models/room\";\nimport {MatrixClient} from \"matrix-js-sdk/src/client\";\n\nimport {_t} from '../../../languageHandler';\nimport {IDialogProps} from \"./IDialogProps\";\nimport BaseDialog from \"./BaseDialog\";\nimport Dropdown from \"../elements/Dropdown\";\nimport SearchBox from \"../../structures/SearchBox\";\nimport SpaceStore from \"../../../stores/SpaceStore\";\nimport RoomAvatar from \"../avatars/RoomAvatar\";\nimport {getDisplayAliasForRoom} from \"../../../Rooms\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport AutoHideScrollbar from \"../../structures/AutoHideScrollbar\";\nimport {sleep} from \"../../../utils/promise\";\nimport DMRoomMap from \"../../../utils/DMRoomMap\";\nimport {calculateRoomVia} from \"../../../utils/permalinks/Permalinks\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport {sortRooms} from \"../../../stores/room-list/algorithms/tag-sorting/RecentAlgorithm\";\nimport ProgressBar from \"../elements/ProgressBar\";\nimport {SpaceFeedbackPrompt} from \"../../structures/SpaceRoomView\";\nimport DecoratedRoomAvatar from \"../avatars/DecoratedRoomAvatar\";\nimport QueryMatcher from \"../../../autocomplete/QueryMatcher\";\n\ninterface IProps extends IDialogProps {\n    matrixClient: MatrixClient;\n    space: Room;\n    onCreateRoomClick(cli: MatrixClient, space: Room): void;\n}\n\nconst Entry = ({ room, checked, onChange }) => {\n    return <label className=\"mx_AddExistingToSpace_entry\">\n        { room?.isSpaceRoom()\n            ? <RoomAvatar room={room} height={32} width={32} />\n            : <DecoratedRoomAvatar room={room} avatarSize={32} />\n        }\n        <span className=\"mx_AddExistingToSpace_entry_name\">{ room.name }</span>\n        <StyledCheckbox\n            onChange={onChange ? (e) => onChange(e.target.checked) : null}\n            checked={checked}\n            disabled={!onChange}\n        />\n    </label>;\n};\n\ninterface IAddExistingToSpaceProps {\n    space: Room;\n    footerPrompt?: ReactNode;\n    emptySelectionButton?: ReactNode;\n    onFinished(added: boolean): void;\n}\n\nexport const AddExistingToSpace: React.FC<IAddExistingToSpaceProps> = ({\n    space,\n    footerPrompt,\n    emptySelectionButton,\n    onFinished,\n}) => {\n    const cli = useContext(MatrixClientContext);\n    const visibleRooms = useMemo(() => cli.getVisibleRooms().filter(r => r.getMyMembership() === \"join\"), [cli]);\n\n    const [selectedToAdd, setSelectedToAdd] = useState(new Set<Room>());\n    const [progress, setProgress] = useState<number>(null);\n    const [error, setError] = useState<Error>(null);\n    const [query, setQuery] = useState(\"\");\n    const lcQuery = query.toLowerCase().trim();\n\n    const existingSubspacesSet = useMemo(() => new Set(SpaceStore.instance.getChildSpaces(space.roomId)), [space]);\n    const existingRoomsSet = useMemo(() => new Set(SpaceStore.instance.getChildRooms(space.roomId)), [space]);\n\n    const [spaces, rooms, dms] = useMemo(() => {\n        let rooms = visibleRooms;\n\n        if (lcQuery) {\n            const matcher = new QueryMatcher<Room>(visibleRooms, {\n                keys: [\"name\"],\n                funcs: [r => [r.getCanonicalAlias(), ...r.getAltAliases()].filter(Boolean)],\n                shouldMatchWordsOnly: false,\n            });\n\n            rooms = matcher.match(lcQuery);\n        }\n\n        const joinRule = space.getJoinRule();\n        return sortRooms(rooms).reduce((arr, room) => {\n            if (room.isSpaceRoom()) {\n                if (room !== space && !existingSubspacesSet.has(room)) {\n                    arr[0].push(room);\n                }\n            } else if (!existingRoomsSet.has(room)) {\n                if (!DMRoomMap.shared().getUserIdForRoomId(room.roomId)) {\n                    arr[1].push(room);\n                } else if (joinRule !== \"public\") {\n                    // Only show DMs for non-public spaces as they make very little sense in spaces other than \"Just Me\" ones.\n                    arr[2].push(room);\n                }\n            }\n            return arr;\n        }, [[], [], []]);\n    }, [visibleRooms, space, lcQuery, existingRoomsSet, existingSubspacesSet]);\n\n    const addRooms = async () => {\n        setError(null);\n        setProgress(0);\n\n        let error;\n\n        for (const room of selectedToAdd) {\n            const via = calculateRoomVia(room);\n            try {\n                await SpaceStore.instance.addRoomToSpace(space, room.roomId, via).catch(async e => {\n                    if (e.errcode === \"M_LIMIT_EXCEEDED\") {\n                        await sleep(e.data.retry_after_ms);\n                        return SpaceStore.instance.addRoomToSpace(space, room.roomId, via); // retry\n                    }\n\n                    throw e;\n                });\n                setProgress(i => i + 1);\n            } catch (e) {\n                console.error(\"Failed to add rooms to space\", e);\n                setError(error = e);\n                break;\n            }\n        }\n\n        if (!error) {\n            onFinished(true);\n        }\n    };\n\n    const busy = progress !== null;\n\n    let footer;\n    if (error) {\n        footer = <>\n            <img\n                src={require(\"../../../../res/img/element-icons/warning-badge.svg\")}\n                height=\"24\"\n                width=\"24\"\n                alt=\"\"\n            />\n\n            <span className=\"mx_AddExistingToSpaceDialog_error\">\n                <div className=\"mx_AddExistingToSpaceDialog_errorHeading\">{ _t(\"Not all selected were added\") }</div>\n                <div className=\"mx_AddExistingToSpaceDialog_errorCaption\">{ _t(\"Try again\") }</div>\n            </span>\n\n            <AccessibleButton className=\"mx_AddExistingToSpaceDialog_retryButton\" onClick={addRooms}>\n                { _t(\"Retry\") }\n            </AccessibleButton>\n        </>;\n    } else if (busy) {\n        footer = <span>\n            <ProgressBar value={progress} max={selectedToAdd.size} />\n            <div className=\"mx_AddExistingToSpaceDialog_progressText\">\n                { _t(\"Adding rooms... (%(progress)s out of %(count)s)\", {\n                    count: selectedToAdd.size,\n                    progress,\n                }) }\n            </div>\n        </span>;\n    } else {\n        let button = emptySelectionButton;\n        if (!button || selectedToAdd.size > 0) {\n            button = <AccessibleButton kind=\"primary\" disabled={selectedToAdd.size < 1} onClick={addRooms}>\n                { _t(\"Add\") }\n            </AccessibleButton>;\n        }\n\n        footer = <>\n            <span>\n                { footerPrompt }\n            </span>\n\n            { button }\n        </>;\n    }\n\n    const onChange = !busy && !error ? (checked, room) => {\n        if (checked) {\n            selectedToAdd.add(room);\n        } else {\n            selectedToAdd.delete(room);\n        }\n        setSelectedToAdd(new Set(selectedToAdd));\n    } : null;\n\n    return <div className=\"mx_AddExistingToSpace\">\n        <SearchBox\n            className=\"mx_textinput_icon mx_textinput_search\"\n            placeholder={ _t(\"Filter your rooms and spaces\") }\n            onSearch={setQuery}\n            autoComplete={true}\n            autoFocus={true}\n        />\n        <AutoHideScrollbar className=\"mx_AddExistingToSpace_content\" id=\"mx_AddExistingToSpace\">\n            { rooms.length > 0 ? (\n                <div className=\"mx_AddExistingToSpace_section\">\n                    <h3>{ _t(\"Rooms\") }</h3>\n                    { rooms.map(room => {\n                        return <Entry\n                            key={room.roomId}\n                            room={room}\n                            checked={selectedToAdd.has(room)}\n                            onChange={onChange ? (checked) => {\n                                onChange(checked, room);\n                            } : null}\n                        />;\n                    }) }\n                </div>\n            ) : undefined }\n\n            { spaces.length > 0 ? (\n                <div className=\"mx_AddExistingToSpace_section mx_AddExistingToSpace_section_spaces\">\n                    <h3>{ _t(\"Spaces\") }</h3>\n                    <div className=\"mx_AddExistingToSpace_section_experimental\">\n                        <div>{ _t(\"Feeling experimental?\") }</div>\n                        <div>{ _t(\"You can add existing spaces to a space.\") }</div>\n                    </div>\n                    { spaces.map(space => {\n                        return <Entry\n                            key={space.roomId}\n                            room={space}\n                            checked={selectedToAdd.has(space)}\n                            onChange={onChange ? (checked) => {\n                                onChange(checked, space);\n                            } : null}\n                        />;\n                    }) }\n                </div>\n            ) : null }\n\n            { dms.length > 0 ? (\n                <div className=\"mx_AddExistingToSpace_section\">\n                    <h3>{ _t(\"Direct Messages\") }</h3>\n                    { dms.map(room => {\n                        return <Entry\n                            key={room.roomId}\n                            room={room}\n                            checked={selectedToAdd.has(room)}\n                            onChange={onChange ? (checked) => {\n                                onChange(checked, room);\n                            } : null}\n                        />;\n                    }) }\n                </div>\n            ) : null }\n\n            { spaces.length + rooms.length + dms.length < 1 ? <span className=\"mx_AddExistingToSpace_noResults\">\n                { _t(\"No results\") }\n            </span> : undefined }\n        </AutoHideScrollbar>\n\n        <div className=\"mx_AddExistingToSpace_footer\">\n            { footer }\n        </div>\n    </div>;\n};\n\nconst AddExistingToSpaceDialog: React.FC<IProps> = ({ matrixClient: cli, space, onCreateRoomClick, onFinished }) => {\n    const [selectedSpace, setSelectedSpace] = useState(space);\n    const existingSubspaces = SpaceStore.instance.getChildSpaces(space.roomId);\n\n    let spaceOptionSection;\n    if (existingSubspaces.length > 0) {\n        const options = [space, ...existingSubspaces].map((space) => {\n            const classes = classNames(\"mx_AddExistingToSpaceDialog_dropdownOption\", {\n                mx_AddExistingToSpaceDialog_dropdownOptionActive: space === selectedSpace,\n            });\n            return <div key={space.roomId} className={classes}>\n                <RoomAvatar room={space} width={24} height={24} />\n                { space.name || getDisplayAliasForRoom(space) || space.roomId }\n            </div>;\n        });\n\n        spaceOptionSection = (\n            <Dropdown\n                id=\"mx_SpaceSelectDropdown\"\n                onOptionChange={(key: string) => {\n                    setSelectedSpace(existingSubspaces.find(space => space.roomId === key) || space);\n                }}\n                value={selectedSpace.roomId}\n                label={_t(\"Space selection\")}\n            >\n                { options }\n            </Dropdown>\n        );\n    } else {\n        spaceOptionSection = <div className=\"mx_AddExistingToSpaceDialog_onlySpace\">\n            { space.name || getDisplayAliasForRoom(space) || space.roomId }\n        </div>;\n    }\n\n    const title = <React.Fragment>\n        <RoomAvatar room={selectedSpace} height={40} width={40} />\n        <div>\n            <h1>{ _t(\"Add existing rooms\") }</h1>\n            { spaceOptionSection }\n        </div>\n    </React.Fragment>;\n\n    return <BaseDialog\n        title={title}\n        className=\"mx_AddExistingToSpaceDialog\"\n        contentId=\"mx_AddExistingToSpace\"\n        onFinished={onFinished}\n        fixedWidth={false}\n    >\n        <MatrixClientContext.Provider value={cli}>\n            <AddExistingToSpace\n                space={space}\n                onFinished={onFinished}\n                footerPrompt={<>\n                    <div>{ _t(\"Want to add a new room instead?\") }</div>\n                    <AccessibleButton onClick={() => onCreateRoomClick(cli, space)} kind=\"link\">\n                        { _t(\"Create a new room\") }\n                    </AccessibleButton>\n                </>}\n            />\n        </MatrixClientContext.Provider>\n\n        <SpaceFeedbackPrompt onClick={() => onFinished(false)} />\n    </BaseDialog>;\n};\n\nexport default AddExistingToSpaceDialog;\n\n"]}