From faef3f0217c6b15630b308d1c163f99976f3d35b Mon Sep 17 00:00:00 2001 From: Heng Sin Low Date: Fri, 10 Oct 2008 07:57:31 +0000 Subject: [PATCH] * Bug: save error prompt twice * Fixed custom messagebox compatibility with 3.5.1 --- .../src/org/adempiere/webui/apps/AEnv.java | 28 +++++++++++++++++++ .../adempiere/webui/component/Messagebox.java | 10 +++---- .../webui/panel/AbstractADWindowPanel.java | 3 +- .../org/adempiere/webui/window/FDialog.java | 7 +++-- 4 files changed, 39 insertions(+), 9 deletions(-) diff --git a/zkwebui/WEB-INF/src/org/adempiere/webui/apps/AEnv.java b/zkwebui/WEB-INF/src/org/adempiere/webui/apps/AEnv.java index 33c21e2175..42873f958d 100644 --- a/zkwebui/WEB-INF/src/org/adempiere/webui/apps/AEnv.java +++ b/zkwebui/WEB-INF/src/org/adempiere/webui/apps/AEnv.java @@ -31,6 +31,7 @@ import java.sql.ResultSet; import java.sql.SQLException; import java.util.Enumeration; import java.util.List; +import java.util.Properties; import java.util.logging.Level; import javax.servlet.ServletRequest; @@ -783,4 +784,31 @@ public final class AEnv } document.close(); } + + /** + * Get window title + * @param ctx context + * @param WindowNo window + * @return Header String + */ + public static String getWindowHeader(Properties ctx, int WindowNo) + { + StringBuffer sb = new StringBuffer(); + if (WindowNo > 0){ + sb.append(Env.getContext(ctx, WindowNo, "WindowName", false)).append(" "); + final String documentNo = Env.getContext(ctx, WindowNo, "DocumentNo", false); + final String value = Env.getContext(ctx, WindowNo, "Value", false); + final String name = Env.getContext(ctx, WindowNo, "Name", false); + if(!"".equals(documentNo)) { + sb.append(documentNo).append(" "); + } + if(!"".equals(value)) { + sb.append(value).append(" "); + } + if(!"".equals(name)) { + sb.append(name).append(" "); + } + } + return sb.toString(); + } // getHeader } // AEnv diff --git a/zkwebui/WEB-INF/src/org/adempiere/webui/component/Messagebox.java b/zkwebui/WEB-INF/src/org/adempiere/webui/component/Messagebox.java index 7c25b23571..f1d0e77a75 100644 --- a/zkwebui/WEB-INF/src/org/adempiere/webui/component/Messagebox.java +++ b/zkwebui/WEB-INF/src/org/adempiere/webui/component/Messagebox.java @@ -78,16 +78,16 @@ public class Messagebox extends Window implements EventListener public static final int IGNORE = 0x0400; /** A symbol consisting of a question mark in a circle. */ - public static final String QUESTION = "~./zul/img/question.gif"; + public static final String QUESTION = "~./zul/img/msgbox/question.gif"; /** A symbol consisting of an exclamation point in a triangle with a yellow background. */ - public static final String EXCLAMATION = "~./zul/img/exclamation.gif"; + public static final String EXCLAMATION = "~./zul/img/msgbox/exclamation.gif"; /** A symbol of a lowercase letter i in a circle. */ - public static final String INFORMATION = "~./zul/img/information.gif"; + public static final String INFORMATION = "~./zul/img/msgbox/information.gif"; /** A symbol consisting of a white X in a circle with a red background. */ - public static final String ERROR = "~./zul/img/error.gif"; + public static final String ERROR = "~./zul/img/msgbox/error.gif"; /** Contains no symbols. */ public static final String NONE = null; @@ -169,7 +169,7 @@ public class Messagebox extends Window implements EventListener this.setWidth("100%"); this.setBorder("normal"); - this.setContentStyle("background-color:#c0d1d2"); + this.setContentStyle("background-color:#ffffff"); this.setPosition("left, top"); Separator blank = new Separator(); diff --git a/zkwebui/WEB-INF/src/org/adempiere/webui/panel/AbstractADWindowPanel.java b/zkwebui/WEB-INF/src/org/adempiere/webui/panel/AbstractADWindowPanel.java index b473c09c84..647e105854 100644 --- a/zkwebui/WEB-INF/src/org/adempiere/webui/panel/AbstractADWindowPanel.java +++ b/zkwebui/WEB-INF/src/org/adempiere/webui/panel/AbstractADWindowPanel.java @@ -926,7 +926,8 @@ public abstract class AbstractADWindowPanel extends AbstractUIPart implements To if (!retValue) { - FDialog.error(curWindowNo, parent, "SaveIgnored"); + //actual error will prompt in the dataStatusChanged event +// FDialog.error(curWindowNo, parent, "SaveIgnored"); statusBar.setStatusLine(Msg.getMsg(Env.getCtx(), "SaveIgnored"), true); } curTabpanel.dynamicDisplay(0); diff --git a/zkwebui/WEB-INF/src/org/adempiere/webui/window/FDialog.java b/zkwebui/WEB-INF/src/org/adempiere/webui/window/FDialog.java index 0bd111d741..61a320a2a1 100644 --- a/zkwebui/WEB-INF/src/org/adempiere/webui/window/FDialog.java +++ b/zkwebui/WEB-INF/src/org/adempiere/webui/window/FDialog.java @@ -26,6 +26,7 @@ import org.compiere.util.Msg; import org.compiere.util.Trace; import org.zkoss.zk.ui.Component; +import org.adempiere.webui.apps.AEnv; import org.adempiere.webui.component.Messagebox; /** @@ -132,7 +133,7 @@ public class FDialog if (title == null) { - newTitle = windowNo > 0 ? Env.getHeader(ctx, windowNo) : null; + newTitle = windowNo > 0 ? AEnv.getWindowHeader(ctx, windowNo) : null; } else { @@ -241,7 +242,7 @@ public class FDialog try { String s = out.toString().replace("\n", "
"); - Messagebox.showDialog(s, (windowNo > 0 ? Env.getHeader(ctx, windowNo) : null), Messagebox.OK, Messagebox.ERROR); + Messagebox.showDialog(s, (windowNo > 0 ? AEnv.getWindowHeader(ctx, windowNo) : null), Messagebox.OK, Messagebox.ERROR); } catch (InterruptedException exception) { @@ -348,7 +349,7 @@ public class FDialog try { String s = out.toString().replace("\n", "
"); - Messagebox.showDialog(s, Env.getHeader(ctx, windowNo), Messagebox.OK, Messagebox.INFORMATION); + Messagebox.showDialog(s, AEnv.getWindowHeader(ctx, windowNo), Messagebox.OK, Messagebox.INFORMATION); } catch (InterruptedException exception) {