AccueilDernières imagesRechercherS'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.

-28%
Le deal à ne pas rater :
-28% Machine à café avec broyeur à grain MELITTA Purista
229.99 € 318.99 €
Voir le deal

    Dynamiser la page "Membres"

    Hiro'
    Hiro'
    MasculinAge : 27Messages : 127

    Sam 21 Sep 2013 - 14:24

    Rappel du premier message :



    Bonjour tout le monde !
    Aujourd'hui, je vous propose mon premier tutoriel. Il servira à dynamiser la page membres de votre forum.
    Ce n'est pas forcément un tuto très utile en soi, mais le réaliser m'a permis de comprendre un peu mieux les templates.

    À noter que ce tuto est fait pour la version de forum PhpBB2.

    Ce tuto nécessite la modification des templates et de la fiche de style CSS. Vous devez donc être administrateur fondateur.
    Ce tuto est valable pour un forum avec des avatars aux dimensions 200*400. En cas de problème pour le personnaliser, je suis à votre écoute.


    Merci à Sparrow à qui j'ai subtilisé le code CSS qu'il utilise ici.


    Première partie : Templates.

    Le template à utiliser est le memberlist_body

    La partie qui nous intéresse est celle-ci :
    Code:
    <td class="{memberrow.ROW_CLASS}" align="center"><div class="avatar mini"><a href="{memberrow.U_VIEWPROFILE}">{memberrow.AVATAR_IMG}</a></div></td>
    Elle se trouve à la ligne 39. Supprimez tout ce qui se trouve entre les balises < td >, soit ceci :

    Code:
    <div class="avatar mini"><a href="{memberrow.U_VIEWPROFILE}">{memberrow.AVATAR_IMG}</a></div>
    Qu'est-ce que j'ai supprimé ?
    Vous avez supprimé le contenu de la case réservée à l'avatar. Nous allons très vite le remplacer.


    Voilà le code que vous allez ajouter à la place de ce code.
    Code:
    <div class="description3"><div style="display: block; text-align: center; width: 200px; height:400px; overflow:visible;">{memberrow.AVATAR_IMG}<div class="description3_contenu" style="margin-top:-400px;"><div style="OVERFLOW: auto; width: 190px; height: 390px; padding: 5px;font-variant:small-caps; text-shadow:1px 1px 1px white; font-size:14px;"><br />{memberrow.USERNAME}.<br />{memberrow.POSTS} messages.<br />Inscrit le {memberrow.JOINED}.</div></div></div></div>
    Examinons ceci en détail.
    Kézako ?

    • {memberrow.AVATAR_IMG} est l'avatar du membre.
    • {memberrow.USERNAME} est le pseudo du membre.
    • {memberrow.POSTS} est le nombre de posts du membre.
    • {memberrow.JOINED} est la date d'inscription du membre.



    Ce qui est contenu entre :
    Code:
    <div style="OVERFLOW: auto; width: 190px; height: 390px; padding: 5px;font-variant:small-caps; text-shadow:1px 1px 1px white; font-size:14px;">
    et :
    Code:
    </div></div></div></div>
    Est ce qui va apparaître quand la souris passera sur l'avatar.

    Personnaliser
    Vous pouvez donc mettre ce que vous voulez. Cependant, ce tutoriel d'adaptera au résultat montré plus haut. Mais je suis ouvert à toutes vos questions si vous avez du mal à personnaliser votre template.


    Le nom du poteur, son nombre de messages et sa date d'inscription sont donc affichés dans la case Avatar. Inutile de les afficher à nouveau dans les autres cases. Il faut donc supprimer la colonne "nombre de messages", la colonne "pseudo" et la colonne "date d'inscription".

    Repérez cette partie-là :

    Code:
    <table class="forumline" width="100%" border="0" cellspacing="1" cellpadding="0">
       <tr>
          <th class="thCornerL" nowrap="nowrap" height="25">#</th>
          <th class="thTop" nowrap="nowrap">{L_AVATAR}</th>
          <th class="thTop" nowrap="nowrap">{L_USERNAME}</th>
          <!-- BEGIN switch_th_group -->
          <th class="thTop" nowrap="nowrap">{L_GROUPS}</th>
          <!-- END switch_th_group -->
          <th class="thTop" nowrap="nowrap">{L_INTERESTS}</th>
          <th class="thTop" nowrap="nowrap">{L_JOINED}</th>
          <th class="thTop" nowrap="nowrap">{L_VISITED}</th>
          <th class="thTop" nowrap="nowrap">{L_POSTS}</th>
          <th class="thTop" nowrap="nowrap">{L_PM}</th>
          <th class="thCornerR" nowrap="nowrap">{L_WEBSITE}</th>
       </tr>
       <!-- BEGIN memberrow -->
       <tr>
          <td class="{memberrow.ROW_CLASS}" align="center"><span class="gen"> {memberrow.ROW_NUMBER} </span></td>
          <td class="{memberrow.ROW_CLASS}" align="center"><div class="avatar mini"><a href="{memberrow.U_VIEWPROFILE}">{memberrow.AVATAR_IMG}</a></div></td>
          <td class="{memberrow.ROW_CLASS}" align="center"><span class="gen"><a class="gen" href="{memberrow.U_VIEWPROFILE}">{memberrow.USERNAME}</a></span></td>
          <!-- BEGIN switch_td_group -->
          <td class="{memberrow.ROW_CLASS}" align="center"><span class="gen">{memberrow.GROUPS}</span></td>
          <!-- END switch_td_group -->
          <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gen">{memberrow.INTERESTS}</span></td>
          <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gensmall">{memberrow.JOINED}</span></td>
          <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gensmall">{memberrow.LASTVISIT}</span></td>
          <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gen">{memberrow.POSTS}</span></td>
          <td class="{memberrow.ROW_CLASS}" align="center"> {memberrow.PM_IMG} </td>
          <td class="{memberrow.ROW_CLASS}" align="center"> {memberrow.WWW_IMG} </td>
       </tr>
       <!-- END memberrow -->
       <!-- BEGIN switch_no_user -->
       <tr>
          <td class="catBottom" colspan="{switch_no_user.COLSPAN_NUMBER}" height="28" align="center"><span class="gensmall">{switch_no_user.L_NO_USER}</span></td>
       </tr>
       <!-- END switch_no_user -->
    </table>
    La première partie du code (c'est-à-dire jusqu'à ), c'est celle qui donne les titres des colonnes. Vous pouvez certainement les identifier facilement.


    Kézako ?

    • {L_AVATAR} affichera "Avatar",
    • {L_USERNAME} affichera "Pseudo",
    • etc.



    Maintenant que nous avons regroupé plusieurs données dans la case avatar nous pouvons les supprimer.

    Les lignes à supprimer sont donc :
    Code:
    <th class="thTop" nowrap="nowrap">{L_USERNAME}</th>
    <th class="thTop" nowrap="nowrap">{L_JOINED}</th>
    <th class="thTop" nowrap="nowrap">{L_JOINED}</th>
    Personnaliser
    Vous pouvez également remplacer le nom de la colonne avatar ({L_AVATAR}) par votre propre appellation. Il suffira de supprimer cette variable et d'y écrire à la place votre appellation, tout simplement.



    Si vous validiez le template à ce moment là, le résultat ne serait pas à la hauteur de vos espérances. En effet, les titres des colonnes auront disparu, mais le contenu de ces colonnes sera resté intact, c'est là qu'intervient la seconde partie du code (c'est-à-dire après ).

    Vous pouvez supprimer les lignes inutiles, à savoir :
    Code:
    <td class="{memberrow.ROW_CLASS}" align="center"><span class="gen"><a class="gen" href="{memberrow.U_VIEWPROFILE}">{memberrow.USERNAME}</a></span></td>

    <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gensmall">{memberrow.JOINED}</span></td>

    <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gen">{memberrow.POSTS}</span></td>
    Ca y est, votre template est prêt ! Maintenant, attaquons-nous à la partie CSS !


    Deuxième partie : CSS.

    Allez, je sens que vous en avez marre, alors voici le code CSS :
    Code:
    .description3 {
      display: block;
      width: 200px;
      margin: auto;
      height: 200px;
      overflow: hidden;
      transition:0.4s ease;
    }

    .description3:hover {
      display: block;
      width: 200px;
      margin: auto;
      height: 400px;
      overflow: hidden;
    }

    .description3_contenu {
      position: absolute;
      width: 200px;
      height: 400px;
      overflow: 400px;
      background-color: #EFE9DD;
      font-size: 11.5px;
      font-family:'Georgia';
      color: #3E352E;
      text-align: justify;
      padding:0px;
      opacity: 0;
      transform: all;
      transition: 1s;
    }
    .description3_contenu:hover {
      opacity: 0.8;
      transform: all;
      transition: 1s;
    }
    Kézako ?

    • description3 contient l'avatar. Comme au départ, l'avatar est en partie caché, il faut réduire ses dimensions (ici 200*200) et lui mettre un overflow:hiddenpour l'empêcher de dépasser. Ensuite, la partie description3:hover est celle où l'on indique que les dimensions changent au passage de la souris.
    • description3_contenu est ce qui va s'afficher au passage de la souris, ici le nom du membre, son nombre de message et sa date d'inscription. Cependant, il doit être invisible quand la souris n'est pas dessus, d'où le opacity:0 qui le rend totalement transparent. La partie description3_contenu:hover est celle qui va indiquer que au passage de la souris, l'opacity augmentera.



    Vous savez tout ! Ah ? Vous vous êtes perdus en chemin ? Bon, je suis gentil et je vous donne le code terminé.


    Troisième partie : Le code tout fini tout beau.

    Remplacer le contenu du template memberlist_body par celui-ci :

    Code:
    <form action="{S_MODE_ACTION}" method="get">
    <table cellspacing="0" cellpadding="5" border="0" align="center" class="forumline" width="100%">
       <tr>
          <th class="thTop" nowrap="nowrap">{L_ORDER_OR_SELECT}</th>
       </tr>
       <tr>
          <td class="row1">
          <table cellspacing="2" cellpadding="0" border="0" align="center" class="genmed">
             <tr>
                <td width="100%">{L_USER_SELECT} <input type="text" class="post" name="username" maxlength="25" size="20" value="{L_USER_SELECT_VALUE}" />      
                {L_SELECT_SORT_METHOD} {S_MODE_SELECT}      
                {L_ORDER} {S_ORDER_SELECT}      
                {S_HIDDEN_SID}
                <input class="liteoption" type="submit" name="submit" value="{L_SUBMIT}" /></td>
             </tr>
          </table>
          </td>
       </tr>
    </table>
    </form>
    <table class="forumline" width="100%" border="0" cellspacing="1" cellpadding="0">
       <tr>
          <th class="thCornerL" nowrap="nowrap" height="25">#</th>
          <th class="thTop" nowrap="nowrap">Avatar</th>
          <!-- BEGIN switch_th_group -->
          <th class="thTop" nowrap="nowrap">{L_GROUPS}</th>
          <!-- END switch_th_group -->
          <th class="thTop" nowrap="nowrap">{L_INTERESTS}</th>
          <th class="thTop" nowrap="nowrap">{L_VISITED}</th>
          <th class="thTop" nowrap="nowrap">{L_PM}</th>
          <th class="thCornerR" nowrap="nowrap">{L_WEBSITE}</th>
       </tr>
       <!-- BEGIN memberrow -->
       <tr>
          <td class="{memberrow.ROW_CLASS}" align="center"><span class="gen"> {memberrow.ROW_NUMBER} </span></td>
          <td class="{memberrow.ROW_CLASS}" align="center">
                      <div class="description3"><div style="display: block; text-align: center; width: 200px; height:400px; overflow:visible;">{memberrow.AVATAR_IMG}<div class="description3_contenu" style="margin-top:-400px;"><div style="OVERFLOW: auto; width: 190px; height: 390px; padding: 5px;font-variant:small-caps; text-shadow:1px 1px 1px white; font-size:14px;"><br />{memberrow.USERNAME}.<br />{memberrow.POSTS} messages.<br />Inscrit le {memberrow.JOINED}.</div></div></div></div></td>
              
          <!-- BEGIN switch_td_group -->
          <td class="{memberrow.ROW_CLASS}" align="center"><span class="gen">{memberrow.GROUPS}</span></td>
          <!-- END switch_td_group -->
          <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gen">{memberrow.INTERESTS}</span></td>
          <td class="{memberrow.ROW_CLASS}" align="center" valign="middle"><span class="gensmall">{memberrow.LASTVISIT}</span></td>
          <td class="{memberrow.ROW_CLASS}" align="center"> {memberrow.PM_IMG} </td>
          <td class="{memberrow.ROW_CLASS}" align="center"> {memberrow.WWW_IMG}&nbsp;</td>
       </tr>
       <!-- END memberrow -->
       <!-- BEGIN switch_no_user -->
       <tr>
          <td class="catBottom" colspan="{switch_no_user.COLSPAN_NUMBER}" height="28" align="center"><span class="gensmall">{switch_no_user.L_NO_USER}</span></td>
       </tr>
       <!-- END switch_no_user -->
    </table>
    <!-- BEGIN switch_pagination -->
    <table width="100%" border="0" cellspacing="0" cellpadding="0">
       <tr>
          <td><span class="nav">{PAGE_NUMBER}</span></td>
          <td align="right"><span class="nav">{PAGINATION}</span></td>
       </tr>
    </table>
    <br />
    <!-- END switch_pagination -->
    Ajoutez ce code à votre feuille de style CSS

    Code:
    .description3 {
      display: block;
      width: 200px;
      margin: auto;
      height: 200px;
      overflow: hidden;
      transition:0.4s ease;
    }

    .description3:hover {
      display: block;
      width: 200px;
      margin: auto;
      height: 400px;
      overflow: hidden;
    }

    .description3_contenu {
      position: absolute;
      width: 200px;
      height: 400px;
      overflow: 400px;
      background-color: #EFE9DD;
      font-size: 11.5px;
      font-family:'Georgia';
      color: #3E352E;
      text-align: justify;
      padding:0px;
      opacity: 0;
      transform: all;
      transition: 1s;
    }
    .description3_contenu:hover {
      opacity: 0.8;
      transform: all;
      transition: 1s;
    }
    Et voilà ! A vous de jouer !




    Pas souvent là, mais je vous aime quand même très fort ! Étudiant en prépa littéraire, quand j'en ai marre de pas comprendre ce que je lis, je code pour ne plus comprendre non plus ce que j'écris.
    Nevida
    Nevida
    FémininAge : 33Messages : 33

    Jeu 18 Fév 2016 - 14:49

    merci :)
    Chromium
    Chromium
    FémininAge : 29Messages : 3

    Sam 20 Fév 2016 - 12:29

    merci hiro !
    Margii
    Margii
    FémininAge : 26Messages : 84

    Dim 21 Fév 2016 - 17:03

    Merci!
    darkhero246
    darkhero246
    MasculinAge : 32Messages : 179

    Jeu 25 Fév 2016 - 10:25

    Merci pour le tuto
    Sundaesys
    Sundaesys
    FémininAge : 29Messages : 29

    Sam 27 Fév 2016 - 12:57

    J'ai déjà un peu modifier la mienne, mais je suis curieuse de voir ce que tu proposes :o
    lavila
    lavila
    FémininAge : 36Messages : 23

    Dim 20 Mar 2016 - 5:59

    merci du partage
    Choubakawa
    Choubakawa
    MasculinAge : 31Messages : 87

    Sam 26 Mar 2016 - 19:01

    Merci :)



    Dynamiser la page "Membres" - Page 9 Witche13
    .cranberry
    .cranberry
    FémininAge : 32Messages : 50

    Dim 3 Avr 2016 - 2:03

    Magnifique ♥
    Skriff
    Skriff
    MasculinAge : 34Messages : 21

    Lun 11 Avr 2016 - 23:57

    Je dis merci pour ceci qui m'a l'air génial ! ~
    Junior.
    Junior.
    FémininAge : 27Messages : 78

    Jeu 19 Mai 2016 - 11:22

    Merci ! **
    Wingo
    Wingo
    FémininAge : 37Messages : 3

    Mar 31 Mai 2016 - 19:28

    Voilà qui m'intrigue, je vais voir si je comprends comment ça fonctionne.
    Merci pour le partage :)
    Takasu-ryuji
    Takasu-ryuji
    MasculinAge : 32Messages : 23

    Mer 15 Juin 2016 - 6:18

    Classe :o merci
    0smose
    0smose
    FémininAge : 29Messages : 167

    Mar 21 Juin 2016 - 10:26

    Merci beaucoup !! Very Happy



    Dynamiser la page "Membres" - Page 9 Bannie10

    But I'm only human
    And I bleed when I fall down... I'm only human and I crash and I break down. Your words in my head,
    knives in my heart. You build me up and then I fall apart.
    'Cause I'm only human.
    Rizhskaya.
    Rizhskaya.
    MasculinAge : 32Messages : 42

    Mar 21 Juin 2016 - 18:21

    Merci pour le partage. :)
    Froufy
    Froufy
    FémininAge : 24Messages : 59

    Jeu 23 Juin 2016 - 18:01

    Merci!



    1+1= 4
          2
    3
    Ausana
    Ausana
    FémininAge : 33Messages : 14

    Dim 10 Juil 2016 - 9:49

    Merci ♥
    .Lucifer.
    .Lucifer.
    MasculinAge : 51Messages : 184

    Dim 10 Juil 2016 - 21:02

    Merci pour le partage ! Wink



    Dynamiser la page "Membres" - Page 9 978358Divine
    Alexielios
    Alexielios
    FémininAge : 33Messages : 62

    Lun 25 Juil 2016 - 12:43

    Thank you



    Dynamiser la page "Membres" - Page 9 Slytherin-House-member

    Dynamiser la page "Membres" - Page 9 Tales-of-Phantasia-Fan
    Dynamiser la page "Membres" - Page 9 Suikoden%2BII%2BFan
    Dynamiser la page "Membres" - Page 9 Star-Wars-Fan
    Dynamiser la page "Membres" - Page 9 Dominion%2BFan

    "People live their lives bound by what they accept as correct and true. That's how they define reality.
    But what does it mean to be correct or true?"
    Yoshine
    Yoshine
    MasculinAge : 26Messages : 18

    Mar 26 Juil 2016 - 23:33

    Merci pour ce tuto Very Happy



    Dynamiser la page "Membres" - Page 9 Lats10
    Helvelina
    Helvelina
    FémininAge : 33Messages : 83

    Lun 1 Aoû 2016 - 12:01

    Merci beaucoup ! :)
    IlyesMcc
    IlyesMcc
    MasculinAge : 30Messages : 2

    Lun 1 Aoû 2016 - 14:21

    Mercii
    Minze
    Minze
    FémininAge : 30Messages : 39

    Jeu 4 Aoû 2016 - 21:18

    Mercii !
    dean winchester
    dean winchester
    MasculinAge : 30Messages : 85

    Mar 9 Aoû 2016 - 20:25

    Merci pour le partage ! Very Happy
    Anonymous
    Invité

    Ven 19 Aoû 2016 - 2:44

    Merci mille fois Very Happy
    cheeky monkey.
    cheeky monkey.
    FémininAge : 32Messages : 12

    Mar 23 Aoû 2016 - 4:34

    Meeerci. :heart: :chomp:
    Contenu sponsorisé


      La date/heure actuelle est Jeu 21 Nov 2024 - 11:22