Smarty Forum Index Smarty
The discussions here are for Smarty, a template engine for the PHP programming language.
Problème récupération de données dans un foreach (hors tpl)

 
Post new topic   Reply to topic    Smarty Forum Index -> Language: French
View previous topic :: View next topic  
Author Message
alfa
Smarty n00b


Joined: 23 Dec 2011
Posts: 1

PostPosted: Fri Dec 23, 2011 7:34 pm    Post subject: Problème récupération de données dans un foreach (hors tpl) Reply with quote

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
View user's profile Send private message
shinix
Smarty n00b


Joined: 01 Jun 2012
Posts: 3

PostPosted: Fri Jun 01, 2012 4:52 pm    Post subject: Reply with quote

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
View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic    Smarty Forum Index -> Language: French All times are GMT
Page 1 of 1

 
Jump to:  
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
Protected by Anti-Spam ACP