Subversion Repositories eFlore/Applications.cel

Rev

Rev 2458 | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
// declare(encoding='UTF-8');
/**
 * Service renvoyant au format JSON les dernières observations publiques d'un utilisateur.
 * Utilisée par l'annuaire appelant les web services résumé de chaque application.
 *
 * @internal   Mininum PHP version : 5.2
 * @category   CEL
 * @package    Services
 * @subpackage Observations
 * @version    0.1
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
 */
class Resume extends Cel {

        public function getElement($uid){
                $idUtilisateurP = Cel::db()->proteger($uid[1]);
                $requete = 'SELECT co.*, ci.id_image, ci.nom_original, ci.largeur, ci.hauteur '.
                        'FROM cel_obs AS co INNER JOIN cel_images AS ci ON (id_observation = ce_observation) '.
                        "WHERE co.ce_utilisateur = $idUtilisateurP ".
                        'ORDER BY co.date_modification DESC '.
                        'LIMIT 0,5 '.
                        ' -- '.__FILE__.':'.__LINE__;
                $resultats = Cel::db()->requeter($requete);

                $urlImgTpl = $this->config['settings']['celImgUrlTpl'];
                $urlAppliCel = $this->config['settings']['celAppliUrl'];
                $resume = array(
                        'titre' => 'Vos dernières observations avec photos publiées',
                        'lien_appli' => '<a href="'.$urlAppliCel.'"> Accéder au carnet en ligne </a>');

                if ($resultats !== false && is_array($resultats) && count($resultats) == 0) {
                        $resume['message'] = 'Aucune observation saisie pour le moment';
                } else if ($resultats !== false && is_array($resultats) && count($resultats) > 0) {

                        foreach ($resultats as $obs) {
                                $obs = array_filter($obs, array($this, 'nettoyerObs'));

                                $nomRetenu = isset($obs['nom_ret']) ? $obs['nom_ret'] : 'Indéterminé';
                                $date = 'Datée du '.$obs['date_modification'];
                                $idZoneGeo = $this->convertirCodeZoneGeoVersDepartement($obs['ce_zone_geo']);
                                $lieuMorceaux = array();
                                $lieuMorceaux[] = $obs['zone_geo'].(!empty($idZoneGeo) ? " ($idZoneGeo)" : '');
                                $lieuMorceaux[] = $obs['station'];
                                $lieuMorceaux[] = $obs['lieudit'];
                                $lieu = 'Lieu : '.implode(', ', $lieuMorceaux);
                                $nomOriginal = htmlspecialchars($obs['nom_original']);
                                list($largeur, $hauteur) = $this->calculerDimensions($obs['largeur'], $obs['hauteur']);
                                $idImg = sprintf('%09s', $obs['id_image']);
                                $urlImgL = sprintf($urlImgTpl, "{$idImg}L");
                                $urlImgM = sprintf($urlImgTpl, "{$idImg}M");
                                $baliseImg = '<img src="'.$urlImgM.'" alt="'.$nomOriginal.'" height="'.$hauteur.'" width="'.$largeur.'" />';

                                $resume['elements'][] = array(
                                        'element' => "$nomRetenu<br />$date<br />$lieu<br />",
                                        'lien' => $urlImgL,
                                        'image' => $baliseImg);
                        }
                }
                $this->envoyerJson($resume);
                return true;
        }

        protected function nettoyerObs($valeur) {
                return ($valeur == '000null') ? '' : trim($valeur);
        }

        private function calculerDimensions($largeur, $hauteur) {
                $tailleOr = 75 ;
                if ($hauteur == 0) {
                        $hauteur = $tailleOr;
                }
                if ($largeur == 0) {
                        $largeur = $tailleOr;
                }
                $maxTaille = max($hauteur, $largeur);

                if ($maxTaille == $hauteur) {
                        $rapport = $hauteur / $largeur;
                        $hauteur = 75;
                        $largeur = round($hauteur / $rapport, 0);
                } else {
                        $rapport = $largeur / $hauteur;
                        $largeur = 75;
                        $hauteur = round($largeur / $rapport, 0);
                }
                return array($largeur, $hauteur);
        }
}