public function __construct(&$oDB, $iPlaceID, $sHousenumber, $mLangPref)
{
if (is_array($mLangPref)) {
- $mLangPref = 'ARRAY['.join(',', array_map('getDBQuoted', $mLangPref)).']';
+ $mLangPref = $oDB->getArraySQL($oDB->getDBQuotedList($mLangPref));
}
- if (!$sHousenumber) {
+ if (!isset($sHousenumber)) {
$sHousenumber = -1;
}
$sSQL = 'SELECT *,';
- $sSQL .= ' get_name_by_language(name,'.$mLangPref.') as localname';
+ $sSQL .= ' get_name_by_language(name,'.$mLangPref.') as localname';
$sSQL .= ' FROM get_addressdata('.$iPlaceID.','.$sHousenumber.')';
- $sSQL .= ' ORDER BY rank_address desc,isaddress DESC';
+ $sSQL .= ' ORDER BY rank_address DESC, isaddress DESC';
- $this->aAddressLines = chksql($oDB->getAll($sSQL));
+ $this->aAddressLines = $oDB->getAll($sSQL);
}
private static function isAddress($aLine)
{
- return $aLine['isaddress'] == 't' || $aLine['type'] == 'country_code';
+ return $aLine['isaddress'] || $aLine['type'] == 'country_code';
}
public function getAddressDetails($bAll = false)
return $this->aAddressLines;
}
- return array_filter($this->aAddressLines, 'AddressDetails::isAddress');
+ return array_filter($this->aAddressLines, array(__CLASS__, 'isAddress'));
}
public function getLocaleAddress()
$sPrevResult = '';
foreach ($this->aAddressLines as $aLine) {
- if ($aLine['isaddress'] == 't' && $sPrevResult != $aLine['localname']) {
+ if ($aLine['isaddress'] && $sPrevResult != $aLine['localname']) {
$sPrevResult = $aLine['localname'];
$aParts[] = $sPrevResult;
}
$bFallback = true;
}
- $sName = false;
- if (isset($aLine['localname']) && $aLine['localname']) {
+ $sName = null;
+ if (isset($aLine['localname']) && $aLine['localname']!=='') {
$sName = $aLine['localname'];
- } elseif (isset($aLine['housenumber']) && $aLine['housenumber']) {
+ } elseif (isset($aLine['housenumber']) && $aLine['housenumber']!=='') {
$sName = $aLine['housenumber'];
}
- if ($sName) {
+ if (isset($sName)) {
$sTypeLabel = strtolower(isset($aTypeLabel['simplelabel']) ? $aTypeLabel['simplelabel'] : $aTypeLabel['label']);
$sTypeLabel = str_replace(' ', '_', $sTypeLabel);
if (!isset($aAddress[$sTypeLabel])
}
}
}
+
return $aAddress;
}
+ /**
+ * Annotates the given json with geocodejson address information fields.
+ *
+ * @param array $aJson Json hash to add the fields to.
+ *
+ * Geocodejson has the following fields:
+ * street, locality, postcode, city, district,
+ * county, state, country
+ *
+ * Postcode and housenumber are added by type, district is not used.
+ * All other fields are set according to address rank.
+ */
+ public function addGeocodeJsonAddressParts(&$aJson)
+ {
+ foreach ($this->aAddressLines as $aLine) {
+ if (!$aLine['isaddress']) {
+ continue;
+ }
+
+ if (!isset($aLine['localname']) || $aLine['localname'] == '') {
+ continue;
+ }
+
+ $iRank = (int)$aLine['rank_address'];
+
+ if ($aLine['type'] == 'postcode' || $aLine['type'] == 'postal_code') {
+ $aJson['postcode'] = $aLine['localname'];
+ } else if ($aLine['type'] == 'house_number') {
+ $aJson['housenumber'] = $aLine['localname'];
+ } else if ($iRank > 25 && $iRank < 28) {
+ $aJson['street'] = $aLine['localname'];
+ } else if ($iRank >= 22 && $iRank <= 25) {
+ $aJson['locality'] = $aLine['localname'];
+ } else if ($iRank >= 17 && $iRank <= 21) {
+ $aJson['district'] = $aLine['localname'];
+ } else if ($iRank >= 13 && $iRank <= 16) {
+ $aJson['city'] = $aLine['localname'];
+ } else if ($iRank >= 10 && $iRank <= 12) {
+ $aJson['county'] = $aLine['localname'];
+ } else if ($iRank >= 5 && $iRank <= 9) {
+ $aJson['state'] = $aLine['localname'];
+ } else if ($iRank == 4) {
+ $aJson['country'] = $aLine['localname'];
+ }
+ }
+ }
+
public function getAdminLevels()
{
$aAddress = array();
- foreach ($this->aAddressLines as $aLine) {
+ foreach (array_reverse($this->aAddressLines) as $aLine) {
if (self::isAddress($aLine)
&& isset($aLine['admin_level'])
&& $aLine['admin_level'] < 15