All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nextapp.echo2.webcontainer.syncpeer.TriCellTableConfigurator Maven / Gradle / Ivy

Go to download

Echo2 bundled with Echo2_Extras, Echo2_FileTransfer and echopointing and various improvements/bugfixes

There is a newer version: 2.0.4
Show newest version
/* 
 * This file is part of the Echo Web Application Framework (hereinafter "Echo").
 * Copyright (C) 2002-2009 NextApp, Inc.
 *
 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License. You may obtain a copy of the License at
 * http://www.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 *
 * Alternatively, the contents of this file may be used under the terms of
 * either the GNU General Public License Version 2 or later (the "GPL"), or
 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 * in which case the provisions of the GPL or the LGPL are applicable instead
 * of those above. If you wish to allow use of your version of this file only
 * under the terms of either the GPL or the LGPL, and not to allow others to
 * use your version of this file under the terms of the MPL, indicate your
 * decision by deleting the provisions above and replace them with the notice
 * and other provisions required by the GPL or the LGPL. If you do not delete
 * the provisions above, a recipient may use your version of this file under
 * the terms of any one of the MPL, the GPL or the LGPL.
 */

package nextapp.echo2.webcontainer.syncpeer;

import nextapp.echo2.app.Alignment;
import nextapp.echo2.app.Component;

/**
 * Provides utility methods to configure TriCellTable for
 * text/state positions specified by buttons/labels.
 */
class TriCellTableConfigurator {
    
    /**
     * Converts the value of a textPosition property into a value
     * suitable to be passed to a TriCellTable as an
     * orientation constructor parameter.
     * This method assumes that the TriCellTable is being rendered
     * with text at index 0 and icon at position 1.
     * 
     * @param textPosition the Alignment
     * @param component the component being rendered
     * @return the orientation value
     */
    static int convertIconTextPositionToOrientation(Alignment textPosition, Component component) {
        if (textPosition.getVertical() == Alignment.DEFAULT) {
            switch (textPosition.getHorizontal()) {
            case Alignment.LEFT:
                return component.getRenderLayoutDirection().isLeftToRight() 
                        ? TriCellTable.LEADING_TRAILING : TriCellTable.TRAILING_LEADING;
            case Alignment.RIGHT:
                return component.getRenderLayoutDirection().isLeftToRight() 
                        ? TriCellTable.TRAILING_LEADING : TriCellTable.LEADING_TRAILING;
            case Alignment.LEADING:
                return TriCellTable.LEADING_TRAILING;
            case Alignment.TRAILING:
                return TriCellTable.TRAILING_LEADING;
            default:
                // Invalid, return value for TRAILING (default).
                return TriCellTable.TRAILING_LEADING;
            }
        } else {
            if (textPosition.getVertical() == Alignment.TOP) {
                return TriCellTable.TOP_BOTTOM;
            } else {
                return TriCellTable.BOTTOM_TOP;
            }
        }
    }
    
    /**
     * Converts the value of the stateAlignment property of a 
     * ToggleButton into a value suitable to be passed to a
     * TriCellTable as an orientation constructor
     * parameter.
     * This method assumes that the TriCellTable is rendered with
     * text/icon at lower indices than the state.
     * 
     * @param statePosition the state position Alignment
     * @param component the button being rendered
     * @return the orientation value
     */
    static int convertStatePositionToOrientation(Alignment statePosition, Component component) {
        if (statePosition.getVertical() == Alignment.DEFAULT) {
            switch (statePosition.getHorizontal()) {
            case Alignment.LEFT:
                return component.getRenderLayoutDirection().isLeftToRight() 
                        ? TriCellTable.TRAILING_LEADING : TriCellTable.LEADING_TRAILING;
            case Alignment.RIGHT:
                return component.getRenderLayoutDirection().isLeftToRight() 
                        ? TriCellTable.LEADING_TRAILING : TriCellTable.TRAILING_LEADING;
            case Alignment.LEADING:
                return TriCellTable.TRAILING_LEADING;
            case Alignment.TRAILING:
                return TriCellTable.LEADING_TRAILING;
            default:
                // Invalid, return value for LEADING (default).
                return TriCellTable.TRAILING_LEADING;
            }
        } else {
            if (statePosition.getVertical() == Alignment.TOP) {
                return TriCellTable.BOTTOM_TOP;
            } else {
                return TriCellTable.TOP_BOTTOM;
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy