Tutorial : les boucles forums

Ceci est une ARCHIVE, peut-être périmée. Vérifiez bien les compatibilités !

Nous allons faire ici le tour de ce qu’il faut savoir pour bien manipuler la boucle forum.

Ce tutorial est une application de la boucle forum décrite ici dans la documentation de Spip

Attention Les exemples sont adaptées à de très anciennes versions de SPIP, et la syntaxe a plusieurs fois changé depuis 20 ans. Remplacez dans les codes ci-dessous : href="forum.php3?(#PARAMETRES_FORUM)" par href="(#PARAMETRES_FORUM|url_reponse_forum)" !

Préalable

Créez une nouvelle rubrique et dedans un nouvel article, notez le numéro de la rubrique et créez un fichier vide que vous nommez article-XX.html ou XX est le numéro de la rubrique.

Le tutorial suivant va vous permettre de voir comment gérer les différents affichages utiles pour des forums étape par étape.

Les types de messages

On distingue deux types de messages :

-  Les sujets

Les sujets sont les messages de niveau 1, c’est à dire que l’on créer un sujet en répondant à un article (ou une brève, ou encore une rubrique).

-  Les réponses

Les réponses sont des messages de niveau 2 ou plus, une réponse est postée en répondant à un sujet ou à une réponse.

Répondre à un article

Pour répondre à un article il faut ajouter l’appel que voici

[<p><a href="forum.php3?(#PARAMETRES_FORUM)"> Nouveau sujet </a></p>] 

Ce code appelle par défaut la page forum.php3/html de Spip qui permet de rédiger un message, il faut impérativement le mettre dans le corps de la boucle article pour permettre à Spip de calculer correctement la valeur de #PARAMETRES_FORUM.

Afficher tous les Sujets

Voici une boucle qui permet de créer un sujet en réponse à un article, d’afficher les sujets et d’en compter le nombre. Recopiez la dans votre fichier article-XX.html et créez un certain nombre de sujets.

<BOUCLE_principale(ARTICLES){id_article}>

[<p><a href="forum.php3?(#PARAMETRES_FORUM)"> Nouveau sujet </a></p>]


<B_sujets>
<ul>
<BOUCLE_sujets(FORUMS){id_article}{par date}{inverse}>

<li>#TITRE</li>

</BOUCLE_sujets>
</ul>
Il y a #TOTAL_BOUCLE sujets postés en réponse à cet article
</B_sujets>


</BOUCLE_principale>

Afficher les 5 derniers sujets et leurs réponses directes

Voici maintenant comment lister les 5 derniers sujets, permettre d’y répondre et afficher les réponses directes à ces sujets (on comptera les réponses pour la forme)

<BOUCLE_principale(ARTICLES){id_article}>

[<p><a href="forum.php3?(#PARAMETRES_FORUM)"> Nouveau sujet </a></p>]

<B_sujets>
<ul>
<BOUCLE_sujets(FORUMS){id_article}{par date}{inverse}{0,5}>

<li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> répondre</a>]</li> 

<B_reponses>
<ul>
<BOUCLE_reponses(FORUMS){id_parent}{par date}>
<li>#TITRE</li>
</BOUCLE_reponses>
</ul>
Il y a #TOTAL_BOUCLE réponses postées en réponse à cette réponse.
</B_reponses>


</BOUCLE_sujets>
</ul>

</BOUCLE_principale>

Permettre de répondre aux réponses et voir ces réponses

Chaque message, quelque soit son niveau dans la hiérarchie des réponses, est considéré comme un élément de type (FORUMS), cela permet à Spip gérer les réponses aux réponses indéfiniment.

On accède aux réponses du niveau d’en dessous en utilisant le critère {id_parent} dans une boucle (FORUMS) contenue dans la boucle (FORUMS) du niveau supérieur.

Fort bien, mais comme on ne peut pas savoir par avance combien de niveaux de réponses va engendrer un sujet, il est impossible de prévoir le nombre de boucles de forum imbriquées nécéssaires, on utilisera donc une astuce qui va nous permettre de prendre en compte tous les cas de figure d’un coup : une boucle récursive.

Voici donc la même boucle que précédement, mais qui permet en plus de répondre aux réponses indéfiniment.

<BOUCLE_principale(ARTICLES){id_article}>

[<p><a href="forum.php3?(#PARAMETRES_FORUM)"> Nouveau sujet </a></p>]

<B_sujets>
<ul>
<BOUCLE_sujets(FORUMS){id_article}{par date}{inverse}{0,5}>

<li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> répondre</a>]</li>

<B_reponses>
<ul>
<BOUCLE_reponses(FORUMS){id_parent}{par date}>
<li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> répondre </a>]</li>
<BOUCLE_recursive(boucle_reponses)></BOUCLE_recursive>
</BOUCLE_reponses>
</ul>
Il y a #TOTAL_BOUCLE réponses postées en réponse à cette réponse.
</B_reponses>


</BOUCLE_sujets>
</ul>

</BOUCLE_principale>

Compter les messages

Il peut etre intérressant pour une page d’accueil de formum de savoir le nombre de sujets et de contributions totales à un article.

-  Compter les sujets

Si vous êtes observateur vous avez remarqué que l’on compte les sujets comme ca :

<BOUCLE_compte_sujets(FORUMS){id_article}> </BOUCLE_compte_sujets>
<p>#PUCE Il y a #TOTAL_BOUCLE sujets en réponse à cet article</p>
</B_compte_sujets>

On ne met qu’un espace au milieu de la boucle car ce qui nous intérresse c’est juste qu’elle tourne pour qu’on puisse compter le nombre de tour.

Vous voyez qu’avec le critère {id_article} Spip compte par défaut le nombre de réponses directement lié à l’article (donc Spip compte les sujets). Si on veut prendre en compte les réponses et les réponses de niveaux inférieurs (les réponses au sujet et les réponses à ces réponses), il faut ajouter le critère {plat} ca donne :

-  Compter tous les messages

<BOUCLE_compte_messages(FORUMS){id_article}{plat}> </BOUCLE_compte_messages>
<p>#PUCE Il y au total #TOTAL_BOUCLE messages en réponse à cet article</p>
</B_compte_messages>

En intégrant tout ça notre fichier article-XX devient :

<BOUCLE_principale(ARTICLES){id_article}>


<BOUCLE_compte_sujets(FORUMS){id_article}> </BOUCLE_compte_sujets>
<p>#PUCE Il y a #TOTAL_BOUCLE sujets en réponse à cet article</p>
</B_compte_sujets>


<BOUCLE_compte_messages(FORUMS){id_article}{plat}> </BOUCLE_compte_messages>
<p>#PUCE Il y au total #TOTAL_BOUCLE messages en réponse à cet article</p>
</B_compte_messages>

<hr>

[<p><a href="forum.php3?(#PARAMETRES_FORUM)"> Nouveau sujet </a></p>]

<B_sujets>
<ul>
  <BOUCLE_sujets(FORUMS){id_article}{par date}{inverse}{0,5}>
  <li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> Nouvelle réponse </a>]</li>
  <B_reponses>
  <ul>
    <BOUCLE_reponses(FORUMS){id_parent}{par date}>
    <li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> Nouvelle réponse </a>]</li>
    <BOUCLE_recursive(boucle_reponses)>
    </BOUCLE_recursive>
    </BOUCLE_reponses>
  </ul>
  Il y a #TOTAL_BOUCLE réponses postées en réponse à cette r&eacute;ponse. 
  </B_reponses>
  </BOUCLE_sujets>
</ul>

</BOUCLE_principale>

Lister les sujets par date inverse des réponses

Âmes sensibles s’abstenir...

Jusqu’ici on listait les sujets du plus récent au plus ancien, mais bien souvent ce qui nous interesse quand on liste les sujets c’est de faire « remonter » un sujet en haut de la pile lorsqu’il recoit une nouvelle réponse. Il faut donc trier les sujets par rapport à la date de leur dernière réponse. Vous êtes bien accrochés ???

-  Récupérer le sujet à l’origine de la discussion où le dernier message a été posté

Pour cela il va falloir utiliser le critère {id_enfant} qui permet de remonter d’un cran. On peut donc savoir de quel message le message courant est la réponse. Mais pour retrouver le sujet il va falloir remonter jusqu’en haut, c’est à dire jusqu’a ce que le message courant n’ai plus de message père car le sujet c’est précisement le message qui n’a pas de père.

L’idée est donc de remonter la hierarchie depuis le dernier message grâce à une boucle récursive et quand on ne trouve plus de résultat (ce qui veut dire qu’on est arrivé en haut) on affiche (donc en code alternatif) le titre du message : qui sera le sujet.

<BOUCLE_liste(FORUMS){id_article}{plat}{par date}{inverse}{0,1}> 

<BOUCLE_remonte(FORUMS){id_enfant}>
<BOUCLE_remonte_rec(boucle_remonte)> </BOUCLE_remonte_rec>
</BOUCLE_remonte>
<br>#TITRE
<//B_remonte>

</BOUCLE_liste>
<hr>
</B_liste>

Bon maintenant qu’on a réussit à récupérer le sujet du dernier message on va pouvoir continuer avec les autres messages les plus récents, mais on risque d’avoir un problème si les messages proviennent d’un sujet déjà listé en effet il ne faudrait pas re lister même le sujet.

En général dans Spip il suffit de mettre le critère {doublons} pour s’assurer que Spip ne re affiche pas un élément déjà affiché par une autre boucle, mais malheureusement ca ne marche pas à l’intérieur d’une même boucle.

Donc pas la peine de tenter de lister les messages issus du sujet qu’on vient de trouver dans une boucle imbriquée avec un {doublons} et de mettre un {doublons} à la boucle liste, ca ne marchera pas parce qu’on reste dans la boucle liste. Du coup on va utiliser un tableau php et vérifier que le sujet n’est pas déjà dedans avant de l’afficher.

<?php $tableau = array();?>
<BOUCLE_liste(FORUMS){id_article}{plat}{par date}{inverse}> 

<BOUCLE_remonte(FORUMS){id_enfant}>
<BOUCLE_remonte_rec(boucle_remonte)> </BOUCLE_remonte_rec>
</BOUCLE_remonte>
<?php 

$id_forum='[(#ID_FORUM|texte_script)]';
$titre='[(#TITRE|texte_script)]';
if(!in_array($id_forum,$tableau)) echo $titre."<br>";
$tableau[$id_forum]=$id_forum;

?>

<//B_remonte>

</BOUCLE_liste>
<hr>
</B_liste>

Et au final notre tutorial devient :

<?php
if(floor(phpversion()) < 4)	{
	// La version de PHP est inférieure à 4,
	// la fonction in_array n'existe donc pas
	function in_array($member, $array)
	{
		reset($array);
		while (list($k, $v) = each($array)) {
			if ($v == $member) return true;
		}
		return false;
	}
}
?>

<BOUCLE_principale(ARTICLES){id_article}>


<BOUCLE_compte_sujets(FORUMS){id_article}> </BOUCLE_compte_sujets>
<p>#PUCE Il y a #TOTAL_BOUCLE sujets en réponse à cet article</p>
</B_compte_sujets>


<BOUCLE_compte_messages(FORUMS){id_article}{plat}> </BOUCLE_compte_messages>
<p>#PUCE Il y au total #TOTAL_BOUCLE messages en réponse à cet article</p>
</B_compte_messages>

<hr>
<?php $tableau = array();?>
<BOUCLE_liste(FORUMS){id_article}{plat}{par date}{inverse}> 

<BOUCLE_remonte(FORUMS){id_enfant}>
<BOUCLE_remonte_rec(boucle_remonte)> </BOUCLE_remonte_rec>
</BOUCLE_remonte>
<?php 

$id_forum='[(#ID_FORUM|texte_script)]';
$titre='[(#TITRE|texte_script)]';
if(!in_array($id_forum,$tableau)) echo $titre."<br>";
$tableau[$id_forum]=$id_forum;

?>

<//B_remonte>

</BOUCLE_liste>
<hr>
</B_liste>



[<p><a href="forum.php3?(#PARAMETRES_FORUM)"> Nouveau sujet </a></p>]

<B_sujets>
<ul>
  <BOUCLE_sujets(FORUMS){id_article}{par date}{inverse}{0,5}>
  <li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> répondre </a>]</li>
  <B_reponses>
  <ul>
    <BOUCLE_reponses(FORUMS){id_parent}{par date}>
    <li>#TITRE[ <a href="forum.php3?(#PARAMETRES_FORUM)"> répondre </a>]</li>
    <BOUCLE_recursive(boucle_reponses)>
    </BOUCLE_recursive>
    </BOUCLE_reponses>
  </ul>
  Il y a #TOTAL_BOUCLE réponses postées en réponse à cette r&eacute;ponse. 
  </B_reponses>
  </BOUCLE_sujets>
</ul>

</BOUCLE_principale>

Voilà vous savez tout, c’est grâce à ces notions qu’on peut réaliser un forum style phpBB en Spip

Discussion

Aucune discussion

Ajouter un commentaire

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

Qui êtes-vous ?
[Se connecter]

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom