New file |
0,0 → 1,94 |
<?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[] = isset($obs['station']) ? $obs['station'] : null; |
$lieuMorceaux[] = isset($obs['lieudit']) ? $obs['lieudit'] : null; |
$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); |
} |
} |