UNPKG

passbolt-styleguide

Version:

Passbolt styleguide contains common styling assets used by the different sites, plugin, etc.

163 lines (143 loc) 4.22 kB
/** * Passbolt ~ Open source password manager for teams * Copyright (c) 2020 Passbolt SA (https://www.passbolt.com) * * Licensed under GNU Affero General Public License version 3 of the or any later version. * For full copyright and license information, please see the LICENSE.txt * Redistributions of files must retain the above copyright notice. * * @copyright Copyright (c) 2020 Passbolt SA (https://www.passbolt.com) * @license https://opensource.org/licenses/AGPL-3.0 AGPL License * @link https://www.passbolt.com Passbolt(tm) * @since 3.0.0 */ import { fireEvent, render, waitFor } from "@testing-library/react"; import React from "react"; import CheckPassphrase from "./CheckPassphrase"; import MockTranslationProvider from "../../../test/mock/components/Internationalisation/MockTranslationProvider"; /** * The CheckPassphrase component represented as a page */ export default class CheckPassphrasePage { /** * Default constructor * @param props Props to attach */ constructor(props) { this._page = render( <MockTranslationProvider> <CheckPassphrase {...props} /> </MockTranslationProvider>, ); } /** * Returns the passphrase value */ get passphrase() { return this.passphraseInput.value; } /** * REturns passphrase input */ get passphraseInput() { return this._page.container.querySelector("#passphrase"); } /** * Returns the token code value */ get rememberMe() { return this.rememberMeInput.value; } /** * Returns remember me input */ get rememberMeInput() { return this._page.container.querySelector("#remember-me"); } get canRememberMe() { return Boolean(this.rememberMeInput); } /** * Returns the verify button element */ get verifyButton() { return this._page.container.querySelector(".button.primary"); } /** * Returns the secondary action link element */ get secondaryActionLink() { return this._page.container.querySelector(".form-actions button.link"); } /** * Returns the warning message for powned password */ get warningMessage() { return this._page.container.querySelector(".warning-message"); } /** * Returns the error message */ get errorMessage() { return this._page.container.querySelector(".error-message"); } /** * Returns true if the user can change something like the token code */ get canChange() { const cannotChangePassphrase = this.passphraseInput.hasAttribute("disabled"); const cannotChangeRememberMe = this.rememberMeInput?.hasAttribute("disabled"); return !cannotChangePassphrase && !cannotChangeRememberMe; } /** * Returns true if one is processing */ get isProcessing() { return this.verifyButton.getAttribute("class").indexOf("processing") > -1; } /** * Returns true if the empty error message is displayed */ get hasEmptyPassphraseError() { return Boolean(this._page.container.querySelector(".empty-passphrase")); } /** * Returns true if the invalid passphrase error is displayed */ hasInvalidPassphraseError() { return Boolean(this._page.container.querySelector(".invalid-passphrase.error-message")); } /** * Toggle the remember me value */ async toggleRememberMe() { const leftClick = { button: 0 }; fireEvent.click(this.rememberMeInput, leftClick); await waitFor(() => {}); } /** * Fill the passphrase with the given value * @param passphrase A passphrase */ async fillPassphrase(passphrase) { fireEvent.change(this.passphraseInput, { target: { value: passphrase } }); await waitFor(() => {}); } /** * Verify the passphrase validity * @param inProgressFn The function called while saving */ async verify(inProgressFn = () => {}) { const leftClick = { button: 0 }; fireEvent.click(this.verifyButton, leftClick); await waitFor(inProgressFn); } /** * Click on the secondary action link. */ async clickSecondaryActionLink(inProgressFn = () => {}) { const leftClick = { button: 0 }; fireEvent.click(this.secondaryActionLink, leftClick); await waitFor(inProgressFn); } }