nexxtway/react-rainbow

View on GitHub
src/components/AvatarMenu/pageObject/index.js

Summary

Maintainability
B
6 hrs
Test Coverage
const PagePrimitiveMenu = require('../../PrimitiveMenu/pageObject');

/**
 * AvatarMenu page object class.
 * @class
 * @tutorial avatarMenu
 */
class PageAvatarMenu {
    /**
     * Create a new AvatarMenu page object.
     * @constructor
     * @param {string} rootElement - The selector of the AvatarMenu root element.
     */
    constructor(rootElement) {
        this.rootElement = rootElement;
        this.primitiveMenu = new PagePrimitiveMenu(
            `${rootElement} button[data-id="avatar-menu-button"]`,
        );
    }

    /**
     * Returns a new AvatarMenu page object of the element in item position.
     * @method
     * @param {number} itemPosition - The base 0 index of the MenuItem.
     */
    async getItem(itemPosition) {
        return this.primitiveMenu.getItem(itemPosition);
    }

    /**
     * Clicks the button element.
     * @method
     */
    async click() {
        await this.primitiveMenu.clickTrigger();
    }

    /**
     * Returns true when the menu is open, false otherwise.
     * @method
     * @returns {bool}
     */
    async isOpen() {
        return this.primitiveMenu.isDropdownOpen();
    }

    /**
     * Returns true when the button element has focus.
     * @method
     * @returns {bool}
     */
    async hasFocusButton() {
        return this.primitiveMenu.hasFocusTrigger();
    }
}

module.exports = PageAvatarMenu;