AccueilFAQRechercherMembresGroupesS'enregistrerConnexion

Forum de graphisme, codage et game design proposant des tutoriels, astuces, libres services et commandes dans les domaines de l'infographie amateur, de l'intégration web (HTML et CSS essentiellement) ainsi que dans la conception de RPG sur forum.


    Mise en forme des sujets (forme 1)

    Partagez
    avatar
    Okhmhaka
    FémininAge : 32Messages : 31851

    le Jeu 13 Sep 2012 - 18:32

    Rappel du premier message :

    Bonjour, bonsoir !

    Cela manquait un peu sur le forum, alors voici un tutoriel pour une mise en forme simple mais plus esthétique que celle de base de la liste des sujets, élément que l'on touche assez peu souvent, et pour cause, elle est à mon sens moins évidente que les catégories ou les messages, mais c'est peut-être justement le manque de pratique qui veut ça.

    Quoi qu'il en soit, voici ce que vous réaliserez avec ce tutoriel :

    >>> LIEN FORUM TEST <<<
    (en bas de page)

    Les couleurs seront modifiables avec le css bien sûr.


    Remarques importantes :
    ▬ vous devez être en phpBB2 pour réaliser ce tutoriel (punBB possible mais le template risque de différer)
    ▬ vous devez enlever les couleurs présentes dans votre panneau d'administration (Couleurs > Les Couleurs de fond > Table couleur rangée 1, 2 et 3)
    ▬ vous devez aller vérifier le réglage suivant dans votre panneau d'admin :
    "Général" > "Messages et Email" > Configuration" => Séparer les annonces et post-it des messages" => NON

    Le contenu n'est pas sous balide hide (explications), mais n'hésitez pas à remercier son auteur.


    I/ S'adapter à votre "forumline"

    Qu'est-ce que le "forumline" ? Il s'agit de l'attribut qui met en forme l'ensemble des cadres du forum. Si vous jetez un oeil dans les templates, vous verrez que
    Code:
    <table class="forumline">
    est présent partout. Ca va de la mise en forme du petit cadre de recherche apparaissant lorsque vous cliquez sur le bouton de navigation "Rechercher" jusqu'au bloc de catégorie en passant par l'encadré des options sous les sujets et les messages. Ce cadre se retrouve partout, il y a des template dans lequel il peut être modifié, ce qui fait que vous pouvez avoir des cadres différents entre vos catégories et vos listes de sujets par exemple, mais d'autres cadres ne sont pas ou difficilement modifiables, comme le cadre d'option qui se trouve en dessous des listes.
    Regardez par exemple sur mon forum test en dessous de la liste de sujet, le "joli" cadre violet qui contient les options... Pas terrible dans le cas présent, n'est-ce pas ? C'est la raison pour laquelle vous devez impérativement vous appliquer sur la mise en forme du "forumline" avant de faire quoi que ce soit.

    Vous aurez donc le choix au final de garder la mise en forme de votre forumline pour le cadre englobant les sujets (dans mon cas le cadre gris) ou bien de le changer en renommant le bloc. Ca parait compliqué ? Je vais vous expliquer un peu mieux à la fin du tutoriel, vous essaierez par vous-même et ça sera d'autant plus clair.


    II/ Modification du Template

    Le template qui gère l'affichage des sujets est : "topics_list_box".
    Je ne vais pas vous ennuyer avec des explications sur ce qu'il faut garder et ce que l'on peut enlever car les trois-quart ne le liront pas, et les intéressés auront le courage de comparer le template de base avec le mien et finiront par reconnaitre les éléments de manière efficace.

    Voici donc le template :

    Code:
    <!-- BEGIN topics_list_box --><!-- BEGIN row --><!-- BEGIN header_table --><!-- BEGIN multi_selection -->
    <script type="text/javascript">
    function check_uncheck_main_{topics_list_box.row.header_table.BOX_ID}() {
       var all_checked = true;
       for (i = 0; (i < document.{topics_list_box.FORMNAME}.elements.length) && all_checked; i++) {
          if (document.{topics_list_box.FORMNAME}.elements[i].name == '{topics_list_box.FIELDNAME}[]{topics_list_box.row.header_table.BOX_ID}') {
             all_checked = document.{topics_list_box.FORMNAME}.elements[i].checked;
          }
       }
       document.{topics_list_box.FORMNAME}.all_mark_{topics_list_box.row.header_table.BOX_ID}.checked = all_checked;
    }
    function check_uncheck_all_{topics_list_box.row.header_table.BOX_ID}() {
       for (i = 0; i < document.{topics_list_box.FORMNAME}.length; i++) {
          if (document.{topics_list_box.FORMNAME}.elements[i].name == '{topics_list_box.FIELDNAME}[]{topics_list_box.row.header_table.BOX_ID}') {
             document.{topics_list_box.FORMNAME}.elements[i].checked = document.{topics_list_box.FORMNAME}.all_mark_{topics_list_box.row.header_table.BOX_ID}.checked;
          }
       }
    }
    </script>
    <!-- END multi_selection -->

    <div class="bloc_sujets">
          <!-- BEGIN multi_selection -->
          <span align="center" nowrap="nowrap" width="20"><input onclick="check_uncheck_all_{topics_list_box.row.header_table.BOX_ID}();" type="checkbox" name="all_mark_{topics_list_box.row.header_table.BOX_ID}" value="0" /></span>
       <!-- END multi_selection -->
     
       <!-- BEGIN pagination -->
          <span align="right"><span class="gensmall">{PAGINATION}</span></span>
       <!-- END pagination -->
     
       <!-- END header_table --><!-- BEGIN header_row -->
    <!-- END header_row -->
     
    <!-- BEGIN topic -->
    {topics_list_box.row.END_TABLE_STICKY}
       
     
        <table class="sujets"><tr>
          <!-- BEGIN single_selection -->
          <td class="{topics_list_box.row.ROW_CLASS}" align="center" valign="middle" width="20"><input type="radio" name="{topics_list_box.FIELDNAME}" value="{topics_list_box.row.FID}" {topics_list_box.row.L_SELECT} /></td>
          <!-- END single_selection -->
          <td><span class="icones_sujets"><img title="{topics_list_box.row.L_TOPIC_FOLDER_ALT}" src="{topics_list_box.row.TOPIC_FOLDER_IMG}" alt="{topics_list_box.row.L_TOPIC_FOLDER_ALT}" /></span></td>
          <!-- BEGIN icon -->
          <td class="{topics_list_box.row.ROW_CLASS}" align="center" valign="middle" width="20">{topics_list_box.row.ICON}</td>
          <!-- END icon -->
                    <td class="{topics_list_box.row.ROW_CLASS}" onmouseover='this.className="row2"' onmouseout='this.className="{topics_list_box.row.ROW_CLASS}"' width="100%">
             <div class="topictitle">
                {topics_list_box.row.NEWEST_POST_IMG}{topics_list_box.row.PARTICIPATE_POST_IMG}{topics_list_box.row.TOPIC_TYPE}
                <h2 class="topic-title">
                   <a class="topictitle2" href="{topics_list_box.row.U_VIEW_TOPIC}">{topics_list_box.row.TOPIC_TITLE}</a>
                </h2>
             </div>
             <!-- BEGIN switch_description -->
             <span class="genmed">
                <br />
                {topics_list_box.row.topic.switch_description.TOPIC_DESCRIPTION}
             </span>
             <!-- END switch_description -->
             <span class="gensmall">{topics_list_box.row.TOPIC_ANNOUNCES_DATES}{topics_list_box.row.TOPIC_CALENDAR_DATES}</span> 
             <span class="gensmall">{topics_list_box.row.GOTO_PAGE}<!-- BEGIN nav_tree -->{topics_list_box.row.TOPIC_NAV_TREE} <!-- END nav_tree --></span>
          </td>

          <td class="row3" align="center" valign="middle"><span class="sujets_auteur"><i>par {topics_list_box.row.TOPIC_AUTHOR}</i></span></td>
          <td class="row3Right" onmouseover='this.className="row1"' onmouseout='this.className="row3Right"' align="center" valign="middle" nowrap="nowrap"><span class="sujet_last">{topics_list_box.row.LAST_POST_TIME}<br />{topics_list_box.row.LAST_POST_AUTHOR} {topics_list_box.row.LAST_POST_IMG}</span></td>
    <!-- BEGIN multi_selection -->
          <td class="row2" align="center" valign="middle"><span class="postdetails"><input onclick="javascript:check_uncheck_main_{topics_list_box.row.BOX_ID}();" type="checkbox" name="{topics_list_box.FIELDNAME}[]{topics_list_box.row.BOX_ID}" value="{topics_list_box.row.FID}" {topics_list_box.row.L_SELECT} /></span></td>
       <!-- END multi_selection -->
       </tr></table>
      <div class="sujets_stats"><span class="sujets_stats_contenu">Ce sujet a été vu {topics_list_box.row.VIEWS} fois et a reçu {topics_list_box.row.REPLIES} réponse(s).</span></div>
       <!-- END topic --><!-- BEGIN no_topics -->
       <table><tr>
          <td class="row1" colspan="{topics_list_box.row.COLSPAN}" align="center" valign="middle" height="30"><span class="gen">{topics_list_box.row.L_NO_TOPICS}</span></td>
              </tr></table>
       <!-- END no_topics --><!-- BEGIN bottom --> 

      <br /><br />
    <div class="pages"><span class="gensmall">{PAGINATION}</span>
      <span><a href="#top">{L_BACK_TO_TOP}</a>&nbsp;</span></div>
     
    <!-- END bottom --><!-- BEGIN footer_table -->
    </div><!-- END footer_table --><!-- BEGIN spacer --><br class="gensmall" /><!-- END spacer --><!-- END row --><!-- END topics_list_box -->

    Vous pouvez enregistrer votre template, n'oubliez pas qu'il faut également le valider une fois enregistré pour que la modification soit prise en compte dans l'affichage en ligne du forum.


    III/ Mise en forme par le CSS

    Voici le code CSS à ajouter à votre propre CSS (PA > Affichage > Couleurs > Feuille CSS)

    Code:
    /* MISE EN FORME DES LISTES DE SUJETS */

    .bloc_sujets
    {
      width: 950px;
      margin: auto;
      background: #dfdfdf;
      border: 1px solid #ececec;
      box-shadow: 0px 0px 3px #868686;
      -o-box-shadow: 0px 0px 3px #868686;
      -moz-box-shadow: 0px 0px 3px #868686;
      -webkit-box-shadow: 0px 0px 3px #868686;
      -htm-box-shadow: 0px 0px 3px #868686;
      padding: 5px;
    }
    .sujets
    {
      background: #ececec;
      border: 1px dotted #ffffff;
      padding: 3px;
    }
    .topictitle
    {
      font-variant: small-caps;
      font-size: 12px;
    }
    .sujets_auteur
    {
      display: block;
      width: 200px;
      font-size: 11px;
    }
    .sujet_last
    {
      display: block;
      width: 180px;
      height: 40px;
      background: #f4f4f4;
      border-left: 3px solid #9e9e9e;
      border-right: 3px solid #9e9e9e;
      padding-top: 10px;
      font-size: 11px;
    }
    .sujets_stats
    {
      width: 900px;
      text-align: right;
      margin-bottom: 5px;
    }
    .sujets_stats_contenu
    {
      font-size: 10px;
      color: #a4a4a4;
    }

    Validez, puis personnalisez selon votre forum en changeant les formes et les couleurs. Il est tout à fait possible de mettre une image de fond (ligne "background") comme une texture par exemple.

    Pour changer les éléments de place comme par exemple mettre le bloc du dernier message avant l'auteur sur la ligne, vous devez aller dans le template et sélectionner la case correspondante. Les cases c'est tout ce qu'il y a entre :

    Code:
    <td>Contenu de la case ... </td>

    (N'oubliez pas les "td" x).

    Pour revenir à votre "forumline" : si vous souhaitez que ce soit la mise en forme de votre "forumline" qui soit le cadre de votre liste, il vous suffit de modifier :
    Code:
    <div class="bloc_sujets">
    par
    Code:
    <div class="forumline">
    (ce code se situe au environ de la ligne 22 de votre template modifié).

    J'espère que ce tutoriel vous sera utile !

    En cas d'utilisation du tutoriel, même si vous en modifiez le contenu, je vous serais reconnaissant de mettre un CREDIT à Never-Utopia, en remerciement pour notre travail et notre aide. C'est peu de chose mais cela nous encourage à vous donner toujours plus. Nous vous épargnons souvent des prises de tête avec les modifications des templates, ces heures gagnées valent bien un petit lien x).
    Merci par avance !


    Dernière édition par Sparrow-style le Jeu 26 Juin 2014 - 11:10, édité 2 fois



    avatar
    •MYV382•
    FémininAge : 20Messages : 55

    le Jeu 8 Nov 2012 - 18:25

    Merci beaucoup ! *O*
    avatar
    Laetitia
    FémininAge : 35Messages : 88

    le Jeu 8 Nov 2012 - 18:31

    merci beaucoup pour ce tuto
    avatar
    OMJ
    FémininAge : 26Messages : 86

    le Jeu 8 Nov 2012 - 19:13

    merciiiii énormément :)
    avatar
    Shy
    MasculinAge : 22Messages : 126

    le Mer 14 Nov 2012 - 22:40

    Merci !



    avatar
    Shiney
    FémininAge : 19Messages : 26

    le Dim 18 Nov 2012 - 0:02

    Merciii *-*
    avatar
    A.Volk
    FémininAge : 25Messages : 145

    le Lun 19 Nov 2012 - 21:33

    Merci ! =3
    avatar
    kingmazigh
    MasculinAge : 27Messages : 13

    le Mar 20 Nov 2012 - 20:38

    merci bq
    avatar
    Alonely
    MasculinAge : 22Messages : 43

    le Jeu 22 Nov 2012 - 23:04

    Merci
    avatar
    Trych
    FémininAge : 22Messages : 80

    le Lun 26 Nov 2012 - 3:18

    magnifique merci!



    avatar
    Awful
    MasculinAge : 99Messages : 162

    le Lun 26 Nov 2012 - 10:32

    Vraiment sympa ^^ Merci ! :3
    avatar
    Honeey L.
    FémininAge : 24Messages : 79

    le Lun 26 Nov 2012 - 11:34

    MERCIIIIII C'est ce que je cherchais depuis des mois !!
    avatar
    Screen
    FémininAge : 25Messages : 92

    le Lun 26 Nov 2012 - 11:54

    Thank's c'est trop beau *w*
    avatar
    Barbosa
    MasculinAge : 25Messages : 22

    le Mer 28 Nov 2012 - 4:18

    Merci :)



    avatar
    alexee29
    FémininAge : 23Messages : 39

    le Mer 28 Nov 2012 - 20:26

    Merci!
    avatar
    Banpaia
    FémininAge : 19Messages : 130

    le Ven 30 Nov 2012 - 19:42

    Merci !
    avatar
    Arphan
    FémininAge : 25Messages : 5

    le Sam 1 Déc 2012 - 17:14

    Très esthétique, merci Wink
    avatar
    HeleneM
    FémininAge : 23Messages : 189

    le Dim 2 Déc 2012 - 11:36

    merci
    avatar
    CuBz
    MasculinAge : 27Messages : 27

    le Dim 2 Déc 2012 - 13:06

    merci Wink
    avatar
    Dastan
    MasculinAge : 33Messages : 111

    le Dim 2 Déc 2012 - 15:14

    Merci merciii
    avatar
    K'Aya
    FémininAge : 18Messages : 427

    le Dim 2 Déc 2012 - 16:28

    Merci :3
    avatar
    ShuwaPon
    FémininAge : 22Messages : 80

    le Lun 3 Déc 2012 - 21:18

    Merci, encore un tuto qui en jette *^*
    avatar
    ♕ William
    MasculinAge : 19Messages : 72

    le Jeu 6 Déc 2012 - 17:13

    Merci !




    William
    avatar
    Mika-chan
    FémininAge : 25Messages : 76

    le Ven 7 Déc 2012 - 9:38

    Je prends ! merci Very Happy
    avatar
    Ocean Lounge.
    FémininAge : 23Messages : 113

    le Ven 7 Déc 2012 - 18:25

    Merci ♥
    avatar
    Nevah
    MasculinAge : 29Messages : 30

    le Lun 10 Déc 2012 - 10:34

    Merci ^^
    Contenu sponsorisé


      La date/heure actuelle est Dim 30 Avr 2017 - 20:48