Merge revision 6246 from branches/adempiere341

This commit is contained in:
Heng Sin Low 2008-08-27 22:41:42 +00:00
parent 34c5801c80
commit fc34e54d53
43 changed files with 3053 additions and 3010 deletions

View File

@ -734,10 +734,7 @@ public class Desktop extends AbstractUIPart implements MenuListener, Serializabl
pd.setPage(page); pd.setPage(page);
pd.setClosable(true); pd.setClosable(true);
pd.setWidth("500px"); pd.setWidth("500px");
try { pd.doHighlighted();
pd.doModal();
} catch (InterruptedException e) {
}
} }
} }
else if(menu.getAction().equals(MMenu.ACTION_Form)) else if(menu.getAction().equals(MMenu.ACTION_Form))

View File

@ -12,6 +12,7 @@
*****************************************************************************/ *****************************************************************************/
package org.adempiere.webui; package org.adempiere.webui;
import java.io.Serializable;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import org.adempiere.webui.session.ServerContext; import org.adempiere.webui.session.ServerContext;
@ -23,7 +24,7 @@ import net.sf.cglib.proxy.InvocationHandler;
* @author Low Heng Sin * @author Low Heng Sin
* *
*/ */
public class ServerContextCallback implements InvocationHandler { public class ServerContextCallback implements InvocationHandler, Serializable {
public Object invoke(Object proxy, Method method, Object[] args) public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable { throws Throwable {

View File

@ -28,6 +28,9 @@ import java.sql.SQLException;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.logging.Level; import java.util.logging.Level;
import javax.servlet.ServletRequest;
import javax.servlet.http.HttpServletRequest;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.session.SessionManager; import org.adempiere.webui.session.SessionManager;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
@ -44,6 +47,9 @@ import org.compiere.util.CLogger;
import org.compiere.util.DB; import org.compiere.util.DB;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Ini; import org.compiere.util.Ini;
import org.zkoss.web.servlet.Servlets;
import org.zkoss.zk.ui.Execution;
import org.zkoss.zk.ui.Executions;
/** /**
* Windows Application Environment and utilities * Windows Application Environment and utilities
@ -691,4 +697,22 @@ public final class AEnv
} }
return uri; return uri;
} // getImageIcon } // getImageIcon
/**
*
* @return boolean
*/
public static boolean isFirefox2() {
Execution execution = Executions.getCurrent();
if (execution == null)
return false;
Object n = execution.getNativeRequest();
if (n instanceof ServletRequest) {
String userAgent = Servlets.getUserAgent((ServletRequest) n);
return userAgent.indexOf("Firefox/2") >= 0;
} else {
return false;
}
}
} // AEnv } // AEnv

View File

@ -1,8 +1,13 @@
package org.adempiere.webui.apps; package org.adempiere.webui.apps;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties; import java.util.Properties;
import java.util.logging.Level; import java.util.logging.Level;
@ -11,13 +16,17 @@ import org.adempiere.webui.component.Panel;
import org.adempiere.webui.component.VerticalBox; import org.adempiere.webui.component.VerticalBox;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.session.SessionManager; import org.adempiere.webui.session.SessionManager;
import org.adempiere.webui.window.FDialog;
import org.adempiere.webui.window.SimplePDFViewer;
import org.compiere.apps.ProcessCtl; import org.compiere.apps.ProcessCtl;
import org.compiere.print.ReportEngine;
import org.compiere.process.ProcessInfo; import org.compiere.process.ProcessInfo;
import org.compiere.process.ProcessInfoUtil; import org.compiere.process.ProcessInfoUtil;
import org.compiere.util.CLogger; import org.compiere.util.CLogger;
import org.compiere.util.DB; import org.compiere.util.DB;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Msg; import org.compiere.util.Msg;
import org.zkoss.zk.au.out.AuEcho;
import org.zkoss.zk.ui.Component; import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.DesktopUnavailableException; import org.zkoss.zk.ui.DesktopUnavailableException;
import org.zkoss.zk.ui.Executions; import org.zkoss.zk.ui.Executions;
@ -29,6 +38,13 @@ import org.zkoss.zul.Div;
import org.zkoss.zul.Hbox; import org.zkoss.zul.Hbox;
import org.zkoss.zul.Html; import org.zkoss.zul.Html;
import com.lowagie.text.Document;
import com.lowagie.text.pdf.PdfContentByte;
import com.lowagie.text.pdf.PdfCopy;
import com.lowagie.text.pdf.PdfImportedPage;
import com.lowagie.text.pdf.PdfReader;
import com.lowagie.text.pdf.PdfWriter;
/****************************************************************************** /******************************************************************************
* Product: Adempiere ERP & CRM Smart Business Solution * * Product: Adempiere ERP & CRM Smart Business Solution *
* Copyright (C) 2007 Low Heng Sin * * Copyright (C) 2007 Low Heng Sin *
@ -334,8 +350,8 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce
m_isLocked = false; m_isLocked = false;
if (Executions.getCurrent() != null) if (Executions.getCurrent() != null)
{ {
updateUI(pi);
Clients.showBusy(null, false); Clients.showBusy(null, false);
updateUI(pi);
} }
else else
{ {
@ -366,17 +382,20 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce
message.setContent(m_messageText.toString()); message.setContent(m_messageText.toString());
//message.setCaretPosition(message.getDocument().getLength()); // scroll down //message.setCaretPosition(message.getDocument().getLength()); // scroll down
m_ids = pi.getIDs(); m_ids = pi.getIDs();
//
bOK.setEnabled(true);
//no longer needed, hide to give more space to display log //no longer needed, hide to give more space to display log
centerPanel.detach(); centerPanel.detach();
invalidate(); invalidate();
Clients.response(new AuEcho(this, "onAfterProcess", null));
}
public void onAfterProcess()
{
// //
afterProcessTask(); afterProcessTask();
// Close automatically // Close automatically
if (m_IsReport && !pi.isError()) if (m_IsReport && !m_pi.isError())
this.dispose(); this.dispose();
// If the process is a silent one and no errors occured, close the dialog // If the process is a silent one and no errors occured, close the dialog
@ -407,62 +426,138 @@ public class ProcessDialog extends Window implements EventListener//, ASyncProce
*/ */
private void printShipments() private void printShipments()
{ {
/*
if (m_ids == null) if (m_ids == null)
return; return;
if (!ADialog.ask(m_WindowNo, this, "PrintShipments")) if (!FDialog.ask(m_WindowNo, this, "PrintShipments"))
return; return;
m_messageText.append("<p>").append(Msg.getMsg(Env.getCtx(), "PrintShipments")).append("</p>"); m_messageText.append("<p>").append(Msg.getMsg(Env.getCtx(), "PrintShipments")).append("</p>");
message.setText(m_messageText.toString()); message.setContent(m_messageText.toString());
int retValue = ADialogDialog.A_CANCEL; Clients.showBusy("Processing...", true);
do Clients.response(new AuEcho(this, "onPrintShipments", null));
} // printInvoices
public void onPrintShipments()
{ {
// Loop through all items // Loop through all items
List<File> pdfList = new ArrayList<File>();
for (int i = 0; i < m_ids.length; i++) for (int i = 0; i < m_ids.length; i++)
{ {
int M_InOut_ID = m_ids[i]; int M_InOut_ID = m_ids[i];
ReportCtl.startDocumentPrint(ReportEngine.SHIPMENT, M_InOut_ID, this, Env.getWindowNo(this), true); ReportEngine re = ReportEngine.get (Env.getCtx(), ReportEngine.SHIPMENT, M_InOut_ID);
pdfList.add(re.getPDF());
}
if (pdfList.size() > 1) {
try {
File outFile = File.createTempFile("PrintShipments", ".pdf");
Document document = null;
PdfWriter copy = null;
for (File f : pdfList)
{
String fileName = f.getAbsolutePath();
PdfReader reader = new PdfReader(fileName);
reader.consolidateNamedDestinations();
if (document == null)
{
document = new Document(reader.getPageSizeWithRotation(1));
copy = PdfWriter.getInstance(document, new FileOutputStream(outFile));
document.open();
}
int pages = reader.getNumberOfPages();
PdfContentByte cb = copy.getDirectContent();
for (int i = 1; i <= pages; i++) {
document.newPage();
PdfImportedPage page = copy.getImportedPage(reader, i);
cb.addTemplate(page, 0, 0);
}
}
document.close();
Clients.showBusy(null, false);
Window win = new SimplePDFViewer(this.getTitle(), new FileInputStream(outFile));
SessionManager.getAppDesktop().showWindow(win, "center");
} catch (Exception e) {
log.log(Level.SEVERE, e.getLocalizedMessage(), e);
}
} else if (pdfList.size() > 0) {
Clients.showBusy(null, false);
try {
Window win = new SimplePDFViewer(this.getTitle(), new FileInputStream(pdfList.get(0)));
SessionManager.getAppDesktop().showWindow(win, "center");
} catch (Exception e)
{
log.log(Level.SEVERE, e.getLocalizedMessage(), e);
}
} }
ADialogDialog d = new ADialogDialog (this,
Env.getHeader(Env.getCtx(), m_WindowNo),
Msg.getMsg(Env.getCtx(), "PrintoutOK?"),
JOptionPane.QUESTION_MESSAGE);
retValue = d.getReturnCode();
} }
while (retValue == ADialogDialog.A_CANCEL);
*/
} // printInvoices
/** /**
* Print Invoices * Print Invoices
*/ */
private void printInvoices() private void printInvoices()
{ {
/*
if (m_ids == null) if (m_ids == null)
return; return;
if (!ADialog.ask(m_WindowNo, this, "PrintInvoices")) if (!FDialog.ask(m_WindowNo, this, "PrintInvoices"))
return; return;
m_messageText.append("<p>").append(Msg.getMsg(Env.getCtx(), "PrintInvoices")).append("</p>"); m_messageText.append("<p>").append(Msg.getMsg(Env.getCtx(), "PrintInvoices")).append("</p>");
message.setText(m_messageText.toString()); message.setContent(m_messageText.toString());
int retValue = ADialogDialog.A_CANCEL; Clients.showBusy("Processing...", true);
do Clients.response(new AuEcho(this, "onPrintInvoices", null));
} // printInvoices
public void onPrintInvoices()
{ {
// Loop through all items // Loop through all items
List<File> pdfList = new ArrayList<File>();
for (int i = 0; i < m_ids.length; i++) for (int i = 0; i < m_ids.length; i++)
{ {
int AD_Invoice_ID = m_ids[i]; int C_Invoice_ID = m_ids[i];
ReportCtl.startDocumentPrint(ReportEngine.INVOICE, AD_Invoice_ID, this, Env.getWindowNo(this), true); ReportEngine re = ReportEngine.get (Env.getCtx(), ReportEngine.INVOICE, C_Invoice_ID);
pdfList.add(re.getPDF());
}
if (pdfList.size() > 1) {
try {
File outFile = File.createTempFile("PrintInvoices", ".pdf");
Document document = null;
PdfWriter copy = null;
for (File f : pdfList)
{
PdfReader reader = new PdfReader(f.getAbsolutePath());
if (document == null)
{
document = new Document(reader.getPageSizeWithRotation(1));
copy = PdfWriter.getInstance(document, new FileOutputStream(outFile));
document.open();
}
PdfContentByte cb = copy.getDirectContent(); // Holds the PDF
int pages = reader.getNumberOfPages();
for (int i = 1; i <= pages; i++) {
document.newPage();
PdfImportedPage page = copy.getImportedPage(reader, i);
cb.addTemplate(page, 0, 0);
}
}
document.close();
Clients.showBusy(null, false);
Window win = new SimplePDFViewer(this.getTitle(), new FileInputStream(outFile));
SessionManager.getAppDesktop().showWindow(win, "center");
} catch (Exception e) {
log.log(Level.SEVERE, e.getLocalizedMessage(), e);
}
} else if (pdfList.size() > 0) {
try {
Window win = new SimplePDFViewer(this.getTitle(), new FileInputStream(pdfList.get(0)));
SessionManager.getAppDesktop().showWindow(win, "center");
} catch (Exception e)
{
log.log(Level.SEVERE, e.getLocalizedMessage(), e);
}
} }
ADialogDialog d = new ADialogDialog (this,
Env.getHeader(Env.getCtx(), m_WindowNo),
Msg.getMsg(Env.getCtx(), "PrintoutOK?"),
JOptionPane.QUESTION_MESSAGE);
retValue = d.getReturnCode();
} }
while (retValue == ADialogDialog.A_CANCEL);
*/
} // printInvoices
public boolean isValid() { public boolean isValid() {
return valid; return valid;

View File

@ -34,7 +34,6 @@ import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.Textbox; import org.adempiere.webui.component.Textbox;
import org.adempiere.webui.component.WListbox; import org.adempiere.webui.component.WListbox;
import org.adempiere.webui.component.WStatusBar;
import org.adempiere.webui.editor.WDateEditor; import org.adempiere.webui.editor.WDateEditor;
import org.adempiere.webui.editor.WSearchEditor; import org.adempiere.webui.editor.WSearchEditor;
import org.adempiere.webui.editor.WTableDirEditor; import org.adempiere.webui.editor.WTableDirEditor;
@ -43,6 +42,7 @@ import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.event.WTableModelEvent; import org.adempiere.webui.event.WTableModelEvent;
import org.adempiere.webui.event.WTableModelListener; import org.adempiere.webui.event.WTableModelListener;
import org.adempiere.webui.panel.ADForm; import org.adempiere.webui.panel.ADForm;
import org.adempiere.webui.panel.StatusBarPanel;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
import org.compiere.model.*; import org.compiere.model.*;
import org.compiere.process.*; import org.compiere.process.*;
@ -85,7 +85,6 @@ public class WAllocation extends ADForm
calculate(); calculate();
southPanel.appendChild(new Separator()); southPanel.appendChild(new Separator());
southPanel.appendChild(statusBar); southPanel.appendChild(statusBar);
statusBar.setWidth("100%");
} }
catch(Exception e) catch(Exception e)
{ {
@ -140,7 +139,7 @@ public class WAllocation extends ADForm
private WTableDirEditor currencyPick = null; private WTableDirEditor currencyPick = null;
private Checkbox multiCurrency = new Checkbox(); private Checkbox multiCurrency = new Checkbox();
private Label allocCurrencyLabel = new Label(); private Label allocCurrencyLabel = new Label();
private WStatusBar statusBar = new WStatusBar(); private StatusBarPanel statusBar = new StatusBarPanel();
private Label dateLabel = new Label(); private Label dateLabel = new Label();
private WDateEditor dateField = new WDateEditor(); private WDateEditor dateField = new WDateEditor();
private Checkbox autoWriteOff = new Checkbox(); private Checkbox autoWriteOff = new Checkbox();

View File

@ -36,7 +36,6 @@ import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.WAppsAction; import org.adempiere.webui.component.WAppsAction;
import org.adempiere.webui.component.WListbox; import org.adempiere.webui.component.WListbox;
import org.adempiere.webui.component.WStatusBar;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.editor.WEditor; import org.adempiere.webui.editor.WEditor;
import org.adempiere.webui.editor.WLocatorEditor; import org.adempiere.webui.editor.WLocatorEditor;
@ -44,6 +43,7 @@ import org.adempiere.webui.editor.WSearchEditor;
import org.adempiere.webui.editor.WStringEditor; import org.adempiere.webui.editor.WStringEditor;
import org.adempiere.webui.event.WTableModelEvent; import org.adempiere.webui.event.WTableModelEvent;
import org.adempiere.webui.event.WTableModelListener; import org.adempiere.webui.event.WTableModelListener;
import org.adempiere.webui.panel.StatusBarPanel;
import org.compiere.model.*; import org.compiere.model.*;
import org.compiere.util.*; import org.compiere.util.*;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
@ -177,7 +177,7 @@ public abstract class WCreateFrom extends Window
private Panel southPanel = new Panel(); private Panel southPanel = new Panel();
// private Borderlayout southLayout = new Borderlayout(); // private Borderlayout southLayout = new Borderlayout();
private ConfirmPanel confirmPanel = new ConfirmPanel(true); private ConfirmPanel confirmPanel = new ConfirmPanel(true);
private WStatusBar statusBar = new WStatusBar(); private StatusBarPanel statusBar = new StatusBarPanel();
protected WListbox dataTable = ListboxFactory.newDataTable(); protected WListbox dataTable = ListboxFactory.newDataTable();
protected Label locatorLabel = new Label(); protected Label locatorLabel = new Label();
protected WLocatorEditor locatorField = new WLocatorEditor(); protected WLocatorEditor locatorField = new WLocatorEditor();

View File

@ -14,78 +14,55 @@
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA * * ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html * * or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/ *****************************************************************************/
/**
* 2007, Modified by Posterita Ltd.
*/
package org.adempiere.webui.apps.form; package org.adempiere.webui.apps.form;
import java.sql.PreparedStatement; import java.sql.*;
import java.sql.ResultSet; import java.util.logging.*;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.Grid; import org.adempiere.webui.component.Grid;
import org.adempiere.webui.component.GridFactory;
import org.adempiere.webui.component.Label; import org.adempiere.webui.component.Label;
import org.adempiere.webui.component.Panel;
import org.adempiere.webui.component.Row; import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.editor.WEditor; import org.adempiere.webui.editor.WEditor;
import org.adempiere.webui.editor.WSearchEditor; import org.adempiere.webui.editor.WSearchEditor;
import org.adempiere.webui.editor.WTableDirEditor; import org.adempiere.webui.editor.WTableDirEditor;
import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.panel.ADForm; import org.adempiere.webui.panel.ADForm;
import org.adempiere.webui.session.SessionManager; import org.adempiere.webui.session.SessionManager;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
import org.compiere.model.MBPartner; import org.compiere.model.*;
import org.compiere.model.MInvoice; import org.compiere.util.*;
import org.compiere.model.MLookup; import org.zkoss.zk.au.out.AuEcho;
import org.compiere.model.MLookupFactory; import org.zkoss.zk.ui.Desktop;
import org.compiere.model.MPayment; import org.zkoss.zk.ui.DesktopUnavailableException;
import org.compiere.model.X_M_Cost; import org.zkoss.zk.ui.Executions;
import org.compiere.util.CLogger;
import org.compiere.util.DB;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.compiere.util.Trx;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.util.Clients;
import org.zkoss.zkex.zul.Borderlayout;
import org.zkoss.zkex.zul.Center;
import org.zkoss.zkex.zul.South;
/** /**
* Merge Entities : Based on VMerge * Merge Dialog.
* Restriction - fails for Accounting
* *
* @author Niraj Sohun * @author Jorg Janke
* @date Jul 28, 2007 * @version $Id: VMerge.java,v 1.2 2006/07/30 00:51:28 jjanke Exp $
*/ */
public class WMerge extends ADForm
public class WMerge extends ADForm implements EventListener, ValueChangeListener implements EventListener
{ {
private static final long serialVersionUID = 1L; private int m_totalCount = 0;
/** Error Log */
private static CLogger log = CLogger.getCLogger(WInvoiceGen.class); private StringBuffer m_errorLog = new StringBuffer();
/** Connection */
private Grid grdAll; //private Connection m_con = null;
private Rows rows; private Trx m_trx = null;
private Row row; /** Logger */
private static CLogger log = CLogger.getCLogger(WMerge.class);
/** Confirmation panel containing Ok and Cancel button. */
private ConfirmPanel m_pnlConfirm;
private WEditor[] from = new WEditor[4];
private WEditor[] to = new WEditor[4];
private int[] fromIDs = new int[4];
private int[] toIDs = new int[4];
private int[] AD_Column_ID = new int[] {2163, 2762, 971, 2221};
private String[] text = new String[] {"AD_Org_ID", "C_BPartner_ID", "AD_User_ID", "M_Product_ID"};
private int m_totalCount;
private StringBuffer m_errorLog;
private Trx m_trx;
static private String AD_ORG_ID = "AD_Org_ID"; static private String AD_ORG_ID = "AD_Org_ID";
static private String C_BPARTNER_ID = "C_BPartner_ID"; static private String C_BPARTNER_ID = "C_BPartner_ID";
@ -93,192 +70,282 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
static private String M_PRODUCT_ID = "M_Product_ID"; static private String M_PRODUCT_ID = "M_Product_ID";
/** Tables to delete (not update) for AD_Org */ /** Tables to delete (not update) for AD_Org */
static private String[] s_delete_Org = new String[] {"AD_OrgInfo"}; static private String[] s_delete_Org = new String[]
{"AD_OrgInfo"};
/** Tables to delete (not update) for AD_User */ /** Tables to delete (not update) for AD_User */
static private String[] s_delete_User = new String[] {"AD_User_Roles"}; static private String[] s_delete_User = new String[]
{"AD_User_Roles"};
/** Tables to delete (not update) for C_BPartner */ /** Tables to delete (not update) for C_BPartner */
static private String[] s_delete_BPartner = new String[] {"C_BP_Employee_Acct", static private String[] s_delete_BPartner = new String[]
"C_BP_Vendor_Acct", "C_BP_Customer_Acct", "T_Aging"}; {"C_BP_Employee_Acct", "C_BP_Vendor_Acct", "C_BP_Customer_Acct",
"T_Aging"};
/** Tables to delete (not update) for M_Product */ /** Tables to delete (not update) for M_Product */
static private String[] s_delete_Product = new String[] {"M_Product_PO", "M_Replenish", "T_Replenish", static private String[] s_delete_Product = new String[]
{"M_Product_PO", "M_Replenish", "T_Replenish",
"M_ProductPrice", "M_Product_Costing", "M_ProductPrice", "M_Product_Costing",
"M_Cost", // teo_sarca [ 1704554 ] "M_Cost", // teo_sarca [ 1704554 ]
"M_Product_Trl", "M_Product_Acct"}; // M_Storage "M_Product_Trl", "M_Product_Acct"}; // M_Storage
private String[] m_columnName = new String[]{"AD_Org_ID", "C_BPartner_ID", "AD_User_ID", "M_Product_ID"}; private String[] m_columnName = null;
private Label[] m_label = null;
private WEditor[] m_from = null;
private WEditor[] m_to = null;
private String[] m_deleteTables = null; private String[] m_deleteTables = null;
public WMerge()
{
}
private Borderlayout mainLayout = new Borderlayout();
private Panel CenterPanel = new Panel();
private Grid centerLayout = GridFactory.newGridLayout();
private Label mergeFromLabel = new Label();
private Label mergeToLabel = new Label();
private ConfirmPanel confirmPanel = new ConfirmPanel(true);
private String m_msg;
private boolean m_success;
/**
* Initialize Panel
*/
protected void initForm() protected void initForm()
{ {
grdAll = new Grid(); log.info( "VMerge.init - WinNo=" + m_WindowNo);
grdAll.setWidth("700px"); try
{
preInit();
jbInit ();
}
catch (Exception ex)
{
log.log(Level.SEVERE, "", ex);
}
} // init
/*btnCancel = new Button(); /**
btnCancel.setImage("/images/Cancel24.png"); * Pre Init
btnCancel.addEventListener(Events.ON_CLICK, this); */
private void preInit()
{
int count = 4; // ** Update **
m_columnName = new String[count];
m_label = new Label[count];
m_from = new WEditor[count];
m_to = new WEditor[count];
btnOk = new Button(); // ** Update **
btnOk.setImage("/images/Ok24.png"); preInit (0, 2163, DisplayType.TableDir, AD_ORG_ID); // C_Order.AD_Org_ID
btnOk.addEventListener(Events.ON_CLICK, this);*/ preInit (1, 2762, DisplayType.Search, C_BPARTNER_ID); // C_Order.C_BPartner_ID
preInit (2, 971, DisplayType.Search, AD_USER_ID); // AD_User_Roles.AD_User_ID
preInit (3, 2221, DisplayType.Search, M_PRODUCT_ID); // C_OrderLine.M_Product_ID
} // preInit
m_pnlConfirm = new ConfirmPanel(true); /**
m_pnlConfirm.addActionListener(this); * Pre Init Line
* @param index index
initComponents(); * @param AD_Column_ID id
* @param displayType display type
* @param ColumnName column name
*/
private void preInit (int index, int AD_Column_ID, int displayType, String ColumnName)
{
m_columnName[index] = ColumnName;
String what = Msg.translate(Env.getCtx(), ColumnName);
m_label[index] = new Label(what);
Lookup lookup = MLookupFactory.get (Env.getCtx(), m_WindowNo, 0, AD_Column_ID, displayType);
if (displayType == DisplayType.Search)
{
m_from[index] = new WSearchEditor(ColumnName, false, false, true, lookup);
m_to[index] = new WSearchEditor (ColumnName, false, false, true, lookup);
}
else
{
m_from[index] = new WTableDirEditor(ColumnName, false, false, true, lookup);
m_to[index] = new WTableDirEditor (ColumnName, false, false, true, lookup);
} }
public void initComponents() } // preInit
/**
* Static init
* @throws java.lang.Exception
*/
void jbInit () throws Exception
{ {
this.setWidth("710px"); this.appendChild (mainLayout);
this.setBorder("normal"); mainLayout.setHeight("100%");
mainLayout.setWidth("100%");
//
South south = new South();
mainLayout.appendChild(south);
south.appendChild(confirmPanel);
confirmPanel.addActionListener(this);
//
Rows rows = centerLayout.newRows();
components(); //
CenterPanel.appendChild(centerLayout);
rows = new Rows(); Center center = new Center();
mainLayout.appendChild(center);
center.appendChild(CenterPanel);
// Row 1 Row row = rows.newRow();
row = new Row(); row.appendChild(new Label());
row.appendChild(new Label("")); row.appendChild(mergeFromLabel);
row.appendChild(new Label("Merge From (Deleted)")); row.appendChild(mergeToLabel);
row.appendChild(new Label("Merge To (Surviving)")); //
rows.appendChild(row); mergeFromLabel.setText (Msg.getMsg(Env.getCtx(), "MergeFrom"));
mergeFromLabel.setStyle("font-weight: bold");
for (int i = 0; i < 4; i++) mergeToLabel.setText (Msg.getMsg(Env.getCtx(), "MergeTo"));
mergeToLabel.setStyle("font-weight: bold");
//
for (int i = 0; i < m_label.length; i++)
{ {
row = new Row(); row = rows.newRow();
row.appendChild(from[i].getLabel()); row.appendChild(m_label[i]);
row.appendChild(from[i].getComponent()); row.appendChild(m_from[i].getComponent());
row.appendChild(to[i].getComponent()); row.appendChild(m_to[i].getComponent());
rows.appendChild(row);
} }
} // jbInit
grdAll.appendChild(rows); /**
this.appendChild(grdAll); * Dispose
*/
// Row 6 public void dispose()
this.appendChild(m_pnlConfirm);
}
private void components()
{ {
MLookup lookup = MLookupFactory.get(Env.getCtx(), m_WindowNo, SessionManager.getAppDesktop().removeWindow();
0, AD_Column_ID[0], DisplayType.TableDir); } // dispose
from[0] = new WTableDirEditor(lookup, Msg.translate( /**
Env.getCtx(), text[0]), "from", true, false, true); * Action Listener
* @param e event
from[0].addValueChangeListener(this); */
public void onEvent (Event e)
to[0] = new WTableDirEditor(lookup, Msg.translate(
Env.getCtx(), text[0]), "to", true, false, true);
to[0].addValueChangeListener(this);
// Search Editors
for (int i = 1; i < AD_Column_ID.length; i++)
{ {
lookup = MLookupFactory.get(Env.getCtx(), m_WindowNo, if (e.getTarget().getId().equals(ConfirmPanel.A_CANCEL))
0, AD_Column_ID[i], DisplayType.Search);
from[i] = new WSearchEditor(lookup, Msg.translate(
Env.getCtx(), text[i]), "from", true, false, true);
from[i].addValueChangeListener(this);
to[i] = new WSearchEditor(lookup, Msg.translate(
Env.getCtx(), text[i]), "to", true, false, true);
to[i].addValueChangeListener(this);
}
}
public void valueChange(ValueChangeEvent evt)
{
if (evt == null)
{ {
dispose();
return; return;
} }
//
WEditor edit = (WEditor)evt.getSource(); String columnName = null;
String des = edit.getDescription(); String from_Info = null;
String to_Info = null;
String name = evt.getPropertyName(); int from_ID = 0;
Object value = evt.getNewValue(); int to_ID = 0;
// get first merge pair
for (int i = 0; (i < m_columnName.length && from_ID == 0 && to_ID == 0); i++)
if (name.equals("AD_Org_ID"))
{ {
if (des.equals("from")) Object value = m_from[i].getValue();
if (value != null)
{ {
from[0].setValue(value); if (value instanceof Integer)
fromIDs[0] = ((Integer)value).intValue(); from_ID = ((Integer)value).intValue();
else
continue;
value = m_to[i].getValue();
if (value != null && value instanceof Integer)
to_ID = ((Integer)value).intValue();
else
from_ID = 0;
if (from_ID != 0)
{
columnName = m_columnName[i];
from_Info = m_from[i].getDisplay ();
to_Info = m_to[i].getDisplay ();
}
}
} // get first merge pair
if (from_ID == 0 || from_ID == to_ID)
return;
m_msg = Msg.getMsg(Env.getCtx(), "MergeFrom") + " = " + from_Info
+ "\n" + Msg.getMsg(Env.getCtx(), "MergeTo") + " = " + to_Info;
if (!FDialog.ask(m_WindowNo, this, "MergeQuestion", m_msg))
return;
// ** Update **
if (columnName.equals(AD_ORG_ID))
m_deleteTables = s_delete_Org;
else if (columnName.equals(AD_USER_ID))
m_deleteTables = s_delete_User;
else if (columnName.equals(C_BPARTNER_ID))
m_deleteTables = s_delete_BPartner;
else if (columnName.equals(M_PRODUCT_ID))
m_deleteTables = s_delete_Product;
Clients.showBusy("Processing...", true);
if (!getDesktop().isServerPushEnabled())
getDesktop().enableServerPush(true);
MergeRunnable runnable = new MergeRunnable(columnName, from_ID, to_ID, this.getDesktop());
new Thread(runnable).start();
} // actionPerformed
class MergeRunnable implements Runnable {
private int to_ID;
private int from_ID;
private String columnName;
private Desktop desktop;
private MergeRunnable(String columnName, int from_ID, int to_ID, Desktop desktop) {
this.columnName = columnName;
this.from_ID = from_ID;
this.to_ID = to_ID;
this.desktop = desktop;
}
public void run() {
//get full control of desktop
try {
Executions.activate(desktop);
try {
m_success = merge (columnName, from_ID, to_ID);
postMerge(columnName, to_ID);
} finally{
Clients.showBusy(null, false);
Clients.response(new AuEcho(WMerge.this, "onAfterProcess", null));
//release full control of desktop
Executions.deactivate(desktop);
}
} catch (DesktopUnavailableException e) {
log.log(Level.SEVERE, e.getLocalizedMessage(), e);
} catch (InterruptedException e) {
log.log(Level.WARNING, e.getLocalizedMessage(), e);
}
}
}
public void onAfterProcess()
{
if (m_success)
{
FDialog.info (m_WindowNo, this, "MergeSuccess",
m_msg + " #" + m_totalCount);
} }
else else
{ {
to[0].setValue(value); FDialog.error(m_WindowNo, this, "MergeError",
toIDs[0] = ((Integer)value).intValue(); m_errorLog.toString());
return;
} }
dispose();
} }
else if (name.equals("C_BPartner_ID")) /**
{ * Merge.
if (des.equals("from")) * @param ColumnName column
{ * @param from_ID from
from[1].setValue(value); * @param to_ID to
fromIDs[1] = ((Integer)value).intValue(); * @return true if merged
} */
else
{
to[1].setValue(value);
toIDs[1] = ((Integer)value).intValue();
}
}
else if (name.equals("M_Product_ID"))
{
if (des.equals("from"))
{
from[3].setValue(value);
fromIDs[3] = ((Integer)value).intValue();
}
else
{
to[3].setValue(value);
toIDs[3] = ((Integer)value).intValue();
}
}
else if (name.equals("AD_User_ID"))
{
if (des.equals("from"))
{
from[2].setValue(value);
fromIDs[2] = ((Integer)value).intValue();
}
else
{
to[2].setValue(value);
toIDs[2] = ((Integer)value).intValue();
}
}
}
private boolean merge (String ColumnName, int from_ID, int to_ID) private boolean merge (String ColumnName, int from_ID, int to_ID)
{ {
String TableName = ColumnName.substring(0, ColumnName.length()-3); String TableName = ColumnName.substring(0, ColumnName.length()-3);
log.config(ColumnName
//log.config(ColumnName + " - From=" + from_ID + ",To=" + to_ID); + " - From=" + from_ID + ",To=" + to_ID);
boolean success = true; boolean success = true;
m_totalCount = 0; m_totalCount = 0;
m_errorLog = new StringBuffer(); m_errorLog = new StringBuffer();
String sql = "SELECT t.TableName, c.ColumnName " String sql = "SELECT t.TableName, c.ColumnName "
+ "FROM AD_Table t" + "FROM AD_Table t"
+ " INNER JOIN AD_Column c ON (t.AD_Table_ID=c.AD_Table_ID) " + " INNER JOIN AD_Column c ON (t.AD_Table_ID=c.AD_Table_ID) "
@ -293,28 +360,24 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
+ "WHERE cc.IsKey='Y' AND cc.ColumnName=?)" // #2 + "WHERE cc.IsKey='Y' AND cc.ColumnName=?)" // #2
+ ") " + ") "
+ "ORDER BY t.LoadSeq DESC"; + "ORDER BY t.LoadSeq DESC";
PreparedStatement pstmt = null; PreparedStatement pstmt = null;
try try
{ {
m_trx = Trx.get(Trx.createTrxName("merge"), true); m_trx = Trx.get(Trx.createTrxName("merge"), true);
//
pstmt = DB.prepareStatement(sql, Trx.createTrxName()); pstmt = DB.prepareStatement(sql, Trx.createTrxName());
pstmt.setString(1, ColumnName); pstmt.setString(1, ColumnName);
pstmt.setString(2, ColumnName); pstmt.setString(2, ColumnName);
ResultSet rs = pstmt.executeQuery(); ResultSet rs = pstmt.executeQuery();
while (rs.next()) while (rs.next())
{ {
String tName = rs.getString(1); String tName = rs.getString(1);
String cName = rs.getString(2); String cName = rs.getString(2);
if (!TableName.equals(tName)) // to be sure - sql should prevent it if (!TableName.equals(tName)) // to be sure - sql should prevent it
{ {
int count = mergeTable (tName, cName, from_ID, to_ID); int count = mergeTable (tName, cName, from_ID, to_ID);
if (count < 0) if (count < 0)
success = false; success = false;
else else
@ -324,24 +387,28 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
rs.close(); rs.close();
pstmt.close(); pstmt.close();
pstmt = null; pstmt = null;
//
//log.config("Success=" + success + " - " + ColumnName + " - From=" + from_ID + ",To=" + to_ID); log.config("Success=" + success
+ " - " + ColumnName + " - From=" + from_ID + ",To=" + to_ID);
if (success) if (success)
{ {
sql = "DELETE " + TableName + " WHERE " + ColumnName + "=" + from_ID; sql = "DELETE " + TableName + " WHERE " + ColumnName + "=" + from_ID;
if ( DB.executeUpdate(sql, m_trx.getTrxName()) < 0 ) if ( DB.executeUpdate(sql, m_trx.getTrxName()) < 0 )
{ {
m_errorLog.append(Env.NL).append("DELETE ").append(TableName).append(" - "); m_errorLog.append(Env.NL).append("DELETE ").append(TableName)
.append(" - ");
success = false; success = false;
//log.config(m_errorLog.toString()); log.config(m_errorLog.toString());
m_trx.rollback(); m_trx.rollback();
return false; return false;
} }
} }
//
if (success) if (success)
m_trx.commit(); m_trx.commit();
else else
@ -352,22 +419,22 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
} }
catch (Exception ex) catch (Exception ex)
{ {
// log.log(Level.SEVERE, ColumnName, ex); log.log(Level.SEVERE, ColumnName, ex);
} }
// Cleanup // Cleanup
try try
{ {
if (pstmt != null) if (pstmt != null)
pstmt.close(); pstmt.close();
} }
catch (Exception ex) catch (Exception ex)
{ {
} }
pstmt = null; pstmt = null;
return success; return success;
} } // merge
/** /**
* Merge Table * Merge Table
@ -377,17 +444,13 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
* @param to_ID to * @param to_ID to
* @return -1 for error or number of changes * @return -1 for error or number of changes
*/ */
private int mergeTable (String TableName, String ColumnName, int from_ID, int to_ID) private int mergeTable (String TableName, String ColumnName, int from_ID, int to_ID)
{ {
// log.fine(TableName + "." + ColumnName + " - From=" + from_ID + ",To=" + to_ID); log.fine(TableName + "." + ColumnName + " - From=" + from_ID + ",To=" + to_ID);
String sql = "UPDATE " + TableName String sql = "UPDATE " + TableName
+ " SET " + ColumnName + "=" + to_ID + " SET " + ColumnName + "=" + to_ID
+ " WHERE " + ColumnName + "=" + from_ID; + " WHERE " + ColumnName + "=" + from_ID;
boolean delete = false; boolean delete = false;
for (int i = 0; i < m_deleteTables.length; i++) for (int i = 0; i < m_deleteTables.length; i++)
{ {
if (m_deleteTables[i].equals(TableName)) if (m_deleteTables[i].equals(TableName))
@ -396,7 +459,6 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
sql = "DELETE " + TableName + " WHERE " + ColumnName + "=" + from_ID; sql = "DELETE " + TableName + " WHERE " + ColumnName + "=" + from_ID;
} }
} }
// Delete newly created MCost records - teo_sarca [ 1704554 ] // Delete newly created MCost records - teo_sarca [ 1704554 ]
if (delete && X_M_Cost.Table_Name.equals(TableName) && M_PRODUCT_ID.equals(ColumnName)) if (delete && X_M_Cost.Table_Name.equals(TableName) && M_PRODUCT_ID.equals(ColumnName))
{ {
@ -411,23 +473,28 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
if ( count < 0 ) if ( count < 0 )
{ {
count = -1; count = -1;
m_errorLog.append(Env.NL).append(delete ? "DELETE " : "UPDATE ").append(TableName).append(" - ").append(" - ").append(sql); m_errorLog.append(Env.NL)
//log.config(m_errorLog.toString()); .append(delete ? "DELETE " : "UPDATE ")
.append(TableName).append(" - ")
.append(" - ").append(sql);
log.config(m_errorLog.toString());
m_trx.rollback(); m_trx.rollback();
} }
//log.fine(count + (delete ? " -Delete- " : " -Update- ") + TableName); log.fine(count
+ (delete ? " -Delete- " : " -Update- ") + TableName);
return count; return count;
} } // mergeTable
/** /**
* Post Merge * Post Merge
* @param ColumnName column name * @param ColumnName column name
* @param to_ID ID * @param to_ID ID
*/ */
private void postMerge (String ColumnName, int to_ID) private void postMerge (String ColumnName, int to_ID)
{ {
if (ColumnName.equals(AD_ORG_ID)) if (ColumnName.equals(AD_ORG_ID))
@ -466,106 +533,7 @@ public class WMerge extends ADForm implements EventListener, ValueChangeListener
{ {
} }
} } // postMerge
private void process()
{
String columnName = null;
String from_Info = null;
String to_Info = null;
int from_ID = 0;
int to_ID = 0;
for (int i = 0; (i < m_columnName.length && from_ID == 0 && to_ID == 0); i++) } // VMerge
{
Object value;
value = from[i].getValue();
if (value != null)
{
if (value instanceof Integer)
from_ID = ((Integer)value).intValue();
else
continue;
value = to[i].getValue();
if (value != null && value instanceof Integer)
to_ID = ((Integer)value).intValue();
else
from_ID = 0;
if (from_ID != 0)
{
columnName = m_columnName[i];
from_Info = from[i].getDisplay ();
to_Info = to[i].getDisplay ();
}
}
} // get first merge pair
if (from_ID == 0 || from_ID == to_ID)
return;
String msg = Msg.getMsg(Env.getCtx(), "MergeFrom") + " = " + from_Info
+ "\n" + Msg.getMsg(Env.getCtx(), "MergeTo") + " = " + to_Info;
//if (!FDialog.ask(super.m_windowNo, this, msg))
// return;
// ** Update **
if (columnName.equals(AD_ORG_ID))
m_deleteTables = s_delete_Org;
else if (columnName.equals(AD_USER_ID))
m_deleteTables = s_delete_User;
else if (columnName.equals(C_BPARTNER_ID))
m_deleteTables = s_delete_BPartner;
else if (columnName.equals(M_PRODUCT_ID))
m_deleteTables = s_delete_Product;
//setCursor(Cursor.getPredefinedCursor(Cursor.WAIT_CURSOR));
//confirmPanel.getOKButton().setEnabled(false);
boolean success = merge (columnName, from_ID, to_ID);
postMerge(columnName, to_ID);
//confirmPanel.getOKButton().setEnabled(true);
//setCursor(Cursor.getDefaultCursor());
//
if (success)
{
FDialog.info (m_WindowNo, this, msg);
}
else
{
FDialog.error(m_WindowNo, this, "MergeError", m_errorLog.toString());
return;
}
}
/**
* React to Ok and Cancel buttons being triggered.
*
* @param event the event to which to respond
* @throws Exception if an exception occurred
*/
public void onEvent(Event event) throws Exception
{
if (event != null)
{
if (event.getTarget().getId().equals(ConfirmPanel.A_CANCEL))
{
SessionManager.getAppDesktop().removeWindow();
return;
}
else if (event.getTarget().getId().equals(ConfirmPanel.A_OK))
{
process();
}
}
}
}

View File

@ -14,128 +14,94 @@
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA * * ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html * * or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/ *****************************************************************************/
/**
* 2007, Modified by Posterita Ltd.
*/
package org.adempiere.webui.apps.form; package org.adempiere.webui.apps.form;
import java.math.BigDecimal; import java.sql.*;
import java.sql.PreparedStatement; import java.util.*;
import java.sql.ResultSet; import java.util.logging.*;
import java.sql.SQLException;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Properties;
import java.util.logging.Level;
import javax.swing.table.AbstractTableModel;
import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.apps.AEnv; import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.component.Column;
import org.adempiere.webui.component.Columns;
import org.adempiere.webui.component.ConfirmPanel; import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.Datebox;
import org.adempiere.webui.component.Grid; import org.adempiere.webui.component.Grid;
import org.adempiere.webui.component.GridFactory;
import org.adempiere.webui.component.Label; import org.adempiere.webui.component.Label;
import org.adempiere.webui.component.Panel; import org.adempiere.webui.component.Panel;
import org.adempiere.webui.component.Row; import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.VerticalBox; import org.adempiere.webui.editor.WDateEditor;
import org.adempiere.webui.component.WStatusBar;
import org.adempiere.webui.editor.WEditor;
import org.adempiere.webui.editor.WLocatorEditor; import org.adempiere.webui.editor.WLocatorEditor;
import org.adempiere.webui.editor.WSearchEditor; import org.adempiere.webui.editor.WSearchEditor;
import org.adempiere.webui.editor.WTableDirEditor; import org.adempiere.webui.editor.WTableDirEditor;
import org.adempiere.webui.event.ValueChangeEvent; import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener; import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.panel.ADForm; import org.adempiere.webui.panel.ADForm;
import org.compiere.model.GridField; import org.adempiere.webui.panel.ADTabpanel;
import org.compiere.model.GridTab; import org.adempiere.webui.panel.StatusBarPanel;
import org.compiere.model.GridTable; import org.adempiere.webui.session.SessionManager;
import org.compiere.model.GridWindow; import org.compiere.model.*;
import org.compiere.model.GridWindowVO; import org.compiere.util.*;
import org.compiere.model.MLocatorLookup;
import org.compiere.model.MLookup;
import org.compiere.model.MLookupFactory;
import org.compiere.model.MQuery;
import org.compiere.util.CLogger;
import org.compiere.util.DB;
import org.compiere.util.DisplayType;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.compiere.util.NamePair;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events; import org.zkoss.zkex.zul.Borderlayout;
import org.zkoss.zul.Hbox; import org.zkoss.zkex.zul.Center;
import org.zkoss.zkex.zul.North;
import org.zkoss.zkex.zul.South;
import org.zkoss.zul.Separator; import org.zkoss.zul.Separator;
public class WTrxMaterial extends ADForm implements EventListener, ValueChangeListener /**
* Material Transaction History
*
* @author Jorg Janke
* @version $Id: VTrxMaterial.java,v 1.3 2006/07/30 00:51:28 jjanke Exp $
*/
public class WTrxMaterial extends ADForm
implements EventListener, ValueChangeListener
{ {
private static final long serialVersionUID = 1L;
/** FormFrame */
//private FormFrame m_frame;
/** GridController */ /** GridController */
private Grid m_gridController = new Grid(); private ADTabpanel m_gridController = null;
private Columns columns = new Columns();
private Rows rows = new Rows();
/** MWindow */ /** MWindow */
private GridWindow m_mWindow = null; private GridWindow m_mWindow = null;
/** MTab pointer */ /** MTab pointer */
private GridTab m_mTab = null; private GridTab m_mTab = null;
private MQuery m_staticQuery = null; private MQuery m_staticQuery = null;
/** Logger */ /** Logger */
private static CLogger log = CLogger.getCLogger(WTrxMaterial.class); private static CLogger log = CLogger.getCLogger(WTrxMaterial.class);
//
private VerticalBox mainPanel = new VerticalBox(); private Panel mainPanel = new Panel();
private Hbox parameterPanel = new Hbox(); private Borderlayout mainLayout = new Borderlayout();
private Panel parameterPanel = new Panel();
private Label orgLabel = new Label(); private Label orgLabel = new Label();
private WEditor orgField; private WTableDirEditor orgField;
private Label locatorLabel = new Label(); private Label locatorLabel = new Label();
private WLocatorEditor locatorField; private WLocatorEditor locatorField;
private Label productLabel = new Label(); private Label productLabel = new Label();
private WEditor productField; private WSearchEditor productField;
private Label dateFLabel = new Label(); private Label dateFLabel = new Label();
private Datebox dateFField; private WDateEditor dateFField;
private Label dateTLabel = new Label(); private Label dateTLabel = new Label();
private Datebox dateTField; private WDateEditor dateTField;
private Label mtypeLabel = new Label(); private Label mtypeLabel = new Label();
private WEditor mtypeField; private WTableDirEditor mtypeField;
private Grid parameterLayout = GridFactory.newGridLayout();
private Panel southPanel = new Panel(); private Panel southPanel = new Panel();
private ConfirmPanel confirmPanel = new ConfirmPanel(true, true, false, false, false, true); private ConfirmPanel confirmPanel = new ConfirmPanel(true, true, false, false, false, true, false);
private WStatusBar statusBar = new WStatusBar(); private StatusBarPanel statusBar = new StatusBarPanel();
public WTrxMaterial()
{
}
/** /**
* Initialize Panel * Initialize Panel
* @param WindowNo window
* @param frame frame
*/ */
protected void initForm() protected void initForm()
{ {
log.info(""); log.info("");
try try
{ {
dynParameter(); dynParameter();
jbInit(); zkInit();
dynInit(); dynInit();
this.appendChild(mainPanel);
this.appendChild(statusBar);
} }
catch(Exception ex) catch(Exception ex)
{ {
@ -147,129 +113,81 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
* Static Init * Static Init
* @throws Exception * @throws Exception
*/ */
void zkInit() throws Exception
void jbInit() throws Exception
{ {
orgLabel.setValue(Msg.translate(Env.getCtx(), "AD_Org_ID")); this.appendChild(mainPanel);
locatorLabel.setValue(Msg.translate(Env.getCtx(), "M_Locator_ID")); mainPanel.setStyle("width: 99%; height: 100%; border: none; padding: 0; margin: 0");
productLabel.setValue(Msg.translate(Env.getCtx(), "Product")); mainPanel.appendChild(mainLayout);
dateFLabel.setValue(Msg.translate(Env.getCtx(), "DateFrom")); mainLayout.setWidth("100%");
dateTLabel.setValue(Msg.translate(Env.getCtx(), "DateTo")); mainLayout.setHeight("100%");
mtypeLabel.setValue(Msg.translate(Env.getCtx(), "MovementType")); parameterPanel.appendChild(parameterLayout);
//
orgLabel.setText(Msg.translate(Env.getCtx(), "AD_Org_ID"));
locatorLabel.setText(Msg.translate(Env.getCtx(), "M_Locator_ID"));
productLabel.setText(Msg.translate(Env.getCtx(), "Product"));
dateFLabel.setText(Msg.translate(Env.getCtx(), "DateFrom"));
dateTLabel.setText(Msg.translate(Env.getCtx(), "DateTo"));
mtypeLabel.setText(Msg.translate(Env.getCtx(), "MovementType"));
//
North north = new North();
mainLayout.appendChild(north);
north.appendChild(parameterPanel);
m_gridController.setWidth("900px"); Rows rows = parameterLayout.newRows();
m_gridController.setHeight("550px"); Row row = rows.newRow();
row.appendChild(orgLabel.rightAlign());
mainPanel.setWidth("100%"); row.appendChild(orgField.getComponent());
mainPanel.appendChild(new Separator()); row.appendChild(mtypeLabel.rightAlign());
mainPanel.appendChild(parameterPanel); row.appendChild(mtypeField.getComponent());
mainPanel.appendChild(new Separator()); row.appendChild(dateFLabel.rightAlign());
mainPanel.appendChild(m_gridController); row.appendChild(dateFField.getComponent());
mainPanel.appendChild(new Separator());
Hbox boxOrg = new Hbox();
boxOrg.setWidth("100%");
boxOrg.setWidth("35%, 75%");
boxOrg.appendChild(orgLabel);
boxOrg.appendChild(orgField.getComponent());
Hbox boxMType = new Hbox();
boxMType.setWidth("100%");
boxMType.setWidth("35%, 75%");
boxMType.appendChild(mtypeLabel);
boxMType.appendChild(mtypeField.getComponent());
Hbox boxDateF = new Hbox();
boxDateF.setWidth("100%");
boxDateF.setWidth("35%, 75%");
boxDateF.appendChild(dateFLabel);
boxDateF.appendChild(dateFField);
Hbox boxLocator = new Hbox();
boxLocator.setWidth("100%");
boxLocator.setWidth("35%, 75%");
boxLocator.appendChild(locatorLabel);
boxLocator.appendChild(locatorField.getComponent());
Hbox boxProduct = new Hbox();
boxProduct.setWidth("100%");
boxProduct.setWidth("35%, 75%");
boxProduct.appendChild(productLabel);
boxProduct.appendChild(productField.getComponent());
Hbox boxDateT = new Hbox();
boxDateT.setWidth("100%");
boxDateT.setWidth("35%, 75%");
boxDateT.appendChild(dateTLabel);
boxDateT.appendChild(dateTField);
VerticalBox boxCol1 = new VerticalBox();
boxCol1.setWidth("100%");
boxCol1.appendChild(boxOrg);
boxCol1.appendChild(boxLocator);
VerticalBox boxCol2 = new VerticalBox();
boxCol2.setWidth("100%");
boxCol2.appendChild(boxMType);
boxCol2.appendChild(boxProduct);
VerticalBox boxCol3 = new VerticalBox();
boxCol3.setWidth("100%");
boxCol3.appendChild(boxDateF);
boxCol3.appendChild(boxDateT);
parameterPanel.setWidth("100%");
parameterPanel.setStyle("text-align:right");
parameterPanel.appendChild(boxCol1);
parameterPanel.appendChild(new Separator());
parameterPanel.appendChild(boxCol2);
parameterPanel.appendChild(new Separator());
parameterPanel.appendChild(boxCol3);
row = rows.newRow();
row.appendChild(locatorLabel.rightAlign());
row.appendChild(locatorField.getComponent());
row.appendChild(productLabel.rightAlign());
row.appendChild(productField.getComponent());
row.appendChild(dateTLabel.rightAlign());
row.appendChild(dateTField.getComponent());
//
southPanel.appendChild(confirmPanel); southPanel.appendChild(confirmPanel);
southPanel.appendChild(new Separator()); southPanel.appendChild(new Separator());
southPanel.appendChild(statusBar); southPanel.appendChild(statusBar);
South south = new South();
south.setStyle("border: none");
mainLayout.appendChild(south);
south.appendChild(southPanel);
mainPanel.appendChild(southPanel); LayoutUtils.addSclass("status-border", statusBar);
} // jbInit
this.setWidth("100%");
this.appendChild(mainPanel);
}
/** /**
* Initialize Parameter fields * Initialize Parameter fields
* @throws Exception if Lookups cannot be initialized * @throws Exception if Lookups cannot be initialized
*/ */
private void dynParameter() throws Exception private void dynParameter() throws Exception
{ {
Properties ctx = Env.getCtx(); Properties ctx = Env.getCtx();
// Organization // Organization
MLookup orgLookup = MLookupFactory.get (ctx, m_WindowNo, 0, 3660, DisplayType.TableDir); MLookup orgLookup = MLookupFactory.get (ctx, m_WindowNo, 0, 3660, DisplayType.TableDir);
orgField = new WTableDirEditor(orgLookup, "AD_Org_ID", "", false, false, true); orgField = new WTableDirEditor("AD_Org_ID", false, false, true, orgLookup);
orgField.addValueChangeListener(this); // orgField.addVetoableChangeListener(this);
// Locator // Locator
MLocatorLookup locatorLookup = new MLocatorLookup(ctx, m_WindowNo); MLocatorLookup locatorLookup = new MLocatorLookup(ctx, m_WindowNo);
locatorField = new WLocatorEditor ("M_Locator_ID", false, false, true, locatorLookup, m_WindowNo); locatorField = new WLocatorEditor ("M_Locator_ID", false, false, true, locatorLookup, m_WindowNo);
locatorField.addValueChangeListener(this); // locatorField.addVetoableChangeListener(this);
// Product // Product
MLookup productLookup = MLookupFactory.get (ctx, m_WindowNo, 0, 3668, DisplayType.Search); MLookup productLookup = MLookupFactory.get (ctx, m_WindowNo, 0, 3668, DisplayType.Search);
productField = new WSearchEditor(productLookup, "M_Product_ID", "", false, false, true); productField = new WSearchEditor("M_Product_ID", false, false, true, productLookup);
productField.addValueChangeListener(this); productField.addValueChangeListener(this);
// Movement Type // Movement Type
MLookup mtypeLookup = MLookupFactory.get (ctx, m_WindowNo, 0, 3666, DisplayType.List); MLookup mtypeLookup = MLookupFactory.get (ctx, m_WindowNo, 0, 3666, DisplayType.List);
mtypeField = new WTableDirEditor(mtypeLookup, "MovementType", "", false, false, true); mtypeField = new WTableDirEditor("MovementType", false, false, true, mtypeLookup);
mtypeField.addValueChangeListener(this);
// Dates // Dates
dateFField = new Datebox();//"DateFrom", false, false, true, DisplayType.Date, Msg.getMsg(Env.getCtx(), "DateFrom")); dateFField = new WDateEditor("DateFrom", false, false, true, DisplayType.Date, Msg.getMsg(Env.getCtx(), "DateFrom"));
dateTField = new Datebox();//"DateTo", false, false, true, DisplayType.Date, Msg.getMsg(Env.getCtx(), "DateTo")); dateTField = new WDateEditor("DateTo", false, false, true, DisplayType.Date, Msg.getMsg(Env.getCtx(), "DateTo"));
//
confirmPanel.addActionListener(Events.ON_CLICK, this); confirmPanel.addActionListener(this);
statusBar.setStatusLine(""); statusBar.setStatusLine("");
} // dynParameter } // dynParameter
@ -283,127 +201,33 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
m_staticQuery.addRestriction("AD_Client_ID", MQuery.EQUAL, Env.getAD_Client_ID(Env.getCtx())); m_staticQuery.addRestriction("AD_Client_ID", MQuery.EQUAL, Env.getAD_Client_ID(Env.getCtx()));
int AD_Window_ID = 223; // Hardcoded int AD_Window_ID = 223; // Hardcoded
GridWindowVO wVO = AEnv.getMWindowVO (m_WindowNo, AD_Window_ID, 0); GridWindowVO wVO = AEnv.getMWindowVO (m_WindowNo, AD_Window_ID, 0);
if (wVO == null) if (wVO == null)
return; return;
m_mWindow = new GridWindow (wVO); m_mWindow = new GridWindow (wVO);
m_mTab = m_mWindow.getTab(0); m_mTab = m_mWindow.getTab(0);
m_mWindow.initTab(0); m_mWindow.initTab(0);
//
populateGrid(); m_gridController = new ADTabpanel();
m_gridController.init(null, m_WindowNo, m_mTab, m_mWindow);
//m_gridController.initGrid(m_mTab, true, m_WindowNo, null, null); m_gridController.switchRowPresentation();
//mainPanel.add(m_gridController, BorderLayout.CENTER); Center center = new Center();
mainLayout.appendChild(center);
center.setFlex(true);
center.appendChild(m_gridController);
//
m_mTab.setQuery(MQuery.getEqualQuery("1", "2")); m_mTab.setQuery(MQuery.getEqualQuery("1", "2"));
m_mTab.query(false); m_mTab.query(false);
statusBar.setStatusLine(" ", false); statusBar.setStatusLine(" ", false);
statusBar.setStatusDB(" "); statusBar.setStatusDB(" ");
} // dynInit } // dynInit
private void populateGrid()
{
m_gridController.getChildren().clear();
m_gridController.appendChild(columns);
m_gridController.appendChild(rows);
columns.getChildren().clear();
Column column = new Column();
AbstractTableModel tableModel = m_mTab.getTableModel();
GridField[] gridfields = ((GridTable)tableModel).getFields();
for (int i = 0; i < gridfields.length; i++)
{
if (gridfields[i].isDisplayed())
{
column = new Column(gridfields[i].getHeader());
columns.appendChild(column);
}
}
rows.getChildren().clear();
for (int i = 0; i < tableModel.getRowCount(); i++)
{
Row row = new Row();
for (int j = 0; j < tableModel.getColumnCount(); j++)
{
Label lab = new Label();
Label label = new Label("");
if (!gridfields[j].isDisplayed())
break;
Object obj = tableModel.getValueAt(i, j);
if (obj != null)
{
if (tableModel.getColumnClass(j).equals(String.class))
{
label.setValue(obj.toString());
}
else if (tableModel.getColumnClass(j).equals(BigDecimal.class))
{
label.setValue(obj.toString());
}
else if (tableModel.getColumnClass(j).equals(Integer.class))
{
if (gridfields[j].isLookup())
{
MLookup lookup = MLookupFactory.get(Env.getCtx(), m_WindowNo,
0, gridfields[j].getAD_Column_ID(), gridfields[j].getDisplayType());
NamePair namepair = lookup.get(obj);
if (namepair != null)
label.setValue(namepair.getName());
else
label.setValue("");
}
}
else if (tableModel.getColumnClass(j).equals(Timestamp.class))
{
SimpleDateFormat dateFormat = DisplayType.getDateFormat(DisplayType.Date);
label.setValue(dateFormat.format((Timestamp)obj));
}
else
label.setValue("Missing Class");
}
lab = new Label(label.getValue());
row.appendChild(lab);
}
rows.appendChild(row);
}
}
/** /**
* Dispose * Dispose
*/ */
public void dispose() public void dispose()
{ {
/*if (m_gridController != null) SessionManager.getAppDesktop().removeWindow();
m_gridController.dispose();
*/
m_gridController = null;
m_mTab = null;
if (m_mWindow != null)
m_mWindow.dispose();
m_mWindow = null;
orgField = null;
locatorField = null;
productField = null;
mtypeField = null;
dateFField = null;
dateTField = null;
} // dispose } // dispose
@ -411,93 +235,61 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
* Action Listener * Action Listener
* @param e event * @param e event
*/ */
public void onEvent (Event e)
public void onEvent(Event event) throws Exception
{ {
if (confirmPanel.getButton("Cancel").equals(event.getTarget())) if (e.getTarget().getId().equals(ConfirmPanel.A_CANCEL))
dispose(); dispose();
else if (confirmPanel.getButton("Refresh").equals(event.getTarget()) else if (e.getTarget().getId().equals(ConfirmPanel.A_REFRESH)
|| confirmPanel.getButton("Ok").equals(event.getTarget())) || e.getTarget().getId().equals(ConfirmPanel.A_OK))
refresh(); refresh();
else if (confirmPanel.getButton("Zoom").equals(event.getTarget())) else if (e.getTarget().getId().equals(ConfirmPanel.A_ZOOM))
zoom(); zoom();
} // actionPerformed
}
/************************************************************************** /**************************************************************************
* Property Listener * Property Listener
* @param e event * @param e event
*/ */
public void valueChange (ValueChangeEvent e)
public void valueChange(ValueChangeEvent evt)
{ {
if (evt.getPropertyName().equals("M_Product_ID")) if (e.getPropertyName().equals("M_Product_ID"))
productField.setValue(evt.getNewValue()); productField.setValue(e.getNewValue());
} } // vetoableChange
/************************************************************************** /**************************************************************************
* Refresh - Create Query and refresh grid * Refresh - Create Query and refresh grid
*/ */
private void refresh() private void refresh()
{ {
/** /**
* Create Where Clause * Create Where Clause
*/ */
MQuery query = m_staticQuery.deepCopy(); MQuery query = m_staticQuery.deepCopy();
// Organization // Organization
Object value = null; Object value = orgField.getValue();
if (orgField.getDisplay() != "")
value = orgField.getValue();
if (value != null && value.toString().length() > 0) if (value != null && value.toString().length() > 0)
query.addRestriction("AD_Org_ID", MQuery.EQUAL, value); query.addRestriction("AD_Org_ID", MQuery.EQUAL, value);
// Locator // Locator
value = null;
if (locatorField.getDisplay() != "")
value = locatorField.getValue(); value = locatorField.getValue();
if (value != null && value.toString().length() > 0) if (value != null && value.toString().length() > 0)
query.addRestriction("M_Locator_ID", MQuery.EQUAL, value); query.addRestriction("M_Locator_ID", MQuery.EQUAL, value);
// Product // Product
value = null;
if (productField.getDisplay() != "")
value = productField.getValue(); value = productField.getValue();
if (value != null && value.toString().length() > 0) if (value != null && value.toString().length() > 0)
query.addRestriction("M_Product_ID", MQuery.EQUAL, value); query.addRestriction("M_Product_ID", MQuery.EQUAL, value);
// MovementType // MovementType
value = null;
if (mtypeField.getDisplay() != "")
value = mtypeField.getValue(); value = mtypeField.getValue();
if (value != null && value.toString().length() > 0) if (value != null && value.toString().length() > 0)
query.addRestriction("MovementType", MQuery.EQUAL, value); query.addRestriction("MovementType", MQuery.EQUAL, value);
// DateFrom // DateFrom
Date f = null; Timestamp ts = (Timestamp)dateFField.getValue();
Timestamp ts =null;
if (dateFField.getValue() != null)
{
f = dateFField.getValue();
ts = new Timestamp(f.getTime());
}
if (ts != null) if (ts != null)
query.addRestriction("TRUNC(MovementDate)", MQuery.GREATER_EQUAL, ts); query.addRestriction("TRUNC(MovementDate)", MQuery.GREATER_EQUAL, ts);
// DateTO // DateTO
Date t = null; ts = (Timestamp)dateTField.getValue();
ts = null;
if (dateTField.getValue() != null)
{
t = dateTField.getValue();
ts = new Timestamp(t.getTime());
}
if (ts != null) if (ts != null)
query.addRestriction("TRUNC(MovementDate)", MQuery.LESS_EQUAL, ts); query.addRestriction("TRUNC(MovementDate)", MQuery.LESS_EQUAL, ts);
log.info( "VTrxMaterial.refresh query=" + query.toString()); log.info( "VTrxMaterial.refresh query=" + query.toString());
@ -505,37 +297,31 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
/** /**
* Refresh/Requery * Refresh/Requery
*/ */
statusBar.setStatusLine(Msg.getMsg(Env.getCtx(), "StartSearch"), false); statusBar.setStatusLine(Msg.getMsg(Env.getCtx(), "StartSearch"), false);
//
m_mTab.setQuery(query); m_mTab.setQuery(query);
m_mTab.query(false); m_mTab.query(false);
//
int no = m_mTab.getRowCount(); int no = m_mTab.getRowCount();
statusBar.setStatusLine(" ", false); statusBar.setStatusLine(" ", false);
statusBar.setStatusDB(Integer.toString(no)); statusBar.setStatusDB(Integer.toString(no));
populateGrid();
} // refresh } // refresh
/** /**
* Zoom * Zoom
*/ */
private void zoom() private void zoom()
{ {
log.info(""); log.info("");
//
int AD_Window_ID = 0; int AD_Window_ID = 0;
String ColumnName = null; String ColumnName = null;
String SQL = null; String SQL = null;
//
int lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_InOutLine_ID"); int lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_InOutLine_ID");
if (lineID != 0) if (lineID != 0)
{ {
log.fine("M_InOutLine_ID=" + lineID); log.fine("M_InOutLine_ID=" + lineID);
if (Env.getContext(Env.getCtx(), m_WindowNo, "MovementType").startsWith("C")) if (Env.getContext(Env.getCtx(), m_WindowNo, "MovementType").startsWith("C"))
AD_Window_ID = 169; // Customer AD_Window_ID = 169; // Customer
else else
@ -546,7 +332,6 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
else else
{ {
lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_InventoryLine_ID"); lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_InventoryLine_ID");
if (lineID != 0) if (lineID != 0)
{ {
log.fine("M_InventoryLine_ID=" + lineID); log.fine("M_InventoryLine_ID=" + lineID);
@ -557,7 +342,6 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
else else
{ {
lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_MovementLine_ID"); lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_MovementLine_ID");
if (lineID != 0) if (lineID != 0)
{ {
log.fine("M_MovementLine_ID=" + lineID); log.fine("M_MovementLine_ID=" + lineID);
@ -568,7 +352,6 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
else else
{ {
lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_ProductionLine_ID"); lineID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, "M_ProductionLine_ID");
if (lineID != 0) if (lineID != 0)
{ {
log.fine("M_ProductionLine_ID=" + lineID); log.fine("M_ProductionLine_ID=" + lineID);
@ -581,19 +364,16 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
} }
} }
} }
if (AD_Window_ID == 0) if (AD_Window_ID == 0)
return; return;
// Get Parent ID // Get Parent ID
int parentID = 0; int parentID = 0;
try try
{ {
PreparedStatement pstmt = DB.prepareStatement(SQL, null); PreparedStatement pstmt = DB.prepareStatement(SQL, null);
pstmt.setInt(1, lineID); pstmt.setInt(1, lineID);
ResultSet rs = pstmt.executeQuery(); ResultSet rs = pstmt.executeQuery();
if (rs.next()) if (rs.next())
parentID = rs.getInt(1); parentID = rs.getInt(1);
rs.close(); rs.close();
@ -603,21 +383,13 @@ public class WTrxMaterial extends ADForm implements EventListener, ValueChangeLi
{ {
log.log(Level.SEVERE, SQL, e); log.log(Level.SEVERE, SQL, e);
} }
MQuery query = MQuery.getEqualQuery(ColumnName, parentID); MQuery query = MQuery.getEqualQuery(ColumnName, parentID);
log.config("AD_Window_ID=" + AD_Window_ID + " - " + query); log.config("AD_Window_ID=" + AD_Window_ID + " - " + query);
if (parentID == 0) if (parentID == 0)
log.log(Level.SEVERE, "No ParentValue - " + SQL + " - " + lineID); log.log(Level.SEVERE, "No ParentValue - " + SQL + " - " + lineID);
// Zoom // Zoom
AEnv.zoom(AD_Window_ID, query); AEnv.zoom(AD_Window_ID, query);
/* ADWindow frame = new ADWindow(Env.getCtx(), AD_Window_ID); } // zoom
if (frame == null) } // VTrxMaterial
return;
SessionManager.getAppDesktop().showWindow(frame);
frame = null;
*/ } // zoom
}

View File

@ -14,10 +14,10 @@ import org.adempiere.webui.component.Listbox;
import org.adempiere.webui.component.Row; import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.Textbox; import org.adempiere.webui.component.Textbox;
import org.adempiere.webui.component.WStatusBar;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.editor.WSearchEditor; import org.adempiere.webui.editor.WSearchEditor;
import org.adempiere.webui.panel.ADForm; import org.adempiere.webui.panel.ADForm;
import org.adempiere.webui.panel.StatusBarPanel;
import org.adempiere.webui.window.FDialog; import org.adempiere.webui.window.FDialog;
import org.compiere.model.MColumn; import org.compiere.model.MColumn;
import org.compiere.model.MLookup; import org.compiere.model.MLookup;
@ -89,7 +89,7 @@ public class WWFActivity extends ADForm implements EventListener
private WSearchEditor fForward = null; // dynInit private WSearchEditor fForward = null; // dynInit
private Label lForward = new Label(Msg.getMsg(Env.getCtx(), "Forward")); private Label lForward = new Label(Msg.getMsg(Env.getCtx(), "Forward"));
private Label lOptional = new Label("(" + Msg.translate(Env.getCtx(), "Optional") + ")"); private Label lOptional = new Label("(" + Msg.translate(Env.getCtx(), "Optional") + ")");
private WStatusBar statusBar = new WStatusBar(); private StatusBarPanel statusBar = new StatusBarPanel();
public WWFActivity() public WWFActivity()
{ {
@ -226,7 +226,6 @@ public class WWFActivity extends ADForm implements EventListener
South south = new South(); South south = new South();
south.appendChild(statusBar); south.appendChild(statusBar);
statusBar.setWidth("100%");
layout.appendChild(south); layout.appendChild(south);
south.setStyle("background-color: transparent"); south.setStyle("background-color: transparent");

View File

@ -18,6 +18,7 @@ import java.util.List;
import org.adempiere.webui.component.ADTabListModel.ADTabLabel; import org.adempiere.webui.component.ADTabListModel.ADTabLabel;
import org.zkoss.zhtml.Button; import org.zkoss.zhtml.Button;
import org.zkoss.zhtml.Text; import org.zkoss.zhtml.Text;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events; import org.zkoss.zk.ui.event.Events;
@ -38,10 +39,15 @@ public class ADButtonTabList extends Panel implements IADTabList, EventListener
this.setStyle("margin:0;padding:0"); this.setStyle("margin:0;padding:0");
} }
public void refresh() { public synchronized void refresh() {
this.getChildren().clear(); List childs = getChildren();
int i = 0; int childCount = childs.size();
for (ADTabLabel tabLabel : listItems) { for (int c = childCount - 1; c >=0; c--) {
removeChild((Component) childs.get(c));
}
Object[] items = listItems.toArray();
for (int i = 0; i < items.length; i++) {
ADTabLabel tabLabel = (ADTabLabel) items[i];
Button button = new Button(); Button button = new Button();
Text text = new Text(tabLabel.label); Text text = new Text(tabLabel.label);
button.appendChild(text); button.appendChild(text);
@ -67,7 +73,6 @@ public class ADButtonTabList extends Panel implements IADTabList, EventListener
button.setParent(this); button.setParent(this);
button.addEventListener(Events.ON_CLICK, this); button.addEventListener(Events.ON_CLICK, this);
i++;
} }
} }
@ -79,7 +84,7 @@ public class ADButtonTabList extends Panel implements IADTabList, EventListener
this.selectedIndex = index; this.selectedIndex = index;
} }
public void setItems(List<ADTabLabel> listItems) { public synchronized void setItems(List<ADTabLabel> listItems) {
this.listItems = listItems; this.listItems = listItems;
refresh(); refresh();
} }

View File

@ -441,7 +441,6 @@ public class CWindowToolbar extends FToolbar implements EventListener
public void enableChanges(boolean enabled) public void enableChanges(boolean enabled)
{ {
this.btnNew.setDisabled(!enabled); this.btnNew.setDisabled(!enabled);
this.btnIgnore.setDisabled(!enabled);
} }
public void enableIgnore(boolean enabled) public void enableIgnore(boolean enabled)

View File

@ -13,15 +13,15 @@
package org.adempiere.webui.component; package org.adempiere.webui.component;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zul.Hbox;
/** /**
* *
* @author Low Heng Sin * @author Low Heng Sin
* *
*/ */
public class Combinationbox extends Hbox public class Combinationbox extends Panel
{ {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
@ -49,11 +49,14 @@ public class Combinationbox extends Hbox
private void initComponents() private void initComponents()
{ {
textbox = new Textbox(); textbox = new Textbox();
textbox.setWidth("100%");
button = new Button(); button = new Button();
button.setHeight("98%"); button.setHeight("22px");
button.setWidth("26px");
appendChild(textbox); appendChild(textbox);
appendChild(button); appendChild(button);
String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";
this.setStyle(style);
} }
public void setText(String value) public void setText(String value)

View File

@ -23,6 +23,8 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import org.adempiere.webui.LayoutUtils; import org.adempiere.webui.LayoutUtils;
import org.compiere.util.Env;
import org.compiere.util.Msg;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events; import org.zkoss.zk.ui.event.Events;
import org.zkoss.zul.Hbox; import org.zkoss.zul.Hbox;
@ -68,6 +70,8 @@ public final class ConfirmPanel extends Hbox
/** Action String New. */ /** Action String New. */
public static final String A_NEW = "New"; public static final String A_NEW = "New";
private boolean m_withText = false;
private Map<String, Button> buttonMap = new HashMap<String, Button>(); private Map<String, Button> buttonMap = new HashMap<String, Button>();
/** /**
@ -98,9 +102,25 @@ public final class ConfirmPanel extends Hbox
Button button = new Button(); Button button = new Button();
button.setName("btn"+name); button.setName("btn"+name);
button.setId(name); button.setId(name);
button.setSrc("images/"+name+"24.png"); String text = Msg.translate(Env.getCtx(), name);
if (!name.equals(text))
text = text.replaceAll("[&]", "");
else
text = null;
if (m_withText && text != null)
{
button.setSrc("images/"+name+"16.png");
button.setLabel(text);
LayoutUtils.addSclass("action-text-button", button);
}
else
{
button.setSrc("images/"+name+"24.png");
if (text != null)
button.setTooltiptext(text);
LayoutUtils.addSclass("action-button", button); LayoutUtils.addSclass("action-button", button);
}
buttonMap.put(name, button); buttonMap.put(name, button);
@ -123,6 +143,28 @@ public final class ConfirmPanel extends Hbox
boolean withHistoryButton, boolean withHistoryButton,
boolean withZoomButton) boolean withZoomButton)
{ {
this(withCancelButton, withRefreshButton, withResetButton, withCustomizeButton, withHistoryButton, withZoomButton, false);
}
/**
* create confirm panel with multiple options
* @param withCancelButton with cancel
* @param withRefreshButton with refresh
* @param withResetButton with reset
* @param withCustomizeButton with customize
* @param withHistoryButton with history
* @param withZoomButton with zoom
*/
public ConfirmPanel(boolean withCancelButton,
boolean withRefreshButton,
boolean withResetButton,
boolean withCustomizeButton,
boolean withHistoryButton,
boolean withZoomButton,
boolean withText)
{
m_withText = withText;
init(); init();
setVisible(A_CANCEL, withCancelButton); setVisible(A_CANCEL, withCancelButton);

View File

@ -20,6 +20,7 @@ package org.adempiere.webui.component;
import java.beans.PropertyChangeListener; import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport; import java.beans.PropertyChangeSupport;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
/** /**
@ -62,6 +63,12 @@ public class EditorBox extends Panel
this.appendChild(txt); this.appendChild(txt);
this.appendChild(btn); this.appendChild(btn);
btn.setHeight("22px");
btn.setWidth("26px");
String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";
this.setStyle(style);
} }
public Textbox getTextBox() public Textbox getTextBox()

View File

@ -60,7 +60,8 @@ public class Label extends org.zkoss.zul.Label
@Override @Override
public void setValue(String value) { public void setValue(String value) {
super.setValue(value != null ? value.replaceAll("[&]", "") : null); super.setValue(value != null ? value.replaceAll("[&]", "") : null);
setupMandatoryDecorator(); if ((value == null || value.trim().length() == 0) && decorator != null)
decorator.setVisible(false);
} }
@Override @Override
@ -75,13 +76,18 @@ public class Label extends org.zkoss.zul.Label
} }
private void setupMandatoryDecorator() { private void setupMandatoryDecorator() {
String value = getValue();
if (value != null && (value.trim().length() > 0) && mandatory) {
if (decorator == null) if (decorator == null)
createMandatoryDecorator();
String value = getValue();
if (mandatory && value != null && value.trim().length() > 0) {
decorator.setVisible(true);
} else
decorator.setVisible(false);
}
private void createMandatoryDecorator() {
decorator = new Label("*"); decorator = new Label("*");
((Label)decorator).setStyle("text-decoration: none; font-size: xx-small; vertical-align: top;"); ((Label)decorator).setStyle("text-decoration: none; font-size: xx-small; vertical-align: top;");
} else if (decorator != null)
decorator.setVisible(false);
} }
/** /**

View File

@ -257,13 +257,16 @@ public class ListModelTable extends ListModelList implements ListModelExt
if (vector) if (vector)
{ {
newRow = new Vector<Object>(getNoColumns()); newRow = new Vector<Object>(getNoColumns());
((Vector)newRow).ensureCapacity(getNoColumns()); ((Vector)newRow).setSize(getNoColumns());
add(newRow); add(newRow);
} }
else else
{ {
newRow = new ArrayList<Object>(getNoColumns()); newRow = new ArrayList<Object>(getNoColumns());
((ArrayList)newRow).ensureCapacity(getNoColumns()); for(int i = 0; i < getNoColumns(); i++)
{
newRow.add(null);
}
add(newRow); add(newRow);
} }
} }

View File

@ -219,7 +219,10 @@ public class Listbox extends org.zkoss.zul.Listbox implements EventListener
* remove all items, to ease porting of swing form * remove all items, to ease porting of swing form
*/ */
public void removeAllItems() { public void removeAllItems() {
getItems().clear(); int cnt = getItemCount();
for (int i = cnt - 1; i >=0; i--) {
removeItemAt(i);
}
} }
/** /**

View File

@ -20,6 +20,7 @@ package org.adempiere.webui.component;
import java.beans.PropertyChangeListener; import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport; import java.beans.PropertyChangeSupport;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
/** Location Editor component /** Location Editor component
@ -53,8 +54,13 @@ public class Locationbox extends Panel
{ {
txt = new Textbox(); txt = new Textbox();
btn = new Button(); btn = new Button();
btn.setHeight("22px");
btn.setWidth("26px");
this.appendChild(txt); this.appendChild(txt);
this.appendChild(btn); this.appendChild(btn);
String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";
this.setStyle(style);
} }
public Textbox getTextBox() public Textbox getTextBox()

View File

@ -101,32 +101,39 @@ public class Messagebox extends Window implements EventListener
lblMsg.setValue(msg); lblMsg.setValue(msg);
btnOk.setLabel("OK"); btnOk.setLabel("OK");
btnOk.setImage("/images/Ok24.png"); btnOk.setImage("/images/Ok16.png");
btnOk.addEventListener(Events.ON_CLICK, this); btnOk.addEventListener(Events.ON_CLICK, this);
btnOk.setSclass("action-text-button");
btnCancel.setLabel("Cancel"); btnCancel.setLabel("Cancel");
btnCancel.setImage("/images/Cancel24.png"); btnCancel.setImage("/images/Cancel16.png");
btnCancel.addEventListener(Events.ON_CLICK, this); btnCancel.addEventListener(Events.ON_CLICK, this);
btnCancel.setSclass("action-text-button");
btnYes.setLabel("Yes"); btnYes.setLabel("Yes");
btnYes.setImage("/images/Ok24.png"); btnYes.setImage("/images/Ok16.png");
btnYes.addEventListener(Events.ON_CLICK, this); btnYes.addEventListener(Events.ON_CLICK, this);
btnYes.setSclass("action-text-button");
btnNo.setLabel("No"); btnNo.setLabel("No");
btnNo.setImage("/images/Cancel24.png"); btnNo.setImage("/images/Cancel16.png");
btnNo.addEventListener(Events.ON_CLICK, this); btnNo.addEventListener(Events.ON_CLICK, this);
btnNo.setSclass("action-text-button");
btnAbort.setLabel("Abort"); btnAbort.setLabel("Abort");
//btnAbort.setImage("/images/"); //btnAbort.setImage("/images/");
btnAbort.addEventListener(Events.ON_CLICK, this); btnAbort.addEventListener(Events.ON_CLICK, this);
btnAbort.setSclass("action-text-button");
btnRetry.setLabel("Retry"); btnRetry.setLabel("Retry");
//btnRetry.setImage("/images/"); //btnRetry.setImage("/images/");
btnRetry.addEventListener(Events.ON_CLICK, this); btnRetry.addEventListener(Events.ON_CLICK, this);
btnRetry.setSclass("action-text-button");
btnIgnore.setLabel("Ignore"); btnIgnore.setLabel("Ignore");
btnIgnore.setImage("/images/Ignore24.png"); btnIgnore.setImage("/images/Ignore16.png");
btnIgnore.addEventListener(Events.ON_CLICK, this); btnIgnore.addEventListener(Events.ON_CLICK, this);
btnIgnore.setSclass("action-text-button");
Panel pnlMessage = new Panel(); Panel pnlMessage = new Panel();
pnlMessage.setWidth("100%"); pnlMessage.setWidth("100%");

View File

@ -16,14 +16,14 @@
package org.adempiere.webui.component; package org.adempiere.webui.component;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zul.Hbox;
/** /**
* Product Attribute Box * Product Attribute Box
* @author Low Heng Sin * @author Low Heng Sin
*/ */
public class PAttributebox extends Hbox public class PAttributebox extends Panel
{ {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
@ -51,11 +51,14 @@ public class PAttributebox extends Hbox
private void initComponents() private void initComponents()
{ {
textBox = new Textbox(); textBox = new Textbox();
textBox.setWidth("100%");
button = new Button(); button = new Button();
button.setHeight("98%"); button.setHeight("22px");
button.setWidth("26px");
appendChild(textBox); appendChild(textBox);
appendChild(button); appendChild(button);
String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";
this.setStyle(style);
} }
public void setText(String value) public void setText(String value)

View File

@ -20,9 +20,10 @@ package org.adempiere.webui.component;
import java.beans.PropertyChangeListener; import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport; import java.beans.PropertyChangeSupport;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
public class Searchbox extends Panel//Hbox public class Searchbox extends Panel
{ {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
private PropertyChangeSupport m_propertyChangeListeners = new PropertyChangeSupport(this); private PropertyChangeSupport m_propertyChangeListeners = new PropertyChangeSupport(this);
@ -48,13 +49,14 @@ public class Searchbox extends Panel//Hbox
private void initComponents() private void initComponents()
{ {
txt = new Textbox(); txt = new Textbox();
// txt.setWidth("100%");
btn = new Button(); btn = new Button();
btn.setHeight("98%"); btn.setHeight("22px");
btn.setWidth("26px");
appendChild(txt); appendChild(txt);
appendChild(btn); appendChild(btn);
this.setStyle("display: inline-block"); String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";
this.setStyle(style);
} }
public Textbox getTextBox() public Textbox getTextBox()

View File

@ -17,13 +17,14 @@
package org.adempiere.webui.component; package org.adempiere.webui.component;
import org.adempiere.webui.apps.AEnv;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zul.Hbox; import org.zkoss.zul.Hbox;
/** /**
* URL Box * URL Box
*/ */
public class Urlbox extends Hbox public class Urlbox extends Panel
{ {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
@ -51,11 +52,14 @@ public class Urlbox extends Hbox
private void initComponents() private void initComponents()
{ {
txtUrl = new Textbox(); txtUrl = new Textbox();
txtUrl.setWidth("100%");
btnUrl = new Button(); btnUrl = new Button();
btnUrl.setHeight("98%"); btnUrl.setHeight("22px");
btnUrl.setWidth("26px");
appendChild(txtUrl); appendChild(txtUrl);
appendChild(btnUrl); appendChild(btnUrl);
String style = AEnv.isFirefox2() ? "display: inline" : "display: inline-block";
this.setStyle(style);
} }
public void setText(String value) public void setText(String value)

View File

@ -400,10 +400,11 @@ public class WListItemRenderer implements ListitemRenderer, EventListener, Listi
* *
* @param headerValue The object to use for generating the header text. * @param headerValue The object to use for generating the header text.
* @param headerIndex The column index of the header * @param headerIndex The column index of the header
* @param classType
* @return The generated ListHeader * @return The generated ListHeader
* @see #renderListHead(ListHead) * @see #renderListHead(ListHead)
*/ */
private Component getListHeaderComponent(Object headerValue, int headerIndex) private Component getListHeaderComponent(Object headerValue, int headerIndex, Class classType)
{ {
ListHeader header = null; ListHeader header = null;
@ -422,6 +423,22 @@ public class WListItemRenderer implements ListitemRenderer, EventListener, Listi
int width = headerText.trim().length() * 9; int width = headerText.trim().length() * 9;
if (width > 300) if (width > 300)
width = 300; width = 300;
else if (classType != null)
{
if (classType.equals(String.class))
{
if (width > 0 && width < 180)
width = 180;
}
else if (classType.equals(IDColumn.class))
{
header.setSort("none");
if (width == 0)
width = 30;
}
else if (width > 0 && width < 100)
width = 100;
}
else if (width > 0 && width < 100) else if (width > 0 && width < 100)
width = 100; width = 100;
@ -483,7 +500,7 @@ public class WListItemRenderer implements ListitemRenderer, EventListener, Listi
for (int columnIndex = 0; columnIndex < m_tableColumns.size(); columnIndex++) for (int columnIndex = 0; columnIndex < m_tableColumns.size(); columnIndex++)
{ {
column = m_tableColumns.get(columnIndex); column = m_tableColumns.get(columnIndex);
header = getListHeaderComponent(column.getHeaderValue(), columnIndex); header = getListHeaderComponent(column.getHeaderValue(), columnIndex, column.getColumnClass());
head.appendChild(header); head.appendChild(header);
} }
head.setSizable(true); head.setSizable(true);
@ -693,6 +710,26 @@ public class WListItemRenderer implements ListitemRenderer, EventListener, Listi
return item; return item;
} }
/**
* @param index
* @param header
*/
public void setColumnHeader(int index, String header)
{
if (index >= 0 && index < m_tableColumns.size())
{
m_tableColumns.get(index).setHeaderValue(Util.cleanAmp(header));
}
}
public void setColumnClass(int index, Class classType) {
if (index >= 0 && index < m_tableColumns.size())
{
m_tableColumns.get(index).setColumnClass(classType);
}
}
} }

View File

@ -444,7 +444,13 @@ public class WListbox extends Listbox implements TableValueChangeListener, WTabl
setColumnReadOnly(index, readOnly); setColumnReadOnly(index, readOnly);
// TODO transfer this to Renderer renderer.setColumnHeader(index, header);
renderer.setColumnClass(index, classType);
if (index < m_modelHeaderClass.size())
m_modelHeaderClass.set(index, classType);
else
m_modelHeaderClass.add(classType); m_modelHeaderClass.add(classType);
return; return;
@ -466,6 +472,10 @@ public class WListbox extends Listbox implements TableValueChangeListener, WTabl
{ {
setColumnReadOnly(index, readOnly); setColumnReadOnly(index, readOnly);
WListItemRenderer renderer = (WListItemRenderer)getItemRenderer();
renderer.setColumnClass(index, classType);
m_modelHeaderClass.add(classType); m_modelHeaderClass.add(classType);
return; return;
@ -489,6 +499,9 @@ public class WListbox extends Listbox implements TableValueChangeListener, WTabl
addColumn(header); addColumn(header);
WListItemRenderer renderer = (WListItemRenderer)getItemRenderer();
renderer.setColumnClass((renderer.getNoColumns() - 1), classType);
return; return;
} }

View File

@ -1,240 +0,0 @@
/******************************************************************************
* Product: Posterita Ajax UI *
* Copyright (C) 2007 Posterita Ltd. All Rights Reserved. *
* This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program 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 General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program; if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
* For the text or an alternative of this public license, you may reach us *
* Posterita Ltd., 3, Draper Avenue, Quatre Bornes, Mauritius *
* or via info@posterita.org or http://www.posterita.org/ *
*****************************************************************************/
package org.adempiere.webui.component;
import java.awt.Color;
import org.adempiere.webui.component.Label;
import org.compiere.model.DataStatusEvent;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events;
/**
* Web UI status bar. Based upon the rich client's
* {@link org.compiere.apps.StatusBar}. The basic status bar contains one or
* both of (a) a general status description and (b) a database status
* description. In addition, components can be added to the status bar to extend
* its functionaility
*
* @author Andrew Kimball
*/
public class WStatusBar extends Grid implements EventListener
{
private static final long serialVersionUID = 1L;
/** label */
private Label statusLine = new Label();
private Label statusDB = new Label();
private Row statusBar = new Row();
private String m_text;
private DataStatusEvent m_dse = null;
private boolean mt_error;
private String mt_text;
/**
* Constructor for a Standard Status Bar.
*/
public WStatusBar()
{
super();
Rows rows = new Rows();
try
{
initialise();
// this.setBorder("normal");
rows.appendChild(statusBar);
this.appendChild(rows);
this.setWidth("99%");
}
catch (Exception e)
{
}
// this.setName("statusBar");
} // StatusBar
/**
* Static Initialisation.
*
* @throws Exception
*/
private void initialise() throws Exception
{
statusLine.setValue("statusLine");
statusBar.appendChild(statusLine);
statusDB.setValue("#");
statusDB.setStyle("text-align:right; " + "color:"
+ ZkCssHelper.createHexColorString(Color.blue));
statusDB.addEventListener(Events.ON_CLICK, this);
statusBar.appendChild(statusDB);
} // jbInit
/**
* Get Status Line text.
*
* @return StatusLine text
*/
public final String getStatusLine()
{
return statusLine.getValue().trim();
} // getStatusLine
/**
* Set Status Line
*
* @param text
* text
* @param error
* error
*/
public final void setStatusLine(final String text, final boolean error)
{
mt_error = error;
mt_text = text;
if (mt_error)
{
/* ZkCssHelper.appendStyle(statusLine, ZkCssHelper
.createHexColorString(AdempierePLAF.getTextColor_Issue()));
*/ }
else
{
/* ZkCssHelper.appendStyle(statusLine, ZkCssHelper
.createHexColorString(AdempierePLAF.getTextColor_OK()));
*/ }
statusLine.setValue(mt_text);
//
} // setStatusLine
/**
* Set ToolTip of StatusLine
*
* @param tip
* tooltip text
*/
public final void setStatusToolTip(final String tip)
{
statusLine.setTooltiptext(tip);
} // setStatusToolTip
/**
* Set Standard Status Line (non error)
*
* @param text
* text to display on the status line
*/
public final void setStatusLine(final String text)
{
if (text == null)
{
setStatusLine("", false);
}
else
{
setStatusLine(text, false);
}
} // setStatusLine
/**
* Set Status DB Info
*
* @param text
* description of database status
* @param dse
* data status event
*/
public final void setStatusDB(final String text, final DataStatusEvent dse)
{
if (text == null || text.length() == 0)
{
statusDB.setValue("");
statusDB.setVisible(false);
statusDB.detach();
}
else
{
StringBuffer sb = new StringBuffer(" ");
sb.append(text).append(" ");
statusDB.setValue(sb.toString());
if (!statusDB.isVisible())
{
statusDB.setVisible(true);
}
statusDB.setParent(statusBar);
}
// Save
m_text = text;
m_dse = dse;
} // setStatusDB
/**
* Set Status DB Info
*
* @param text
* description of database status
*/
public final void setStatusDB(final String text)
{
setStatusDB(text, null);
} // setStatusDB
/**
* Set Status DB Info
*
* @param no
* Database status identifier
*/
public final void setStatusDB(final int no)
{
setStatusDB(String.valueOf(no), null);
} // setStatusDB
/**
* Add Component to East of StatusBar
*
* @param component
* component
*/
public final void addStatusComponent(final Component component)
{
this.appendChild(component);
} // addStatusComponent
/*
* (non-Javadoc)
*
* @see org.zkoss.zk.ui.event.EventListener#onEvent(org.zkoss.zk.ui.event.Event)
*/
public void onEvent(final Event evt) throws Exception
{
// TODO Auto-generated method stub
}
}

View File

@ -41,6 +41,8 @@ public class WTableColumn
/** The header value of the column. */ /** The header value of the column. */
protected Object headerValue; protected Object headerValue;
protected Class columnClass;
/** /**
* Cover method, using a default width of 75 * Cover method, using a default width of 75
* @see #WTableColumn(int) * @see #WTableColumn(int)
@ -252,4 +254,22 @@ public class WTableColumn
{ {
return isResizable; return isResizable;
} }
/**
*
* @return Class
*/
public Class getColumnClass()
{
return columnClass;
}
/**
*
* @param columnClass
*/
public void setColumnClass(Class columnClass)
{
this.columnClass = columnClass;
}
} }

View File

@ -77,6 +77,22 @@ public class WDateEditor extends WEditor
this("Date", "Date", false, false, true); this("Date", "Date", false, false, true);
} // VDate } // VDate
/**
*
* @param columnName
* @param mandatory
* @param readonly
* @param updateable
* @param displayType
* @param label
*/
public WDateEditor(String columnName, boolean mandatory, boolean readonly, boolean updateable,
int displayType, String label) {
//TODO: support for displayType
super(new Datebox(), columnName, label, null, mandatory, readonly, updateable);
}
public void onEvent(Event event) public void onEvent(Event event)
{ {
Date date = getComponent().getValue(); Date date = getComponent().getValue();
@ -126,6 +142,7 @@ public class WDateEditor extends WEditor
if (value == null) if (value == null)
{ {
oldValue = null; oldValue = null;
getComponent().setValue(null);
} }
else if (value instanceof Timestamp) else if (value instanceof Timestamp)
{ {

View File

@ -411,4 +411,8 @@ public abstract class WEditor implements EventListener, PropertyChangeListener
{ {
return true; return true;
} }
public void dynamicDisplay()
{
}
} }

View File

@ -53,7 +53,7 @@ public class WLocatorEditor extends WEditor implements EventListener, PropertyCh
private String m_columnName; private String m_columnName;
private MLocatorLookup m_mLocator; private MLocatorLookup m_mLocator;
private MLocator m_value; private Object m_value;
private int m_WindowNo; private int m_WindowNo;
private static CLogger log = CLogger.getCLogger(WLocatorEditor.class); private static CLogger log = CLogger.getCLogger(WLocatorEditor.class);
@ -113,7 +113,7 @@ public class WLocatorEditor extends WEditor implements EventListener, PropertyCh
value = null; value = null;
} }
m_value = m_mLocator.getMLocator(value, null); m_value = value;
getComponent().setText(m_mLocator.getDisplay(value)); // loads value getComponent().setText(m_mLocator.getDisplay(value)); // loads value
// Data Binding // Data Binding
@ -159,8 +159,9 @@ public class WLocatorEditor extends WEditor implements EventListener, PropertyCh
public int getM_Locator_ID() public int getM_Locator_ID()
{ {
if (m_value != null/* && m_value instanceof Integer*/) if (m_value != null
return m_value.getM_Locator_ID(); && m_value instanceof Integer)
return ((Integer)m_value).intValue();
return 0; return 0;
} // getM_Locator_ID } // getM_Locator_ID
@ -193,9 +194,8 @@ public class WLocatorEditor extends WEditor implements EventListener, PropertyCh
int M_Locator_ID = 0; int M_Locator_ID = 0;
//if (m_value instanceof Integer) if (m_value instanceof Integer)
if (m_value != null) M_Locator_ID = ((Integer)m_value).intValue();
M_Locator_ID = m_value.getM_Locator_ID();
m_mLocator.setOnly_Warehouse_ID(only_Warehouse_ID); m_mLocator.setOnly_Warehouse_ID(only_Warehouse_ID);
m_mLocator.setOnly_Product_ID(getOnly_Product_ID()); m_mLocator.setOnly_Product_ID(getOnly_Product_ID());

View File

@ -827,17 +827,17 @@ public class WSearchEditor extends WEditor implements ContextMenuListener, Value
public void valueChange(ValueChangeEvent evt) public void valueChange(ValueChangeEvent evt)
{ {
if (getColumnName().equals(evt.getPropertyName())) if ("zoom".equals(evt.getPropertyName()))
{
actionZoom(evt.getNewValue());
}
else
{ {
if (evt.getNewValue() != null) if (evt.getNewValue() != null)
{ {
actionCombo(evt.getNewValue()); actionCombo(evt.getNewValue());
} }
} }
else if ("zoom".equals(evt.getPropertyName()))
{
actionZoom(evt.getNewValue());
}
} }
} }

View File

@ -211,7 +211,7 @@ ContextMenuListener, IZoomableEditor
private void refreshList() private void refreshList()
{ {
if (getComponent().getItemCount() > 0) if (getComponent().getItemCount() > 0)
getComponent().getItems().clear(); getComponent().removeAllItems();
if (isReadWrite()) if (isReadWrite())
{ {
@ -327,4 +327,11 @@ ContextMenuListener, IZoomableEditor
setValue(evt.getNewValue()); setValue(evt.getNewValue());
} }
} }
@Override
public void dynamicDisplay()
{
if (isReadWrite() && (!lookup.isValidated() || !lookup.isLoaded()))
this.actionRefresh();
}
} }

View File

@ -26,6 +26,7 @@ import java.util.Map.Entry;
import java.util.logging.Level; import java.util.logging.Level;
import org.adempiere.webui.LayoutUtils; import org.adempiere.webui.LayoutUtils;
import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.component.Bandbox; import org.adempiere.webui.component.Bandbox;
import org.adempiere.webui.component.Datebox; import org.adempiere.webui.component.Datebox;
import org.adempiere.webui.component.Grid; import org.adempiere.webui.component.Grid;
@ -347,6 +348,7 @@ DataStatusListener, ValueChangeListener, IADTabpanel
if (editor instanceof WButtonEditor) if (editor instanceof WButtonEditor)
{ {
if (windowPanel != null)
((WButtonEditor)editor).addActionListener(windowPanel); ((WButtonEditor)editor).addActionListener(windowPanel);
} }
else else
@ -356,8 +358,11 @@ DataStatusListener, ValueChangeListener, IADTabpanel
if (editor.getComponent() instanceof HtmlBasedComponent) { if (editor.getComponent() instanceof HtmlBasedComponent) {
//can't stretch bandbox & datebox //can't stretch bandbox & datebox
if (!(editor.getComponent() instanceof Bandbox) && !(editor.getComponent() instanceof Datebox)) if (!(editor.getComponent() instanceof Bandbox) &&
((HtmlBasedComponent)editor.getComponent()).setWidth("100%"); !(editor.getComponent() instanceof Datebox)) {
String width = AEnv.isFirefox2() ? "99%" : "100%";
((HtmlBasedComponent)editor.getComponent()).setWidth(width);
}
} }
WEditorPopupMenu popupMenu = editor.getPopupMenu(); WEditorPopupMenu popupMenu = editor.getPopupMenu();
@ -460,14 +465,20 @@ DataStatusListener, ValueChangeListener, IADTabpanel
} }
else else
{ {
comp.dynamicDisplay();
boolean rw = mField.isEditable(true); // r/w - check Context boolean rw = mField.isEditable(true); // r/w - check Context
comp.setReadWrite(rw); comp.setReadWrite(rw);
if (comp.getLabel() != null)
{
comp.setMandatory(mField.isMandatory(true)); // check context
}
/*
boolean manMissing = false; boolean manMissing = false;
if (rw && mField.getValue() == null && mField.isMandatory(true)) // check context if (rw && mField.getValue() == null && mField.isMandatory(true)) // check context
{ {
manMissing = true; manMissing = true;
} }
comp.setBackground(manMissing || mField.isError()); comp.setBackground(manMissing || mField.isError());*/
} }
} }
else if (comp.isVisible()) else if (comp.isVisible())
@ -724,6 +735,8 @@ DataStatusListener, ValueChangeListener, IADTabpanel
} }
//if (col >= 0) //if (col >= 0)
if (!uiCreated)
createUI();
dynamicDisplay(col); dynamicDisplay(col);
//sync tree //sync tree
@ -835,7 +848,9 @@ DataStatusListener, ValueChangeListener, IADTabpanel
// //
if (e.getNewValue() == null && e.getOldValue() != null if (e.getNewValue() == null && e.getOldValue() != null
&& e.getOldValue().toString().length() > 0) // some editors return "" instead of null && e.getOldValue().toString().length() > 0) // some editors return "" instead of null
mTable.setChanged (true); // this is the original code from GridController, don't know what it does there but it breaks ignore button for web ui
// mTable.setChanged (true);
mTable.setValueAt (e.getNewValue(), row, col);
else else
{ {
// mTable.setValueAt (e.getNewValue(), row, col, true); // mTable.setValueAt (e.getNewValue(), row, col, true);

View File

@ -31,7 +31,6 @@ import org.adempiere.webui.apps.AEnv;
import org.adempiere.webui.component.ConfirmPanel; import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.ListModelTable; import org.adempiere.webui.component.ListModelTable;
import org.adempiere.webui.component.WListbox; import org.adempiere.webui.component.WListbox;
import org.adempiere.webui.component.WStatusBar;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.event.ValueChangeEvent; import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener; import org.adempiere.webui.event.ValueChangeListener;
@ -266,7 +265,7 @@ public abstract class InfoPanel extends Window implements EventListener, WTableM
protected boolean p_multipleSelection; protected boolean p_multipleSelection;
/** Initial WHERE Clause */ /** Initial WHERE Clause */
protected String p_whereClause = ""; protected String p_whereClause = "";
protected WStatusBar statusBar = new WStatusBar(); protected StatusBarPanel statusBar = new StatusBarPanel();
/** */ /** */
private Vector<Object> line; private Vector<Object> line;
private boolean m_ok = false; private boolean m_ok = false;

View File

@ -25,6 +25,7 @@ import org.compiere.model.DataStatusEvent;
import org.compiere.model.MRole; import org.compiere.model.MRole;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Msg; import org.compiere.util.Msg;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zk.ui.event.Events; import org.zkoss.zk.ui.event.Events;
@ -52,6 +53,10 @@ public class StatusBarPanel extends Panel implements EventListener
private String m_text; private String m_text;
private Div east;
private Div west;
public StatusBarPanel() public StatusBarPanel()
{ {
super(); super();
@ -61,40 +66,41 @@ public class StatusBarPanel extends Panel implements EventListener
private void init() private void init()
{ {
statusLine = new Label(); statusLine = new Label();
statusDB = new Label(); statusDB = new Label(" ");
infoLine = new Label(); infoLine = new Label();
Hbox hbox = new Hbox(); Hbox hbox = new Hbox();
hbox.setWidth("100%"); hbox.setWidth("100%");
hbox.setHeight("100%"); hbox.setHeight("100%");
hbox.setWidths("50%, 50%"); hbox.setWidths("50%, 50%");
Div div = new Div(); west = new Div();
div.setStyle("text-align: left; "); west.setStyle("text-align: left; ");
div.appendChild(statusLine); west.appendChild(statusLine);
div.setWidth("100%"); west.setWidth("100%");
Vbox vbox = new Vbox(); Vbox vbox = new Vbox();
vbox.setPack("center"); vbox.setPack("center");
LayoutUtils.addSclass("status", vbox); LayoutUtils.addSclass("status", vbox);
vbox.appendChild(div); vbox.appendChild(west);
hbox.appendChild(vbox); hbox.appendChild(vbox);
div = new Div(); east = new Div();
div.setWidth("100%"); east.setWidth("100%");
div.setStyle("text-align: right; "); east.setStyle("text-align: right; ");
div.appendChild(infoLine); east.appendChild(infoLine);
div.appendChild(statusDB); east.appendChild(statusDB);
LayoutUtils.addSclass("status-db", statusDB); LayoutUtils.addSclass("status-db", statusDB);
LayoutUtils.addSclass("status-info", infoLine); LayoutUtils.addSclass("status-info", infoLine);
vbox = new Vbox(); vbox = new Vbox();
vbox.setPack("center"); vbox.setPack("center");
LayoutUtils.addSclass("status", vbox); LayoutUtils.addSclass("status", vbox);
vbox.appendChild(div); vbox.appendChild(east);
hbox.appendChild(vbox); hbox.appendChild(vbox);
this.appendChild(hbox); this.appendChild(hbox);
statusDB.addEventListener(Events.ON_CLICK, this); statusDB.addEventListener(Events.ON_CLICK, this);
infoLine.setVisible(false);
} }
public void setStatusDB (String text) public void setStatusDB (String text)
@ -130,13 +136,28 @@ public class StatusBarPanel extends Panel implements EventListener
statusLine.setTooltiptext(text); statusLine.setTooltiptext(text);
} }
/**
* Add Component to East of StatusBar
*
* @param component
* component
*/
public final void addStatusComponent(final Component component)
{
east.appendChild(component);
} // addStatusComponent
/** /**
* Set Info Line * Set Info Line
* @param text text * @param text text
*/ */
public void setInfo (String text) public void setInfo (String text)
{ {
infoLine.setValue(text); infoLine.setValue(text != null ? text : "");
if (text == null || text.trim().length() == 0)
infoLine.setVisible(false);
else
infoLine.setVisible(true);
} // setInfo } // setInfo
public void onEvent(Event event) throws Exception { public void onEvent(Event event) throws Exception {
@ -147,7 +168,7 @@ public class StatusBarPanel extends Panel implements EventListener
return; return;
String title = Msg.getMsg(Env.getCtx(), "Who") + m_text; String title = Msg.getMsg(Env.getCtx(), "Who") + m_text;
WRecordInfo info = new WRecordInfo (title, m_dse); new WRecordInfo (title, m_dse);
} }
} }

View File

@ -132,7 +132,7 @@ public class FDialog
if (title == null) if (title == null)
{ {
newTitle = Env.getHeader(ctx, windowNo); newTitle = windowNo > 0 ? Env.getHeader(ctx, windowNo) : null;
} }
else else
{ {
@ -141,7 +141,8 @@ public class FDialog
try try
{ {
Messagebox.showDialog(out.toString(), newTitle, Messagebox.OK, Messagebox.EXCLAMATION); String s = out.toString().replace("\n", "<br>");
Messagebox.showDialog(s, newTitle, Messagebox.OK, Messagebox.EXCLAMATION);
} }
catch (InterruptedException exception) catch (InterruptedException exception)
{ {
@ -239,7 +240,8 @@ public class FDialog
try try
{ {
Messagebox.showDialog(out.toString(), Env.getHeader(ctx, windowNo), Messagebox.OK, Messagebox.ERROR); String s = out.toString().replace("\n", "<br>");
Messagebox.showDialog(s, (windowNo > 0 ? Env.getHeader(ctx, windowNo) : null), Messagebox.OK, Messagebox.ERROR);
} }
catch (InterruptedException exception) catch (InterruptedException exception)
{ {
@ -267,7 +269,8 @@ public class FDialog
out.append(Msg.getMsg(Env.getCtx(), adMessage)); out.append(Msg.getMsg(Env.getCtx(), adMessage));
if (msg != null && msg.length() > 0) if (msg != null && msg.length() > 0)
out.append("\n").append(msg); out.append("\n").append(msg);
return ask(windowNo, comp, out.toString()); String s = out.toString().replace("\n", "<br>");
return ask(windowNo, comp, s);
} }
/************************************************************************** /**************************************************************************
@ -284,7 +287,8 @@ public class FDialog
{ {
try try
{ {
int response = Messagebox.showDialog(Msg.getMsg(Env.getCtx(), adMessage), "Confirmation", Messagebox.YES | Messagebox.NO, Messagebox.QUESTION); String s = Msg.getMsg(Env.getCtx(), adMessage).replace("\n", "<br>");
int response = Messagebox.showDialog(s, "Confirmation", Messagebox.YES | Messagebox.NO, Messagebox.QUESTION);
return (response == Messagebox.YES); return (response == Messagebox.YES);
} }
@ -343,7 +347,8 @@ public class FDialog
try try
{ {
Messagebox.showDialog(out.toString(), Env.getHeader(ctx, windowNo), Messagebox.OK, Messagebox.INFORMATION); String s = out.toString().replace("\n", "<br>");
Messagebox.showDialog(s, Env.getHeader(ctx, windowNo), Messagebox.OK, Messagebox.INFORMATION);
} }
catch (InterruptedException exception) catch (InterruptedException exception)
{ {

View File

@ -0,0 +1,49 @@
/******************************************************************************
* Copyright (C) 2008 Low Heng Sin *
* This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program 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 General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program; if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
*****************************************************************************/
package org.adempiere.webui.window;
import java.io.InputStream;
import org.adempiere.webui.component.Window;
import org.adempiere.webui.session.SessionManager;
import org.zkoss.util.media.AMedia;
import org.zkoss.zul.Iframe;
/**
*
* @author Low Heng Sin
*
*/
public class SimplePDFViewer extends Window {
public SimplePDFViewer(String title, InputStream pdfInput) {
Iframe iframe = new Iframe();
iframe.setId("reportFrame");
int height = Double.valueOf(SessionManager.getAppDesktop().getClientInfo().desktopHeight * 0.85).intValue();
this.setHeight(height + "px");
height = height - 30;
iframe.setHeight(height + "px");
iframe.setWidth("100%");
AMedia media = new AMedia(getTitle(), "pdf", "application/pdf", pdfInput);
iframe.setContent(media);
this.setBorder("normal");
this.appendChild(iframe);
this.setClosable(true);
this.setTitle(title);
int width = Double.valueOf(SessionManager.getAppDesktop().getClientInfo().desktopWidth * 0.80).intValue();
this.setWidth(width + "px");
}
}

View File

@ -70,8 +70,8 @@ public final class WAccountDialog extends Window
{ {
super (); super ();
this.setTitle(title); this.setTitle(title);
this.setHeight("450px"); this.setHeight("500px");
this.setWidth("650px"); this.setWidth("700px");
log.config("C_AcctSchema_ID=" + C_AcctSchema_ID log.config("C_AcctSchema_ID=" + C_AcctSchema_ID
+ ", C_ValidCombination_ID=" + mAccount.C_ValidCombination_ID); + ", C_ValidCombination_ID=" + mAccount.C_ValidCombination_ID);
@ -185,7 +185,7 @@ public final class WAccountDialog extends Window
// //
northPanel.appendChild(parameterPanel); northPanel.appendChild(parameterPanel);
parameterPanel.setWidth("80%"); parameterPanel.setWidth("95%");
northPanel.appendChild(toolBar); northPanel.appendChild(toolBar);
northPanel.setWidth("100%"); northPanel.setWidth("100%");
@ -193,15 +193,25 @@ public final class WAccountDialog extends Window
Borderlayout layout = new Borderlayout(); Borderlayout layout = new Borderlayout();
layout.setParent(this); layout.setParent(this);
if (AEnv.isFirefox2())
{
layout.setHeight("93%");
layout.setWidth("98%");
layout.setStyle("background-color: transparent; position: absolute;");
this.setStyle("position: relative;");
}
else
{
layout.setHeight("100%"); layout.setHeight("100%");
layout.setWidth("100%"); layout.setWidth("100%");
layout.setStyle("background-color: transparent;"); layout.setStyle("background-color: transparent;");
}
North nRegion = new North(); North nRegion = new North();
nRegion.setParent(layout); nRegion.setParent(layout);
nRegion.setFlex(true); nRegion.setFlex(false);
nRegion.appendChild(northPanel); nRegion.appendChild(northPanel);
nRegion.setStyle("background-color: transparent;"); nRegion.setStyle("background-color: transparent; border: none");
northPanel.setStyle("background-color: transparent;"); northPanel.setStyle("background-color: transparent;");
Center cRegion = new Center(); Center cRegion = new Center();
@ -216,7 +226,7 @@ public final class WAccountDialog extends Window
confirmPanel.setStyle("margin-top: 5px; margin-bottom: 5px"); confirmPanel.setStyle("margin-top: 5px; margin-bottom: 5px");
div.appendChild(statusBar); div.appendChild(statusBar);
sRegion.appendChild(div); sRegion.appendChild(div);
sRegion.setStyle("background-color: transparent;"); sRegion.setStyle("background-color: transparent; border: none");
confirmPanel.addActionListener(Events.ON_CLICK, this); confirmPanel.addActionListener(Events.ON_CLICK, this);

View File

@ -29,11 +29,11 @@ import org.adempiere.webui.component.Row;
import org.adempiere.webui.component.Rows; import org.adempiere.webui.component.Rows;
import org.adempiere.webui.component.Textbox; import org.adempiere.webui.component.Textbox;
import org.adempiere.webui.component.ConfirmPanel; import org.adempiere.webui.component.ConfirmPanel;
import org.adempiere.webui.component.WStatusBar;
import org.adempiere.webui.component.Window; import org.adempiere.webui.component.Window;
import org.adempiere.webui.editor.WSearchEditor; import org.adempiere.webui.editor.WSearchEditor;
import org.adempiere.webui.event.ValueChangeEvent; import org.adempiere.webui.event.ValueChangeEvent;
import org.adempiere.webui.event.ValueChangeListener; import org.adempiere.webui.event.ValueChangeListener;
import org.adempiere.webui.panel.StatusBarPanel;
import org.compiere.model.Lookup; import org.compiere.model.Lookup;
import org.compiere.model.MClient; import org.compiere.model.MClient;
import org.compiere.model.MLookupFactory; import org.compiere.model.MLookupFactory;
@ -167,7 +167,7 @@ public class WEMailDialog extends Window implements EventListener, ValueChangeLi
private Textbox fAttachment = new Textbox();//40); private Textbox fAttachment = new Textbox();//40);
private Textbox fMessage = new Textbox(); private Textbox fMessage = new Textbox();
private ConfirmPanel confirmPanel = new ConfirmPanel(true); private ConfirmPanel confirmPanel = new ConfirmPanel(true);
private WStatusBar statusBar = new WStatusBar(); private StatusBarPanel statusBar = new StatusBarPanel();
/** /**
* Static Init * Static Init
@ -284,7 +284,6 @@ public class WEMailDialog extends Window implements EventListener, ValueChangeLi
South south = new South(); South south = new South();
south.appendChild(statusBar); south.appendChild(statusBar);
statusBar.setWidth("100%");
layout.appendChild(south); layout.appendChild(south);
south.setStyle("background-color: white"); south.setStyle("background-color: white");

View File

@ -309,7 +309,7 @@ public class WPAttributeDialog extends Window implements EventListener
row = new Row(); row = new Row();
row.setParent(rows); row.setParent(rows);
m_row++; m_row++;
rows.appendChild(label); row.appendChild(label);
row.appendChild(fieldLot); row.appendChild(fieldLot);
if (m_masi.getM_Lot_ID() != 0) if (m_masi.getM_Lot_ID() != 0)
{ {

View File

@ -142,7 +142,7 @@ public class WPAttributeInstance extends Window implements EventListener
South south = new South(); South south = new South();
south.setParent(mainLayout); south.setParent(mainLayout);
south.appendChild(confirmPanel); south.appendChild(confirmPanel);
confirmPanel.addEventListener(Events.ON_CLICK, this); confirmPanel.addActionListener(this);
} // jbInit } // jbInit
/** Table Column Layout Info */ /** Table Column Layout Info */

View File

@ -46,6 +46,11 @@ html,body {
width: 48px; width: 48px;
} }
.action-text-button {
height: 32px;
width: 80px;
}
div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none { div.wc-modal, div.wc-modal-none, div.wc-highlighted, div.wc-highlighted-none {
background-color: white; background-color: white;
} }
@ -253,4 +258,9 @@ tr.tab-desktop-tb-m {
.status-info { .status-info {
padding-right: 10px; padding-right: 10px;
border-left: solid 1px #9CBDFF;
}
.status-border {
border: solid 1px #9CBDFF;
} }