Mercurial > defr > DualBlog
view includes/class.post.php @ 32:4cea8b128fdd
Possibilité de choisir des templates différents en fonction du type de sortie.
Le fichier templates.conf permet d'associer à chaque type de sortie
(correspondant à une section du fichier INI) des templates pour le squelette,
les posts et les commentaires.
Il est possible de définir virtuellement
une infinité de type de sorties différents, pour le moment seul de quoi
obtenir un flux Atom a été ajouté.
Pour changer le type de sortie, il faut passer en GET au script appellant
un paramètre outputType. Si le paramètre reçu ne correspondant à aucun
des types de sorties définis dans templates.conf, alors on prend du
xhtml par défaut.
author | Franck Deroche <webmaster@defr.org> |
---|---|
date | Mon, 05 Nov 2007 09:06:46 +0100 |
parents | fa43c43763a2 |
children | c6508503269a |
line wrap: on
line source
<?php class Post { private $tpl; private $infos; private $mess; private $dateFormatee; private $url; private $commentLabel; private $mood; private $tags; public function __construct($infos) { $this->infos = (object)$infos; $this->tpl = new Template(Skeleton::getTemplateFile('post')); // Création du document fragment contenant le message $Mess = str_replace( array('<P>', '</P>'), array('<p>', '</p>'), $infos['Message']); $Mess = Factory::getDB()->utf8_ensure($Mess); $this->mess = $this->tpl->getDocumentFragment(); $this->mess->appendXML($Mess); // Formatage de la date $time = strtotime($infos['DatePost']); $this->dateFormatee = strftime("%A %d %B %Y, %Hh%M", $time); // On détermine l'url de ce post $strippedTitle = TextUtils::StripTitle($infos['Titre']); $this->url = '/blog/posts/' . $infos['num_mess'] . '-' . $strippedTitle; // On détermine le label du lien vers les commentaires $this->commentLabel = "Un p'tit commentaire ?"; if($infos['NbCommentaires'] > 0) $this->commentLabel .= " (" . $infos['NbCommentaires'] . ")"; // On s'occupe de l'indicateur d'humeur if(!empty($infos['Emot'])) { $mood = array('src' => "/blog/mood/{$infos['Emot']}.png", 'alt' => 'Mood: ' . $infos['Emot']); $this->mood = (object)$mood; } // On détermine les tags du post $db = Factory::getDB(); $nbTags = $db->Query(" SELECT T.Tag FROM Tags T, Lien_Tags_Posts L WHERE L.idMess={$infos['num_mess']} AND L.idTag = T.idTag ORDER BY T.Tag ", 2); $tags = ''; if($nbTags > 0) { while(0 !== ($tag = $db->GetRow(2))) $tags .= " <a href='/blog/tags/{$tag['Tag']}'>{$tag['Tag']}</a> |"; $tags = substr($tags, 0, -1); $this->tags = $this->tpl->getDocumentFragment(); $this->tags->appendXML($tags); } else { $this->tags = 'aucun'; } } public function format() { $this->tpl->setParams($this->getTplParams()); return $this->tpl; } public function getTplParams() { $params = array( '#post@class' => 'PostContent ' . $this->infos->Emot, 'postTitle' => $this->infos->Titre, 'postDate' => $this->dateFormatee, 'postContent' => $this->mess, 'postNumber' => $this->infos->num_mess, 'postComments' => $this->commentLabel, '#linkPostNumber@href' => $this->url, '#linkPostComments@href' => $this->url, 'postTags' => $this->tags ); if(!empty($this->mood->src)) { $params['#mood@src'] = $this->mood->src; $params['#mood@alt'] = $this->mood->alt; $params['#mood@class'] = 'mood'; } return $params; } public function getURL() { return $this->url; } } ?>