New file |
0,0 → 1,92 |
<?php |
// declare(encoding='UTF-8'); |
/** |
* Service renvoyant une liste HTML très succinte des images (et infos sur l'obs liée) d'un utilisateur. |
* |
* @internal Mininum PHP version : 5.2 |
* @category CEL |
* @package Services |
* @subpackage Images |
* @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 ImageContribution extends Cel { |
|
/** |
* Renvoi un petit bout de html contenant les dernières obs liées à |
* une image d'un utilisateur |
* |
* @param string $uid[0] mail de l'utilisateur |
* @param string $uid[1] identifiant numérique de l'utilisateur |
*/ |
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); |
|
$html = '<div id="resume_cel">'; |
if ($resultats !== false && is_array($resultats)) { |
$urlImgTpl = $this->config['settings']['celImgUrlTpl']; |
foreach ($resultats as $obs) { |
$nom_ret = (!empty($obs['nom_ret'])) ? $obs['nom_ret'] : 'Indéterminée'; |
$obs['nom_original'] = htmlspecialchars($obs['nom_original']); |
$obs['id_image'] = htmlspecialchars($obs['id_image']); |
$obs['zone_geo'] = trim($obs['zone_geo'],'000null'); |
$obs['ce_zone_geo'] = trim($obs['ce_zone_geo'],'000null'); |
$obs['station'] = trim($obs['station'],'000null'); |
$obs['lieudit'] = trim($obs['lieudit'],'000null'); |
$id = $obs['id_image']; |
|
list($largeur, $hauteur) = $this->calculerDimensions($obs['largeur'], $obs['hauteur']); |
$id = sprintf('%09s', $id); |
$urlImgL = sprintf($urlImgTpl, "{$id}L"); |
$urlImgS = sprintf($urlImgTpl, "{$id}S"); |
|
$html .= '<div class="item_resume_cel">'. |
'<h4><a href="'.$urlImgL.'">'.$nom_ret.'</a></h4>'. |
'<img src="'.$urlImgS.'" alt="'.$obs['nom_original'].'" height="'.$hauteur.'px" width="'.$largeur.'px" /><br/>'. |
'<span>Datée du '.$obs['date_modification'].'<br/>'. |
'Lieu : '.$obs['zone_geo'].' ('.$obs['ce_zone_geo'].') '.$obs['station'].' '.$obs['lieudit'].'<br/></p>'. |
'</span>'. |
'</div>'; |
} |
} |
$html .= '</div>'; |
|
header("Content-Type: text/html; charset=UTF-8"); |
print $html; |
exit; |
} |
|
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); |
} |
} |