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

nextapp.echo.app.WindowPane Maven / Gradle / Ivy

/* 
 * 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.echo.app;

import java.util.EventListener;

import nextapp.echo.app.event.WindowPaneControlListener;
import nextapp.echo.app.event.WindowPaneEvent;
import nextapp.echo.app.event.WindowPaneListener;

/**
 * WindowPane component: displays content in a movable and/or resizable window. May only be added to a ContentPane. May
 * contain at most one child component. May contain Panes as children.
 */
public class WindowPane extends Component 
implements FloatingPane, ModalSupport, PaneContainer {

    /** Serial Version UID. */
    private static final long serialVersionUID = 20070101L;

    public static final String INPUT_CLOSE = "close";
    public static final String INPUT_MINIMIZE = "minimize";
    public static final String INPUT_MAXIMIZE = "maximize";
    
    public static final String PROPERTY_BACKGROUND_IMAGE = "backgroundImage";
    public static final String PROPERTY_BORDER = "border";
    public static final String PROPERTY_BOX_SHADOW = "boxShadow";
    public static final String PROPERTY_CLOSABLE = "closable";
    public static final String PROPERTY_CLOSE_ANIMATION_TIME = "closeAnimationTime";
    public static final String PROPERTY_CLOSE_ICON = "closeIcon";
    public static final String PROPERTY_CLOSE_ICON_INSETS = "closeIconInsets";
    public static final String PROPERTY_CLOSE_ROLLOVER_ICON = "closeRolloverIcon";
    public static final String PROPERTY_CONTENT_HEIGHT = "contentHeight";
    public static final String PROPERTY_CONTENT_WIDTH = "contentWidth";
    public static final String PROPERTY_CONTROLS_INSETS = "controlsInsets";
    public static final String PROPERTY_CONTROLS_SPACING = "controlsSpacing";
    public static final String PROPERTY_DEFAULT_CLOSE_OPERATION = "defaultCloseOperation";
    public static final String PROPERTY_HEIGHT = "height";
    public static final String PROPERTY_ICON = "icon";
    public static final String PROPERTY_ICON_INSETS = "iconInsets";
    public static final String PROPERTY_INSETS = "insets";
    public static final String PROPERTY_MAXIMIZE_ENABLED = "maximizeEnabled";
    public static final String PROPERTY_MAXIMIZE_ICON = "maximizeIcon";
    public static final String PROPERTY_MAXIMIZE_ICON_INSETS = "maximizeIconInsets";
    public static final String PROPERTY_MAXIMIZE_ROLLOVER_ICON = "maximizeRolloverIcon";
    public static final String PROPERTY_MAXIMUM_HEIGHT = "maximumHeight";
    public static final String PROPERTY_MAXIMUM_WIDTH = "maximumWidth";
    public static final String PROPERTY_MINIMIZE_ENABLED = "minimizeEnabled";
    public static final String PROPERTY_MINIMIZE_ICON = "minimizeIcon";
    public static final String PROPERTY_MINIMIZE_ICON_INSETS = "minimizeIconInsets";
    public static final String PROPERTY_MINIMIZE_ROLLOVER_ICON = "minimizeRolloverIcon";
    public static final String PROPERTY_MINIMUM_HEIGHT = "minimumHeight";
    public static final String PROPERTY_MINIMUM_WIDTH = "minimumWidth";
    public static final String PROPERTY_MOVABLE = "movable";
    public static final String PROPERTY_OPEN_ANIMATION_TIME = "openAnimationTime";
    public static final String PROPERTY_POSITION_X = "positionX";
    public static final String PROPERTY_POSITION_Y = "positionY";
    public static final String PROPERTY_RADIUS = "radius";
    public static final String PROPERTY_RESIZABLE = "resizable";
    public static final String PROPERTY_TITLE = "title";
    public static final String PROPERTY_TITLE_BACKGROUND = "titleBackground";
    public static final String PROPERTY_TITLE_BACKGROUND_IMAGE = "titleBackgroundImage";
    public static final String PROPERTY_TITLE_FONT = "titleFont";
    public static final String PROPERTY_TITLE_FOREGROUND = "titleForeground";
    public static final String PROPERTY_TITLE_HEIGHT = "titleHeight";
    public static final String PROPERTY_TITLE_INSETS = "titleInsets";
    public static final String PROPERTY_WIDTH = "width";
    public static final String PROPERTY_Z_INDEX = "zIndex";

    
    /**
     * A constant for the defaultCloseOperation property 
     * indicating that nothing should be done when the user attempts 
     * to close a window.
     */
    public static final int DO_NOTHING_ON_CLOSE = 0;

    /**
     * A constant for the defaultCloseOperation property 
     * indicating that a window should be hidden when the user attempts 
     * to close it.
     */
    public static final int HIDE_ON_CLOSE = 1;

    /**
     * A constant for the defaultCloseOperation property 
     * indicating that a window should be removed from the component
     * hierarchy when a user attempts to close it.
     */
    public static final int DISPOSE_ON_CLOSE = 2;
    
    /**
     * The modal state of the window.
     */
    private boolean modal = false;
    
    /**
     * Creates a  new WindowPane.
     */    
    public WindowPane() {
        this(null, null, null);
    }
    
    /**
     * Creates a new WindowPane with the specified title
     * and dimensions.
     *
     * @param title the title
     * @param width The width
     * @param height The height
     */
    public WindowPane(String title, Extent width, Extent height) {
        super();
        if (title != null) {
            setTitle(title);
        }
        if (width != null) {
            setWidth(width);
        }
        if (height != null) {
            setHeight(height);
        }
    }
    
    /**
     * Adds a WindowPaneListener (or WindowPaneControlListener) to receive event notifications.
     * 
     * @param l the WindowPaneListener to add
     */
    public void addWindowPaneListener(WindowPaneListener l) {
        getEventListenerList().addListener(WindowPaneListener.class, l);
    }
    
    /**
     * Notifies WindowPaneListeners that the user has requested 
     * to close this WindowPane. 
     */
    protected void fireWindowClosing() {
        if (!hasEventListenerList()) {
            return;
        }
        EventListener[] listeners = getEventListenerList().getListeners(WindowPaneListener.class);
        if (listeners.length == 0) {
            return;
        }
        WindowPaneEvent e = new WindowPaneEvent(this);
        for (int i = 0; i < listeners.length; ++i) {
            ((WindowPaneListener) listeners[i]).windowPaneClosing(e);
        }
    }
    
    /**
     * Notifies WindowPaneListeners that the user has maximized the WindowPane
     */
    protected void fireWindowMaximized() {
        if (!hasEventListenerList()) {
            return;
        }
        EventListener[] listeners = getEventListenerList().getListeners(WindowPaneListener.class);
        if (listeners.length == 0) {
            return;
        }
        WindowPaneEvent e = new WindowPaneEvent(this);
        for (int i = 0; i < listeners.length; ++i) {
            if (listeners[i] instanceof WindowPaneControlListener) {
                ((WindowPaneControlListener) listeners[i]).windowPaneMaximized(e);
            }
        }
    }
    
    /**
     * Notifies WindowPaneListeners that the user has minimized the WindowPane
     */
    protected void fireWindowMinimized() {
        if (!hasEventListenerList()) {
            return;
        }
        EventListener[] listeners = getEventListenerList().getListeners(WindowPaneListener.class);
        if (listeners.length == 0) {
            return;
        }
        WindowPaneEvent e = new WindowPaneEvent(this);
        for (int i = 0; i < listeners.length; ++i) {
            if (listeners[i] instanceof WindowPaneControlListener) {
                ((WindowPaneControlListener) listeners[i]).windowPaneMinimized(e);
            }
        }
    }
    
    /**
     * Returns the background image of the WindowPane.
     * 
     * @return the background image
     */
    public FillImage getBackgroundImage() {
        return (FillImage) get(PROPERTY_BACKGROUND_IMAGE);
    }
    
    /**
     * Returns the border which surrounds the entire WindowPane.
     * 
     * @return border
     */
    public FillImageBorder getBorder() {
        return (FillImageBorder) get(PROPERTY_BORDER);
    }
    
    /**
     * Returns the specific box shadow (CSS3) setting of this component, if any.
     * This method will return null unless a BoxShadow is
     * specifically set on this Component.
     * 
     * @return the box shadow property of this
     *         Component
     */
    public BoxShadow getBoxShadow() {
        return (BoxShadow) get(PROPERTY_BOX_SHADOW);
    }

    /**
     * Returns the animation time for the window closing effect.
     * A value of 0 (the default) indicates the window will be immediately closed.
     * 
     * @return the animation time, in milliseconds
     */
    public int getCloseAnimationTime() {
        Integer animationTime = (Integer) get(PROPERTY_CLOSE_ANIMATION_TIME);
        return animationTime == null ? 0 : animationTime.intValue();
    }
    
    /**
     * Returns the close button icon.
     * 
     * @return the icon
     */
    public ImageReference getCloseIcon() {
        return (ImageReference) get(PROPERTY_CLOSE_ICON);
    }
    
    /**
     * Returns the inset margin around the close button icon.
     * 
     * @return the inset margin
     */
    public Insets getCloseIconInsets() {
        return (Insets) get(PROPERTY_CLOSE_ICON_INSETS);
    }
    
    /**
     * Returns the close button rollover icon.
     * 
     * @return the icon
     */
    public ImageReference getCloseRolloverIcon() {
        return (ImageReference) get(PROPERTY_CLOSE_ROLLOVER_ICON);
    }
    
    /**
     * Returns the configured height of the content region of the window.
     * 
     * @return the height
     */
    public Extent getContentHeight() {
        return (Extent) get(PROPERTY_HEIGHT);
    }
    
    /**
     * Returns the configured width of the content region of the window.
     * 
     * @return the width
     */
    public Extent getContentWidth() {
        return (Extent) get(PROPERTY_HEIGHT);
    }
    
    /**
     * Returns the spacing between the window control icons
     * (e.g., close, minimize, and maximize buttons).
     * 
     * @return the controls spacing
     */
    public Extent getControlsSpacing() {
        return (Extent) get(PROPERTY_CONTROLS_SPACING);
    }
    
    /**
     * Returns the inset margin around the window controls 
     * (e.g., close, minimize, and maximize buttons)
     * 
     * @return the inset margin
     */
    public Insets getControlsInsets() {
        return (Insets) get(PROPERTY_CONTROLS_INSETS);
    }
    
    /**
     * Returns the default close operation.
     * 
     * @return the default close operation, one of the following values:
     *         
    *
  • DO_NOTHING_ON_CLOSE
  • *
  • HIDE_ON_CLOSE
  • *
  • DISPOSE_ON_CLOSE
  • *
*/ public int getDefaultCloseOperation() { Integer defaultCloseOperationValue = (Integer) get(PROPERTY_DEFAULT_CLOSE_OPERATION); return defaultCloseOperationValue == null ? 0 : defaultCloseOperationValue.intValue(); } /** * Returns the configured height of the overall window, including its border. * * @return the height */ public Extent getHeight() { return (Extent) get(PROPERTY_HEIGHT); } /** * Returns the icon displayed in the title region. * * @return the icon */ public ImageReference getIcon() { return (ImageReference) get(PROPERTY_ICON); } /** * Returns the inset margin around the icon. * * @return the inset margin */ public Insets getIconInsets() { return (Insets) get(PROPERTY_ICON_INSETS); } /** * Returns the inset of the window content. * This property is not rendered when the content is a Pane * component. * * @return the inset */ public Insets getInsets() { return (Insets) get(PROPERTY_INSETS); } /** * Returns the maximize button icon. * * @return the icon */ public ImageReference getMaximizeIcon() { return (ImageReference) get(PROPERTY_MAXIMIZE_ICON); } /** * Returns the inset margin around the maximize button icon. * * @return the inset margin */ public Insets getMaximizeIconInsets() { return (Insets) get(PROPERTY_MAXIMIZE_ICON_INSETS); } /** * Returns the maximize button rollover icon. * * @return the icon */ public ImageReference getMaximizeRolloverIcon() { return (ImageReference) get(PROPERTY_MAXIMIZE_ROLLOVER_ICON); } /** * Returns the maximum height of the content region of the * WindowPane. * * @return the maximum height */ public Extent getMaximumHeight() { return (Extent) get(PROPERTY_MAXIMUM_HEIGHT); } /** * Returns the maximum width of the content region of the * WindowPane. * * @return the maximum width */ public Extent getMaximumWidth() { return (Extent) get(PROPERTY_MAXIMUM_WIDTH); } /** * Returns the minimize button icon. * * @return the icon */ public ImageReference getMinimizeIcon() { return (ImageReference) get(PROPERTY_MINIMIZE_ICON); } /** * Returns the inset margin around the minimize button icon. * * @return the inset margin */ public Insets getMinimizeIconInsets() { return (Insets) get(PROPERTY_MINIMIZE_ICON_INSETS); } /** * Returns the minimize button rollover icon. * * @return the icon */ public ImageReference getMinimizeRolloverIcon() { return (ImageReference) get(PROPERTY_MINIMIZE_ROLLOVER_ICON); } /** * Returns the minimum height of the content region of the * WindowPane. * * @return the minimum height */ public Extent getMinimumHeight() { return (Extent) get(PROPERTY_MINIMUM_HEIGHT); } /** * Returns the minimum width of the content region of the * WindowPane. * * @return the minimum width */ public Extent getMinimumWidth() { return (Extent) get(PROPERTY_MINIMUM_WIDTH); } /** * Returns the animation time for the window opening effect. * A value of 0 (the default) indicates the window will be immediately opened. * * @return the animation time, in milliseconds */ public int getOpenAnimationTime() { Integer animationTime = (Integer) get(PROPERTY_OPEN_ANIMATION_TIME); return animationTime == null ? 0 : animationTime.intValue(); } /** * Returns the horizontal (Y) position of the WindowPane with * respect to its container. * * @return the position */ public Extent getPositionX() { return (Extent) get(PROPERTY_POSITION_X); } /** * Returns the vertical (Y) position of the WindowPane with * respect to its container. * * @return the position */ public Extent getPositionY() { return (Extent) get(PROPERTY_POSITION_Y); } /** * Returns the corder radius of the component (or null of radius applied). * * @return the radius */ public Insets getRadius() { return (Insets) get(PROPERTY_RADIUS); } /** * Returns the title of the WindowPane. * * @return the title */ public String getTitle() { return (String) get(PROPERTY_TITLE); } /** * Returns the background color of the title region. * * @return the color */ public Color getTitleBackground() { return (Color) get(PROPERTY_TITLE_BACKGROUND); } /** * Returns the background image of the title region. * * @return the background image */ public FillImage getTitleBackgroundImage() { return (FillImage) get(PROPERTY_TITLE_BACKGROUND_IMAGE); } /** * Returns the font of the title region. * * @return the font */ public Font getTitleFont() { return (Font) get(PROPERTY_TITLE_FONT); } /** * Returns the foreground color of the title region. * * @return the color */ public Color getTitleForeground() { return (Color) get(PROPERTY_TITLE_FOREGROUND); } /** * Returns the height of the title region. * * @return the height */ public Extent getTitleHeight() { return (Extent) get(PROPERTY_TITLE_HEIGHT); } /** * Returns the insets of the title region. * * @return the insets */ public Insets getTitleInsets() { return (Insets) get(PROPERTY_TITLE_INSETS); } /** * Returns the configured width of the overall window, including its border. * * @return the width */ public Extent getWidth() { return (Extent) get(PROPERTY_WIDTH); } /** * Returns the z-index of the window with respect to its parent * ContentPane. Windows with higher z-indices will * visually obscure windows with lower z-indices. * * @return the z-index */ public int getZIndex() { Integer value = (Integer) get(PROPERTY_Z_INDEX); return value == null ? -1 : value.intValue(); } /** * Determines if the window is closable via a provided close button in * the title bar. * * @return true if the window is closable */ public boolean isClosable() { Boolean value = (Boolean) get(PROPERTY_CLOSABLE); return value == null ? true: value.booleanValue(); } /** * Determines if the window can be maximized via a provided close button in * the title bar. * * @return true if the window can be maximized */ public boolean isMaximizeEnabled() { Boolean value = (Boolean) get(PROPERTY_MAXIMIZE_ENABLED); return value == null ? true: value.booleanValue(); } /** * Determines if the window can be minimized via a provided close button in * the title bar. * * @return true if the window can be minimized */ public boolean isMinimizeEnabled() { Boolean value = (Boolean) get(PROPERTY_MINIMIZE_ENABLED); return value == null ? true: value.booleanValue(); } /** * @see nextapp.echo.app.ModalSupport#isModal() */ public boolean isModal() { return modal; } /** * Determines if the window is movable. * * @return true if the window is movable */ public boolean isMovable() { Boolean value = (Boolean) get(PROPERTY_MOVABLE); return value == null ? true : value.booleanValue(); } /** * Determines if the window is resizable. * * @return true if the window is resizable */ public boolean isResizable() { Boolean value = (Boolean) get(PROPERTY_RESIZABLE); return value == null ? true : value.booleanValue(); } /** * Limit content to a single child. * * @see nextapp.echo.app.Component#isValidChild(nextapp.echo.app.Component) */ public boolean isValidChild(Component component) { return getComponentCount() == 0; } /** * Only allow ContentPanes as parents. * * @see nextapp.echo.app.Component#isValidParent(nextapp.echo.app.Component) */ public boolean isValidParent(Component parent) { return parent instanceof ContentPane; } /** * @see nextapp.echo.app.Component#processInput(java.lang.String, java.lang.Object) */ public void processInput(String inputName, Object inputValue) { if (INPUT_CLOSE.equals(inputName)) { userClose(); } else if (INPUT_MAXIMIZE.equals(inputName)) { userMaximize(); } else if (INPUT_MINIMIZE.equals(inputName)) { userMinimize(); } else if (PROPERTY_POSITION_X.equals(inputName)) { setPositionX((Extent) inputValue); } else if (PROPERTY_POSITION_Y.equals(inputName)) { setPositionY((Extent) inputValue); } else if (PROPERTY_WIDTH.equals(inputName)) { setWidth((Extent) inputValue); } else if (PROPERTY_HEIGHT.equals(inputName)) { setHeight((Extent) inputValue); } else if (PROPERTY_Z_INDEX.equals(inputName)) { set(PROPERTY_Z_INDEX, (Integer) inputValue); } } /** * Removes a WindowPaneListener (or WindowPaneControlListener) from receiving event notifications. * * @param l the WindowPaneListener to remove */ public void removeWindowPaneListener(WindowPaneListener l) { if (!hasEventListenerList()) { return; } getEventListenerList().removeListener(WindowPaneListener.class, l); } /** * Sets the background image of the WindowPane. * * @param newValue the new background image */ public void setBackgroundImage(FillImage newValue) { set(PROPERTY_BACKGROUND_IMAGE, newValue); } /** * Sets the border which surrounds the entire WindowPane. * * @param newValue the new border */ public void setBorder(FillImageBorder newValue) { set(PROPERTY_BORDER, newValue); } /** * Sets the BoxShadow (CSS3) of this Component. * * @param newValue the new BoxShadow. */ public void setBoxShadow(BoxShadow newValue) { set(PROPERTY_BOX_SHADOW, newValue); } /** * Sets whether the window is closable via a provided close button in * the title bar. * * @param newValue true if the window is closable */ public void setClosable(boolean newValue) { set(PROPERTY_CLOSABLE, new Boolean(newValue)); } /** * Sets the animation time for the window closing effect. * A value of 0 (the default) indicates the window will be immediately closed. * * @param newValue the new animation time, in milliseconds */ public void setCloseAnimationTime(int newValue) { set(PROPERTY_CLOSE_ANIMATION_TIME, new Integer(newValue)); } /** * Sets the close button icon. * * @param newValue the new icon */ public void setCloseIcon(ImageReference newValue) { set(PROPERTY_CLOSE_ICON, newValue); } /** * Sets the inset margin around the close button icon. * * @param newValue the new inset margin */ public void setCloseIconInsets(Insets newValue) { set(PROPERTY_CLOSE_ICON_INSETS, newValue); } /** * Sets the close button rollover icon. * * @param newValue the new icon */ public void setCloseRolloverIcon(ImageReference newValue) { set(PROPERTY_CLOSE_ROLLOVER_ICON, newValue); } /** * Sets the content height of the WindowPane. * This value will be overridden by the height property, if it is set. * * @param newValue the new content height */ public void setContentHeight(Extent newValue) { set(PROPERTY_CONTENT_HEIGHT, newValue); } /** * Sets the content width of the WindowPane. * This value will be overridden by the width property, if it is set. * * @param newValue the new content width */ public void setContentWidth(Extent newValue) { set(PROPERTY_CONTENT_WIDTH, newValue); } /** * Sets the spacing between the window control icons * (e.g., close, minimize, and maximize buttons). * * @param newValue the new controls spacing */ public void setControlsSpacing(Extent newValue) { set(PROPERTY_CONTROLS_SPACING, newValue); } /** * Sets the inset margin around the window controls * (e.g., close, minimize, and maximize buttons). * * @param newValue the new inset margin */ public void setControlsInsets(Insets newValue) { set(PROPERTY_CONTROLS_INSETS, newValue); } /** * Sets the default close operation. * * @param newValue the new default close operation, one of the following * values: *
    *
  • DO_NOTHING_ON_CLOSE
  • *
  • HIDE_ON_CLOSE
  • *
  • DISPOSE_ON_CLOSE
  • *
*/ public void setDefaultCloseOperation(int newValue) { set(PROPERTY_DEFAULT_CLOSE_OPERATION, new Integer(newValue)); } /** * Sets the overall height of the WindowPane, including its border. * This value will override any setting of the contentHeight property. * * @param newValue the new height */ public void setHeight(Extent newValue) { set(PROPERTY_HEIGHT, newValue); } /** * Sets the icon displayed in the title region. * * @param newValue the new icon */ public void setIcon(ImageReference newValue) { set(PROPERTY_ICON, newValue); } /** * Sets the inset margin around the icon. * * @param newValue the new inset margin */ public void setIconInsets(Insets newValue) { set(PROPERTY_ICON_INSETS, newValue); } /** * Sets the inset of the window content. * This property is not rendered when the content is a Pane * component. * * @param newValue the new inset */ public void setInsets(Insets newValue) { set(PROPERTY_INSETS, newValue); } /** * Sets whether the window can be maximized via a provided button in * the title bar. * * @param newValue true if the window can be maximized */ public void setMaximizeEnabled(boolean newValue) { set(PROPERTY_MAXIMIZE_ENABLED, new Boolean(newValue)); } /** * Sets the maximize button icon. * * @param newValue the new icon */ public void setMaximizeIcon(ImageReference newValue) { set(PROPERTY_MAXIMIZE_ICON, newValue); } /** * Sets the inset margin around the maximize button icon. * * @param newValue the new inset margin */ public void setMaximizeIconInsets(Insets newValue) { set(PROPERTY_MAXIMIZE_ICON_INSETS, newValue); } /** * Sets the maximize button rollover icon. * * @param newValue the new icon */ public void setMaximizeRolloverIcon(ImageReference newValue) { set(PROPERTY_MAXIMIZE_ROLLOVER_ICON, newValue); } /** * Sets the maximum height of the content region of the * WindowPane. * * @param newValue the new maximum height */ public void setMaximumHeight(Extent newValue) { set(PROPERTY_MAXIMUM_HEIGHT, newValue); } /** * Sets the maximum width of the content region of the * WindowPane. * * @param newValue the new maximum width */ public void setMaximumWidth(Extent newValue) { set(PROPERTY_MAXIMUM_WIDTH, newValue); } /** * Sets whether the window can be minimized via a provided button in * the title bar. * * @param newValue true if the window can be minimized */ public void setMinimizeEnabled(boolean newValue) { set(PROPERTY_MINIMIZE_ENABLED, new Boolean(newValue)); } /** * Sets the minimize button icon. * * @param newValue the new icon */ public void setMinimizeIcon(ImageReference newValue) { set(PROPERTY_MINIMIZE_ICON, newValue); } /** * Sets the inset margin around the minimize button icon. * * @param newValue the new inset margin */ public void setMinimizeIconInsets(Insets newValue) { set(PROPERTY_MINIMIZE_ICON_INSETS, newValue); } /** * Sets the minimize button rollover icon. * * @param newValue the new icon */ public void setMinimizeRolloverIcon(ImageReference newValue) { set(PROPERTY_MINIMIZE_ROLLOVER_ICON, newValue); } /** * Sets the minimum height of the content region of the * WindowPane. * * @param newValue the new minimum height */ public void setMinimumHeight(Extent newValue) { set(PROPERTY_MINIMUM_HEIGHT, newValue); } /** * Sets the minimum width of the content region of the * WindowPane. * * @param newValue the new minimum width */ public void setMinimumWidth(Extent newValue) { set(PROPERTY_MINIMUM_WIDTH, newValue); } /** * @see nextapp.echo.app.ModalSupport#setModal(boolean) */ public void setModal(boolean newValue) { boolean oldValue = modal; modal = newValue; firePropertyChange(MODAL_CHANGED_PROPERTY, new Boolean(oldValue), new Boolean(newValue)); } /** * Sets whether the window is movable. * * @param newValue true if the window may be moved by the user */ public void setMovable(boolean newValue) { set(PROPERTY_MOVABLE, new Boolean(newValue)); } /** * Sets the animation time for the window opening effect. * A value of 0 (the default) indicates the window will be immediately opened. * * @param newValue the new animation time, in milliseconds */ public void setOpenAnimationTime(int newValue) { set(PROPERTY_OPEN_ANIMATION_TIME, new Integer(newValue)); } /** * Sets the horizontal (X) position of the WindowPane with * respect to its container. * * @param newValue the new position */ public void setPositionX(Extent newValue) { set(PROPERTY_POSITION_X, newValue); } /** * Sets the vertical (Y) position of the WindowPane with * respect to its container. * * @param newValue the new position */ public void setPositionY(Extent newValue) { set(PROPERTY_POSITION_Y, newValue); } /** * Sets the radius of the corners of the component. * * @param newValue the new radius */ public void setRadius(Insets newValue) { set(PROPERTY_RADIUS, newValue); } /** * Sets whether the window is resizable. * * @param newValue true if the window may be resized by the user */ public void setResizable(boolean newValue) { set(PROPERTY_RESIZABLE, new Boolean(newValue)); } /** * Sets the title of the WindowPane. * * @param newValue the title */ public void setTitle(String newValue) { set(PROPERTY_TITLE, newValue); } /** * Sets the font of the title region. * * @param newValue the new font */ public void setTitleFont(Font newValue) { set(PROPERTY_TITLE_FONT, newValue); } /** * Sets the background color of the title region. * * @param newValue the new color */ public void setTitleBackground(Color newValue) { set(PROPERTY_TITLE_BACKGROUND, newValue); } /** * Sets the background image of the title region. * * @param newValue the new background image */ public void setTitleBackgroundImage(FillImage newValue) { set(PROPERTY_TITLE_BACKGROUND_IMAGE, newValue); } /** * Sets the foreground color of the title region. * * @param newValue the new color */ public void setTitleForeground(Color newValue) { set(PROPERTY_TITLE_FOREGROUND, newValue); } /** * Sets the height of the title region. * * @param newValue the new height */ public void setTitleHeight(Extent newValue) { set(PROPERTY_TITLE_HEIGHT, newValue); } /** * Sets the insets of the title region. * * @param newValue the new insets */ public void setTitleInsets(Insets newValue) { set(PROPERTY_TITLE_INSETS, newValue); } /** * Sets the overall width of the WindowPane, including its border. * This value will override any setting of the contentWidth property. * * @param newValue the new width */ public void setWidth(Extent newValue) { set(PROPERTY_WIDTH, newValue); } /** * Sets the z-index of the window with respect to its parent * ContentPane. Windows with higher z-indices will * visually obscure windows with lower z-indices. * * @param newValue the new z-index */ public void setZIndex(int newValue) { set(PROPERTY_Z_INDEX, new Integer(newValue)); } /** * Processes a user request to close the window (via the close button). */ public void userClose() { fireWindowClosing(); Integer defaultCloseOperationValue = (Integer) getRenderProperty(PROPERTY_DEFAULT_CLOSE_OPERATION); int defaultCloseOperation = defaultCloseOperationValue == null ? DISPOSE_ON_CLOSE : defaultCloseOperationValue.intValue(); switch (defaultCloseOperation) { case DISPOSE_ON_CLOSE: getParent().remove(this); break; case HIDE_ON_CLOSE: setVisible(false); break; } } /** * Processes a user request to maximize the window (via the close button). * Performs no operation by default. The client is responsible for configuring the window appropriately. */ public void userMaximize() { fireWindowMaximized(); } /** * Processes a user request to minimize the window (via the close button). * Sets the window invisible. */ public void userMinimize() { setVisible(false); fireWindowMinimized(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy