photoprism/frontend/tests/acceptance/page-model/context-menu.js

57 lines
1.7 KiB
JavaScript
Raw Normal View History

import { Selector, t } from "testcafe";
export default class Page {
constructor() {}
async openContextMenu() {
if (!(await Selector(".action-clear").visible)) {
await t.click(Selector("button.action-menu"));
}
}
async checkContextMenuCount(count) {
const Count = await Selector("span.count-clipboard", { timeout: 5000 });
await t.expect(Count.textContent).eql(count);
}
async checkContextMenuActionAvailability(action, visible) {
await this.openContextMenu();
if (visible) {
2022-10-06 14:45:24 +02:00
await t
.expect(Selector("#t-clipboard button.action-" + action).visible)
.ok()
.expect(Selector("#t-clipboard button.action-" + action).hasAttribute("disabled"))
.notOk();
} else {
2022-10-06 14:45:24 +02:00
if (await Selector("#t-clipboard button.action-" + action).visible) {
await t
.expect(Selector("#t-clipboard button.action-" + action).hasAttribute("disabled"))
.ok();
} else {
await t.expect(Selector("#t-clipboard button.action-" + action).visible).notOk();
}
}
}
async triggerContextMenuAction(action, albumName) {
await this.openContextMenu();
if (t.browser.platform === "mobile") {
await t.wait(5000);
}
await t.click(Selector("#t-clipboard button.action-" + action));
if (action === "delete") {
await t.click(Selector("button.action-confirm"));
}
if ((action === "album") | (action === "clone")) {
await t
.typeText(Selector(".input-album input"), albumName, { replace: true })
.pressKey("enter");
}
}
async clearSelection() {
await this.openContextMenu();
await t.click(Selector(".action-clear"));
}
}