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) { await t .expect(Selector("#t-clipboard button.action-" + action).visible) .ok() .expect(Selector("#t-clipboard button.action-" + action).hasAttribute("disabled")) .notOk(); } else { 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")); } }