annotate index.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 6125c7a882b8
children a6c3716cab6a
rev   line source
webmaster@0 1 <?php
webmaster@11 2 require_once("classes.php");
webmaster@11 3 $sk = Factory::getSkeleton();
webmaster@11 4 $sk->setTitle('Dual { v10 : OS Edition } Blog');
webmaster@11 5 // Détermination de la requête à exécuter
webmaster@11 6 if(!array_key_exists('mode', $_GET)) {
webmaster@11 7 $query = "
webmaster@11 8 SELECT *
webmaster@11 9 FROM Mess
webmaster@6 10 WHERE num_version='Version 10'
webmaster@6 11 ORDER BY num_mess DESC
webmaster@6 12 LIMIT 10
webmaster@11 13 ";
webmaster@11 14 } elseif($_GET['mode'] == 'cal') {
webmaster@11 15 $sk->showCalendar(true);
webmaster@11 16 $year = intval($_GET['year']);
webmaster@11 17 $month = intval($_GET['month']);
webmaster@11 18 $sk->setCalendarMonth($month, $year);
webmaster@11 19 $query = "
webmaster@6 20 SELECT *
webmaster@11 21 FROM Mess
webmaster@11 22 WHERE
webmaster@11 23 YEAR(DatePost) = $year AND
webmaster@11 24 MONTH(DatePost) = $month
webmaster@6 25 ORDER BY num_mess DESC
webmaster@11 26 LIMIT 10
webmaster@11 27 ";
webmaster@11 28 } elseif($_GET['mode'] == 'tag') {
webmaster@11 29 $tag = $_GET['tag'];
webmaster@11 30 $query = "
webmaster@11 31 SELECT *
webmaster@11 32 FROM Mess m
webmaster@11 33 LEFT JOIN Lien_Tags_Posts l ON m.num_mess=l.idMess
webmaster@11 34 LEFT JOIN Tags t ON l.idTag = t.idTag
webmaster@11 35 WHERE t.Tag='{$_GET['tag']}'
webmaster@11 36 ORDER BY num_mess DESC
webmaster@11 37 ";
webmaster@0 38 }
webmaster@11 39 $db = Factory::getDB();
webmaster@27 40 $db->query($query);
webmaster@11 41 while($row = $db->GetRow()) {
webmaster@11 42 $post = new Post($row);
webmaster@11 43 $sk->addBlogPost($post->format());
webmaster@0 44 }
webmaster@11 45 echo $sk;
webmaster@0 46 ?>