Phone class: new class to access profile_phones.
[platal.git] / modules / profile / addresses.inc.php
index f06534b..9722476 100644 (file)
  *  59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                *
  ***************************************************************************/
 
-class ProfileAddress extends ProfileGeoloc
+class ProfileSettingAddress extends ProfileSettingGeocoding
 {
     private $bool;
     private $pub;
-    private $tel;
 
     public function __construct()
     {
-        $this->bool = new ProfileBool();
-        $this->pub  = new ProfilePub();
-        $this->tel  = new ProfileTel();
+        $this->bool = new ProfileSettingBool();
+        $this->pub  = new ProfileSettingPub();
     }
 
-    private function cleanAddress(ProfilePage &$page, array &$address, &$success)
+    private function cleanAddress(ProfilePage &$page, $addrid, array &$address)
     {
-        if (@$address['changed']) {
-            $address['datemaj'] = time();
-        }
-        $success = true;
-        foreach ($address['tel'] as $t=>&$tel) {
-            if (@$tel['removed'] || !trim($tel['tel'])) {
-                unset($address['tel'][$t]);
-            } else {
-                $tel['pub'] = $this->pub->value($page, 'pub', $tel['pub'], $s);
-                $tel['tel'] = $this->tel->value($page, 'tel', $tel['tel'], $s);
-                if (!$s) {
-                    $tel['error'] = true;
-                    $success = false;
-                }
-            }
-            unset($tel['removed']);
-        }
-        $address['checked'] = $this->bool->value($page, 'checked', $address['checked'], $s);
-        $address['secondaire'] = $this->bool->value($page, 'secondaire', $address['secondaire'], $s);
-        $address['mail'] = $this->bool->value($page, 'mail', $address['mail'], $s);
+        $address['tel']       = Phone::formatFormArray($address['tel'], $s);
+        $address['current']   = $this->bool->value($page, 'current',   $address['current'],   $s);
         $address['temporary'] = $this->bool->value($page, 'temporary', $address['temporary'], $s);
-        $address['current'] = $this->bool->value($page, 'current', @$address['current'], $s);
-        $address['pub'] = $this->pub->value($page, 'pub', $address['pub'], $s);
-        unset($address['parsevalid']);
-        unset($address['changed']);
-        unset($address['removed']);
-        unset($address['display']);
+        $address['secondary'] = $this->bool->value($page, 'secondary', $address['secondary'], $s);
+        $address['mail']      = $this->bool->value($page, 'mail',      $address['mail'],      $s);
+        $address['pub']       = $this->pub->value($page,  'pub',       $address['pub'],       $s);
     }
 
     public function value(ProfilePage &$page, $field, $value, &$success)
@@ -68,170 +45,145 @@ class ProfileAddress extends ProfileGeoloc
         $init = false;
         if (is_null($value)) {
             $value = $page->values['addresses'];
-            $init = true;
+            $init  = true;
         }
-        foreach ($value as $key=>&$adr) {
-            if (@$adr['removed']) {
-                unset($value[$key]);
+        foreach ($value as $key => &$address) {
+            if (isset($address['removed']) && $address['removed']) {
+                array_splice($value, $key, 1);
             }
         }
         $current = 0;
         $success = true;
-        foreach ($value as $key=>&$adr) {
-            if (@$adr['current']) {
+        foreach ($value as $key => &$address) {
+            if (isset($address['current']) && $address['current']) {
                 $current++;
             }
         }
         if ($current == 0 && count($value) > 0) {
-            foreach ($value as $key=>&$adr) {
-                $adr['current'] = true;
+            foreach ($value as &$address) {
+                $address['current'] = true;
                 break;
             }
-        } else if ($current > 1) {
+        } elseif ($current > 1) {
             $success = false;
         }
-        foreach ($value as $key=>&$adr) {
-            $ls = true;
-            $this->geolocAddress($adr, $s);
-            $ls = ($ls && $s);
-            $this->cleanAddress($page, $adr, $s);
-            $ls = ($ls && $s);
-            if (!trim($adr['text'])) {
+        foreach ($value as $key => &$address) {
+            if (!trim($address['text'])) {
                 unset($value[$key]);
-            } else if (!$init) {
-                $success = ($success && $ls);
+            } elseif (!$init) {
+                $this->geocodeAddress($address, $s);
+                $success = $success && $s;
             }
+            $this->cleanAddress($page, $key, $address);
         }
         return $value;
     }
 
-    private function saveTel($adrid, $telid, array &$tel)
+    public function saveAddress($pid, $addrid, array &$address, $type)
     {
-        XDB::execute("INSERT INTO  tels (uid, adrid, telid,
-                                         tel_type, tel_pub, tel)
-                           VALUES  ({?}, {?}, {?},
-                                    {?}, {?}, {?})",
-                    S::i('uid'), $adrid, $telid,
-                    $tel['type'], $tel['pub'], $tel['tel']);
-    }
+        require_once 'geocoding.inc.php';
 
-    private function saveAddress($adrid, array &$address)
-    {
         $flags = new PlFlagSet();
-        if ($address['secondaire']) {
-            $flags->addFlag('res-secondaire');
-        }
-        if ($address['mail']) {
-            $flags->addFlag('courrier');
-        }
-        if ($address['temporary']) {
-            $flags->addFlag('temporaire');
-        }
-        if ($address['current']) {
-            $flags->addFlag('active');
-        }
-        if ($address['checked']) {
-            $flags->addFlag('coord-checked');
-        }
-        XDB::execute("INSERT INTO  adresses (adr1, adr2, adr3,
-                                              postcode, city, cityid,
-                                              country, region, regiontxt,
-                                              pub, datemaj, statut,
-                                              uid, adrid, glat, glng)
-                           VALUES  ({?}, {?}, {?},
-                                    {?}, {?}, {?},
-                                    {?}, {?}, {?},
-                                    {?}, FROM_UNIXTIME({?}), {?},
-                                    {?}, {?}, {?}, {?})",
-                     $address['adr1'], $address['adr2'], $address['adr3'],
-                     $address['postcode'], $address['city'], $address['cityid'],
-                     $address['country'], $address['region'], $address['regiontxt'],
-                     $address['pub'], $address['datemaj'], $flags,
-                     S::i('uid'), $adrid, $address['precise_lat'], $address['precise_lon']);
-        foreach ($address['tel'] as $telid=>&$tel) {
-            $this->saveTel($adrid, $telid, $tel);
-        }
+        $flags->addFlag('current', $address['current']);
+        $flags->addFlag('temporary', $address['temporary']);
+        $flags->addFlag('secondary', $address['secondary']);
+        $flags->addFlag('mail', $address['mail']);
+        $flags->addFlag('cedex', $address['cedex'] =
+            (strpos(strtoupper(preg_replace(array("/[0-9,\"'#~:;_\- ]/", "/\r\n/"),
+                                            array("", "\n"), $address['text'])), 'CEDEX')) !== false);
+        Geocoder::getAreaId($address, "administrativeArea");
+        Geocoder::getAreaId($address, "subAdministrativeArea");
+        Geocoder::getAreaId($address, "locality");
+        XDB::execute("INSERT INTO  profile_addresses (pid, type, id, flags, accuracy,
+                                                      text, postalText, postalCode, localityId,
+                                                      subAdministrativeAreaId, administrativeAreaId,
+                                                      countryId, latitude, longitude, updateTime, pub, comment,
+                                                      north, south, east, west)
+                           VALUES  ({?}, {?}, {?}, {?}, {?}, {?}, {?}, {?}, {?}, {?}, {?}, {?},
+                                    {?}, {?}, FROM_UNIXTIME({?}), {?}, {?}, {?}, {?}, {?}, {?})",
+                     $pid, $type, $addrid, $flags, $address['accuracy'],
+                     $address['text'], $address['postalText'], $address['postalCode'], $address['localityId'],
+                     $address['subAdministrativeAreaId'], $address['administrativeAreaId'],
+                     $address['countryId'], $address['latitude'], $address['longitude'],
+                     $address['updateTime'], $address['pub'], $address['comment'],
+                     $address['north'], $address['south'], $address['east'], $address['west']);
     }
 
     public function save(ProfilePage &$page, $field, $value)
     {
-        XDB::execute("DELETE FROM  adresses
-                            WHERE  uid = {?}",
-                     S::i('uid'));
-        XDB::execute("DELETE FROM  tels
-                            WHERE  uid = {?}",
-                     S::i('uid'));
-        foreach ($value as $adrid=>&$address) {
-            $this->saveAddress($adrid, $address);
+        XDB::execute("DELETE FROM  profile_addresses
+                            WHERE  pid = {?} AND type = 'home'",
+                     $page->pid());
+        Phone::deletePhones($page->pid(), Phone::LINK_ADDRESS);
+        foreach ($value as $addrid => &$address) {
+            $this->saveAddress($page->pid(), $addrid, $address, 'home');
+            Phone::savePhones($address['tel'], $page->pid(), Phone::LINK_ADDRESS, $addrid);
         }
     }
+
+    public function getText($value) {
+        $addresses = array();
+        foreach ($value as $addrid => $address) {
+            $phones = Phone::formArrayToString($address['tel']);
+            $addresses[] = 'Adresse : ' . $address['text'] . ', affichage : ' . $address['pub']
+                         . ', commentaire : ' . $address['comment'] . ', actuelle : ' . ($address['current'] ? 'oui' : 'non')
+                         . ', temporaire : ' . ($address['temporary'] ? 'oui' : 'non') . ', secondaire : '
+                         . ($address['secondary'] ? 'oui' : 'non') . ', conctactable par courier : '
+                         . ($address['mail'] ? 'oui' : 'non') . ($phones ? ', ' . $phones : '');
+        }
+        return implode(' ; ' , $addresses);
+    }
 }
 
-class ProfileAddresses extends ProfilePage
+class ProfileSettingAddresses extends ProfilePage
 {
     protected $pg_template = 'profile/adresses.tpl';
 
     public function __construct(PlWizard &$wiz)
     {
         parent::__construct($wiz);
-        $this->settings['addresses'] = new ProfileAddress();
-        $this->watched['addresses'] = true;
+        $this->settings['addresses'] = new ProfileSettingAddress();
+        $this->watched['addresses']  = true;
     }
 
     protected function _fetchData()
     {
-        // Build the addresses tree
-        $res = XDB::query("SELECT  a.adrid AS id, a.adr1, a.adr2, a.adr3,
-                                   UNIX_TIMESTAMP(a.datemaj) AS datemaj,
-                                   a.postcode, a.city, a.cityid, a.region, a.regiontxt,
-                                   a.pub, a.country, gp.pays AS countrytxt, gp.display,
-                                   FIND_IN_SET('coord-checked', a.statut) AS checked,
-                                   FIND_IN_SET('res-secondaire', a.statut) AS secondaire,
-                                   FIND_IN_SET('courrier', a.statut) AS mail,
-                                   FIND_IN_SET('temporaire', a.statut) AS temporary,
-                                   FIND_IN_SET('active', a.statut) AS current,
-                                   a.glat AS precise_lat, a.glng AS precise_lon
-                             FROM  adresses AS a
-                       INNER JOIN  geoloc_pays AS gp ON(gp.a2 = a.country)
-                            WHERE  uid = {?} AND NOT FIND_IN_SET('pro', statut)
-                         ORDER BY  adrid",
-                           S::i('uid'));
+        $res = XDB::query("SELECT  id, accuracy, text, postalText,
+                                   postalCode, localityId, subAdministrativeAreaId, administrativeAreaId,
+                                   countryId, latitude, longitude, pub, comment, UNIX_TIMESTAMP(updateTime) AS updateTime,
+                                   north, south, east, west,
+                                   FIND_IN_SET('current', flags) AS current,
+                                   FIND_IN_SET('temporary', flags) AS temporary,
+                                   FIND_IN_SET('secondary', flags) AS secondary,
+                                   FIND_IN_SET('mail', flags) AS mail,
+                                   FIND_IN_SET('cedex', flags) AS cedex
+                             FROM  profile_addresses
+                            WHERE  pid = {?} AND type = 'home'
+                         ORDER BY  id",
+                           $this->pid());
         if ($res->numRows() == 0) {
             $this->values['addresses'] = array();
         } else {
             $this->values['addresses'] = $res->fetchAllAssoc();
         }
 
-        $res = XDB::iterator("SELECT  adrid, tel_type AS type, tel_pub AS pub, tel
-                                FROM  tels
-                               WHERE  uid = {?}
-                            ORDER BY  adrid",
-                             S::i('uid'));
-        $i = 0;
-        $adrNb = count($this->values['addresses']);
-        while ($tel = $res->next()) {
-            $adrid = $tel['adrid'];
-            unset($tel['adrid']);
-            while ($i < $adrNb && $this->values['addresses'][$i]['id'] < $adrid) {
-                $i++;
-            }
-            if ($i >= $adrNb) {
-                break;
-            }
-            $address =& $this->values['addresses'][$i];
-            if (!isset($address['tel'])) {
-                $address['tel'] = array();
-            }
-            if ($address['id'] == $adrid) {
-                $address['tel'][] = $tel;
-            }
+        // Adds phones to addresses.
+        $it = Phone::iterate(array($this->pid()), array(Phone::LINK_ADDRESS));
+        while ($phone = $it->next()) {
+            $this->values['addresses'][$phone->linkId()]['tel'][$phone->id()] = $phone->toFormArray();
         }
-        foreach ($this->values['addresses'] as $id=>&$address) {
+
+        // Properly formats addresses.
+        foreach ($this->values['addresses'] as $id => &$address) {
+            $phone = new Phone();
             if (!isset($address['tel'])) {
-                $address['tel'] = array();
+                $address['tel'] = array(0 => $phone->toFormArray());
             }
             unset($address['id']);
+            $address['changed'] = 0;
+            $address['removed'] = 0;
         }
+        //var_dump($this->values['addresses']['tel']);
     }
 }