Class PopupPanel
- All Implemented Interfaces:
HasAttachHandlers,HasCloseHandlers<PopupPanel>,HasHandlers,EventListener,EventPreview,AcceptsOneWidget,HasAnimation,HasOneWidget,HasVisibility,HasWidgets,HasWidgets.ForIsWidget,IsWidget,SourcesPopupEvents,Iterable<Widget>
- Direct Known Subclasses:
DecoratedPopupPanel,LoggingPopup
A PopupPanel should not generally be added to other panels; rather, it should
be shown and hidden using the show() and hide() methods.
The width and height of the PopupPanel cannot be explicitly set; they are
determined by the PopupPanel's widget. Calls to setWidth(String) and
setHeight(String) will call these methods on the PopupPanel's
widget.
The PopupPanel can be optionally displayed with a "glass" element behind it,
which is commonly used to gray out the widgets behind it. It can be enabled
using setGlassEnabled(boolean). It has a default style name of
"gwt-PopupPanelGlass", which can be changed using
setGlassStyleName(String).
Example
public class PopupPanelExample implements EntryPoint {
private static class MyPopup extends PopupPanel {
public MyPopup() {
// PopupPanel's constructor takes 'auto-hide' as its boolean parameter.
// If this is set, the panel closes itself automatically when the user
// clicks outside of it.
super(true);
// PopupPanel is a SimplePanel, so you have to set it's widget property to
// whatever you want its contents to be.
setWidget(new Label("Click outside of this popup to close it"));
}
}
public void onModuleLoad() {
Button b1 = new Button("Click me to show popup");
b1.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
// Instantiate the popup and show it.
new MyPopup().show();
}
});
RootPanel.get().add(b1);
Button b2 = new Button("Click me to show popup partway across the screen");
b2.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
// Create the new popup.
final MyPopup popup = new MyPopup();
// Position the popup 1/3rd of the way down and across the screen, and
// show the popup. Since the position calculation is based on the
// offsetWidth and offsetHeight of the popup, you have to use the
// setPopupPositionAndShow(callback) method. The alternative would
// be to call show(), calculate the left and top positions, and
// call setPopupPosition(left, top). This would have the ugly side
// effect of the popup jumping from its original position to its
// new position.
popup.setPopupPositionAndShow(new PopupPanel.PositionCallback() {
public void setPosition(int offsetWidth, int offsetHeight) {
int left = (Window.getClientWidth() - offsetWidth) / 3;
int top = (Window.getClientHeight() - offsetHeight) / 3;
popup.setPopupPosition(left, top);
}
});
}
});
RootPanel.get().add(b2);
}
}
CSS Style Rules
- .gwt-PopupPanel
- the outside of the popup
- .gwt-PopupPanel .popupContent
- the wrapper around the content
- .gwt-PopupPanelGlass
- the glass background behind the popup
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic enumThe type of animation to use when opening the popup.static interfaceA callback that is used to set the position of aPopupPanelright before it is shown.(package private) static classAnAnimationused to enlarge the popup into view.Nested classes/interfaces inherited from class com.google.gwt.user.client.ui.UIObject
UIObject.DebugIdImpl, UIObject.DebugIdImplEnabledNested classes/interfaces inherited from interface com.google.gwt.user.client.ui.HasWidgets
HasWidgets.ForIsWidget -
Field Summary
Fields inherited from class com.google.gwt.user.client.ui.SimplePanel
widgetFields inherited from class com.google.gwt.user.client.ui.Widget
eventsToSinkFields inherited from class com.google.gwt.user.client.ui.UIObject
DEBUG_ID_PREFIX, MISSING_ELEMENT_ERROR, SETELEMENT_TWICE_ERROR -
Constructor Summary
ConstructorsConstructorDescriptionCreates an empty popup panel.PopupPanel(boolean autoHide) Creates an empty popup panel, specifying its "auto-hide" property.PopupPanel(boolean autoHide, boolean modal) Creates an empty popup panel, specifying its "auto-hide" and "modal" properties. -
Method Summary
Modifier and TypeMethodDescriptionvoidaddAutoHidePartner(Element partner) Mouse events that occur within an autoHide partner will not hide a panel set to autoHide.addCloseHandler(CloseHandler<PopupPanel> handler) Adds aCloseEventhandler.voidaddPopupListener(PopupListener listener) Deprecated.voidcenter()Centers the popup in the browser window and shows it.Get the type of animation to use when opening and closing the popup.protected ElementOverride this method to specify that an element other than the root element be the container for the panel's child widget.protected ElementGet the glass element used by thisPopupPanel.Gets the style name to be used on the glass element.intGets the panel's offset height in pixels.intGets the panel's offset width in pixels.intGets the popup's left position relative to the browser's client area.intGets the popup's top position relative to the browser's client area.protected ElementTemplate method that returns the element to which style names will be applied.getTitle()Gets the title associated with this object.voidhide()Hides the popup and detaches it from the page.voidhide(boolean autoClosed) Hides the popup and detaches it from the page.booleanReturns true if animations are enabled, false if not.booleanReturnstrueif the popup should be automatically hidden when the user clicks outside of it.booleanReturnstrueif the popup should be automatically hidden when the history token changes, such as when the user presses the browser's back button.booleanReturnstrueif a glass element will be displayed under thePopupPanel.booleanisModal()Returnstrueif keyboard or mouse events that do not target the PopupPanel or its children should be ignored.booleanReturnstrueif the popup should preview all native events, even if the event has already been consumed by another popup.booleanDetermines whether or not this popup is showing.booleanDetermines whether or not this popup is visible.(package private) voidWe control size by setting our child widget's size.booleanonEventPreview(Event event) Deprecated.booleanonKeyDownPreview(char key, int modifiers) Deprecated.booleanonKeyPressPreview(char key, int modifiers) Deprecated.booleanonKeyUpPreview(char key, int modifiers) Deprecated.protected voidprotected voidonUnload()This method is called immediately before a widget will be detached from the browser's document.voidremoveAutoHidePartner(Element partner) Remove an autoHide partner.voidremovePopupListener(PopupListener listener) Deprecated.Use theHandlerRegistration.removeHandler()method on the object returned byaddCloseHandler(com.google.gwt.event.logical.shared.CloseHandler<com.google.gwt.user.client.ui.PopupPanel>)instead(package private) voidsetAnimation(PopupPanel.ResizeAnimation animation) Sets the animation used to animate this popup.voidsetAnimationEnabled(boolean enable) Enable or disable animations.voidSet the type of animation to use when opening and closing the popup.voidsetAutoHideEnabled(boolean autoHide) Enable or disable the autoHide feature.voidsetAutoHideOnHistoryEventsEnabled(boolean enabled) Enable or disable autoHide on history change events.voidsetGlassEnabled(boolean enabled) When enabled, the background will be blocked with a semi-transparent pane the next time it is shown.voidsetGlassStyleName(String glassStyleName) Sets the style name to be used on the glass element.voidSets the height of the panel's child widget.voidsetModal(boolean modal) When the popup is modal, keyboard or mouse events that do not target the PopupPanel or its children will be ignored.voidsetPopupPosition(int left, int top) Sets the popup's position relative to the browser's client area.voidSets the popup's position using aPopupPanel.PositionCallback, and shows the popup.voidsetPreviewingAllNativeEvents(boolean previewAllNativeEvents) When enabled, the popup will preview all native events, even if another popup was opened after this one.voidSets the title associated with this object.voidsetVisible(boolean visible) Sets whether this object is visible.voidSets this panel's widget.voidSets the width of the panel's child widget.voidshow()Shows the popup and attach it to the page.final voidshowRelativeTo(UIObject target) Normally, the popup is positioned directly below the relative target, with its left edge aligned with the left edge of the target.Methods inherited from class com.google.gwt.user.client.ui.SimplePanel
add, getWidget, iterator, remove, setWidgetMethods inherited from class com.google.gwt.user.client.ui.Panel
add, adopt, clear, doAttachChildren, doDetachChildren, orphan, removeMethods inherited from class com.google.gwt.user.client.ui.Widget
addAttachHandler, addBitlessDomHandler, addDomHandler, addHandler, asWidget, asWidgetOrNull, createHandlerManager, delegateEvent, ensureHandlers, fireEvent, getHandlerCount, getHandlerManager, getLayoutData, getParent, isAttached, isOrWasAttached, onAttach, onBrowserEvent, onDetach, onLoad, removeFromParent, replaceElement, setLayoutData, setParent, sinkEvents, unsinkEventsMethods inherited from class com.google.gwt.user.client.ui.UIObject
addStyleDependentName, addStyleName, ensureDebugId, ensureDebugId, ensureDebugId, getAbsoluteLeft, getAbsoluteTop, getElement, getStyleName, getStyleName, getStylePrimaryName, getStylePrimaryName, isVisible, onEnsureDebugId, removeStyleDependentName, removeStyleName, resolvePotentialElement, setElement, setElement, setPixelSize, setSize, setStyleDependentName, setStyleName, setStyleName, setStyleName, setStyleName, setStylePrimaryName, setStylePrimaryName, setVisible, sinkBitlessEvent, toStringMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface com.google.gwt.event.shared.HasHandlers
fireEventMethods inherited from interface java.lang.Iterable
forEach, spliterator
-
Constructor Details
-
PopupPanel
public PopupPanel()Creates an empty popup panel. A child widget must be added to it before it is shown. -
PopupPanel
public PopupPanel(boolean autoHide) Creates an empty popup panel, specifying its "auto-hide" property.- Parameters:
autoHide-trueif the popup should be automatically hidden when the user clicks outside of it or the history token changes.
-
PopupPanel
public PopupPanel(boolean autoHide, boolean modal) Creates an empty popup panel, specifying its "auto-hide" and "modal" properties.- Parameters:
autoHide-trueif the popup should be automatically hidden when the user clicks outside of it or the history token changes.modal-trueif keyboard or mouse events that do not target the PopupPanel or its children should be ignored
-
-
Method Details
-
addAutoHidePartner
Mouse events that occur within an autoHide partner will not hide a panel set to autoHide.- Parameters:
partner- the auto hide partner to add
-
addPopupListener
Deprecated.Description copied from interface:SourcesPopupEventsAdds a listener interface to receive popup events.- Specified by:
addPopupListenerin interfaceSourcesPopupEvents- Parameters:
listener- the listener interface to add.
-
center
public void center()Centers the popup in the browser window and shows it. If the popup was already showing, then the popup is centered. -
getGlassStyleName
Gets the style name to be used on the glass element. By default, this is "gwt-PopupPanelGlass".- Returns:
- the glass element's style name
-
getOffsetHeight
public int getOffsetHeight()Gets the panel's offset height in pixels. Calls tosetHeight(String)before the panel's child widget is set will not influence the offset height.- Overrides:
getOffsetHeightin classUIObject- Returns:
- the object's offset height
-
getOffsetWidth
public int getOffsetWidth()Gets the panel's offset width in pixels. Calls tosetWidth(String)before the panel's child widget is set will not influence the offset width.- Overrides:
getOffsetWidthin classUIObject- Returns:
- the object's offset width
-
getPopupLeft
public int getPopupLeft()Gets the popup's left position relative to the browser's client area.- Returns:
- the popup's left position
-
getPopupTop
public int getPopupTop()Gets the popup's top position relative to the browser's client area.- Returns:
- the popup's top position
-
getTitle
Description copied from class:UIObjectGets the title associated with this object. The title is the 'tool-tip' displayed to users when they hover over the object. -
hide
public void hide()Hides the popup and detaches it from the page. This has no effect if it is not currently showing. -
hide
public void hide(boolean autoClosed) Hides the popup and detaches it from the page. This has no effect if it is not currently showing.- Parameters:
autoClosed- the value that will be passed toCloseHandler.onClose(CloseEvent)when the popup is closed
-
isAnimationEnabled
public boolean isAnimationEnabled()Description copied from interface:HasAnimationReturns true if animations are enabled, false if not.- Specified by:
isAnimationEnabledin interfaceHasAnimation
-
isAutoHideEnabled
public boolean isAutoHideEnabled()Returnstrueif the popup should be automatically hidden when the user clicks outside of it.- Returns:
- true if autoHide is enabled, false if disabled
-
isAutoHideOnHistoryEventsEnabled
public boolean isAutoHideOnHistoryEventsEnabled()Returnstrueif the popup should be automatically hidden when the history token changes, such as when the user presses the browser's back button.- Returns:
- true if enabled, false if disabled
-
isGlassEnabled
public boolean isGlassEnabled()Returnstrueif a glass element will be displayed under thePopupPanel.- Returns:
- true if enabled
-
isModal
public boolean isModal()Returnstrueif keyboard or mouse events that do not target the PopupPanel or its children should be ignored.- Returns:
- true if popup is modal, false if not
-
isPreviewingAllNativeEvents
public boolean isPreviewingAllNativeEvents()Returnstrueif the popup should preview all native events, even if the event has already been consumed by another popup.- Returns:
- true if previewAllNativeEvents is enabled, false if disabled
-
isShowing
public boolean isShowing()Determines whether or not this popup is showing. -
isVisible
public boolean isVisible()Determines whether or not this popup is visible. Note that this just checks thevisibilitystyle attribute, which is set in thesetVisible(boolean)method. If you want to know if the popup is attached to the page, useisShowing()instead.- Specified by:
isVisiblein interfaceHasVisibility- Overrides:
isVisiblein classUIObject- Returns:
trueif the object is visible- See Also:
-
onEventPreview
Deprecated.Description copied from interface:EventPreviewCalled when a browser event occurs and this event preview is on top of the preview stack.- Specified by:
onEventPreviewin interfaceEventPreview- Parameters:
event- the browser event- Returns:
falseto cancel the event- See Also:
-
onKeyDownPreview
Deprecated.Popups get an opportunity to preview keyboard events before they are passed to a widget contained by the Popup.- Parameters:
key- the key code of the depressed keymodifiers- keyboard modifiers, as specified inKeyCodes.- Returns:
falseto suppress the event
-
onKeyPressPreview
Deprecated.Popups get an opportunity to preview keyboard events before they are passed to a widget contained by the Popup.- Parameters:
key- the unicode character pressedmodifiers- keyboard modifiers, as specified inKeyCodes.- Returns:
falseto suppress the event
-
onKeyUpPreview
Deprecated.Popups get an opportunity to preview keyboard events before they are passed to a widget contained by the Popup.- Parameters:
key- the key code of the released keymodifiers- keyboard modifiers, as specified inKeyCodes.- Returns:
falseto suppress the event
-
removeAutoHidePartner
Remove an autoHide partner.- Parameters:
partner- the auto hide partner to remove
-
removePopupListener
Deprecated.Use theHandlerRegistration.removeHandler()method on the object returned byaddCloseHandler(com.google.gwt.event.logical.shared.CloseHandler<com.google.gwt.user.client.ui.PopupPanel>)insteadDescription copied from interface:SourcesPopupEventsRemoves a previously added popup listener.- Specified by:
removePopupListenerin interfaceSourcesPopupEvents- Parameters:
listener- the listener interface to remove.
-
setAnimationEnabled
public void setAnimationEnabled(boolean enable) Description copied from interface:HasAnimationEnable or disable animations.- Specified by:
setAnimationEnabledin interfaceHasAnimation- Parameters:
enable- true to enable, false to disable
-
setAutoHideEnabled
public void setAutoHideEnabled(boolean autoHide) Enable or disable the autoHide feature. When enabled, the popup will be automatically hidden when the user clicks outside of it.- Parameters:
autoHide- true to enable autoHide, false to disable
-
setAutoHideOnHistoryEventsEnabled
public void setAutoHideOnHistoryEventsEnabled(boolean enabled) Enable or disable autoHide on history change events. When enabled, the popup will be automatically hidden when the history token changes, such as when the user presses the browser's back button. Disabled by default.- Parameters:
enabled- true to enable, false to disable
-
setGlassEnabled
public void setGlassEnabled(boolean enabled) When enabled, the background will be blocked with a semi-transparent pane the next time it is shown. If the PopupPanel is already visible, the glass will not be displayed until it is hidden and shown again.- Parameters:
enabled- true to enable, false to disable
-
setGlassStyleName
Sets the style name to be used on the glass element. By default, this is "gwt-PopupPanelGlass".- Parameters:
glassStyleName- the glass element's style name
-
setHeight
Sets the height of the panel's child widget. If the panel's child widget has not been set, the height passed in will be cached and used to set the height immediately after the child widget is set.Note that subclasses may have a different behavior. A subclass may decide not to change the height of the child widget. It may instead decide to change the height of an internal panel widget, which contains the child widget.
-
setModal
public void setModal(boolean modal) When the popup is modal, keyboard or mouse events that do not target the PopupPanel or its children will be ignored.- Parameters:
modal- true to make the popup modal
-
setPopupPosition
public void setPopupPosition(int left, int top) Sets the popup's position relative to the browser's client area. The popup's position may be set before callingshow().- Parameters:
left- the left position, in pixelstop- the top position, in pixels
-
setPopupPositionAndShow
Sets the popup's position using aPopupPanel.PositionCallback, and shows the popup. The callback allows positioning to be performed based on the offsetWidth and offsetHeight of the popup, which are normally not available until the popup is showing. By positioning the popup before it is shown, the popup will not jump from its original position to the new position.- Parameters:
callback- the callback to set the position of the popup- See Also:
-
setPreviewingAllNativeEvents
public void setPreviewingAllNativeEvents(boolean previewAllNativeEvents) When enabled, the popup will preview all native events, even if another popup was opened after this one.
If autoHide is enabled, enabling this feature will cause the popup to autoHide even if another non-modal popup was shown after it. If this feature is disabled, the popup will only autoHide if it was the last popup opened.
- Parameters:
previewAllNativeEvents- true to enable, false to disable
-
setTitle
Description copied from class:UIObjectSets the title associated with this object. The title is the 'tool-tip' displayed to users when they hover over the object. -
setVisible
public void setVisible(boolean visible) Sets whether this object is visible. This method just sets thevisibilitystyle attribute. You need to callshow()to actually attached/detach thePopupPanelto the page.- Specified by:
setVisiblein interfaceHasVisibility- Overrides:
setVisiblein classUIObject- Parameters:
visible-trueto show the object,falseto hide it- See Also:
-
setWidget
Description copied from class:SimplePanelSets this panel's widget. Any existing child widget will be removed.- Specified by:
setWidgetin interfaceHasOneWidget- Overrides:
setWidgetin classSimplePanel- Parameters:
w- the panel's new widget, ornullto clear the panel
-
setWidth
Sets the width of the panel's child widget. If the panel's child widget has not been set, the width passed in will be cached and used to set the width immediately after the child widget is set.Note that subclasses may have a different behavior. A subclass may decide not to change the width of the child widget. It may instead decide to change the width of an internal panel widget, which contains the child widget.
-
show
public void show()Shows the popup and attach it to the page. It must have a child widget before this method is called. -
showRelativeTo
Normally, the popup is positioned directly below the relative target, with its left edge aligned with the left edge of the target. Depending on the width and height of the popup and the distance from the target to the bottom and right edges of the window, the popup may be displayed directly above the target, and/or its right edge may be aligned with the right edge of the target.- Parameters:
target- the target to show the popup below
-
getContainerElement
Description copied from class:SimplePanelOverride this method to specify that an element other than the root element be the container for the panel's child widget. This can be useful when you want to create a simple panel that decorates its contents. Note that this method continues to return theElementclass defined in theUsermodule to maintain backwards compatibility.- Overrides:
getContainerElementin classSimplePanel- Returns:
- the element to be used as the panel's container
-
getGlassElement
Get the glass element used by thisPopupPanel. The element is not created until it is enabled viasetGlassEnabled(boolean).- Returns:
- the glass element, or null if not created
-
getStyleElement
Description copied from class:UIObjectTemplate method that returns the element to which style names will be applied. By default it returns the root element, but this method may be overridden to apply styles to a child element.- Overrides:
getStyleElementin classUIObject- Returns:
- the element to which style names will be applied
-
onPreviewNativeEvent
-
onUnload
protected void onUnload()Description copied from class:WidgetThis method is called immediately before a widget will be detached from the browser's document. -
maybeUpdateSize
void maybeUpdateSize()We control size by setting our child widget's size. However, if we don't currently have a child, we record the size the user wanted so that when we do get a child, we can set it correctly. Until size is explicitly cleared, any child put into the popup will be given that size. -
setAnimation
Sets the animation used to animate this popup. Used by gwt-incubator to allow DropDownPanel to override the default popup animation. Not protected because the exact API may change in gwt 1.6.- Parameters:
animation- the animation to use for this popup
-
setAnimationType
Set the type of animation to use when opening and closing the popup.- Parameters:
type- the type of animation to use- See Also:
-
getAnimationType
Get the type of animation to use when opening and closing the popup.- Returns:
- the type of animation used
- See Also:
-
addCloseHandler(com.google.gwt.event.logical.shared.CloseHandler<com.google.gwt.user.client.ui.PopupPanel>)instead