keycloak-scim/js/apps/admin-ui/cypress/support/util/ModalUtils.ts
Jon Koops d3c2475041
Upgrade admin and account console to PatternFly 5 (#28196)
Closes #21345
Closes #21344

Signed-off-by: Jon Koops <jonkoops@gmail.com>
Co-authored-by: Erik Jan de Wit <erikjan.dewit@gmail.com>
Co-authored-by: Mark Franceschelli <mfrances@redhat.com>
Co-authored-by: Hynek Mlnařík <hmlnarik@redhat.com>
Co-authored-by: Agnieszka Gancarczyk <agancarc@redhat.com>
2024-04-05 16:37:05 +02:00

107 lines
2.5 KiB
TypeScript

import PageObject from "../pages/admin-ui/components/PageObject";
import TablePage from "../pages/admin-ui/components/TablePage";
export default class ModalUtils extends PageObject {
#modalDiv = ".pf-v5-c-modal-box";
#modalTitle = ".pf-v5-c-modal-box .pf-v5-c-modal-box__title-text";
#modalMessage = ".pf-v5-c-modal-box .pf-v5-c-modal-box__body";
#confirmModalBtn = "confirm";
#cancelModalBtn = "cancel";
#closeModalBtn = ".pf-v5-c-modal-box .pf-m-plain";
#copyToClipboardBtn = '[id*="copy-button"]';
#addModalDropdownBtn = "#add-dropdown > button";
#addModalDropdownItem = "#add-dropdown [role='menuitem']";
#addBtn = "add";
#tablePage = new TablePage(TablePage.tableSelector);
table() {
return this.#tablePage;
}
add() {
cy.findByTestId(this.#addBtn).click();
return this;
}
confirmModal() {
cy.findByTestId(this.#confirmModalBtn).click({ force: true });
return this;
}
checkConfirmButtonText(text: string) {
cy.findByTestId(this.#confirmModalBtn).contains(text);
return this;
}
confirmModalWithItem(itemName: string) {
cy.get(this.#addModalDropdownBtn).click();
cy.get(this.#addModalDropdownItem).contains(itemName).click();
return this;
}
cancelModal() {
cy.findByTestId(this.#cancelModalBtn).click({ force: true });
return this;
}
cancelButtonContains(text: string) {
cy.findByTestId(this.#cancelModalBtn).contains(text);
return this;
}
copyToClipboard() {
cy.get(this.#copyToClipboardBtn).click();
return this;
}
closeModal() {
cy.get(this.#closeModalBtn).click({ force: true });
return this;
}
checkModalTitle(title: string) {
//deprecated
this.assertModalTitleEqual(title);
return this;
}
checkModalMessage(message: string) {
cy.get(this.#modalMessage).invoke("text").should("eq", message);
return this;
}
assertModalMessageContainText(text: string) {
cy.get(this.#modalMessage).should("contain.text", text);
return this;
}
assertModalHasElement(elementSelector: string, exist: boolean) {
cy.get(this.#modalDiv)
.find(elementSelector)
.should((exist ? "" : ".not") + "exist");
return this;
}
assertModalVisible(isVisible: boolean) {
super.assertIsVisible(cy.get(this.#modalDiv), isVisible);
return this;
}
assertModalExist(exist: boolean) {
super.assertExist(cy.get(this.#modalDiv), exist);
return this;
}
assertModalTitleEqual(text: string) {
cy.get(this.#modalTitle).invoke("text").should("eq", text);
return this;
}
}