Subversion Repositories eFlore/Applications.cel

Rev

Rev 2446 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2446 Rev 2447
1
<?php
1
<?php
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
-
 
3
 
-
 
4
/**
-
 
5
* PHP Version 5
-
 
6
*
-
 
7
* @category  PHP
-
 
8
* @package   jrest
-
 
9
* @author    aurelien <aurelien@tela-botanica.org>
-
 
10
* @copyright 2010 Tela-Botanica
-
 
11
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
-
 
12
* @version   SVN: <svn_id>
2
// declare(encoding='UTF-8');
13
* @link      /doc/jrest/
-
 
14
*/
-
 
15
 
-
 
16
/**
3
/**
17
 * Classe renvoyant une liste très succinte des observations liées à une image de l'utilisateur
4
 * Classe renvoyant une liste très succinte des observations liées à une image de l'utilisateur
18
 *
5
 *
-
 
6
 * @category   DEL
-
 
7
 * @package    Services
-
 
8
 * @subpackage Communes
-
 
9
 * @version    0.1
-
 
10
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
-
 
11
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
-
 
12
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
-
 
13
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
-
 
14
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
-
 
15
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
19
 */
16
 */
20
class ImageContribution extends Cel {
17
class ImageContribution extends Cel {
21
 
18
 
22
	/**
19
	/**
23
	 * Renvoi un petit bout de html contenant les dernières obs liées à
20
	 * Renvoi un petit bout de html contenant les dernières obs liées à
24
	 * une image d'un utilisateur
21
	 * une image d'un utilisateur
25
	 *
22
	 *
26
	 * @param string $uid[0] mail de l'utilisateur
23
	 * @param string $uid[0] mail de l'utilisateur
27
	 * @param string $uid[1] identifiant numérique de l'utilisateur
24
	 * @param string $uid[1] identifiant numérique de l'utilisateur
28
	 */
25
	 */
29
	function getElement($uid){
26
	function getElement($uid){
30
		$idUtilisateurP = Cel::db()->proteger($uid[1]);
27
		$idUtilisateurP = Cel::db()->proteger($uid[1]);
31
		$requete = 'SELECT co.*, ci.id_image, ci.nom_original, ci.largeur, ci.hauteur '.
28
		$requete = 'SELECT co.*, ci.id_image, ci.nom_original, ci.largeur, ci.hauteur '.
32
			'FROM cel_obs AS co INNER JOIN cel_images AS ci ON (id_observation = ce_observation) '.
29
			'FROM cel_obs AS co INNER JOIN cel_images AS ci ON (id_observation = ce_observation) '.
33
			"WHERE co.ce_utilisateur = $idUtilisateurP ".
30
			"WHERE co.ce_utilisateur = $idUtilisateurP ".
34
			'ORDER BY co.date_modification DESC '.
31
			'ORDER BY co.date_modification DESC '.
35
			'LIMIT 0,5 '.
32
			'LIMIT 0,5 '.
36
			' -- '.__FILE__.':'.__LINE__;
33
			' -- '.__FILE__.':'.__LINE__;
37
		$resultats = Cel::db()->requeter($requete);
34
		$resultats = Cel::db()->requeter($requete);
38
 
35
 
39
		$html = '<div id="resume_cel">';
36
		$html = '<div id="resume_cel">';
40
		if ($resultats !== false && is_array($resultats)) {
37
		if ($resultats !== false && is_array($resultats)) {
41
			$urlImgTpl = $this->config['settings']['celImgUrlTpl'];
38
			$urlImgTpl = $this->config['settings']['celImgUrlTpl'];
42
			foreach ($resultats as $obs) {
39
			foreach ($resultats as $obs) {
43
				$nom_ret = (!empty($obs['nom_ret'])) ? $obs['nom_ret'] : 'Indéterminée';
40
				$nom_ret = (!empty($obs['nom_ret'])) ? $obs['nom_ret'] : 'Indéterminée';
44
				$obs['nom_original'] = htmlspecialchars($obs['nom_original']);
41
				$obs['nom_original'] = htmlspecialchars($obs['nom_original']);
45
				$obs['id_image'] = htmlspecialchars($obs['id_image']);
42
				$obs['id_image'] = htmlspecialchars($obs['id_image']);
46
				$obs['zone_geo'] = trim($obs['zone_geo'],'000null');
43
				$obs['zone_geo'] = trim($obs['zone_geo'],'000null');
47
				$obs['ce_zone_geo'] = trim($obs['ce_zone_geo'],'000null');
44
				$obs['ce_zone_geo'] = trim($obs['ce_zone_geo'],'000null');
48
				$obs['station'] = trim($obs['station'],'000null');
45
				$obs['station'] = trim($obs['station'],'000null');
49
				$obs['lieudit'] = trim($obs['lieudit'],'000null');
46
				$obs['lieudit'] = trim($obs['lieudit'],'000null');
50
				$id = $obs['id_image'];
47
				$id = $obs['id_image'];
51
 
48
 
52
				list($largeur, $hauteur) = $this->calculerDimensions($obs['largeur'], $obs['hauteur']);
49
				list($largeur, $hauteur) = $this->calculerDimensions($obs['largeur'], $obs['hauteur']);
53
				$id = sprintf('%09s', $id);
50
				$id = sprintf('%09s', $id);
54
				$urlImgL = sprintf($urlImgTpl, "{$id}L");
51
				$urlImgL = sprintf($urlImgTpl, "{$id}L");
55
				$urlImgS = sprintf($urlImgTpl, "{$id}S");
52
				$urlImgS = sprintf($urlImgTpl, "{$id}S");
56
 
53
 
57
				$html .= '<div class="item_resume_cel">'.
54
				$html .= '<div class="item_resume_cel">'.
58
					'<h4><a href="'.$urlImgL.'">'.$nom_ret.'</a></h4>'.
55
					'<h4><a href="'.$urlImgL.'">'.$nom_ret.'</a></h4>'.
59
					'<img src="'.$urlImgS.'" alt="'.$obs['nom_original'].'" height="'.$hauteur.'px" width="'.$largeur.'px" /><br/>'.
56
					'<img src="'.$urlImgS.'" alt="'.$obs['nom_original'].'" height="'.$hauteur.'px" width="'.$largeur.'px" /><br/>'.
60
					'<span>Datée du '.$obs['date_modification'].'<br/>'.
57
					'<span>Datée du '.$obs['date_modification'].'<br/>'.
61
					'Lieu : '.$obs['zone_geo'].' ('.$obs['ce_zone_geo'].') '.$obs['station'].' '.$obs['lieudit'].'<br/></p>'.
58
					'Lieu : '.$obs['zone_geo'].' ('.$obs['ce_zone_geo'].') '.$obs['station'].' '.$obs['lieudit'].'<br/></p>'.
62
					'</span>'.
59
					'</span>'.
63
					'</div>';
60
					'</div>';
64
			}
61
			}
65
		}
62
		}
66
		$html .= '</div>';
63
		$html .= '</div>';
67
 
64
 
68
		header("Content-Type: text/html; charset=UTF-8");
65
		header("Content-Type: text/html; charset=UTF-8");
69
		print $html;
66
		print $html;
70
		exit;
67
		exit;
71
	}
68
	}
72
 
69
 
73
	private function calculerDimensions($largeur, $hauteur) {
70
	private function calculerDimensions($largeur, $hauteur) {
74
		$tailleOr = 75 ;
71
		$tailleOr = 75 ;
75
		if ($hauteur == 0) {
72
		if ($hauteur == 0) {
76
			$hauteur = $tailleOr;
73
			$hauteur = $tailleOr;
77
		}
74
		}
78
		if ($largeur == 0) {
75
		if ($largeur == 0) {
79
			$largeur = $tailleOr;
76
			$largeur = $tailleOr;
80
		}
77
		}
81
		$maxTaille = max($hauteur, $largeur);
78
		$maxTaille = max($hauteur, $largeur);
82
 
79
 
83
		if ($maxTaille == $hauteur) {
80
		if ($maxTaille == $hauteur) {
84
			$rapport = $hauteur / $largeur;
81
			$rapport = $hauteur / $largeur;
85
			$hauteur = 75;
82
			$hauteur = 75;
86
			$largeur = round($hauteur / $rapport, 0);
83
			$largeur = round($hauteur / $rapport, 0);
87
		} else {
84
		} else {
88
			$rapport = $largeur / $hauteur;
85
			$rapport = $largeur / $hauteur;
89
			$largeur = 75;
86
			$largeur = 75;
90
			$hauteur = round($largeur / $rapport, 0);
87
			$hauteur = round($largeur / $rapport, 0);
91
		}
88
		}
92
		return array($largeur, $hauteur);
89
		return array($largeur, $hauteur);
93
	}
90
	}
94
}
91
}