IDEMPIERE-5666 - Prevent Closing the Tab of a Running Report (#1778)
* IDEMPIERE-5666 - Prevent Closing the Tab of a Running Report * IDEMPIERE-5666 - fix javascript error * IDEMPIERE-5666 - pr1778 patch
This commit is contained in:
parent
fdf2f0299c
commit
47891709ad
|
@ -30,9 +30,11 @@ import org.adempiere.webui.LayoutUtils;
|
|||
import org.adempiere.webui.component.ConfirmPanel;
|
||||
import org.adempiere.webui.component.DocumentLink;
|
||||
import org.adempiere.webui.component.Mask;
|
||||
import org.adempiere.webui.component.Tabpanel;
|
||||
import org.adempiere.webui.component.Window;
|
||||
import org.adempiere.webui.desktop.IDesktop;
|
||||
import org.adempiere.webui.panel.IHelpContext;
|
||||
import org.adempiere.webui.panel.ITabOnCloseHandler;
|
||||
import org.adempiere.webui.part.WindowContainer;
|
||||
import org.adempiere.webui.process.WProcessInfo;
|
||||
import org.adempiere.webui.session.SessionManager;
|
||||
|
@ -69,6 +71,7 @@ import org.zkoss.zul.A;
|
|||
import org.zkoss.zul.Div;
|
||||
import org.zkoss.zul.Html;
|
||||
import org.zkoss.zul.Label;
|
||||
import org.zkoss.zul.Tab;
|
||||
import org.zkoss.zul.Vlayout;
|
||||
|
||||
import com.lowagie.text.Document;
|
||||
|
@ -87,7 +90,7 @@ import com.lowagie.text.pdf.PdfWriter;
|
|||
* @author arboleda - globalqss
|
||||
* - Implement ShowHelp option on processes and reports
|
||||
*/
|
||||
public class ProcessDialog extends AbstractProcessDialog implements EventListener<Event>, IHelpContext
|
||||
public class ProcessDialog extends AbstractProcessDialog implements EventListener<Event>, IHelpContext, ITabOnCloseHandler
|
||||
{
|
||||
/**
|
||||
* generated serial id
|
||||
|
@ -170,6 +173,11 @@ public class ProcessDialog extends AbstractProcessDialog implements EventListene
|
|||
super.onPageAttached(newpage, oldpage);
|
||||
try {
|
||||
SessionManager.getSessionApplication().getKeylistener().addEventListener(Events.ON_CTRL_KEY, this);
|
||||
|
||||
Component parentTab = this.getParent();
|
||||
if (parentTab != null && parentTab instanceof Tabpanel) {
|
||||
((Tabpanel)parentTab).setOnCloseHandler(this);
|
||||
}
|
||||
} catch (Exception e) {}
|
||||
}
|
||||
|
||||
|
@ -780,4 +788,23 @@ public class ProcessDialog extends AbstractProcessDialog implements EventListene
|
|||
this.dispose();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClose(Tabpanel tabPanel) {
|
||||
if(!isUILocked()) {
|
||||
Tab tab = tabPanel.getLinkedTab();
|
||||
if (tab != null) {
|
||||
tab.close();
|
||||
cleanUp();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void cleanUp() {
|
||||
if (m_WindowNo >= 0)
|
||||
{
|
||||
SessionManager.getAppDesktop().unregisterWindow(m_WindowNo);
|
||||
m_WindowNo = -1;
|
||||
}
|
||||
}
|
||||
|
||||
} // ProcessDialog
|
||||
|
|
|
@ -20,8 +20,10 @@ import java.util.logging.Level;
|
|||
|
||||
import org.adempiere.webui.ClientInfo;
|
||||
import org.adempiere.webui.LayoutUtils;
|
||||
import org.adempiere.webui.component.Tabpanel;
|
||||
import org.adempiere.webui.component.Window;
|
||||
import org.adempiere.webui.event.DialogEvents;
|
||||
import org.adempiere.webui.panel.ITabOnCloseHandler;
|
||||
import org.adempiere.webui.util.ZKUpdateUtil;
|
||||
import org.compiere.model.MPInstance;
|
||||
import org.compiere.print.MPrintFormat;
|
||||
|
@ -30,6 +32,7 @@ import org.compiere.util.CLogger;
|
|||
import org.compiere.util.Env;
|
||||
import org.zkoss.zk.ui.Component;
|
||||
import org.zkoss.zk.ui.HtmlBasedComponent;
|
||||
import org.zkoss.zk.ui.Page;
|
||||
import org.zkoss.zk.ui.event.Event;
|
||||
import org.zkoss.zk.ui.event.EventListener;
|
||||
import org.zkoss.zk.ui.event.Events;
|
||||
|
@ -45,7 +48,7 @@ import org.zkoss.zk.ui.event.Events;
|
|||
* @author arboleda - globalqss
|
||||
* - Implement ShowHelp option on processes and reports
|
||||
*/
|
||||
public class ProcessModalDialog extends AbstractProcessDialog implements EventListener<Event>, DialogEvents
|
||||
public class ProcessModalDialog extends AbstractProcessDialog implements EventListener<Event>, DialogEvents, ITabOnCloseHandler
|
||||
{
|
||||
/**
|
||||
* generated serial id
|
||||
|
@ -66,6 +69,10 @@ public class ProcessModalDialog extends AbstractProcessDialog implements EventLi
|
|||
*/
|
||||
private String orientation;
|
||||
|
||||
private ITabOnCloseHandler originalOnCloseHandler;
|
||||
|
||||
private Tabpanel parentTabPanel;
|
||||
|
||||
/**
|
||||
* @param WindowNo
|
||||
* @param pi
|
||||
|
@ -268,7 +275,11 @@ public class ProcessModalDialog extends AbstractProcessDialog implements EventLi
|
|||
|
||||
@Override
|
||||
public void updateUI() {
|
||||
|
||||
if (parentTabPanel != null) {
|
||||
parentTabPanel.setOnCloseHandler(originalOnCloseHandler);
|
||||
originalOnCloseHandler = null;
|
||||
parentTabPanel = null;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -276,6 +287,32 @@ public class ProcessModalDialog extends AbstractProcessDialog implements EventLi
|
|||
closeBusyDialog();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPageAttached(Page newpage, Page oldpage) {
|
||||
super.onPageAttached(newpage, oldpage);
|
||||
Component parent = this.getParent();
|
||||
while (parent != null) {
|
||||
if (parent instanceof Tabpanel) {
|
||||
parentTabPanel = (Tabpanel) parent;
|
||||
originalOnCloseHandler = parentTabPanel.getOnCloseHandler();
|
||||
parentTabPanel.setOnCloseHandler(this);
|
||||
break;
|
||||
}
|
||||
parent = parent.getParent();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void onPageDetached(Page page) {
|
||||
super.onPageDetached(page);
|
||||
if (parentTabPanel != null && isCancel()) {
|
||||
parentTabPanel.setOnCloseHandler(originalOnCloseHandler);
|
||||
originalOnCloseHandler = null;
|
||||
parentTabPanel = null;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* handle events
|
||||
*/
|
||||
|
@ -343,4 +380,10 @@ public class ProcessModalDialog extends AbstractProcessDialog implements EventLi
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClose(Tabpanel tabPanel) {
|
||||
return;
|
||||
}
|
||||
|
||||
} // ProcessModalDialog
|
||||
|
|
|
@ -115,6 +115,13 @@ public class Tabpanel extends org.zkoss.zul.Tabpanel implements IdSpace, ISuppor
|
|||
this.onCloseHandler = handler;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return {@link ITabOnCloseHandler}
|
||||
*/
|
||||
public ITabOnCloseHandler getOnCloseHandler() {
|
||||
return onCloseHandler;
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
|
|
|
@ -62,7 +62,6 @@ import org.adempiere.webui.event.DrillEvent;
|
|||
import org.adempiere.webui.event.DrillEvent.DrillData;
|
||||
import org.adempiere.webui.event.ZoomEvent;
|
||||
import org.adempiere.webui.panel.ADForm;
|
||||
import org.adempiere.webui.panel.ITabOnCloseHandler;
|
||||
import org.adempiere.webui.panel.StatusBarPanel;
|
||||
import org.adempiere.webui.report.HTMLExtension;
|
||||
import org.adempiere.webui.session.SessionManager;
|
||||
|
@ -125,7 +124,6 @@ import org.zkoss.zul.North;
|
|||
import org.zkoss.zul.Popup;
|
||||
import org.zkoss.zul.Separator;
|
||||
import org.zkoss.zul.South;
|
||||
import org.zkoss.zul.Tab;
|
||||
import org.zkoss.zul.Toolbar;
|
||||
import org.zkoss.zul.Toolbarbutton;
|
||||
import org.zkoss.zul.Vlayout;
|
||||
|
@ -149,7 +147,7 @@ import org.zkoss.zul.impl.XulElement;
|
|||
*
|
||||
* @author Low Heng Sin
|
||||
*/
|
||||
public class ZkReportViewer extends Window implements EventListener<Event>, ITabOnCloseHandler, IReportViewerExportSource {
|
||||
public class ZkReportViewer extends Window implements EventListener<Event>, IReportViewerExportSource {
|
||||
|
||||
/**
|
||||
* generated serial id
|
||||
|
@ -425,6 +423,7 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
try {
|
||||
SessionManager.getSessionApplication().getKeylistener().removeEventListener(Events.ON_CTRL_KEY, this);
|
||||
} catch (Exception e) {}
|
||||
cleanUp();
|
||||
}
|
||||
|
||||
private void init() {
|
||||
|
@ -841,6 +840,21 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
init = true;
|
||||
|
||||
Events.echoEvent("onPostInit", this, null);
|
||||
|
||||
setTabOnCloseHandler();
|
||||
}
|
||||
|
||||
private void setTabOnCloseHandler() {
|
||||
Component parent = this.getParent();
|
||||
while (parent != null) {
|
||||
if (parent instanceof Tabpanel) {
|
||||
Tabpanel parentTabPanel = (Tabpanel) parent;
|
||||
parentTabPanel.setOnCloseHandler(t -> {
|
||||
});
|
||||
break;
|
||||
}
|
||||
parent = parent.getParent();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1112,25 +1126,6 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
super.onClose();
|
||||
} // dispose
|
||||
|
||||
@Override
|
||||
public void onClose(Tabpanel tabPanel) {
|
||||
Tab tab = tabPanel.getLinkedTab();
|
||||
tab.close();
|
||||
cleanUp();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void setParent(Component parent) {
|
||||
super.setParent(parent);
|
||||
if (parent != null) {
|
||||
if (parent instanceof Tabpanel) {
|
||||
Tabpanel tabPanel = (Tabpanel) parent;
|
||||
tabPanel.setOnCloseHandler(this);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void cleanUp() {
|
||||
if (m_reportEngine != null || m_WindowNo >= 0)
|
||||
{
|
||||
|
@ -1174,7 +1169,15 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
else if (event.getTarget() instanceof ProcessModalDialog)
|
||||
{
|
||||
if(DialogEvents.ON_WINDOW_CLOSE.equals(event.getName()))
|
||||
{
|
||||
hideBusyMask();
|
||||
ProcessModalDialog dialog = (ProcessModalDialog) event.getTarget();
|
||||
if (dialog.isCancel())
|
||||
{
|
||||
if (getDesktop() != null)
|
||||
clearTabOnCloseHandler();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1522,6 +1525,7 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
return;
|
||||
ProcessInfo pi = new ProcessInfo("RefreshWithParameters", AD_Process_ID);
|
||||
pi.setReplaceTabContent();
|
||||
setTabOnCloseHandler();
|
||||
ProcessModalDialog processModalDialog = new ProcessModalDialog(this, m_WindowNo, pi);
|
||||
ZKUpdateUtil.setWindowWidthX(processModalDialog, 850);
|
||||
this.getParent().appendChild(processModalDialog);
|
||||
|
@ -1785,7 +1789,7 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
if (mask != null && mask.getParent() != null) {
|
||||
mask.detach();
|
||||
StringBuilder script = new StringBuilder("(function(){let w=zk.Widget.$('#");
|
||||
script.append(getParent().getUuid()).append("');w.busy=false;");
|
||||
script.append(getParent().getUuid()).append("');if(w){w.busy=false;}");
|
||||
script.append("})()");
|
||||
Clients.response(new AuScript(script.toString()));
|
||||
}
|
||||
|
@ -1797,6 +1801,23 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
|||
progressWindow.dispose();
|
||||
progressWindow = null;
|
||||
}
|
||||
|
||||
if (getDesktop() != null)
|
||||
clearTabOnCloseHandler();
|
||||
}
|
||||
|
||||
private void clearTabOnCloseHandler() {
|
||||
Executions.schedule(getDesktop(), e -> {
|
||||
Component parent = this.getParent();
|
||||
while (parent != null) {
|
||||
if (parent instanceof Tabpanel) {
|
||||
Tabpanel parentTabPanel = (Tabpanel) parent;
|
||||
parentTabPanel.setOnCloseHandler(null);
|
||||
break;
|
||||
}
|
||||
parent = parent.getParent();
|
||||
}
|
||||
}, new Event("onClearTabOnCloseHandler"));
|
||||
}
|
||||
|
||||
static class PDFRendererRunnable extends ZkContextRunnable implements IServerPushCallback {
|
||||
|
|
Loading…
Reference in New Issue