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 Pane
s 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 WindowPaneListener
s 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 WindowPaneListener
s 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 WindowPaneListener
s 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 ContentPane
s 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