Bonjour à tous,
Je travaille actuellement sur un site que je dois remettre à niveau, et qui est basé sur Smarty, mais j'ai un problème pour récupérer des données dans une boucle forEach en php (pas dans le tpl mais dans le module qui récupère les données de la classe correspondante). Je cherche à créer une galerie photos avec albums, le nom des albums sont stockés dans la bd, et je récupère la liste des photos grâce à la fonction Glob.
Mais mon forEach n'affiche que le dernier enregistrement de ma table albums.
C'est sûrement un problème d'indexation, mais je n'arrive pas à m'en sortir, je suis un peu largué...
Donc :
j'ai une classe "Photos" photos.class.php qui récupère le nom des albums photos dans la base de données sql, que voici :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65 class Photos { private $id, $nom, $description; /** * Constructeur * * @param integer $id L'identifiant */ public function __construct($id) { $this->id = $id; $db = DB::getSingleton(WEBFC_SQL_TYPE); $sql = "SELECT * FROM `albums` WHERE id = $id"; $rs = $db->query($sql); if ($row = $db->fetchArray($rs)) { $this->id = $row["id"]; $this->nom = $row["nom"]; $this->description = $row["description"]; } $db->free($rs); } public function getNom() { return $this->nom; } public function getId() { return $this->id; } public function getDesc() { return $this->description; } public static function getItems() { $list = array(); $db = DB::getSingleton(WEBFC_SQL_TYPE); $sql = "SELECT `id` FROM `albums` ORDER BY `id` ASC"; $rs = $db->query($sql); while ($row = $db->fetchArray($rs)) { $p = new Photos($row['id']); array_push($list, $p); } $db->free($rs); return $list; } }
J'ai ensuite un module fo_medias.php où la classe est appelée et qui gère les données qui seront envoyées au template, dans ce module j'ai :
c'est là où ça coince, le forEach me retourne uniquement le dernier enregistrement
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 $photos = Photos::getItems(); foreach ($photos as $p) { //$listeAlbum[$p->getId()] = $p->getNom(); //$listeAlbum[] = $p->getNom(); //path to directory to scan $thumbnails = "files/image/medias/photos/".$p->getNom()."/thumbs/"; $large = "files/image/medias/photos/".$p->getNom()."/"; //get all image files with a .jpg extension. $imagesThumbnails = glob($thumbnails. "*.jpg"); $imagesLarge = glob($large. "*.jpg"); $filecount = count(glob($thumbnails. "*.jpg")); } $template->assign("imagesThumbnails", $imagesThumbnails); $template->assign("imagesLarge", $imagesLarge); $template->assign("thumbPagination", $thumbPagination); $template->assign("filecount", $filecount); $template->assign("photos", $photos);
et enfin j'affiche le tout dans mon tpl medias.tpl :
un petit screen du résultat obtenu :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13 {foreach from=$photos item=entry name=link} <div id="liensPhotos"> <div id="pagination" class="pagination">{$thumbPagination}</div> <h1 class="titre" onclick="closePhotos()"><img src="templates/images/photo.png" style="vertical-align: -10%;" /> {$entry->getNom()} <span>{if $filecount > 0} /// {$filecount} {if $filecount == 1}photo{else}photos{/if} actuellement{else} /// Aucune photo actuellement{/if}</span></h1> <ul> {foreach from=$imagesThumbnails item=Thumbs name=thumbList} <li><a href="{$imagesLarge[$smarty.foreach.thumbList.index]}" rel="lightbox_gal"><img src="{$Thumbs}" class="thumbs" border="0"/></a></li> {/foreach} </ul> </div> {/foreach}
ma liste d'albums est ok, par contre ça ne récupère que les photos qui correspondent au dernier dossier, l'erreur vient je pense de mon forEach dans le modules fo_media.php, et pas du tpl, mais je ne m'en dépatouille pas...
Si quelqu'un pouvait me dire où ça coince, ça serait génial !!
Merci d'avance pour votre aide.
Olivier
Partager