org.alfresco.po.share.admin.VisibilityDropDown.java Source code

Java tutorial

Introduction

Here is the source code for org.alfresco.po.share.admin.VisibilityDropDown.java

Source

/*
 * #%L
 * share-po
 * %%
 * Copyright (C) 2005 - 2016 Alfresco Software Limited
 * %%
 * This file is part of the Alfresco software. 
 * 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:
 * 
 * Alfresco 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.
 * 
 * Alfresco 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
 * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 * #L%
 */
package org.alfresco.po.share.admin;

import java.util.List;

import org.alfresco.po.share.enums.SiteVisibility;
import org.alfresco.po.share.util.PageUtils;
import org.openqa.selenium.WebDriver;
import org.apache.commons.lang3.StringUtils;
import org.openqa.selenium.By;
import org.openqa.selenium.WebElement;

/**
 * Representation of a Visibility Menu
 * 
 * @author Richard Smith
 */
public class VisibilityDropDown {

    /** Constants */
    private static final By CONTROL_ELEMENT = By.cssSelector("table.dijitSelect");
    private static final String MENU_ELEMENT_SUFFIX = "_dropdown";
    private static final String MENU_ELEMENT_SELECTOR_TEMPLATE = "div#?";
    private static final By MENU_ROWS = By.cssSelector("tr.dijitMenuItem");
    private static final By MENU_LABEL = By.cssSelector("td.dijitMenuItemLabel");

    private WebDriver driver;
    private WebElement control;
    private String menuId;
    private SiteVisibility value;

    /**
     * Instantiates a new visibility drop down.
     * 
     * @param driver the web driver
     * @param element the element
     */
    public VisibilityDropDown(WebDriver driver, WebElement element) {
        this.driver = driver;
        this.value = SiteVisibility.getEnum(StringUtils.trim(element.getText()));
        this.control = element.findElement(CONTROL_ELEMENT);
        // The dropdown menu has the same id as the control element with '_dropdown' appended
        this.menuId = this.control.getAttribute("id") + MENU_ELEMENT_SUFFIX;
    }

    /**
     * Get the current value of the visibility drop down.
     * 
     * @return the value
     */
    public SiteVisibility getValue() {
        return value;
    }

    /**
     * Select a new visibility drop down value.
     * 
     * @param visibility the visibility
     */
    public void selectValue(SiteVisibility visibility) {
        // Click the control to open the menu
        control.click();

        // Compose the selector for the drop down menu
        String menuSelector = StringUtils.replace(MENU_ELEMENT_SELECTOR_TEMPLATE, "?", this.menuId);

        // Find the menu
        WebElement menu = this.driver.findElement(By.cssSelector(menuSelector));

        // If the menu is not null and is displayed and is enabled
        if (PageUtils.usableElement(menu)) {

            // Within the menu element find the MENU_ROWS
            List<WebElement> menuRows = menu.findElements(MENU_ROWS);

            // Iterate over the menuRows and click the item that matches the required visibility
            for (WebElement menuRow : menuRows) {
                if (visibility.getDisplayValue()
                        .equals(StringUtils.trim(menuRow.findElement(MENU_LABEL).getText()))) {
                    menuRow.click();
                    this.value = visibility;
                    break;
                }
            }
        }
    }

    /**
     * Is the provided value the current value of the drop down?
     * 
     * @return true, if the value is selected
     */
    public boolean isValueSelected(SiteVisibility visibility) {
        return this.value == visibility;
    }
}