/*! * Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved. * * Alfresco Example Content Application * * This file is part of the Alfresco Example Content Application. * If the software was purchased under a paid Alfresco license, the terms of * the paid license agreement will prevail. Otherwise, the software is * provided under the following open source license terms: * * The Alfresco Example Content Application is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * The Alfresco Example Content Application 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * from Hyland Software. If not, see . */ import { Locator, Page } from '@playwright/test'; import { PlaywrightBase } from '../playwright-base'; export abstract class BaseComponent extends PlaywrightBase { private rootElement: string; private overlayElement = this.page.locator('.cdk-overlay-backdrop-showing'); constructor(page: Page, rootElement: string) { super(page); this.rootElement = rootElement; } /** * Method which should be used across the repository, while creating * reference to elements, which are in root element of component. * * @param cssLocator css selector as String. Need to be in the tree under the root element * @param options if you want to localize it by text, then provide an optional hasText * @returns Locator object */ getChild(cssLocator: string, options?: { hasText?: string | RegExp; has?: Locator }): Locator { return this.page.locator(`${this.rootElement} ${cssLocator}`, options); } async closeAdditionalOverlayElementIfVisible(): Promise { if (await this.overlayElement.isVisible()) { await this.page.keyboard.press('Escape'); await this.overlayElement.waitFor({ state: 'detached', timeout: 5000 }); } } async spinnerWaitForReload(): Promise { try { await this.page.locator('mat-progress-spinner').waitFor({ state: 'attached', timeout: 2000 }); await this.page.locator('mat-progress-spinner').waitFor({ state: 'detached', timeout: 2000 }); } catch (e) { this.logger.info('Spinner was not present'); } } }