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

org.opencms.gwt.client.ui.CmsFrameDialog Maven / Gradle / Ivy

Go to download

OpenCms is an enterprise-ready, easy to use website content management system based on Java and XML technology. Offering a complete set of features, OpenCms helps content managers worldwide to create and maintain beautiful websites fast and efficiently.

There is a newer version: 18.0
Show newest version
/*
 * This library is part of OpenCms -
 * the Open Source Content Management System
 *
 * Copyright (c) Alkacon Software GmbH & Co. KG (http://www.alkacon.com)
 *
 * This library 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 2.1 of the License, or (at your option) any later version.
 *
 * This library 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.
 *
 * For further information about Alkacon Software, please see the
 * company website: http://www.alkacon.com
 *
 * For further information about OpenCms, please see the
 * project website: http://www.opencms.org
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

package org.opencms.gwt.client.ui;

import org.opencms.gwt.client.ui.css.I_CmsLayoutBundle;
import org.opencms.gwt.client.util.CmsDomUtil;
import org.opencms.gwt.client.util.CmsDomUtil.Method;

import java.util.Map;

import com.google.gwt.core.client.Scheduler;
import com.google.gwt.core.client.Scheduler.ScheduledCommand;
import com.google.gwt.dom.client.FormElement;
import com.google.gwt.dom.client.Style.Unit;
import com.google.gwt.event.logical.shared.CloseEvent;
import com.google.gwt.event.logical.shared.CloseHandler;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.PopupPanel;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.SimplePanel;
import com.google.gwt.user.client.ui.Widget;

/**
 * Frame dialog utility class.

* * Use to render the dialog content within an iFrame on top of a regular {@link org.opencms.gwt.client.ui.CmsPopup}. * May also be used to wrap the popup if no iFrame is needed.

* * Provides function to show an iFrame dialog.

* * @since 8.5 */ public class CmsFrameDialog { /** The name of the close function. */ public static final String CLOSE_FUNCTION = "cmsDialogClose"; /** The dialog height. */ public static final int DIALOG_HEIGHT = 300; /** The dialog width. */ public static final int DIALOG_WIDTH = 200; /** The name of the enable dialog close function. */ public static final String ENABLE_CLOSE_FUNCTION = "cmsEnableDialogClose"; /** The name of the dialog height function. */ public static final String HEIGHT_FUNCTION = "cmsDialogHeight"; /** The name of the IFrame used for displaying the upload hook page. */ public static final String IFRAME_NAME = "upload_hook"; /** The name of the dialog title function. */ public static final String TITLE_FUNCTION = "cmsDialogTitle"; /** The name of the dialog width function. */ public static final String WIDTH_FUNCTION = "cmsUploadHookDialogWidth"; /** The button panel. */ private FlowPanel m_buttonPanel; /** The content widget. */ private Widget m_content; /** The panel holding the content widget. */ private SimplePanel m_contentPanel; /** Flag indicating if this dialog is displayed within an iFrame on top of a popup. */ private boolean m_isFrame; /** Flag indicating that the dialog is showing.< */ private boolean m_isShowing; /** The main panel. */ private FlowPanel m_main; /** The popup. */ private CmsPopup m_popup; /** * Constructor.

*/ public CmsFrameDialog() { m_isFrame = hasParentFrame(); if (m_isFrame) { m_main = new FlowPanel(); m_main.addStyleName(I_CmsLayoutBundle.INSTANCE.dialogCss().frameDialog()); m_contentPanel = new SimplePanel(); m_contentPanel.addStyleName(I_CmsLayoutBundle.INSTANCE.dialogCss().popupMainContent()); m_contentPanel.addStyleName(I_CmsLayoutBundle.INSTANCE.dialogCss().contentPadding()); m_main.add(m_contentPanel); } else { m_popup = new CmsPopup(); m_popup.setGlassEnabled(true); } } /** * Returns if this dialog has a parent frame.

* * @return true if the parent frame is available */ public static native boolean hasParentFrame() /*-{ if ($wnd.parent[@org.opencms.gwt.client.ui.CmsFrameDialog::CLOSE_FUNCTION]) { return true; } return false; }-*/; /** * Shows an iFrame dialog popup.

* * @param title the dialog title * @param dialogUri the dialog URI * @param parameters the dialog post parameters * @param closeHandler the dialog close handler * * @return the opened popup */ public static CmsPopup showFrameDialog( String title, String dialogUri, Map parameters, CloseHandler closeHandler) { CmsPopup popup = new CmsPopup(title); popup.removePadding(); popup.addStyleName(I_CmsLayoutBundle.INSTANCE.contentEditorCss().contentEditor()); popup.setGlassEnabled(true); CmsIFrame editorFrame = new CmsIFrame(IFRAME_NAME, ""); popup.add(editorFrame); final FormElement formElement = CmsDomUtil.generateHiddenForm(dialogUri, Method.post, IFRAME_NAME, parameters); RootPanel.getBodyElement().appendChild(formElement); exportDialogFunctions(popup); popup.addCloseHandler(new CloseHandler() { public void onClose(CloseEvent event) { formElement.removeFromParent(); removeExportedFunctions(); } }); if (closeHandler != null) { popup.addCloseHandler(closeHandler); } popup.center(); formElement.submit(); return popup; } /** * Removes exported functions from the window context.

*/ protected static native void removeExportedFunctions() /*-{ $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::CLOSE_FUNCTION] = null; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::HEIGHT_FUNCTION] = null; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::WIDTH_FUNCTION] = null; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::TITLE_FUNCTION] = null; }-*/; /** * Installs the Javascript function which should be called by the child iframe when the dialog should be closed.

* * @param popup the popup */ private static native void exportDialogFunctions(final CmsPopup popup) /*-{ var self = this; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::CLOSE_FUNCTION] = function() { [email protected]::hide()(); }; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::HEIGHT_FUNCTION] = function( height) { [email protected]::setHeight(I)(height); if ([email protected]::isShowing()) { [email protected]::center()(); } }; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::WIDTH_FUNCTION] = function( width) { [email protected]::setWidth(I)(width); if ([email protected]::isShowing()) { [email protected]::center()(); } }; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::TITLE_FUNCTION] = function( title) { [email protected]::setCaption(Ljava/lang/String;)(title); }; $wnd[@org.opencms.gwt.client.ui.CmsFrameDialog::ENABLE_CLOSE_FUNCTION] = function( title) { [email protected]::addDialogClose(Lcom/google/gwt/user/client/Command;)(null); }; }-*/; /** * Adds a new button to the button bar.

* * @param button the button to add */ public void addButton(Widget button) { if (m_isFrame) { initButtonPanel(); m_buttonPanel.insert(button, 0); } else { m_popup.addButton(button); } } /** * Adds a new button to the button bar at the specified index position.

* * @param button the button to add * @param index the index position */ public void addButton(Widget button, int index) { if (m_isFrame) { initButtonPanel(); m_buttonPanel.insert(button, index); } else { m_popup.addButton(button, index); } } /** * Enables the dialog close button on the popup.

*/ public void enableDialogClose() { if (m_isFrame) { enableParentDialogClose(); } else { m_popup.addDialogClose(null); } } /** * Hides the dialog.

*/ public void hide() { if (m_isFrame) { hideParent(); } else { m_popup.hide(); } } /** * Returns if the popup is showing and the content is rendered.

* * @return true if the popup and content are showing */ public boolean isShowing() { if (m_isFrame) { return m_isShowing; } else { return m_popup.isShowing(); } } /** * Removes the given button from the button bar.

* * @param button the button to remove */ public void removeButton(Widget button) { if (m_isFrame) { if (m_buttonPanel != null) { m_buttonPanel.remove(button); } } else { m_popup.removeButton(button); } } /** * Sets the content widget.

* * @param content the content widget */ public void setContent(Widget content) { if (m_content != null) { m_content.removeFromParent(); } if (m_isFrame) { m_contentPanel.setWidget(content); } else { m_popup.setMainContent(content); } m_content = content; } /** * Sets the popup height.

* * @param height the height */ public void setHeight(int height) { if (m_isFrame) { setParentHeight(height); } else { m_popup.setHeight(height); if (m_popup.isShowing()) { m_popup.center(); } } } /** * Sets the dialog title.

* * @param title the title */ public void setTitle(String title) { if (m_isFrame) { setParentTitle(title); } else { m_popup.setCaption(title); } } /** * Sets the popup width.

* * @param width the width */ public void setWidth(int width) { if (m_isFrame) { setParentWidth(width); } else { m_popup.setWidth(width); if (m_popup.isShowing()) { m_popup.center(); } } } /** * Shows the dialog.

*/ public void show() { if (m_isFrame) { RootPanel root = RootPanel.get(); root.getElement().getStyle().setMargin(0, Unit.PX); root.getElement().getStyle().setPadding(0, Unit.PX); RootPanel.get().add(m_main); m_isShowing = true; Scheduler.get().scheduleDeferred(new ScheduledCommand() { public void execute() { adjustContentSize(); } }); } else { m_popup.center(); } } /** * Adjusts the content panel size according to the button panel height.

*/ protected void adjustContentSize() { if (m_isFrame && m_isShowing) { if (m_buttonPanel != null) { m_contentPanel.getElement().getStyle().setBottom(m_buttonPanel.getOffsetHeight() + 6, Unit.PX); } else { m_contentPanel.getElement().getStyle().clearBottom(); } } } /** * Enables the dialog close button on the parent frame popup.

*/ private native void enableParentDialogClose() /*-{ $wnd.parent[@org.opencms.gwt.client.ui.CmsFrameDialog::ENABLE_CLOSE_FUNCTION] (); }-*/; /** * Hides the parent dialog.

*/ private native void hideParent() /*-{ $wnd.parent[@org.opencms.gwt.client.ui.CmsFrameDialog::CLOSE_FUNCTION](); }-*/; /** * Initializes the button panel within frame mode.

*/ private void initButtonPanel() { if ((m_buttonPanel == null) && m_isFrame) { m_buttonPanel = new FlowPanel(); m_buttonPanel.addStyleName(I_CmsLayoutBundle.INSTANCE.dialogCss().popupButtonPanel()); m_main.add(m_buttonPanel); } } /** * Sets the parent dialog height.

* * @param height the height to set */ private native void setParentHeight(int height) /*-{ $wnd.parent[@org.opencms.gwt.client.ui.CmsFrameDialog::HEIGHT_FUNCTION] (height); }-*/; /** * Sets the title of the parent dialog.

* * @param title the title */ private native void setParentTitle(String title) /*-{ $wnd.parent[@org.opencms.gwt.client.ui.CmsFrameDialog::TITLE_FUNCTION] (title); }-*/; /** * Sets the parent dialog width.

* * @param width the width to set */ private native void setParentWidth(int width) /*-{ $wnd.parent[@org.opencms.gwt.client.ui.CmsFrameDialog::WIDTH_FUNCTION] (width); }-*/; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy