2022-04-14 14:42:48 +02:00
|
|
|
import { Selector, t } from "testcafe";
|
|
|
|
|
|
|
|
export default class Page {
|
|
|
|
constructor() {}
|
|
|
|
|
|
|
|
async openNav() {
|
2022-10-05 12:38:09 +02:00
|
|
|
if (await Selector("div.nav-expand").visible) {
|
2022-11-15 15:08:12 +01:00
|
|
|
await t.click(Selector("div.nav-expand a"));
|
2022-10-05 12:38:09 +02:00
|
|
|
} else if (await Selector("div.nav-expand").visible) {
|
2022-04-14 14:42:48 +02:00
|
|
|
await t.click(Selector("div.nav-expand i"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async openPage(page) {
|
|
|
|
await this.openNav();
|
2022-05-31 20:38:17 +02:00
|
|
|
if (t.browser.platform === "mobile") {
|
|
|
|
await t.wait(5000);
|
|
|
|
}
|
2022-10-28 11:16:40 +02:00
|
|
|
if (await Selector(".nav-" + page).visible) {
|
|
|
|
await t.click(Selector(".nav-" + page));
|
|
|
|
} else {
|
|
|
|
if (
|
|
|
|
(page === "monochrome") |
|
|
|
|
(page === "panoramas") |
|
|
|
|
(page === "stacks") |
|
|
|
|
(page === "scans") |
|
|
|
|
(page === "review") |
|
|
|
|
(page === "archive")
|
|
|
|
) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-browse").visible)) {
|
|
|
|
await t.click(Selector("div.nav-browse + div"));
|
|
|
|
}
|
|
|
|
} else if (page === "live") {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-video").visible)) {
|
|
|
|
await t.click(Selector("div.nav-video + div"));
|
|
|
|
}
|
|
|
|
} else if (page === "states") {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-places").visible)) {
|
|
|
|
await t.click(Selector("div.nav-places + div"));
|
|
|
|
}
|
|
|
|
} else if ((page === "originals") | (page === "hidden") | (page === "errors")) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-library").visible)) {
|
|
|
|
await t.click(Selector("div.nav-library + div"));
|
|
|
|
}
|
|
|
|
} else if ((page === "about") | (page === "feedback") | (page === "license")) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-settings").visible)) {
|
|
|
|
await t.click(Selector("div.nav-settings + div"));
|
|
|
|
}
|
2022-04-14 14:42:48 +02:00
|
|
|
}
|
2022-10-28 11:16:40 +02:00
|
|
|
await t.click(Selector(".nav-" + page));
|
2022-04-14 14:42:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async checkMenuItemAvailability(page, visible) {
|
2022-05-31 20:38:17 +02:00
|
|
|
if (t.browser.platform === "mobile") {
|
|
|
|
await t.wait(5000);
|
|
|
|
}
|
2022-04-14 14:42:48 +02:00
|
|
|
await this.openNav();
|
2022-05-31 20:38:17 +02:00
|
|
|
if (t.browser.platform === "mobile") {
|
|
|
|
await t.wait(5000);
|
|
|
|
}
|
2022-04-14 14:42:48 +02:00
|
|
|
if (
|
|
|
|
(page === "monochrome") |
|
|
|
|
(page === "panoramas") |
|
|
|
|
(page === "stacks") |
|
|
|
|
(page === "scans") |
|
|
|
|
(page === "review") |
|
|
|
|
(page === "archive")
|
|
|
|
) {
|
2022-05-31 20:38:17 +02:00
|
|
|
if (
|
|
|
|
!(await Selector("div.v-list__group--active div.nav-browse", { timeout: 15000 }).visible)
|
|
|
|
) {
|
|
|
|
await t.click(Selector("div.nav-browse + div", { timeout: 15000 }));
|
2022-04-14 14:42:48 +02:00
|
|
|
}
|
|
|
|
} else if (page === "live") {
|
|
|
|
if (await Selector(".nav-video").visible) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-video").visible)) {
|
|
|
|
await t.click(Selector("div.nav-video + div"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (page === "states") {
|
|
|
|
if (await Selector(".nav-places").visible) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-places").visible)) {
|
|
|
|
await t.click(Selector("div.nav-places + div"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if ((page === "originals") | (page === "hidden") | (page === "errors")) {
|
|
|
|
if (await Selector(".nav-library").visible) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-library").visible)) {
|
|
|
|
if (await Selector("div.nav-library + div").visible) {
|
|
|
|
await t.click(Selector("div.nav-library + div"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if ((page === "abouts") | (page === "feedback") | (page === "license")) {
|
|
|
|
if (await Selector(".nav-settings").visible) {
|
|
|
|
if (!(await Selector("div.v-list__group--active div.nav-settings").visible)) {
|
|
|
|
await t.click(Selector("div.nav-settings + div"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (visible) {
|
|
|
|
await t.expect(Selector(".nav-" + page).visible).ok();
|
|
|
|
} else {
|
|
|
|
await t.expect(Selector(".nav-" + page).visible).notOk();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|