photoprism/frontend/tests/page-model/photo.js
2022-06-22 17:39:49 +02:00

134 lines
4.2 KiB
JavaScript

import { Selector, t } from "testcafe";
import Toolbar from "./toolbar";
const toolbar = new Toolbar();
export default class Page {
constructor() {}
async getNthPhotoUid(type, nth) {
if (type === "all") {
const NthPhoto = await Selector("div.is-photo").nth(nth).getAttribute("data-uid");
return NthPhoto;
} else {
const NthPhoto = await Selector("div.type-" + type)
.nth(nth)
.getAttribute("data-uid");
return NthPhoto;
}
}
async getPhotoCount(type) {
await t.wait(7000);
if (type === "all") {
const PhotoCount = await Selector("div.is-photo", { timeout: 2000 }).count;
return PhotoCount;
} else {
const PhotoCount = await Selector("div.type-" + type, { timeout: 2000 }).count;
return PhotoCount;
}
}
async selectPhotoFromUID(uid) {
await t
.hover(Selector("div.is-photo").withAttribute("data-uid", uid))
.click(Selector(`.uid-${uid} .input-select`));
}
async toggleSelectNthPhoto(nPhoto, type) {
if (type === "all") {
await t
.hover(Selector(".is-photo", { timeout: 4000 }).nth(nPhoto))
.click(Selector(".is-photo .input-select").nth(nPhoto));
} else {
await t
.hover(Selector("div.type-" + type, { timeout: 4000 }).nth(nPhoto))
.click(Selector("div.type-" + type + " .input-select").nth(nPhoto));
}
}
async checkPhotoVisibility(uid, visible) {
if (visible) {
await t.expect(Selector("div.is-photo").withAttribute("data-uid", uid).exists).ok();
} else {
await t.expect(Selector("div.is-photo").withAttribute("data-uid", uid).exists).notOk();
}
}
async checkHoverActionAvailability(mode, uidOrNth, action, visible) {
if (mode === "uid") {
await t.hover(Selector("div.is-photo").withAttribute("data-uid", uidOrNth));
if (visible) {
await t.expect(Selector(`.uid-${uidOrNth} .input-` + action).visible).ok();
} else {
await t.expect(Selector(`.uid-${uidOrNth} .input-` + action).visible).notOk();
}
}
if (mode === "nth") {
await t.hover(Selector("div.is-photo").nth(uidOrNth));
if (visible) {
await t.expect(Selector(`div.is-photo .input-` + action).visible).ok();
} else {
await t.expect(Selector(`div.is-photo .input-` + action).visible).notOk();
}
}
}
async triggerHoverAction(mode, uidOrNth, action) {
if (mode === "uid") {
await t.hover(Selector("div.is-photo").withAttribute("data-uid", uidOrNth, { timeout: 7000 }));
await t.click(Selector(`div.uid-${uidOrNth} .input-` + action));
}
if (mode === "nth") {
await t.hover(Selector("div.is-photo").nth(uidOrNth));
await t.click(Selector(`div.is-photo .input-` + action).nth(uidOrNth));
}
}
async checkHoverActionState(mode, uidOrNth, action, set) {
if (mode === "uid") {
await t.hover(Selector("div.is-photo").withAttribute("data-uid", uidOrNth));
if (set) {
await t.expect(Selector(`div.uid-${uidOrNth}`).hasClass("is-" + action)).ok();
} else {
await t.expect(Selector(`div.uid-${uidOrNth}`).hasClass("is-" + action)).notOk();
}
}
if (mode === "nth") {
await t.hover(Selector("div.is-photo").nth(uidOrNth));
if (set) {
await t
.expect(
Selector("div.is-photo")
.nth(uidOrNth)
.hasClass("is-" + action)
)
.ok();
} else {
await t
.expect(
Selector("div.is-photo")
.nth(uidOrNth)
.hasClass("is-" + action)
)
.notOk();
}
}
}
async triggerListViewActions(mode, uidOrnth, action) {
if (mode === "nth") {
await t.click(Selector(`td button.input-` + action).nth(uidOrnth));
} else if (mode === "uid") {
await t.click(Selector(`td button.input-` + action).withAttribute("data-uid", uidOrnth));
}
}
async checkListViewActionAvailability(action, disabled) {
if (disabled) {
await t.expect(Selector(`td button.input-` + action).hasAttribute("disabled")).ok();
} else {
await t.expect(Selector(`td button.input-` + action).hasAttribute("disabled")).notOk();
}
}
}