BF: [ 2576434 ] C_BPartner_Location Name should not be overwritten by system

https://sourceforge.net/tracker/index.php?func=detail&aid=2576434&group_id=176962&atid=879332

When user create C_BPartner_Location record and provide value of Name
column Adempiere overwrite Name column and generates new one.

This behavior is wrong. System must create new Name only if provided by
user Name is not unique.
This commit is contained in:
trifonnt 2009-02-07 10:00:10 +00:00
parent b55471c66d
commit 68bad5a176
1 changed files with 10 additions and 9 deletions

View File

@ -166,10 +166,12 @@ public class MBPartnerLocation extends X_C_BPartner_Location
return true; return true;
MLocation address = getLocation(true); MLocation address = getLocation(true);
m_uniqueName = getName(); m_uniqueName = getName();
if (m_uniqueName != null && m_uniqueName.equals(".")) // default
m_uniqueName = null;
m_unique = 0; m_unique = 0;
makeUnique(address); if (m_uniqueName != null && m_uniqueName.equals(".")) {
// default
m_uniqueName = null;
makeUnique(address);
}
// Check uniqueness // Check uniqueness
MBPartnerLocation[] locations = getForBPartner(getCtx(), getC_BPartner_ID()); MBPartnerLocation[] locations = getForBPartner(getCtx(), getC_BPartner_ID());
@ -184,6 +186,7 @@ public class MBPartnerLocation extends X_C_BPartner_Location
continue; continue;
if (m_uniqueName.equals(location.getName())) if (m_uniqueName.equals(location.getName()))
{ {
//m_uniqueName = null;
makeUnique(address); makeUnique(address);
unique = false; unique = false;
break; break;
@ -200,8 +203,6 @@ public class MBPartnerLocation extends X_C_BPartner_Location
*/ */
private void makeUnique (MLocation address) private void makeUnique (MLocation address)
{ {
// m_uniqueName = address.toString();
// return;
if (m_uniqueName == null) if (m_uniqueName == null)
m_uniqueName = ""; m_uniqueName = "";
@ -216,7 +217,7 @@ public class MBPartnerLocation extends X_C_BPartner_Location
m_unique = 0; m_unique = 0;
} }
// 1 + Address1 // 1 + Address1
if (m_unique == 1 || m_uniqueName.length() == 0) if (m_unique == 1 || m_uniqueName.length() == 0)
{ {
String xx = address.getAddress1(); String xx = address.getAddress1();
if (xx != null && xx.length() > 0) if (xx != null && xx.length() > 0)
@ -228,7 +229,7 @@ public class MBPartnerLocation extends X_C_BPartner_Location
m_unique = 1; m_unique = 1;
} }
// 2 + Address2 // 2 + Address2
if (m_unique == 2 || m_uniqueName.length() == 0) if (m_unique == 2 || m_uniqueName.length() == 0)
{ {
String xx = address.getAddress2(); String xx = address.getAddress2();
if (xx != null && xx.length() > 0) if (xx != null && xx.length() > 0)
@ -240,7 +241,7 @@ public class MBPartnerLocation extends X_C_BPartner_Location
m_unique = 2; m_unique = 2;
} }
// 3 - Region // 3 - Region
if (m_unique == 3 || m_uniqueName.length() == 0) if (m_unique == 3 || m_uniqueName.length() == 0)
{ {
String xx = address.getRegionName(true); String xx = address.getRegionName(true);
{ {
@ -251,7 +252,7 @@ public class MBPartnerLocation extends X_C_BPartner_Location
m_unique = 3; m_unique = 3;
} }
// 4 - ID // 4 - ID
if (m_unique == 4 || m_uniqueName.length() == 0) if (m_unique == 4 || m_uniqueName.length() == 0)
{ {
int id = get_ID(); int id = get_ID();
if (id == 0) if (id == 0)