UNPKG

passbolt-styleguide

Version:

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

277 lines (245 loc) 7.45 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 2.11.0 */ import { fireEvent, render, waitFor } from "@testing-library/react"; import AppContext from "../../../../shared/context/AppContext/AppContext"; import React from "react"; import { BrowserRouter as Router } from "react-router-dom"; import { FilterResourcesByFoldersItemPageObject } from "./FilterResourcesByFoldersItem.test.page"; import MockTranslationProvider from "../../../test/mock/components/Internationalisation/MockTranslationProvider"; import FilterResourcesByFolders from "./FilterResourcesByFolders"; import { DragContext } from "../../../contexts/DragContext"; import { ResourceWorkspaceContext } from "../../../contexts/ResourceWorkspaceContext"; import { ContextualMenuContext } from "../../../contexts/ContextualMenuContext"; import { DialogContext } from "../../../contexts/DialogContext"; import { ResourceTypesLocalStorageContext } from "../../../../shared/context/ResourceTypesLocalStorageContext/ResourceTypesLocalStorageContext"; /** * The FilterResourcesByFolders component represented as a page */ export default class FilterResourcesByFoldersPage { /** * Default constructor * @param props Props to attach */ constructor(props) { this._page = render( <MockTranslationProvider> <AppContext.Provider value={props.context}> <Router> <ContextualMenuContext.Provider value={props.contextualMenuContext}> <DialogContext.Provider value={props.dialogContext}> <ResourceTypesLocalStorageContext.Provider value={{ get: () => props.resourceTypes, resourceTypes: props.resourceTypes }} > <ResourceWorkspaceContext.Provider value={props.resourceWorkspaceContext}> <DragContext.Provider value={props.dragContext}> <FilterResourcesByFolders.WrappedComponent {...props} /> </DragContext.Provider> </ResourceWorkspaceContext.Provider> </ResourceTypesLocalStorageContext.Provider> </DialogContext.Provider> </ContextualMenuContext.Provider> </Router> </AppContext.Provider> </MockTranslationProvider>, ); this.setupPageObjects(); } /** * Set up the objects of the page */ setupPageObjects() { this._titleHeader = new TitleHeaderPageObject(this._page.container); this._filterResourcesByFolders = new FilterResourcesByFoldersPageObject(this._page.container); this._filterResourcesByFoldersItem = new FilterResourcesByFoldersItemPageObject(this._page.container); } /** * Return the page object of the title header */ get title() { return this._titleHeader; } /** * Returns the page object of display folders tree */ get filterResourcesByFolders() { return this._filterResourcesByFolders; } /** * Returns the page object of display folders tree item */ get filterResourcesByFoldersItem() { return this._filterResourcesByFoldersItem; } } /** * Page object for the TitleHeader element */ class TitleHeaderPageObject { /** * Default constructor * @param container The container which includes the FolderTree Component */ constructor(container) { this._container = container; } /** * Returns the clickable area of the header */ get hyperlink() { return this._container.querySelectorAll(".folders-label button")[0]; } /** Click on the component */ async click() { const leftClick = { button: 0 }; fireEvent.click(this.hyperlink, leftClick); await waitFor(() => {}); } } class FilterResourcesByFoldersPageObject { /** * Default constructor * @param container The container which includes the FolderTree Component */ constructor(container) { this._container = container; } /** * Returns the folder tree component */ get component() { return this._container.querySelector(".navigation-secondary.navigation-folders"); } /** * Returns the root folder */ get rootFolder() { return this._container.querySelectorAll(".folders-label button")[0]; } /** * Returns the root folder caret */ get rootFolderCaret() { return this._container.querySelector(".folders-label .toggle-folder"); } /** * Returns the root folder */ get rootFolderName() { return this.rootFolder.textContent; } /** * Returns the more button root folder */ get moreButton() { return this._container.querySelector(".accordion-header .node.root .row.title .right-cell.more-ctrl button"); } /** * Returns the list of folders */ get displayFolderList() { return this._container.querySelector(".folders-tree") !== null; } /** * Returns the empty content element */ get emptyContent() { return this._container.querySelector(".empty-content"); } /** * Returns true */ isEmpty() { return this.emptyContent !== null && this.emptyContent.innerHTML === "empty"; } /** * Returns true if the page object exists in the container */ exists() { return this.component !== null; } /** * Expand or collapse the folders list */ async toggleExpanded() { await this.click(this.rootFolderCaret); } /** * Open the contextual menu with the button */ get openContextualMenuWithButton() { return this.click(this.moreButton); } /** * Open the contextual menu with the button */ get openContextualMenuWithRightClick() { return this.rightClick(this.rootFolder); } /** * Returns the loading element */ get loadingMessage() { return this._container.querySelector(".processing-text"); } /** * Returns true */ isLoading() { return this.loadingMessage !== null && this.loadingMessage.innerHTML === "Retrieving folders"; } /** Click on the component */ async click(component) { const leftClick = { button: 0 }; fireEvent.click(component, leftClick); await waitFor(() => {}); } /** Right click on the component */ async rightClick(component) { fireEvent.contextMenu(component); await waitFor(() => {}); } /** Drop on the component */ async drop(component) { fireEvent.drop(component); await waitFor(() => {}); } /** Drag over on the component */ async dragOver(component) { fireEvent.dragOver(component); await waitFor(() => {}); } /** Drag over on the component */ async dragLeave(component) { fireEvent.dragLeave(component); await waitFor(() => {}); } /** * Drop on the root folder */ get onDrop() { return this.drop(this.rootFolder); } /** * Drop on the root folder */ get onDragOver() { return this.dragOver(this.rootFolder); } /** * Drop on the root folder */ get onDragLeave() { return this.dragLeave(this.rootFolder); } }