import {Selector, t} from 'testcafe'; export default class Page { constructor() { this.view = Selector('div.p-view-select', {timeout: 15000}); this.camera = Selector('div.p-camera-select', {timeout: 15000}); this.countries = Selector('div.p-countries-select', {timeout: 15000}); this.time = Selector('div.p-time-select', {timeout: 15000}); this.search1 = Selector('div.p-search-field input', {timeout: 15000}); } async setFilter(filter, option) { let filterSelector = ""; switch (filter) { case 'view': filterSelector = 'div.p-view-select'; break; case 'camera': filterSelector = 'div.p-camera-select'; break; case 'time': filterSelector = 'div.p-time-select'; break; case 'countries': filterSelector = 'div.p-countries-select'; break; default: throw "unknown filter"; } await t .click(filterSelector, {timeout: 15000}); if (option) { await t .click(Selector('div.menuable__content__active div.v-select-list a').withText(option), {timeout: 15000}) } else { await t .click(Selector('div.menuable__content__active div.v-select-list a').nth(1), {timeout: 15000}) } } async search(term) { await t .typeText(this.search1, term) .pressKey('enter') } async openNav() { if (await Selector('button.p-navigation-show').visible) { await t.click(Selector('button.p-navigation-show')); } else if (await Selector('div.p-navigation-expand').exists) { await t.click(Selector('div.p-navigation-expand i')); } } async selectPhoto(nPhoto) { const count = await this.getSelectedCount(); await t .hover(Selector('div[class="v-image__image v-image__image--cover"]', {timeout:4000}).nth(nPhoto)) .click(Selector('button.p-photo-select').nth(count)); } async unselectPhoto(nPhoto) { const count = await this.getSelectedCount(); const nButton = count -1; await t .hover(Selector('div[class="v-image__image v-image__image--cover"]', {timeout:4000}).nth(nPhoto)) .click(Selector('button.p-photo-select').nth(nButton)); } async likePhoto(nPhoto) { const count = await this.getSelectedCount(); await t .hover(Selector('div[class="v-image__image v-image__image--cover"]', {timeout:4000}).nth(nPhoto)) .click(Selector('button.p-photo-like').nth(count)); } async getSelectedCount() { const countSelected = await Selector('div.p-photo-clipboard').innerText; const countSelectedInt = (Number.isInteger(parseInt(countSelected))) ? parseInt(countSelected) : 0; return countSelectedInt; } async login(password) { await t .typeText(Selector('input[type="password"]'), password) .pressKey('enter'); } async logout() { await t .click(Selector('div.p-navigation-logout')); } }