From 07d342ec1de3f67a5898dd3f2859014b1fd2dda3 Mon Sep 17 00:00:00 2001 From: Heng Sin Low Date: Tue, 27 Jul 2010 12:05:42 +0800 Subject: [PATCH] added support to allow re-run of process and report. --- .../adempiere/webui/apps/ProcessDialog.java | 43 +- .../webui/apps/ProcessParameterPanel.java | 828 +++++++++--------- 2 files changed, 441 insertions(+), 430 deletions(-) diff --git a/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessDialog.java b/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessDialog.java index a1645fca07..dcf9663c7c 100644 --- a/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessDialog.java +++ b/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessDialog.java @@ -173,7 +173,6 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce private int m_AD_Process_ID; private String m_Name = null; - private boolean m_IsReport = false; private int[] m_ids = null; private StringBuffer m_messageText = new StringBuffer(); private String m_ShowHelp = null; // Determine if a Help Process Window is shown @@ -191,6 +190,7 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce private ProcessInfo m_pi = null; private boolean m_isLocked = false; + private boolean isParameterPage = true; private String initialMessage; private BusyDialog progressWindow; @@ -244,7 +244,6 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce if (rs.next()) { m_Name = rs.getString(1); - m_IsReport = rs.getString(4).equals("Y"); m_ShowHelp = rs.getString(5); // m_messageText.append(""); @@ -321,10 +320,10 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce if (component instanceof Button) { Button element = (Button)component; if ("Ok".equalsIgnoreCase(element.getId())) { - if (element.getLabel().length() > 0) + if (isParameterPage) this.startProcess(); else - this.dispose(); + restart(); } else if ("Cancel".equalsIgnoreCase(element.getId())) { this.dispose(); } @@ -369,7 +368,10 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce m_messageText.append(pi.getLogInfo(true)); message.setContent(m_messageText.toString()); - bOK.setLabel(""); + bOK.setLabel(Msg.getMsg(Env.getCtx(), "Parameter")); + bOK.setImage("/images/Reset16.png"); + isParameterPage = false; + m_ids = pi.getIDs(); //move message div to center to give more space to display potentially very long log info @@ -383,15 +385,38 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce Clients.response(new AuEcho(this, "onAfterProcess", null)); } + private void restart() { + m_messageText = new StringBuffer(initialMessage); + message.setContent(initialMessage); + + north.setVisible(true); + messageDiv.detach(); + messageDiv.setStyle(MESSAGE_DIV_STYLE); + north.appendChild(messageDiv); + + center.appendChild(centerPanel); + + isParameterPage = true; + + bOK.setLabel(Msg.getMsg(Env.getCtx(), "Start")); + bOK.setImage("/images/Ok16.png"); + + //recreate process info + m_pi = new WProcessInfo(m_Name, m_AD_Process_ID); + m_pi.setAD_User_ID (Env.getAD_User_ID(Env.getCtx())); + m_pi.setAD_Client_ID(Env.getAD_Client_ID(Env.getCtx())); + parameterPanel.setProcessInfo(m_pi); + + m_ids = null; + + invalidate(); + } + public void onAfterProcess() { // afterProcessTask(); - // Close automatically - if (m_IsReport && !m_pi.isError()) - this.dispose(); - // If the process is a silent one and no errors occured, close the dialog if(m_ShowHelp != null && m_ShowHelp.equals("S")) this.dispose(); diff --git a/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessParameterPanel.java b/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessParameterPanel.java index b7e09ccbc9..e5227ec775 100644 --- a/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessParameterPanel.java +++ b/zkwebui/WEB-INF/src/org/adempiere/webui/apps/ProcessParameterPanel.java @@ -14,8 +14,6 @@ package org.adempiere.webui.apps; - - import java.math.BigDecimal; import java.sql.PreparedStatement; import java.sql.ResultSet; @@ -51,108 +49,112 @@ import org.zkoss.zul.Hbox; import org.zkoss.zul.Label; /** - * Process Parameter Panel, based on existing ProcessParameter dialog. - * - Embedded in ProcessDialog - * - checks, if parameters exist and inquires and saves them - * - * @author Low Heng Sin - * @version 2006-12-01 + * Process Parameter Panel, based on existing ProcessParameter dialog. - + * Embedded in ProcessDialog - checks, if parameters exist and inquires and + * saves them + * + * @author Low Heng Sin + * @version 2006-12-01 */ @SuppressWarnings("serial") -public class ProcessParameterPanel extends Panel -implements ValueChangeListener, IProcessParameter -{ - private String width; +public class ProcessParameterPanel extends Panel implements + ValueChangeListener, IProcessParameter { + private String width; - /** - * Dynamic generated Parameter panel. - * @param WindowNo window - * @param pi process info - */ - public ProcessParameterPanel(int WindowNo, ProcessInfo pi) - { - this(WindowNo, pi, "100%"); - } // ProcessParameterPanel - - /** - * Dynamic generated Parameter panel. - * @param WindowNo window - * @param pi process info - */ - public ProcessParameterPanel(int WindowNo, ProcessInfo pi, String width) - { - // - m_WindowNo = WindowNo; - m_processInfo = pi; - this.width = width; - // - initComponent(); - } // ProcessParameterPanel + /** + * Dynamic generated Parameter panel. + * + * @param WindowNo + * window + * @param pi + * process info + */ + public ProcessParameterPanel(int WindowNo, ProcessInfo pi) { + this(WindowNo, pi, "100%"); + } // ProcessParameterPanel - private void initComponent() { - centerPanel = GridFactory.newGridLayout(); - centerPanel.setInnerWidth(width); - this.appendChild(centerPanel); - - //setup columns - Columns columns = new Columns(); - centerPanel.appendChild(columns); - Column col = new Column(); - col.setWidth("30%"); - columns.appendChild(col); - col = new Column(); - col.setWidth("65%"); - columns.appendChild(col); - col = new Column(); - col.setWidth("5%"); - columns.appendChild(col); - } - - private int m_WindowNo; - private ProcessInfo m_processInfo; - /** Logger */ - private static CLogger log = CLogger.getCLogger(ProcessParameterPanel.class); - + /** + * Dynamic generated Parameter panel. + * + * @param WindowNo + * window + * @param pi + * process info + */ + public ProcessParameterPanel(int WindowNo, ProcessInfo pi, String width) { // - private ArrayList m_wEditors = new ArrayList(); - private ArrayList m_wEditors2 = new ArrayList(); // for ranges - private ArrayList m_mFields = new ArrayList(); - private ArrayList m_mFields2 = new ArrayList(); - private ArrayList