hg merge release-2.0 (merge release2 into development)
This commit is contained in:
commit
5583a606c2
|
@ -0,0 +1,23 @@
|
||||||
|
SET SQLBLANKLINES ON
|
||||||
|
SET DEFINE OFF
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:16 PM COT
|
||||||
|
-- IDEMPIERE-85 Add confirmation on TreeMaintenance when moving all nodes
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Add to Tree',200255,'D','0f54ecd3-b5ea-47de-8ff9-a3a7ffe0826f','AddToTree','Y',TO_DATE('2014-03-07 22:13:15','YYYY-MM-DD HH24:MI:SS'),100,100,TO_DATE('2014-03-07 22:13:15','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:32 PM COT
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Add ALL to Tree',200256,'D','b544cbd4-9d28-401d-93a5-6351b6480108','AddAllToTree','Y',TO_DATE('2014-03-07 22:13:32','YYYY-MM-DD HH24:MI:SS'),100,100,TO_DATE('2014-03-07 22:13:32','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:44 PM COT
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Delete from Tree',200257,'D','27c456c5-4044-4502-8e7b-f42e1097f25b','DeleteFromTree','Y',TO_DATE('2014-03-07 22:13:43','YYYY-MM-DD HH24:MI:SS'),100,100,TO_DATE('2014-03-07 22:13:43','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:54 PM COT
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Delete ALL from Tree',200258,'D','ed972baa-3e1b-4819-b62a-fbf8047cd62d','DeleteAllFromTree','Y',TO_DATE('2014-03-07 22:13:53','YYYY-MM-DD HH24:MI:SS'),100,100,TO_DATE('2014-03-07 22:13:53','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201403072215_IDEMPIERE-85.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
-- Mar 7, 2014 10:13:16 PM COT
|
||||||
|
-- IDEMPIERE-85 Add confirmation on TreeMaintenance when moving all nodes
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Add to Tree',200255,'D','0f54ecd3-b5ea-47de-8ff9-a3a7ffe0826f','AddToTree','Y',TO_TIMESTAMP('2014-03-07 22:13:15','YYYY-MM-DD HH24:MI:SS'),100,100,TO_TIMESTAMP('2014-03-07 22:13:15','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:32 PM COT
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Add ALL to Tree',200256,'D','b544cbd4-9d28-401d-93a5-6351b6480108','AddAllToTree','Y',TO_TIMESTAMP('2014-03-07 22:13:32','YYYY-MM-DD HH24:MI:SS'),100,100,TO_TIMESTAMP('2014-03-07 22:13:32','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:44 PM COT
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Delete from Tree',200257,'D','27c456c5-4044-4502-8e7b-f42e1097f25b','DeleteFromTree','Y',TO_TIMESTAMP('2014-03-07 22:13:43','YYYY-MM-DD HH24:MI:SS'),100,100,TO_TIMESTAMP('2014-03-07 22:13:43','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Mar 7, 2014 10:13:54 PM COT
|
||||||
|
INSERT INTO AD_Message (MsgType,MsgText,AD_Message_ID,EntityType,AD_Message_UU,Value,IsActive,Updated,CreatedBy,UpdatedBy,Created,AD_Client_ID,AD_Org_ID) VALUES ('I','Delete ALL from Tree',200258,'D','ed972baa-3e1b-4819-b62a-fbf8047cd62d','DeleteAllFromTree','Y',TO_TIMESTAMP('2014-03-07 22:13:53','YYYY-MM-DD HH24:MI:SS'),100,100,TO_TIMESTAMP('2014-03-07 22:13:53','YYYY-MM-DD HH24:MI:SS'),0,0)
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201403072215_IDEMPIERE-85.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -38,7 +38,7 @@ import org.compiere.util.Msg;
|
||||||
* @author victor.perez@e-evolution.com, www.e-evolution.com
|
* @author victor.perez@e-evolution.com, www.e-evolution.com
|
||||||
* <li>RF [ 2214883 ] Remove SQL code and Replace for Query http://sourceforge.net/tracker/index.php?func=detail&aid=2214883&group_id=176962&atid=879335
|
* <li>RF [ 2214883 ] Remove SQL code and Replace for Query http://sourceforge.net/tracker/index.php?func=detail&aid=2214883&group_id=176962&atid=879335
|
||||||
*/
|
*/
|
||||||
public final class MAcctSchemaElement extends X_C_AcctSchema_Element
|
public class MAcctSchemaElement extends X_C_AcctSchema_Element
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,7 @@ import org.compiere.util.Msg;
|
||||||
* <li>BF [ 2880182 ] Error you can allocate a payment to invoice that was paid
|
* <li>BF [ 2880182 ] Error you can allocate a payment to invoice that was paid
|
||||||
* <li> https://sourceforge.net/tracker/index.php?func=detail&aid=2880182&group_id=176962&atid=879332
|
* <li> https://sourceforge.net/tracker/index.php?func=detail&aid=2880182&group_id=176962&atid=879332
|
||||||
*/
|
*/
|
||||||
public final class MAllocationHdr extends X_C_AllocationHdr implements DocAction
|
public class MAllocationHdr extends X_C_AllocationHdr implements DocAction
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
|
@ -29,7 +29,7 @@ import org.compiere.util.CLogger;
|
||||||
*
|
*
|
||||||
* @author Mario Calderon / Carlos Ruiz
|
* @author Mario Calderon / Carlos Ruiz
|
||||||
*/
|
*/
|
||||||
public final class MCity extends X_C_City
|
public class MCity extends X_C_City
|
||||||
implements Comparator<Object>, Serializable
|
implements Comparator<Object>, Serializable
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -147,7 +147,7 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
BigDecimal Amt, BigDecimal Qty,
|
BigDecimal Amt, BigDecimal Qty,
|
||||||
String Description, String trxName)
|
String Description, String trxName)
|
||||||
{
|
{
|
||||||
MCostDetail cd = get (as.getCtx(), "C_InvoiceLine_ID=? AND Coalesce(M_CostElement_ID,0)="+M_CostElement_ID,
|
MCostDetail cd = get (as.getCtx(), "C_InvoiceLine_ID=? AND Coalesce(M_CostElement_ID,0)="+M_CostElement_ID+" AND M_Product_ID="+M_Product_ID,
|
||||||
C_InvoiceLine_ID, M_AttributeSetInstance_ID, as.getC_AcctSchema_ID(), trxName);
|
C_InvoiceLine_ID, M_AttributeSetInstance_ID, as.getC_AcctSchema_ID(), trxName);
|
||||||
//
|
//
|
||||||
if (cd == null) // createNew
|
if (cd == null) // createNew
|
||||||
|
@ -921,6 +921,16 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
private boolean process (MAcctSchema as, MProduct product, MCostElement ce,
|
private boolean process (MAcctSchema as, MProduct product, MCostElement ce,
|
||||||
int Org_ID, int M_ASI_ID)
|
int Org_ID, int M_ASI_ID)
|
||||||
{
|
{
|
||||||
|
//handle compatibility issue between average invoice and average po
|
||||||
|
String costingMethod = product.getCostingMethod(as);
|
||||||
|
if (X_M_Cost.COSTINGMETHOD_AverageInvoice.equals(costingMethod)) {
|
||||||
|
if (ce.isAveragePO())
|
||||||
|
return true;
|
||||||
|
} else if (X_M_Cost.COSTINGMETHOD_AveragePO.equals(costingMethod)) {
|
||||||
|
if (ce.isAverageInvoice())
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
MCost cost = MCost.get(product, M_ASI_ID, as,
|
MCost cost = MCost.get(product, M_ASI_ID, as,
|
||||||
Org_ID, ce.getM_CostElement_ID(), get_TrxName());
|
Org_ID, ce.getM_CostElement_ID(), get_TrxName());
|
||||||
|
|
||||||
|
@ -1139,7 +1149,7 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
{
|
{
|
||||||
if (adjustment)
|
if (adjustment)
|
||||||
{
|
{
|
||||||
String costingMethod = getM_InventoryLine().getM_Inventory().getCostingMethod();
|
costingMethod = getM_InventoryLine().getM_Inventory().getCostingMethod();
|
||||||
if (MCostElement.COSTINGMETHOD_AverageInvoice.equals(costingMethod))
|
if (MCostElement.COSTINGMETHOD_AverageInvoice.equals(costingMethod))
|
||||||
{
|
{
|
||||||
cost.setWeightedAverage(amt.multiply(cost.getCurrentQty()), qty);
|
cost.setWeightedAverage(amt.multiply(cost.getCurrentQty()), qty);
|
||||||
|
@ -1164,7 +1174,7 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
{
|
{
|
||||||
if (adjustment)
|
if (adjustment)
|
||||||
{
|
{
|
||||||
String costingMethod = getM_InventoryLine().getM_Inventory().getCostingMethod();
|
costingMethod = getM_InventoryLine().getM_Inventory().getCostingMethod();
|
||||||
if (MCostElement.COSTINGMETHOD_AveragePO.equals(costingMethod))
|
if (MCostElement.COSTINGMETHOD_AveragePO.equals(costingMethod))
|
||||||
{
|
{
|
||||||
cost.setWeightedAverage(amt.multiply(cost.getCurrentQty()), qty);
|
cost.setWeightedAverage(amt.multiply(cost.getCurrentQty()), qty);
|
||||||
|
@ -1234,7 +1244,7 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
{
|
{
|
||||||
if (adjustment)
|
if (adjustment)
|
||||||
{
|
{
|
||||||
String costingMethod = getM_InventoryLine().getM_Inventory().getCostingMethod();
|
costingMethod = getM_InventoryLine().getM_Inventory().getCostingMethod();
|
||||||
if (MCostElement.COSTINGMETHOD_StandardCosting.equals(costingMethod))
|
if (MCostElement.COSTINGMETHOD_StandardCosting.equals(costingMethod))
|
||||||
{
|
{
|
||||||
cost.add(amt.multiply(cost.getCurrentQty()), qty);
|
cost.add(amt.multiply(cost.getCurrentQty()), qty);
|
||||||
|
|
|
@ -41,7 +41,7 @@ import static org.compiere.model.SystemIDs.*;
|
||||||
* * @author Michael Judd (Akuna Ltd)
|
* * @author Michael Judd (Akuna Ltd)
|
||||||
* <li>BF [ 2695078 ] Country is not translated on invoice
|
* <li>BF [ 2695078 ] Country is not translated on invoice
|
||||||
*/
|
*/
|
||||||
public final class MCountry extends X_C_Country
|
public class MCountry extends X_C_Country
|
||||||
implements Comparator<Object>, Serializable
|
implements Comparator<Object>, Serializable
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -37,7 +37,7 @@ import org.compiere.util.Msg;
|
||||||
* @author Jorg Janke
|
* @author Jorg Janke
|
||||||
* @version $Id: MPaySelectionCheck.java,v 1.3 2006/07/30 00:51:02 jjanke Exp $
|
* @version $Id: MPaySelectionCheck.java,v 1.3 2006/07/30 00:51:02 jjanke Exp $
|
||||||
*/
|
*/
|
||||||
public final class MPaySelectionCheck extends X_C_PaySelectionCheck
|
public class MPaySelectionCheck extends X_C_PaySelectionCheck
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
|
@ -77,7 +77,7 @@ import org.compiere.util.ValueNamePair;
|
||||||
* @author Carlos Ruiz - globalqss [ 2141475 ] Payment <> allocations must not be completed - implement lots of validations on prepareIt
|
* @author Carlos Ruiz - globalqss [ 2141475 ] Payment <> allocations must not be completed - implement lots of validations on prepareIt
|
||||||
* @version $Id: MPayment.java,v 1.4 2006/10/02 05:18:39 jjanke Exp $
|
* @version $Id: MPayment.java,v 1.4 2006/10/02 05:18:39 jjanke Exp $
|
||||||
*/
|
*/
|
||||||
public final class MPayment extends X_C_Payment
|
public class MPayment extends X_C_Payment
|
||||||
implements DocAction, ProcessCall, PaymentInterface
|
implements DocAction, ProcessCall, PaymentInterface
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ import static org.compiere.model.SystemIDs.*;
|
||||||
* @author Jorg Janke
|
* @author Jorg Janke
|
||||||
* @version $Id: MRegion.java,v 1.3 2006/07/30 00:58:36 jjanke Exp $
|
* @version $Id: MRegion.java,v 1.3 2006/07/30 00:58:36 jjanke Exp $
|
||||||
*/
|
*/
|
||||||
public final class MRegion extends X_C_Region
|
public class MRegion extends X_C_Region
|
||||||
implements Comparator<Object>, Serializable
|
implements Comparator<Object>, Serializable
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -33,7 +33,7 @@ import org.compiere.wf.MWFNode;
|
||||||
* @author Jorg Janke
|
* @author Jorg Janke
|
||||||
* @version $Id: MTreeNode.java,v 1.3 2006/07/30 00:51:05 jjanke Exp $
|
* @version $Id: MTreeNode.java,v 1.3 2006/07/30 00:51:05 jjanke Exp $
|
||||||
*/
|
*/
|
||||||
public final class MTreeNode extends DefaultMutableTreeNode
|
public class MTreeNode extends DefaultMutableTreeNode
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
|
@ -125,10 +125,10 @@ public class VTreeMaintenance extends TreeMaintenance
|
||||||
cbAllNodes.setEnabled (false);
|
cbAllNodes.setEnabled (false);
|
||||||
cbAllNodes.setText (Msg.translate(Env.getCtx(), "IsAllNodes"));
|
cbAllNodes.setText (Msg.translate(Env.getCtx(), "IsAllNodes"));
|
||||||
treeInfo.setText (" ");
|
treeInfo.setText (" ");
|
||||||
bAdd.setToolTipText("Add to Tree");
|
bAdd.setToolTipText(Msg.getMsg(Env.getCtx(), "AddToTree"));
|
||||||
bAddAll.setToolTipText("Add ALL to Tree");
|
bAddAll.setToolTipText(Msg.getMsg(Env.getCtx(), "AddAllToTree"));
|
||||||
bDelete.setToolTipText("Delete from Tree");
|
bDelete.setToolTipText(Msg.getMsg(Env.getCtx(), "DeleteFromTree"));
|
||||||
bDeleteAll.setToolTipText("Delete ALL from Tree");
|
bDeleteAll.setToolTipText(Msg.getMsg(Env.getCtx(), "DeleteAllFromTree"));
|
||||||
bAdd.addActionListener(this);
|
bAdd.addActionListener(this);
|
||||||
bAddAll.addActionListener(this);
|
bAddAll.addActionListener(this);
|
||||||
bDelete.addActionListener(this);
|
bDelete.addActionListener(this);
|
||||||
|
|
|
@ -77,7 +77,7 @@ public class AdempiereWebUI extends Window implements EventListener<Event>, IWeb
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 6505634026383902627L;
|
private static final long serialVersionUID = 5875869799688466929L;
|
||||||
|
|
||||||
private static final String SAVED_CONTEXT = "saved.context";
|
private static final String SAVED_CONTEXT = "saved.context";
|
||||||
|
|
||||||
|
@ -103,8 +103,6 @@ public class AdempiereWebUI extends Window implements EventListener<Event>, IWeb
|
||||||
|
|
||||||
public static final String EXECUTION_CARRYOVER_SESSION_KEY = "execution.carryover";
|
public static final String EXECUTION_CARRYOVER_SESSION_KEY = "execution.carryover";
|
||||||
|
|
||||||
public static final String ZK_DESKTOP_SESSION_KEY = "zk.desktop";
|
|
||||||
|
|
||||||
private static final String CLIENT_INFO = "client.info";
|
private static final String CLIENT_INFO = "client.info";
|
||||||
|
|
||||||
private static boolean eventThreadEnabled = false;
|
private static boolean eventThreadEnabled = false;
|
||||||
|
@ -246,7 +244,6 @@ public class AdempiereWebUI extends Window implements EventListener<Event>, IWeb
|
||||||
IDesktop appDesktop = createDesktop();
|
IDesktop appDesktop = createDesktop();
|
||||||
appDesktop.setClientInfo(clientInfo);
|
appDesktop.setClientInfo(clientInfo);
|
||||||
appDesktop.createPart(this.getPage());
|
appDesktop.createPart(this.getPage());
|
||||||
ctx.put(ZK_DESKTOP_SESSION_KEY, new WeakReference<Desktop>(this.getPage().getDesktop()));
|
|
||||||
this.getPage().getDesktop().setAttribute(APPLICATION_DESKTOP_KEY, new WeakReference<IDesktop>(appDesktop));
|
this.getPage().getDesktop().setAttribute(APPLICATION_DESKTOP_KEY, new WeakReference<IDesktop>(appDesktop));
|
||||||
|
|
||||||
//track browser tab per session
|
//track browser tab per session
|
||||||
|
|
|
@ -34,7 +34,6 @@ import java.util.logging.Level;
|
||||||
|
|
||||||
import javax.servlet.ServletRequest;
|
import javax.servlet.ServletRequest;
|
||||||
|
|
||||||
import org.adempiere.webui.AdempiereWebUI;
|
|
||||||
import org.adempiere.webui.component.Window;
|
import org.adempiere.webui.component.Window;
|
||||||
import org.adempiere.webui.desktop.IDesktop;
|
import org.adempiere.webui.desktop.IDesktop;
|
||||||
import org.adempiere.webui.session.SessionManager;
|
import org.adempiere.webui.session.SessionManager;
|
||||||
|
@ -749,8 +748,7 @@ public final class AEnv
|
||||||
if (inUIThread) {
|
if (inUIThread) {
|
||||||
return Executions.getCurrent().getDesktop();
|
return Executions.getCurrent().getDesktop();
|
||||||
} else {
|
} else {
|
||||||
@SuppressWarnings("unchecked")
|
WeakReference<Desktop> ref = DesktopRunnable.getThreadLocalDesktop();
|
||||||
WeakReference<Desktop> ref = (WeakReference<Desktop>) Env.getCtx().get(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY);
|
|
||||||
return ref != null ? ref.get() : null;
|
return ref != null ? ref.get() : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.adempiere.webui.apps;
|
||||||
|
|
||||||
|
import java.lang.ref.WeakReference;
|
||||||
|
|
||||||
|
import org.zkoss.zk.ui.Desktop;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If your background task need access to desktop, wrap your runnable with this, i.e new DesktopRunnable(yourRunnable, desktop).
|
||||||
|
* You can then use AEnv.getDesktop() in your runnable to get access to desktop.
|
||||||
|
* @author hengsin
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class DesktopRunnable implements Runnable {
|
||||||
|
|
||||||
|
private Runnable runnable;
|
||||||
|
private WeakReference<Desktop> desktopWeakRef;
|
||||||
|
|
||||||
|
private static ThreadLocal<WeakReference<Desktop>> threadLocalDesktop = new ThreadLocal<WeakReference<Desktop>>() {
|
||||||
|
protected WeakReference<Desktop> initialValue()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public DesktopRunnable(Runnable runnable, Desktop desktop) {
|
||||||
|
this.runnable = runnable;
|
||||||
|
this.desktopWeakRef = new WeakReference<Desktop>(desktop);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see java.lang.Runnable#run()
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
threadLocalDesktop.set(desktopWeakRef);
|
||||||
|
runnable.run();
|
||||||
|
} finally {
|
||||||
|
threadLocalDesktop.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* package */static WeakReference<Desktop> getThreadLocalDesktop() {
|
||||||
|
return threadLocalDesktop.get();
|
||||||
|
}
|
||||||
|
}
|
|
@ -6,7 +6,6 @@ import static org.compiere.model.SystemIDs.PROCESS_M_INOUT_GENERATE;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
@ -20,8 +19,6 @@ import java.util.logging.Level;
|
||||||
import org.adempiere.util.Callback;
|
import org.adempiere.util.Callback;
|
||||||
import org.adempiere.util.ContextRunnable;
|
import org.adempiere.util.ContextRunnable;
|
||||||
import org.adempiere.util.IProcessUI;
|
import org.adempiere.util.IProcessUI;
|
||||||
import org.adempiere.util.ServerContext;
|
|
||||||
import org.adempiere.webui.AdempiereWebUI;
|
|
||||||
import org.adempiere.webui.LayoutUtils;
|
import org.adempiere.webui.LayoutUtils;
|
||||||
import org.adempiere.webui.component.Button;
|
import org.adempiere.webui.component.Button;
|
||||||
import org.adempiere.webui.component.ConfirmPanel;
|
import org.adempiere.webui.component.ConfirmPanel;
|
||||||
|
@ -108,9 +105,10 @@ import com.lowagie.text.pdf.PdfWriter;
|
||||||
public class ProcessDialog extends Window implements EventListener<Event>, IProcessUI, IHelpContext
|
public class ProcessDialog extends Window implements EventListener<Event>, IProcessUI, IHelpContext
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* generate serial version ID
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 5545731871518761455L;
|
private static final long serialVersionUID = 6316822220179816250L;
|
||||||
|
|
||||||
private static final String MESSAGE_DIV_STYLE = "max-height: 150pt; overflow: auto; margin: 10px;";
|
private static final String MESSAGE_DIV_STYLE = "max-height: 150pt; overflow: auto; margin: 10px;";
|
||||||
private Div messageDiv;
|
private Div messageDiv;
|
||||||
private Center center;
|
private Center center;
|
||||||
|
@ -347,15 +345,8 @@ public class ProcessDialog extends Window implements EventListener<Event>, IProc
|
||||||
}
|
}
|
||||||
|
|
||||||
public void runProcess() {
|
public void runProcess() {
|
||||||
//prepare context for background thread
|
|
||||||
Properties context = ServerContext.getCurrentInstance();
|
|
||||||
if (context.get(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY) == null) {
|
|
||||||
Desktop desktop = this.getDesktop();
|
|
||||||
context.put(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY, new WeakReference<Desktop>(desktop));
|
|
||||||
}
|
|
||||||
|
|
||||||
processDialogRunnable = new ProcessDialogRunnable();
|
processDialogRunnable = new ProcessDialogRunnable();
|
||||||
future = Adempiere.getThreadPoolExecutor().submit(processDialogRunnable);
|
future = Adempiere.getThreadPoolExecutor().submit(new DesktopRunnable(processDialogRunnable, getDesktop()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onComplete() {
|
private void onComplete() {
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
package org.adempiere.webui.apps;
|
package org.adempiere.webui.apps;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
@ -30,8 +29,6 @@ import java.util.logging.Level;
|
||||||
import org.adempiere.util.Callback;
|
import org.adempiere.util.Callback;
|
||||||
import org.adempiere.util.ContextRunnable;
|
import org.adempiere.util.ContextRunnable;
|
||||||
import org.adempiere.util.IProcessUI;
|
import org.adempiere.util.IProcessUI;
|
||||||
import org.adempiere.util.ServerContext;
|
|
||||||
import org.adempiere.webui.AdempiereWebUI;
|
|
||||||
import org.adempiere.webui.LayoutUtils;
|
import org.adempiere.webui.LayoutUtils;
|
||||||
import org.adempiere.webui.component.Button;
|
import org.adempiere.webui.component.Button;
|
||||||
import org.adempiere.webui.component.ConfirmPanel;
|
import org.adempiere.webui.component.ConfirmPanel;
|
||||||
|
@ -50,7 +47,6 @@ 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.au.out.AuEcho;
|
||||||
import org.zkoss.zk.ui.Component;
|
import org.zkoss.zk.ui.Component;
|
||||||
import org.zkoss.zk.ui.Desktop;
|
|
||||||
import org.zkoss.zk.ui.Executions;
|
import org.zkoss.zk.ui.Executions;
|
||||||
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;
|
||||||
|
@ -74,13 +70,14 @@ import org.zkoss.zul.Vlayout;
|
||||||
*/
|
*/
|
||||||
public class ProcessModalDialog extends Window implements EventListener<Event>, IProcessUI, DialogEvents
|
public class ProcessModalDialog extends Window implements EventListener<Event>, IProcessUI, DialogEvents
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
private static final long serialVersionUID = -3708004619583382450L;
|
||||||
|
|
||||||
private static final String ON_STATUS_UPDATE = "onStatusUpdate";
|
private static final String ON_STATUS_UPDATE = "onStatusUpdate";
|
||||||
private static final String ON_COMPLETE = "onComplete";
|
private static final String ON_COMPLETE = "onComplete";
|
||||||
|
|
||||||
/**
|
|
||||||
* generated serial version ID
|
|
||||||
*/
|
|
||||||
private static final long serialVersionUID = -7109707014309321369L;
|
|
||||||
private boolean m_autoStart;
|
private boolean m_autoStart;
|
||||||
private VerticalBox dialogBody;
|
private VerticalBox dialogBody;
|
||||||
|
|
||||||
|
@ -379,15 +376,8 @@ public class ProcessModalDialog extends Window implements EventListener<Event>,
|
||||||
* internal use, don't call this directly
|
* internal use, don't call this directly
|
||||||
*/
|
*/
|
||||||
public void runProcess() {
|
public void runProcess() {
|
||||||
//prepare context for background thread
|
|
||||||
Properties context = ServerContext.getCurrentInstance();
|
|
||||||
if (context.get(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY) == null) {
|
|
||||||
Desktop desktop = this.getDesktop();
|
|
||||||
context.put(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY, new WeakReference<Desktop>(desktop));
|
|
||||||
}
|
|
||||||
|
|
||||||
processDialogRunnable = new ProcessDialogRunnable();
|
processDialogRunnable = new ProcessDialogRunnable();
|
||||||
future = Adempiere.getThreadPoolExecutor().submit(processDialogRunnable);
|
future = Adempiere.getThreadPoolExecutor().submit(new DesktopRunnable(processDialogRunnable, getDesktop()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void hideBusyDialog() {
|
private void hideBusyDialog() {
|
||||||
|
|
|
@ -144,10 +144,10 @@ public class WTreeMaintenance extends TreeMaintenance implements IFormController
|
||||||
cbAllNodes.setEnabled (false);
|
cbAllNodes.setEnabled (false);
|
||||||
cbAllNodes.setText (Msg.translate(Env.getCtx(), "IsAllNodes"));
|
cbAllNodes.setText (Msg.translate(Env.getCtx(), "IsAllNodes"));
|
||||||
treeInfo.setText (" ");
|
treeInfo.setText (" ");
|
||||||
bAdd.setTooltiptext("Add to Tree");
|
bAdd.setTooltiptext(Msg.getMsg(Env.getCtx(), "AddToTree"));
|
||||||
bAddAll.setTooltiptext("Add ALL to Tree");
|
bAddAll.setTooltiptext(Msg.getMsg(Env.getCtx(), "AddAllToTree"));
|
||||||
bDelete.setTooltiptext("Delete from Tree");
|
bDelete.setTooltiptext(Msg.getMsg(Env.getCtx(), "DeleteFromTree"));
|
||||||
bDeleteAll.setTooltiptext("Delete ALL from Tree");
|
bDeleteAll.setTooltiptext(Msg.getMsg(Env.getCtx(), "DeleteAllFromTree"));
|
||||||
bAdd.addActionListener(this);
|
bAdd.addActionListener(this);
|
||||||
bAddAll.addActionListener(this);
|
bAddAll.addActionListener(this);
|
||||||
bDelete.addActionListener(this);
|
bDelete.addActionListener(this);
|
||||||
|
|
|
@ -49,6 +49,7 @@ public class WFNodeContainer
|
||||||
private int currentRow = 1;
|
private int currentRow = 1;
|
||||||
private int currentColumn = 0;
|
private int currentColumn = 0;
|
||||||
private int noOfColumns = 4;
|
private int noOfColumns = 4;
|
||||||
|
private int maxColumn = 0;
|
||||||
private int rowCount = 0;
|
private int rowCount = 0;
|
||||||
|
|
||||||
private WorkflowGraphScene graphScene = new WorkflowGraphScene();
|
private WorkflowGraphScene graphScene = new WorkflowGraphScene();
|
||||||
|
@ -146,6 +147,9 @@ public class WFNodeContainer
|
||||||
w.setRow(currentRow);
|
w.setRow(currentRow);
|
||||||
|
|
||||||
nodes[currentColumn - 1] = node.getAD_WF_Node_ID();
|
nodes[currentColumn - 1] = node.getAD_WF_Node_ID();
|
||||||
|
if (currentColumn > maxColumn) {
|
||||||
|
maxColumn = currentColumn;
|
||||||
|
}
|
||||||
|
|
||||||
if (currentRow < oldRow) {
|
if (currentRow < oldRow) {
|
||||||
currentRow = oldRow;
|
currentRow = oldRow;
|
||||||
|
@ -227,6 +231,10 @@ public class WFNodeContainer
|
||||||
return noOfColumns;
|
return noOfColumns;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getMaxColumnWithNode() {
|
||||||
|
return maxColumn;
|
||||||
|
}
|
||||||
|
|
||||||
public GraphScene<Integer, MWFNodeNext> getGraphScene() {
|
public GraphScene<Integer, MWFNodeNext> getGraphScene() {
|
||||||
return graphScene;
|
return graphScene;
|
||||||
}
|
}
|
||||||
|
|
|
@ -187,14 +187,15 @@ public class WFPanel extends Borderlayout implements EventListener<Event>, IHelp
|
||||||
|
|
||||||
try {
|
try {
|
||||||
int row = nodeContainer.getRowCount();
|
int row = nodeContainer.getRowCount();
|
||||||
|
int maxCol = nodeContainer.getMaxColumnWithNode();
|
||||||
for(int i = 0; i < row; i++) {
|
for(int i = 0; i < row; i++) {
|
||||||
Tr tr = new Tr();
|
Tr tr = new Tr();
|
||||||
table.appendChild(tr);
|
table.appendChild(tr);
|
||||||
for(int c = 0; c < 4; c++) {
|
for(int c = 0; c < maxCol; c++) {
|
||||||
BufferedImage t = new BufferedImage(WFGraphLayout.COLUMN_WIDTH, WFGraphLayout.ROW_HEIGHT, BufferedImage.TYPE_INT_ARGB);
|
BufferedImage t = new BufferedImage(WFGraphLayout.COLUMN_WIDTH, WFGraphLayout.ROW_HEIGHT, BufferedImage.TYPE_INT_ARGB);
|
||||||
Graphics2D tg = t.createGraphics();
|
Graphics2D tg = t.createGraphics();
|
||||||
Td td = new Td();
|
Td td = new Td();
|
||||||
// td.setStyle("border: 1px dotted lightgray");
|
td.setSclass("workflow-panel-table");
|
||||||
tr.appendChild(td);
|
tr.appendChild(td);
|
||||||
|
|
||||||
int x = c * WFGraphLayout.COLUMN_WIDTH;
|
int x = c * WFGraphLayout.COLUMN_WIDTH;
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
package org.adempiere.webui.desktop;
|
package org.adempiere.webui.desktop;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.adempiere.webui.AdempiereWebUI;
|
import org.adempiere.webui.AdempiereWebUI;
|
||||||
|
@ -26,6 +27,7 @@ import org.compiere.model.MMenu;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.util.CLogger;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.util.Env;
|
||||||
import org.zkoss.zk.ui.Executions;
|
import org.zkoss.zk.ui.Executions;
|
||||||
|
import org.zkoss.zk.ui.Session;
|
||||||
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.zul.Window.Mode;
|
import org.zkoss.zul.Window.Mode;
|
||||||
|
@ -39,13 +41,10 @@ public abstract class AbstractDesktop extends AbstractUIPart implements IDesktop
|
||||||
|
|
||||||
private transient ClientInfo clientInfo;
|
private transient ClientInfo clientInfo;
|
||||||
|
|
||||||
private List<Object> windows = null;
|
|
||||||
|
|
||||||
@SuppressWarnings("unused")
|
@SuppressWarnings("unused")
|
||||||
private static final CLogger logger = CLogger.getCLogger(AbstractDesktop.class);
|
private static final CLogger logger = CLogger.getCLogger(AbstractDesktop.class);
|
||||||
|
|
||||||
public AbstractDesktop() {
|
public AbstractDesktop() {
|
||||||
windows = new ArrayList<Object>();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -112,6 +111,7 @@ public abstract class AbstractDesktop extends AbstractUIPart implements IDesktop
|
||||||
* @param win
|
* @param win
|
||||||
*/
|
*/
|
||||||
public int registerWindow(Object win) {
|
public int registerWindow(Object win) {
|
||||||
|
List<Object> windows = getWindows();
|
||||||
int retValue = windows.size();
|
int retValue = windows.size();
|
||||||
windows.add(win);
|
windows.add(win);
|
||||||
return retValue;
|
return retValue;
|
||||||
|
@ -121,6 +121,7 @@ public abstract class AbstractDesktop extends AbstractUIPart implements IDesktop
|
||||||
* @param WindowNo
|
* @param WindowNo
|
||||||
*/
|
*/
|
||||||
public void unregisterWindow(int WindowNo) {
|
public void unregisterWindow(int WindowNo) {
|
||||||
|
List<Object> windows = getWindows();
|
||||||
if (WindowNo < windows.size())
|
if (WindowNo < windows.size())
|
||||||
windows.set(WindowNo, null);
|
windows.set(WindowNo, null);
|
||||||
Env.clearWinContext(WindowNo);
|
Env.clearWinContext(WindowNo);
|
||||||
|
@ -132,6 +133,7 @@ public abstract class AbstractDesktop extends AbstractUIPart implements IDesktop
|
||||||
* @return Object
|
* @return Object
|
||||||
*/
|
*/
|
||||||
public Object findWindow(int WindowNo) {
|
public Object findWindow(int WindowNo) {
|
||||||
|
List<Object> windows = getWindows();
|
||||||
if (WindowNo < windows.size())
|
if (WindowNo < windows.size())
|
||||||
return windows.get(WindowNo);
|
return windows.get(WindowNo);
|
||||||
else
|
else
|
||||||
|
@ -297,7 +299,14 @@ public abstract class AbstractDesktop extends AbstractUIPart implements IDesktop
|
||||||
}
|
}
|
||||||
|
|
||||||
protected List<Object> getWindows(){
|
protected List<Object> getWindows(){
|
||||||
return windows;
|
Session session = getComponent().getDesktop().getSession();
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
List<Object> list = (List<Object>) session.getAttribute("windows.list");
|
||||||
|
if (list == null) {
|
||||||
|
list = new ArrayList<Object>();
|
||||||
|
session.setAttribute("windows.list", list);
|
||||||
|
}
|
||||||
|
return Collections.synchronizedList(list);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,7 @@ import org.adempiere.util.ServerContext;
|
||||||
import org.adempiere.webui.adwindow.ADWindow;
|
import org.adempiere.webui.adwindow.ADWindow;
|
||||||
import org.adempiere.webui.apps.AEnv;
|
import org.adempiere.webui.apps.AEnv;
|
||||||
import org.adempiere.webui.apps.BusyDialog;
|
import org.adempiere.webui.apps.BusyDialog;
|
||||||
|
import org.adempiere.webui.apps.DesktopRunnable;
|
||||||
import org.adempiere.webui.apps.ProcessDialog;
|
import org.adempiere.webui.apps.ProcessDialog;
|
||||||
import org.adempiere.webui.apps.WReport;
|
import org.adempiere.webui.apps.WReport;
|
||||||
import org.adempiere.webui.component.Tab;
|
import org.adempiere.webui.component.Tab;
|
||||||
|
@ -266,7 +267,7 @@ public class DefaultDesktop extends TabbedDesktop implements MenuListener, Seria
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
Adempiere.getThreadPoolExecutor().submit(runnable);
|
Adempiere.getThreadPoolExecutor().submit(new DesktopRunnable(runnable,layout.getDesktop()));
|
||||||
|
|
||||||
ToolBar toolbar = new ToolBar();
|
ToolBar toolbar = new ToolBar();
|
||||||
windowContainer.getComponent().appendChild(toolbar);
|
windowContainer.getComponent().appendChild(toolbar);
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
|
|
||||||
package org.adempiere.webui.session;
|
package org.adempiere.webui.session;
|
||||||
|
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -133,8 +132,6 @@ public class SessionContextListener implements ExecutionInit,
|
||||||
//set locale
|
//set locale
|
||||||
Locales.setThreadLocal(Env.getLanguage(ServerContext.getCurrentInstance()).getLocale());
|
Locales.setThreadLocal(Env.getLanguage(ServerContext.getCurrentInstance()).getLocale());
|
||||||
}
|
}
|
||||||
Properties ctx = ServerContext.getCurrentInstance();
|
|
||||||
ctx.put(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY, new WeakReference<Desktop>(exec.getDesktop()));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,7 @@ public interface ITheme {
|
||||||
|
|
||||||
//stylesheet url
|
//stylesheet url
|
||||||
public static final String THEME_STYLESHEET = "/css/theme.css.dsp";
|
public static final String THEME_STYLESHEET = "/css/theme.css.dsp";
|
||||||
|
//http://books.zkoss.org/wiki/ZK_Developer's_Reference/Internationalization/Locale-Dependent_Resources#Specifying_Locale-_and_browser-dependent_URL
|
||||||
public static final String THEME_STYLESHEET_BY_BROWSER = "/css/theme*.css.dsp*";
|
public static final String THEME_STYLESHEET_BY_BROWSER = "/css/theme*.css.dsp*";
|
||||||
|
|
||||||
//theme preference
|
//theme preference
|
||||||
|
|
|
@ -21,7 +21,6 @@ import static org.compiere.model.SystemIDs.WINDOW_PRINTFORMAT;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
@ -36,11 +35,10 @@ import javax.servlet.http.HttpServletRequest;
|
||||||
import org.adempiere.exceptions.DBException;
|
import org.adempiere.exceptions.DBException;
|
||||||
import org.adempiere.pdf.Document;
|
import org.adempiere.pdf.Document;
|
||||||
import org.adempiere.util.ContextRunnable;
|
import org.adempiere.util.ContextRunnable;
|
||||||
import org.adempiere.util.ServerContext;
|
|
||||||
import org.adempiere.webui.AdempiereWebUI;
|
|
||||||
import org.adempiere.webui.LayoutUtils;
|
import org.adempiere.webui.LayoutUtils;
|
||||||
import org.adempiere.webui.apps.AEnv;
|
import org.adempiere.webui.apps.AEnv;
|
||||||
import org.adempiere.webui.apps.BusyDialog;
|
import org.adempiere.webui.apps.BusyDialog;
|
||||||
|
import org.adempiere.webui.apps.DesktopRunnable;
|
||||||
import org.adempiere.webui.apps.WReport;
|
import org.adempiere.webui.apps.WReport;
|
||||||
import org.adempiere.webui.apps.form.WReportCustomization;
|
import org.adempiere.webui.apps.form.WReportCustomization;
|
||||||
import org.adempiere.webui.component.Checkbox;
|
import org.adempiere.webui.component.Checkbox;
|
||||||
|
@ -138,7 +136,7 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 6208607687967139151L;
|
private static final long serialVersionUID = 3463776496724974142L;
|
||||||
|
|
||||||
/** Window No */
|
/** Window No */
|
||||||
private int m_WindowNo = -1;
|
private int m_WindowNo = -1;
|
||||||
|
@ -461,21 +459,14 @@ public class ZkReportViewer extends Window implements EventListener<Event>, ITab
|
||||||
}
|
}
|
||||||
|
|
||||||
private void renderReport() {
|
private void renderReport() {
|
||||||
//prepare context for background thread
|
|
||||||
Properties context = ServerContext.getCurrentInstance();
|
|
||||||
if (context.get(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY) == null) {
|
|
||||||
Desktop desktop = this.getDesktop();
|
|
||||||
context.put(AdempiereWebUI.ZK_DESKTOP_SESSION_KEY, new WeakReference<Desktop>(desktop));
|
|
||||||
}
|
|
||||||
|
|
||||||
media = null;
|
media = null;
|
||||||
Listitem selected = previewType.getSelectedItem();
|
Listitem selected = previewType.getSelectedItem();
|
||||||
if (selected == null || "PDF".equals(selected.getValue())) {
|
if (selected == null || "PDF".equals(selected.getValue())) {
|
||||||
future = Adempiere.getThreadPoolExecutor().submit(new PDFRendererRunnable(this));
|
future = Adempiere.getThreadPoolExecutor().submit(new DesktopRunnable(new PDFRendererRunnable(this),getDesktop()));
|
||||||
} else if ("HTML".equals(previewType.getSelectedItem().getValue())) {
|
} else if ("HTML".equals(previewType.getSelectedItem().getValue())) {
|
||||||
future = Adempiere.getThreadPoolExecutor().submit(new HTMLRendererRunnable(this));
|
future = Adempiere.getThreadPoolExecutor().submit(new DesktopRunnable(new HTMLRendererRunnable(this),getDesktop()));
|
||||||
} else if ("XLS".equals(previewType.getSelectedItem().getValue())) {
|
} else if ("XLS".equals(previewType.getSelectedItem().getValue())) {
|
||||||
future = Adempiere.getThreadPoolExecutor().submit(new XLSRendererRunnable(this));
|
future = Adempiere.getThreadPoolExecutor().submit(new DesktopRunnable(new XLSRendererRunnable(this),getDesktop()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1764,6 +1764,10 @@ table.z-vbox > tbody > tr > td > table {
|
||||||
.workflow-activity-form {
|
.workflow-activity-form {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.workflow-panel-table {
|
||||||
|
border: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
<%-- find window --%>
|
<%-- find window --%>
|
||||||
.find-window {
|
.find-window {
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
<%@ page contentType="text/css;charset=UTF-8" %>
|
||||||
|
<%@ taglib uri="http://www.zkoss.org/dsp/web/core" prefix="c" %>
|
|
@ -0,0 +1,2 @@
|
||||||
|
<%@ page contentType="text/css;charset=UTF-8" %>
|
||||||
|
<%@ taglib uri="http://www.zkoss.org/dsp/web/core" prefix="c" %>
|
|
@ -421,7 +421,8 @@ public class Allocation
|
||||||
|
|
||||||
if (col == i_payment)
|
if (col == i_payment)
|
||||||
{
|
{
|
||||||
if ( open.signum() > 0 && applied.signum() == -open.signum() )
|
if (! MSysConfig.getBooleanValue("ALLOW_APPLY_PAYMENT_TO_CREDITMEMO", false, Env.getAD_Client_ID(Env.getCtx()))
|
||||||
|
&& open.signum() > 0 && applied.signum() == -open.signum() )
|
||||||
applied = applied.negate();
|
applied = applied.negate();
|
||||||
if (! MSysConfig.getBooleanValue("ALLOW_OVER_APPLIED_PAYMENT", false, Env.getAD_Client_ID(Env.getCtx())))
|
if (! MSysConfig.getBooleanValue("ALLOW_OVER_APPLIED_PAYMENT", false, Env.getAD_Client_ID(Env.getCtx())))
|
||||||
if ( open.abs().compareTo( applied.abs() ) < 0 )
|
if ( open.abs().compareTo( applied.abs() ) < 0 )
|
||||||
|
@ -758,7 +759,7 @@ public class Allocation
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( unmatchedApplied.signum() != 0 )
|
if ( unmatchedApplied.signum() != 0 )
|
||||||
log.log(Level.SEVERE, "Allocation not balanced -- out by " + unmatchedApplied );
|
throw new AdempiereException("Allocation not balanced -- out by " + unmatchedApplied);
|
||||||
|
|
||||||
// Should start WF
|
// Should start WF
|
||||||
if (alloc.get_ID() != 0)
|
if (alloc.get_ID() != 0)
|
||||||
|
|
|
@ -26,6 +26,7 @@ import org.compiere.model.MTree_NodeMM;
|
||||||
import org.compiere.model.MTree_NodePR;
|
import org.compiere.model.MTree_NodePR;
|
||||||
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.KeyNamePair;
|
import org.compiere.util.KeyNamePair;
|
||||||
|
|
||||||
public class TreeMaintenance {
|
public class TreeMaintenance {
|
||||||
|
@ -51,14 +52,29 @@ public class TreeMaintenance {
|
||||||
String fromClause = m_tree.getSourceTableName(false); // fully qualified
|
String fromClause = m_tree.getSourceTableName(false); // fully qualified
|
||||||
String columnNameX = m_tree.getSourceTableName(true);
|
String columnNameX = m_tree.getSourceTableName(true);
|
||||||
String actionColor = m_tree.getActionColorName();
|
String actionColor = m_tree.getActionColorName();
|
||||||
|
String fieldName = null;
|
||||||
|
String fieldDescription = null;
|
||||||
|
String join = null;
|
||||||
|
if (m_tree.getTreeType().equals(MTree.TREETYPE_Menu) // IDEMPIERE-1581 (see MTree.getNodeDetails)
|
||||||
|
&& ! Env.isBaseLanguage(Env.getCtx(), "AD_Menu")) {
|
||||||
|
fieldName = "trl.Name";
|
||||||
|
fieldDescription ="trl.Description";
|
||||||
|
join = " LEFT JOIN AD_Menu_Trl trl ON (t.AD_Menu_ID = trl.AD_Menu_ID AND trl.AD_Language='"
|
||||||
|
+ Env.getAD_Language(Env.getCtx()) + "')";
|
||||||
|
} else {
|
||||||
|
fieldName ="t.Name";
|
||||||
|
fieldDescription ="t.Description";
|
||||||
|
join = "";
|
||||||
|
}
|
||||||
|
|
||||||
String sql = "SELECT t." + columnNameX
|
StringBuilder sqlb = new StringBuilder("SELECT t.")
|
||||||
+ "_ID,t.Name,t.Description,t.IsSummary,"
|
.append(columnNameX)
|
||||||
+ actionColor
|
.append("_ID,").append(fieldName).append(",").append(fieldDescription).append(",t.IsSummary,")
|
||||||
+ " FROM " + fromClause
|
.append(actionColor)
|
||||||
// + " WHERE t.IsActive='Y'" // R/O
|
.append(" FROM ").append(fromClause).append(join)
|
||||||
+ " ORDER BY 2";
|
// .append(" WHERE t.IsActive='Y'") // R/O
|
||||||
sql = MRole.getDefault().addAccessSQL(sql,
|
.append(" ORDER BY 2");
|
||||||
|
String sql = MRole.getDefault().addAccessSQL(sqlb.toString(),
|
||||||
"t", MRole.SQL_FULLYQUALIFIED, MRole.SQL_RO);
|
"t", MRole.SQL_FULLYQUALIFIED, MRole.SQL_RO);
|
||||||
log.config(sql);
|
log.config(sql);
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in New Issue