IDEMPIERE-3732 : MRefList.getList cannot allow to choose order by (#746)

* IDEMPIERE-3732 : MRefList.getList cannot allow to choose order by

* @nmicoud IDEMPIERE-3732 : MRefList.getList cannot allow to choose order by - ASP filter

Co-Authored-By: Carlos Ruiz <carg67@gmail.com>
This commit is contained in:
Nicolas Micoud 2021-07-07 10:44:07 +02:00 committed by GitHub
parent 19e36d16e9
commit 8ef060d938
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 56 additions and 42 deletions

View File

@ -293,7 +293,8 @@ public class MLookupFactory
return retValue.cloneIt(); return retValue.cloneIt();
} }
String byValue = DB.getSQLValueString(null, "SELECT IsOrderByValue FROM AD_Reference WHERE AD_Reference_ID = ? ", AD_Reference_Value_ID); boolean orderByValue = MReference.get(AD_Reference_Value_ID).isOrderByValue();
StringBuilder realSQL = new StringBuilder ("SELECT NULL, AD_Ref_List.Value,"); StringBuilder realSQL = new StringBuilder ("SELECT NULL, AD_Ref_List.Value,");
MClient client = MClient.get(Env.getCtx()); MClient client = MClient.get(Env.getCtx());
StringBuilder AspFilter = new StringBuilder(); StringBuilder AspFilter = new StringBuilder();
@ -322,7 +323,7 @@ public class MLookupFactory
String directSql = realSQL.toString() + " AND AD_Ref_List.Value=?"; String directSql = realSQL.toString() + " AND AD_Ref_List.Value=?";
realSQL.append(AspFilter.toString()); realSQL.append(AspFilter.toString());
if ("Y".equals(byValue)) if (orderByValue)
realSQL.append(" ORDER BY 2"); realSQL.append(" ORDER BY 2");
else else
realSQL.append(" ORDER BY 3"); // sort by name/translated name - teo_sarca, [ 1672820 ] realSQL.append(" ORDER BY 3"); // sort by name/translated name - teo_sarca, [ 1672820 ]

View File

@ -19,7 +19,6 @@ package org.compiere.model;
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.Properties; import java.util.Properties;
import java.util.logging.Level; import java.util.logging.Level;
@ -27,6 +26,7 @@ import org.compiere.util.CCache;
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.Util;
import org.compiere.util.ValueNamePair; import org.compiere.util.ValueNamePair;
/** /**
@ -44,7 +44,7 @@ public class MRefList extends X_AD_Ref_List
/** /**
* *
*/ */
private static final long serialVersionUID = -3612793187620297377L; private static final long serialVersionUID = 2342762307330992884L;
/** /**
* Get Reference List * Get Reference List
@ -210,45 +210,58 @@ public class MRefList extends X_AD_Ref_List
*/ */
public static ValueNamePair[] getList (Properties ctx, int AD_Reference_ID, boolean optional) public static ValueNamePair[] getList (Properties ctx, int AD_Reference_ID, boolean optional)
{ {
String ad_language = Env.getAD_Language(ctx); return getList(ctx, AD_Reference_ID, optional, "");
boolean isBaseLanguage = Env.isBaseLanguage(ad_language, "AD_Ref_List");
String sql = isBaseLanguage ?
"SELECT Value, Name FROM AD_Ref_List WHERE AD_Reference_ID=? AND IsActive='Y' ORDER BY Name"
:
"SELECT r.Value, t.Name FROM AD_Ref_List_Trl t"
+ " INNER JOIN AD_Ref_List r ON (r.AD_Ref_List_ID=t.AD_Ref_List_ID)"
+ " WHERE r.AD_Reference_ID=? AND t.AD_Language=? AND r.IsActive='Y'"
+ " ORDER BY t.Name"
;
PreparedStatement pstmt = null;
ResultSet rs = null;
ArrayList<ValueNamePair> list = new ArrayList<ValueNamePair>();
if (optional)
list.add(new ValueNamePair("", ""));
try
{
pstmt = DB.prepareStatement(sql, null);
pstmt.setInt(1, AD_Reference_ID);
if (!isBaseLanguage)
pstmt.setString(2, ad_language);
rs = pstmt.executeQuery();
while (rs.next())
list.add(new ValueNamePair(rs.getString(1), rs.getString(2)));
}
catch (SQLException e)
{
s_log.log(Level.SEVERE, sql, e);
}
finally
{
DB.close(rs, pstmt);
rs = null; pstmt = null;
}
ValueNamePair[] retValue = new ValueNamePair[list.size()];
list.toArray(retValue);
return retValue;
} // getList } // getList
/**
* Get Reference List (translated)
* @param ctx context
* @param AD_Reference_ID reference
* @param optional if true add "",""
* @param orderBy N-Name, V-Value, D-Default (IsOrderByValue)
* @return List or null
*/
public static ValueNamePair[] getList (Properties ctx, int AD_Reference_ID, boolean optional, String orderBy) {
String language = Env.getAD_Language(ctx);
boolean orderByValue = MReference.get(AD_Reference_ID).isOrderByValue();
if (Util.isEmpty(orderBy) || "N".equals(orderBy))
orderByValue = false;
else if ("V".equals(orderBy))
orderByValue = true;
StringBuilder sql = new StringBuilder ("SELECT AD_Ref_List.Value,");
MClient client = MClient.get(Env.getCtx());
StringBuilder AspFilter = new StringBuilder();
if ( client.isUseASP() ) {
AspFilter.append(" AND AD_Ref_List.AD_Ref_List_ID NOT IN ( ")
.append(" SELECT li.AD_Ref_List_ID")
.append(" FROM ASP_Ref_List li")
.append(" INNER JOIN ASP_Level l ON ( li.ASP_Level_ID = l.ASP_Level_ID)")
.append(" INNER JOIN ASP_ClientLevel cl on (l.ASP_Level_ID = cl.ASP_Level_ID)")
.append(" INNER JOIN AD_Client c on (cl.AD_Client_ID = c.AD_Client_ID)")
.append(" WHERE li.AD_Reference_ID=").append(AD_Reference_ID)
.append(" AND li.IsActive='Y'")
.append(" AND c.AD_Client_ID=").append(client.getAD_Client_ID())
.append(" AND li.ASP_Status='H')");
}
if (Env.isBaseLanguage(language, "AD_Ref_List"))
sql.append("AD_Ref_List.Name,AD_Ref_List.IsActive FROM AD_Ref_List ");
else
sql.append("trl.Name, AD_Ref_List.IsActive ")
.append("FROM AD_Ref_List INNER JOIN AD_Ref_List_Trl trl ")
.append(" ON (AD_Ref_List.AD_Ref_List_ID=trl.AD_Ref_List_ID AND trl.AD_Language='")
.append(language).append("')");
sql.append(" WHERE AD_Ref_List.AD_Reference_ID=").append(AD_Reference_ID);
sql.append(AspFilter.toString());
if (orderByValue)
sql.append(" ORDER BY 1");
else
sql.append(" ORDER BY 2");
return DB.getValueNamePairs(sql.toString(), optional, null);
} // getList
/** Logger */ /** Logger */
private static CLogger s_log = CLogger.getCLogger (MRefList.class); private static CLogger s_log = CLogger.getCLogger (MRefList.class);