Files
notesnook/apps/web/__e2e__/models/app.model.ts
2023-06-20 12:36:21 +05:00

146 lines
4.4 KiB
TypeScript

/*
This file is part of the Notesnook project (https://notesnook.com/)
Copyright (C) 2023 Streetwriters (Private) Limited
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import { Locator, Page } from "@playwright/test";
import { getTestId } from "../utils";
import { AuthModel } from "./auth.model";
import { CheckoutModel } from "./checkout.model";
import { ItemsViewModel } from "./items-view.model";
import { NavigationMenuModel } from "./navigation-menu.model";
import { NotebooksViewModel } from "./notebooks-view.model";
import { NotesViewModel } from "./notes-view.model";
import { RemindersViewModel } from "./reminders-view.model";
import { SearchViewModel } from "./search-view-model";
import { SettingsViewModel } from "./settings-view.model";
import { ToastsModel } from "./toasts.model";
import { TrashViewModel } from "./trash-view.model";
export class AppModel {
readonly page: Page;
readonly toasts: ToastsModel;
readonly navigation: NavigationMenuModel;
readonly auth: AuthModel;
readonly checkout: CheckoutModel;
readonly routeHeader: Locator;
constructor(page: Page) {
this.page = page;
this.toasts = new ToastsModel(page);
this.navigation = new NavigationMenuModel(page, "navigation-menu");
this.auth = new AuthModel(page);
this.checkout = new CheckoutModel(page);
this.routeHeader = this.page.locator(getTestId("routeHeader"));
}
async goto(isLoggedIn = false) {
await this.page.goto("/");
await this.routeHeader.waitFor({ state: "visible" });
if (!isLoggedIn) await this.navigation.waitForItem("Login");
}
goBack() {
const goBackButton = this.page.locator(getTestId("go-back"));
return goBackButton.click();
}
async goToNotes() {
await this.navigateTo("Notes");
return new NotesViewModel(this.page, "home");
}
async goToNotebooks() {
await this.navigateTo("Notebooks");
return new NotebooksViewModel(this.page);
}
async goToFavorites() {
await this.navigateTo("Favorites");
return new NotesViewModel(this.page, "notes");
}
async goToReminders() {
await this.navigateTo("Reminders");
return new RemindersViewModel(this.page);
}
async goToTags() {
await this.navigateTo("Tags");
return new ItemsViewModel(this.page, "tags");
}
async goToColor(color: string) {
await this.navigateTo(color);
return new NotesViewModel(this.page, "notes");
}
async goToTrash() {
await this.navigateTo("Trash");
return new TrashViewModel(this.page);
}
async goToSettings() {
await this.navigateTo("Settings");
return new SettingsViewModel(this.page);
}
async navigateTo(title: string) {
if ((await this.getRouteHeader()) === title) return;
const item = await this.navigation.findItem(title);
if (!item) throw new Error(`Could not find item to navigate to: ${title}`);
await item.click();
await this.page.waitForTimeout(1000);
}
async getRouteHeader() {
if (!(await this.routeHeader.isVisible())) return;
return await this.routeHeader.innerText();
}
async isSynced() {
return (
(await this.page
.locator(getTestId("sync-status-completed"))
.isVisible()) ||
(await this.page.locator(getTestId("sync-status-synced")).isVisible())
);
}
async waitForSync(
state: "completed" | "synced" = "completed",
text?: string
) {
await this.page
.locator(getTestId(`sync-status-${state}`), { hasText: text })
.waitFor({ state: "visible" });
}
async search(query: string, type: string) {
const searchinput = this.page.locator(getTestId("search-input"));
const searchButton = this.page.locator(getTestId("search-button"));
const openSearch = this.page.locator(getTestId("open-search"));
await openSearch.click();
await searchinput.fill(query);
await searchButton.click();
return new SearchViewModel(this.page, type);
}
}