Refactoring of [2877108] - columns with DisplayType.Location are not correctly cast
https://sourceforge.net/tracker/?func=detail&atid=879332&aid=2877108&group_id=176962
This commit is contained in:
parent
2d3e729318
commit
62ab3c9244
|
@ -50,7 +50,6 @@ import org.compiere.model.MReplicationStrategy;
|
||||||
import org.compiere.model.MTable;
|
import org.compiere.model.MTable;
|
||||||
import org.compiere.model.ModelValidator;
|
import org.compiere.model.ModelValidator;
|
||||||
import org.compiere.model.PO;
|
import org.compiere.model.PO;
|
||||||
import org.compiere.model.X_AD_Client;
|
|
||||||
import org.compiere.model.X_AD_ReplicationTable;
|
import org.compiere.model.X_AD_ReplicationTable;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.util.CLogger;
|
||||||
import org.compiere.util.DB;
|
import org.compiere.util.DB;
|
||||||
|
@ -418,13 +417,9 @@ public class ImportHelper {
|
||||||
//
|
//
|
||||||
po.set_ValueOfColumn(formatLines[i].getAD_Column_ID(), value);
|
po.set_ValueOfColumn(formatLines[i].getAD_Column_ID(), value);
|
||||||
log.info("Set value of column ["+column.getColumnName()+"]=["+value+"]");
|
log.info("Set value of column ["+column.getColumnName()+"]=["+value+"]");
|
||||||
} else if (column.getAD_Reference_ID() == DisplayType.ID
|
} else if (DisplayType.isID(column.getAD_Reference_ID())
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Integer
|
|| column.getAD_Reference_ID() == DisplayType.Integer
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Search
|
)
|
||||||
|| column.getAD_Reference_ID() == DisplayType.TableDir
|
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Table
|
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Location
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
if (! Util.isEmpty(value.toString()))
|
if (! Util.isEmpty(value.toString()))
|
||||||
|
@ -436,11 +431,8 @@ public class ImportHelper {
|
||||||
log.info("About to set int value of column ["+column.getColumnName()+"]=["+value+"]");
|
log.info("About to set int value of column ["+column.getColumnName()+"]=["+value+"]");
|
||||||
po.set_ValueOfColumn(formatLines[i].getAD_Column_ID(), value);
|
po.set_ValueOfColumn(formatLines[i].getAD_Column_ID(), value);
|
||||||
log.info("Set int value of column ["+column.getColumnName()+"]=["+value+"]");
|
log.info("Set int value of column ["+column.getColumnName()+"]=["+value+"]");
|
||||||
} else if (column.getAD_Reference_ID() == DisplayType.Amount
|
} else if (DisplayType.isNumeric(column.getAD_Reference_ID())
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Number
|
&& column.getAD_Reference_ID() != DisplayType.Integer)
|
||||||
|| column.getAD_Reference_ID() == DisplayType.CostPrice
|
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Quantity
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
if (! Util.isEmpty(value.toString()))
|
if (! Util.isEmpty(value.toString()))
|
||||||
|
@ -490,8 +482,8 @@ public class ImportHelper {
|
||||||
MClient result = null;
|
MClient result = null;
|
||||||
|
|
||||||
StringBuffer sql = new StringBuffer("SELECT AD_Client_ID ")
|
StringBuffer sql = new StringBuffer("SELECT AD_Client_ID ")
|
||||||
.append(" FROM ").append(X_AD_Client.Table_Name)
|
.append(" FROM ").append(MClient.Table_Name)
|
||||||
.append(" WHERE ").append(X_AD_Client.COLUMNNAME_Value).append(" = ?")
|
.append(" WHERE ").append(MClient.COLUMNNAME_Value).append(" = ?")
|
||||||
// .append(" AND IsActive = ?")
|
// .append(" AND IsActive = ?")
|
||||||
;
|
;
|
||||||
//s_log.info(sql.toString());
|
//s_log.info(sql.toString());
|
||||||
|
@ -561,10 +553,8 @@ public class ImportHelper {
|
||||||
MColumn column = MColumn.get(ctx, uniqueFormatLines[i].getAD_Column_ID());
|
MColumn column = MColumn.get(ctx, uniqueFormatLines[i].getAD_Column_ID());
|
||||||
log.info("column = ["+column+"]");
|
log.info("column = ["+column+"]");
|
||||||
String valuecol=column.getColumnName();
|
String valuecol=column.getColumnName();
|
||||||
if(column.getAD_Reference_ID() == DisplayType.Amount
|
if (DisplayType.isNumeric(column.getAD_Reference_ID())
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Number
|
&& column.getAD_Reference_ID() != DisplayType.Integer)
|
||||||
|| column.getAD_Reference_ID() == DisplayType.CostPrice
|
|
||||||
|| column.getAD_Reference_ID() == DisplayType.Quantity)
|
|
||||||
{
|
{
|
||||||
valuecol="Round("+valuecol+",2)";
|
valuecol="Round("+valuecol+",2)";
|
||||||
}
|
}
|
||||||
|
@ -637,19 +627,14 @@ public class ImportHelper {
|
||||||
String value = (String)values[i];
|
String value = (String)values[i];
|
||||||
pstmt.setString(i+1, value);
|
pstmt.setString(i+1, value);
|
||||||
}
|
}
|
||||||
else if(col.getAD_Reference_ID() == DisplayType.Amount
|
else if (DisplayType.isNumeric(col.getAD_Reference_ID())
|
||||||
|| col.getAD_Reference_ID() == DisplayType.Number
|
&& col.getAD_Reference_ID() != DisplayType.Integer)
|
||||||
|| col.getAD_Reference_ID() == DisplayType.CostPrice
|
|
||||||
|| col.getAD_Reference_ID() == DisplayType.Quantity)
|
|
||||||
{
|
{
|
||||||
BigDecimal value = new BigDecimal((String)values[i]);
|
BigDecimal value = new BigDecimal((String)values[i]);
|
||||||
pstmt.setBigDecimal(i+1, value.setScale(2, BigDecimal.ROUND_HALF_UP));
|
pstmt.setBigDecimal(i+1, value.setScale(2, BigDecimal.ROUND_HALF_UP));
|
||||||
}
|
}
|
||||||
else if(col.getAD_Reference_ID() == DisplayType.Integer
|
else if (DisplayType.isID(col.getAD_Reference_ID())
|
||||||
|| col.getAD_Reference_ID() == DisplayType.ID
|
|| col.getAD_Reference_ID() == DisplayType.Integer)
|
||||||
|| col.getAD_Reference_ID() == DisplayType.TableDir
|
|
||||||
|| col.getAD_Reference_ID() == DisplayType.Table
|
|
||||||
|| col.getAD_Reference_ID() == DisplayType.Search)
|
|
||||||
{
|
{
|
||||||
String stringValue = (String)values[i].toString();
|
String stringValue = (String)values[i].toString();
|
||||||
int value = Integer.parseInt(stringValue);
|
int value = Integer.parseInt(stringValue);
|
||||||
|
|
Loading…
Reference in New Issue