You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
import BasePage from "../../../Base";
|
|
|
|
import { GridPage } from "../../Grid";
|
|
|
|
import { GalleryPage } from "../../Gallery";
|
|
|
|
import { KanbanPage } from "../../Kanban";
|
|
|
|
import { FormPage } from "../../Form";
|
|
|
|
|
|
|
|
export class ProjectMenuObject extends BasePage {
|
|
|
|
constructor(parent: GridPage | GalleryPage | KanbanPage | FormPage) {
|
|
|
|
super(parent.rootPage);
|
|
|
|
}
|
|
|
|
|
|
|
|
get() {
|
|
|
|
return this.rootPage.locator(`[pw-data="nc-fields-menu"]`);
|
|
|
|
}
|
|
|
|
|
|
|
|
async toggle() {
|
|
|
|
await this.rootPage.locator('[pw-data="nc-project-menu"]').click();
|
|
|
|
}
|
|
|
|
|
|
|
|
async click({ menu, subMenu }: { menu: string; subMenu: string }) {
|
|
|
|
let pMenu = await this.rootPage.locator(
|
|
|
|
`.nc-dropdown-project-menu:visible`
|
|
|
|
);
|
|
|
|
await pMenu
|
|
|
|
.locator(`div.nc-project-menu-item:has-text("${menu}"):visible`)
|
|
|
|
.click();
|
|
|
|
await this.rootPage.waitForTimeout(2000);
|
|
|
|
|
|
|
|
if (subMenu) {
|
|
|
|
await this.rootPage
|
|
|
|
.locator(`div.nc-project-menu-item:has-text("${subMenu}"):visible`)
|
|
|
|
.click();
|
|
|
|
await this.rootPage.waitForTimeout(1000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async clickPreview(role: string) {
|
|
|
|
await this.click({
|
|
|
|
menu: "Preview as",
|
|
|
|
subMenu: role,
|
|
|
|
});
|
|
|
|
await this.rootPage.waitForTimeout(2500);
|
|
|
|
}
|
|
|
|
}
|