BF [2910358] - Error in context when Key field is found in different tabs.
https://sourceforge.net/tracker/?func=detail&atid=879332&aid=2910358&group_id=176962
This commit is contained in:
parent
18842d7ca0
commit
9f9e61da29
|
@ -102,7 +102,7 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
/**
|
||||
*
|
||||
*/
|
||||
private static final long serialVersionUID = 7198494041906579986L;
|
||||
private static final long serialVersionUID = -5882167959482156252L;
|
||||
|
||||
public static final String DEFAULT_STATUS_MESSAGE = "NavigateOrUpdate";
|
||||
|
||||
|
@ -187,13 +187,15 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
private DataStatusEvent m_lastDataStatusEvent;
|
||||
|
||||
// Context property names:
|
||||
public static final String CTX_KeyColumnName = "KeyColumnName";
|
||||
public static final String CTX_LinkColumnName = "LinkColumnName";
|
||||
public static final String CTX_TabLevel = "TabLevel";
|
||||
public static final String CTX_AccessLevel = "AccessLevel";
|
||||
public static final String CTX_AD_Tab_ID = "AD_Tab_ID";
|
||||
public static final String CTX_Name = "Name";
|
||||
public static final String CTX_AD_Table_ID = "AD_Table_ID";
|
||||
public static final String CTX_KeyColumnName = "_TabInfo_KeyColumnName";
|
||||
public static final String CTX_LinkColumnName = "_TabInfo_LinkColumnName";
|
||||
public static final String CTX_TabLevel = "_TabInfo_TabLevel";
|
||||
public static final String CTX_AccessLevel = "_TabInfo_AccessLevel";
|
||||
public static final String CTX_AD_Tab_ID = "_TabInfo_AD_Tab_ID";
|
||||
public static final String CTX_Name = "_TabInfo_Name";
|
||||
public static final String CTX_AD_Table_ID = "_TabInfo_AD_Table_ID";
|
||||
public static final String CTX_FindSQL = "_TabInfo_FindSQL";
|
||||
public static final String CTX_SQL = "_TabInfo_SQL";
|
||||
|
||||
|
||||
|
||||
|
|
|
@ -359,7 +359,7 @@ public class GridTable extends AbstractTableModel
|
|||
m_SQL += " ORDER BY " + m_orderClause;
|
||||
//
|
||||
log.fine(m_SQL_Count);
|
||||
Env.setContext(m_ctx, m_WindowNo, m_TabNo, "SQL", m_SQL);
|
||||
Env.setContext(m_ctx, m_WindowNo, m_TabNo, GridTab.CTX_SQL, m_SQL);
|
||||
return m_SQL;
|
||||
} // createSelectSql
|
||||
|
||||
|
|
|
@ -75,6 +75,7 @@ import org.compiere.model.DataStatusEvent;
|
|||
import org.compiere.model.DataStatusListener;
|
||||
import org.compiere.model.GridField;
|
||||
import org.compiere.model.GridFieldVO;
|
||||
import org.compiere.model.GridTab;
|
||||
import org.compiere.model.MLookupFactory;
|
||||
import org.compiere.model.MProduct;
|
||||
import org.compiere.model.MQuery;
|
||||
|
@ -111,8 +112,10 @@ import org.compiere.util.ValueNamePair;
|
|||
public final class Find extends CDialog
|
||||
implements ActionListener, ChangeListener, DataStatusListener
|
||||
{
|
||||
/**
|
||||
*
|
||||
*/
|
||||
private static final long serialVersionUID = 6414604433732835410L;
|
||||
|
||||
private int m_AD_Tab_ID;
|
||||
|
||||
/**
|
||||
|
@ -1425,7 +1428,7 @@ public final class Find extends CDialog
|
|||
String finalSQL = MRole.getDefault().addAccessSQL(sql.toString(),
|
||||
m_tableName, MRole.SQL_NOTQUALIFIED, MRole.SQL_RO);
|
||||
finalSQL = Env.parseContext(Env.getCtx(), m_targetWindowNo, finalSQL, false);
|
||||
Env.setContext(Env.getCtx(), m_targetWindowNo, TABNO, "FindSQL", finalSQL);
|
||||
Env.setContext(Env.getCtx(), m_targetWindowNo, TABNO, GridTab.CTX_FindSQL, finalSQL);
|
||||
|
||||
// Execute Qusery
|
||||
m_total = 999999;
|
||||
|
|
|
@ -427,8 +427,7 @@ public abstract class AbstractADWindowPanel extends AbstractUIPart implements To
|
|||
gridWindow.initTab(tabIndex);
|
||||
|
||||
GridTab gTab = gridWindow.getTab(tabIndex);
|
||||
Env.setContext(ctx, curWindowNo, tabIndex, "TabLevel", Integer
|
||||
.toString(gTab.getTabLevel()));
|
||||
Env.setContext(ctx, curWindowNo, tabIndex, GridTab.CTX_TabLevel, Integer.toString(gTab.getTabLevel()));
|
||||
|
||||
// Query first tab
|
||||
if (tabIndex == 0)
|
||||
|
|
|
@ -60,6 +60,7 @@ import org.adempiere.webui.event.ValueChangeListener;
|
|||
import org.adempiere.webui.part.MultiTabPart;
|
||||
import org.compiere.model.GridField;
|
||||
import org.compiere.model.GridFieldVO;
|
||||
import org.compiere.model.GridTab;
|
||||
import org.compiere.model.MLookupFactory;
|
||||
import org.compiere.model.MProduct;
|
||||
import org.compiere.model.MQuery;
|
||||
|
@ -1480,7 +1481,7 @@ public class FindWindow extends Window implements EventListener,ValueChangeListe
|
|||
String finalSQL = MRole.getDefault().addAccessSQL(sql.toString(),
|
||||
m_tableName, MRole.SQL_NOTQUALIFIED, MRole.SQL_RO);
|
||||
finalSQL = Env.parseContext(Env.getCtx(), m_targetWindowNo, finalSQL, false);
|
||||
Env.setContext(Env.getCtx(), m_targetWindowNo, TABNO, "FindSQL", finalSQL);
|
||||
Env.setContext(Env.getCtx(), m_targetWindowNo, TABNO, GridTab.CTX_FindSQL, finalSQL);
|
||||
|
||||
// Execute Qusery
|
||||
m_total = 999999;
|
||||
|
|
Loading…
Reference in New Issue