|
Smarty
WARNING: All discussion is moving to https://reddit.com/r/smarty, please go there! This forum will be closing soon. |
|
View previous topic :: View next topic |
Author |
Message |
alfa Smarty n00b
Joined: 23 Dec 2011 Posts: 1
|
Posted: Fri Dec 23, 2011 7:34 pm Post subject: Problème récupération de données dans un foreach (hors tpl) |
|
|
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: |
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 :
Code: |
$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);
|
c'est là où ça coince, le forEach me retourne uniquement le dernier enregistrement
et enfin j'affiche le tout dans mon tpl medias.tpl :
Code: |
{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}
|
un petit screen du résultat obtenu :
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[/code] |
|
Back to top |
|
shinix Smarty n00b
Joined: 01 Jun 2012 Posts: 3
|
Posted: Fri Jun 01, 2012 4:52 pm Post subject: |
|
|
As.tu essayés en ajoutant au début $i=0; puis sur chaque champs tu ajoutes $i puis à la fin $i++;
ce qui devrait te donner les photos de chaque album. |
|
Back to top |
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|