* Move user avatar to Space panel * Add room list header for 'Home' or 'Space Name' to room list Add existing Space context menus to room list header * Re-add pending room join spinner * Iterate RoomListHeader plus context menu * Iterate space context menu * Iterate room list + interactions * Move DND to new iA model * Replace composer custom status management with usermenu one * Cull Quick Actions * Iterate minimized room list state * delint * Merge the RoomListNumResults into the RoomListHeader * Make the search shortcut prompt semi-bold * Iterate RoomListHeader based on design review * Iterate UserMenu based on feedback * Add name to expanded spacepanel usermenu button * i18n * Make room sub list aux button components more generic * Change left panel explore button to only refer to room directory * Iterate RoomListHeader * Fix custom user status input field width in Chrome * Bring back Notification settings button * delint * i18n * post-merge fix * iterate pr * Remove unused state * update copy * Apply suggestions from PR review * delint * Update invite iconography * Iterate Space context menu to match Figma * Fix chevron alignment * Fix edge case for RoomListHeader on metaspaces * Wire up general rageshake-driven feedback mechanism * Add IA1.1 info toast * add missing alt attribute * delint * delint * tweak ia toast priority * e2e test account for new toast * autofocus feedback field and remove old subheading * tweak copy * Iterate space panel colours to match Figma * Iterate PR * delint * Fix feedback submission with object setting values * iterate based on review * Tweak colours and update splash image * Tweaks based on review * Remove room list prompt, made redundant by the big fat `+` * Fix edge cases around User Menu positioning and dnd * Add missing import, bad merge? * Update aria label in e2e test * Fix room list space rooms context menu explore button behaviour * Tweak copy * Revert order of options in the UserMenu * Tweak copy * i18n
81 lines
2.9 KiB
JavaScript
81 lines
2.9 KiB
JavaScript
/*
|
|
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.
|
|
*/
|
|
|
|
async function openSpaceCreateMenu(session) {
|
|
const spaceCreateButton = await session.query('.mx_SpaceButton_new');
|
|
await spaceCreateButton.click();
|
|
}
|
|
|
|
async function createSpace(session, name, isPublic = false) {
|
|
session.log.step(`creates space "${name}"`);
|
|
|
|
await openSpaceCreateMenu(session);
|
|
const className = isPublic ? ".mx_SpaceCreateMenuType_public" : ".mx_SpaceCreateMenuType_private";
|
|
const visibilityButton = await session.query(className);
|
|
await visibilityButton.click();
|
|
|
|
const nameInput = await session.query('input[name="spaceName"]');
|
|
await session.replaceInputText(nameInput, name);
|
|
|
|
await session.delay(100);
|
|
|
|
const createButton = await session.query('.mx_SpaceCreateMenu_wrapper .mx_AccessibleButton_kind_primary');
|
|
await createButton.click();
|
|
|
|
if (!isPublic) {
|
|
const justMeButton = await session.query('.mx_SpaceRoomView_privateScope_justMeButton');
|
|
await justMeButton.click();
|
|
const continueButton = await session.query('.mx_AddExistingToSpace_footer .mx_AccessibleButton_kind_primary');
|
|
await continueButton.click();
|
|
} else {
|
|
for (let i = 0; i < 2; i++) {
|
|
const continueButton = await session.query('.mx_SpaceRoomView_buttons .mx_AccessibleButton_kind_primary');
|
|
await continueButton.click();
|
|
}
|
|
}
|
|
|
|
session.log.done();
|
|
}
|
|
|
|
async function inviteSpace(session, spaceName, userId) {
|
|
session.log.step(`invites "${userId}" to space "${spaceName}"`);
|
|
|
|
const spaceButton = await session.query(`.mx_SpaceButton[aria-label="${spaceName}"]`);
|
|
await spaceButton.click({
|
|
button: 'right',
|
|
});
|
|
|
|
const inviteButton = await session.query('.mx_SpacePanel_contextMenu_inviteButton[aria-label="Invite"]');
|
|
await inviteButton.click();
|
|
|
|
try {
|
|
const button = await session.query('.mx_SpacePublicShare_inviteButton');
|
|
await button.click();
|
|
} catch (e) {
|
|
// ignore
|
|
}
|
|
|
|
const inviteTextArea = await session.query(".mx_InviteDialog_editor input");
|
|
await inviteTextArea.type(userId);
|
|
const selectUserItem = await session.query(".mx_InviteDialog_roomTile");
|
|
await selectUserItem.click();
|
|
const confirmButton = await session.query(".mx_InviteDialog_goButton");
|
|
await confirmButton.click();
|
|
session.log.done();
|
|
}
|
|
|
|
module.exports = { openSpaceCreateMenu, createSpace, inviteSpace };
|