[PHPBB2] Afficher les derniers sujets en temps réels style notifications toolbar

Voir le sujet précédent Voir le sujet suivant Aller en bas

Milouze14
avatar
Fondateur

MessageMilouze14

  • 16px
  • 24px
  • Zoom
Hello les ami(e)s,

tout d'abord je voulais remercier Arnaud @no_way pour le développement de son script .

L'astuce sera donc visible pour tout le monde mais un petit message sera toujours apprécié afin de remercier l'auteur de ce script.

En faite, vous avez des notifications actuellement lorsque vous suivez un sujet ou autre suivant ce que vous avez coché dans les paramètres
de notifications comme ici:

https://www.milouze14.com/profile?mode=editprofile&page_profil=notifications

Je vais donc vous donner à l'aide du script d'Arnaud vous donner une apparence quasi identique ,
la fenêtre viendra se positionner en haut à droite de votre forum.

L'aperçu imagé:



Pour cela:

1)
Que le portail soit activé:
Modules/Portail & Widgets/Configuration du portail/Options Générales du Portail

Afficher le portail : :cocher oui

Cliquez ensuite sur  Enregistr  



Plus bas

Cliquez sur Structure
recherchez le module "SUJETS RECENTS" et faire un glisser dans la partie gauche
Cliquez ensuite sur  Enregistr

2)
Il faut que votre forum pointe vers la page d'accueil:

Affichage/Page d'accueil/Généralités/Général

L'adresse de votre forum dirige vers : L'index du forum



3)

Il va falloir faire des petits changement dans le template mod_recent_topics:
Affichage/Templates/Portail/mod_recent_topics


Rechercher ceci:
Code:

<div class="marquee" align="left" data-direction='{SCROLL_WAY}' data-duration='{SCROLL_DELAY}' data-pauseOnHover="true" style="overflow:hidden;height:{SCROLL_HEIGHT}px;">


Juste après déposez ceci:
Code:
<div id="M14_Sujets_Recents">

Juste après recherchez ceci:
Code:
                   
» <a href="{scrolling_row.recent_topic_row.U_TITLE}" title="{scrolling_row.recent_topic_row.L_TITLE}">{scrolling_row.recent_topic_row.L_TITLE}</a><br />
<img src="{ICON_TIME}" alt="" />{scrolling_row.recent_topic_row.S_POSTTIME} {BY} 

Supprimez et remplacez par ceci:
Code:

» <a class="M14_lastNotif"href="{scrolling_row.recent_topic_row.U_TITLE}" title="{scrolling_row.recent_topic_row.L_TITLE}">{scrolling_row.recent_topic_row.L_TITLE}</a><br />
<img src="{ICON_TIME}" alt="" />{scrolling_row.recent_topic_row.S_POSTTIME} {BY} 

recherchez ceci:

Code:

<!-- END recent_topic_row -->
</div>

Juste après déposez ceci:

Code:
</div>
Recherchez ceci:
Code:
<td class="row1" align="left"><span class="gensmall">
 <!-- BEGIN recent_topic_row -->

Remplacez par ceci:
Code:
<td id="M14_Sujets_Recents"class="row1" align="left"><span class="gensmall">
 <!-- BEGIN recent_topic_row -->

Recherchez ceci:
Code:
» <a href="{classical_row.recent_topic_row.U_TITLE}">{classical_row.recent_topic_row.L_TITLE}</a><br /><img src="{ICON_TIME}" alt="" />{BY} 

Supprimez et remplacez par ceci:

Code:

» <a class="M14_lastNotif"href="{classical_row.recent_topic_row.U_TITLE}">{classical_row.recent_topic_row.L_TITLE}</a><br /><img src="{ICON_TIME}" alt="" />{BY} 




Pensez à enregistrer puis à valider en cliquant respectivement sur Enregistrer  puis  Ajout

Le template dans sa totalité si ce dernier n'a pas été modifié auparavant:
Code:

<!-- BEGIN scrolling_row -->
    {MARQUEE_JS_SRC}
    <table class="forumline genmed" width="100%" border="0" cellspacing="1" cellpadding="0">
            <tr>
                    <td class="catLeft" height="25">
                            <span class="genmed module-title">{L_RECENT_TOPICS}</span>
                    </td>
            </tr>
            <tr>
                    <td class="row1" style="height:{SCROLL_HEIGHT}px;">
                        <div class="marquee" align="left" data-direction='{SCROLL_WAY}' data-duration='{SCROLL_DELAY}' data-pauseOnHover="true" style="overflow:hidden;height:{SCROLL_HEIGHT}px;">
                       <div id="M14_Sujets_Recents">    
                          <!-- BEGIN recent_topic_row -->
                                » <a class="M14_lastNotif"href="{scrolling_row.recent_topic_row.U_TITLE}" title="{scrolling_row.recent_topic_row.L_TITLE}">{scrolling_row.recent_topic_row.L_TITLE}</a><br />
                                <img src="{ICON_TIME}" alt="" />{scrolling_row.recent_topic_row.S_POSTTIME} {BY} 

                                <!-- BEGIN switch_poster -->
                                <a href="{scrolling_row.recent_topic_row.switch_poster.U_POSTER}">{scrolling_row.recent_topic_row.switch_poster.S_POSTER}</a><br /><br />
                                <!-- END switch_poster -->

                                <!-- BEGIN switch_poster_guest -->
                                {scrolling_row.recent_topic_row.switch_poster_guest.S_POSTER}<br /><br />
                                <!-- END switch_poster_guest -->
                            <!-- END recent_topic_row -->
                        </div></div>
                    </td>
            </tr>
    </table>
    <script>
        $(".marquee").marquee();
    </script>
<!-- END scrolling_row -->
<!-- BEGIN classical_row -->
<table class="forumline" width="100%" border="0" cellspacing="1" cellpadding="0">
 <tr>
 <td class="catHead" height="25"><span class="genmed"><b><center>{L_RECENT_TOPICS}</center></b></span></td>
 </tr>
 <tr>
 <td id="M14_Sujets_Recents"class="row1" align="left"><span class="gensmall">
 <!-- BEGIN recent_topic_row -->
 » <a class="M14_lastNotif"href="{classical_row.recent_topic_row.U_TITLE}">{classical_row.recent_topic_row.L_TITLE}</a><br /><img src="{ICON_TIME}" alt="" />{BY}&nbsp;

 <!-- BEGIN switch_poster -->
 <a href="{classical_row.recent_topic_row.switch_poster.U_POSTER}">{classical_row.recent_topic_row.switch_poster.S_POSTER}</a>
 <!-- END switch_poster -->

 <!-- BEGIN switch_poster_guest -->
 {classical_row.recent_topic_row.switch_poster_guest.S_POSTER}
 <!-- END switch_poster_guest -->

 {ON} {classical_row.recent_topic_row.S_POSTTIME}<br /><br />

 <!--
 <a href="{classical_row.recent_topic_row.U_POSTER}">{classical_row.recent_topic_row.S_POSTER}</a> {ON} {classical_row.recent_topic_row.S_POSTTIME}<br /><br />
 -->
 <!-- END recent_topic_row -->
 </span></td>
 </tr>
</table>
<!-- END classical_row -->


Ensuite le script d'Arnaud:

Modules/HTML JAVASCRIPT/Gestion des codes JavascriptCréer un nouveau javascript


Mettre un titre explicite.
Cochez les endroits ou vous désirez avoir ces notifications.

Déposez ceci:
Code:
$(function(){
        var activeForGuests=true;
        function getLastTopics(){
            try{
                var NOW=Date.now(),FNOW=NOW+30000,NREG=0,lS=localStorage.lastTopics?JSON.parse(localStorage.lastTopics):(NREG=1,[NOW]);
                if(lS[0]*1>NOW)return false;
                $("#M14_notifLastSujet").remove();
                var $lT=$("<ul id=\"M14_notifLastSujet\">");
                $.get("/portal",function(d){
                    try{
                        $list=$("#M14_Sujets_Recents a",d);
                        var i=0,html="",notifList=[],lSF=[FNOW];
                        if($list.length%2)throw "Balises A en nombre impair";
                        for(;i<$list.length;i++){
                            var $sujet=($list[i].href=$list[i].href.replace(/\?change_version=\w+/,""),$list[i]),$auteur=$list[++i],html=$("<li>").append($sujet).append($("<span> par </span>")).append($auteur)[0].outerHTML;
                            lSF.push(html);
                            if(lS.indexOf(html)==-1)notifList.push(html);
                        }
                        localStorage.lastTopics=JSON.stringify(lSF);
                        if(!NREG && notifList.length){
                            $lT.html(notifList.join(""));
                            $("body").append($lT);
                        }
                    }catch(e){
                        console.error(e,"Abandon")
                    }
                })
            }catch(e){
                console.error(e,"Abandon")
            }
        }
        try{
            localStorage.test="test"&&localStorage.removeItem("test");
            activeForGuests?setInterval(getLastTopics,5000):_userdata["session_logged_in"]&&setInterval(getLastTopics,5000);
        }catch(e){
            console.error(e,"Abandon")
        }
    }());

Pensez a cliquer sur le bouton Valider

Si vous désirez que les sujets restent toujours affichés:

Dans le script recherchez ceci:

Code:
 activeForGuests?setInterval(getLastTopics,5000):_userdata["session_logged_in"]&&setInterval(getLastTopics,5000);

Remplacez par:
Code:
 activeForGuests?getLastTopics():_userdata["session_logged_in"]&&getLastTopics();

Dans la feuille de style:
Affichage/Images et Couleurs/Couleurs/Feuille de style

Déposez ceci:
Code:
/*La fenetre notification des derniers sujets*/
ul#M14_notifLastSujet
{
background-color: #333;
border-radius: 5px;
opacity: .7;
padding: 10px;
position:fixed;
top:60px;
right:10px;
width:300px;
min-height:30px;
max-height:300px;
overflow:auto;
transition: opacity 0.5s ease-in;
}
/*Au survol de la fenetre l opacite a 1*/
#M14_notifLastSujet:hover{opacity:1;}
/*L image de notification*/
#M14_notifLastSujet li:before
{
content:'';
background:url(https://i62.servimg.com/u/f62/11/26/21/37/notifi10.png)no-repeat;
position:absolute;
width:24px;
height:24px;
margin-left:-24px;
}
/*Chaque ligne de notification*/
ul#M14_notifLastSujet li
{
margin-left:24px;
display: inline-flex;
color:white !important;
line-height:24px;
font-size: 10px !important;
margin-bottom:4px;
}
/*Les espaces sur les differentes balises*/
ul#M14_notifLastSujet li a.M14_lastNotif,ul#M14_notifLastSujet li span,
ul#M14_notifLastSujet li a[href^="/u"],#M14_notifLastSujet li a[href^="/u"] span
{
margin:-4px 2px 0px 2px;
}
/*Les liens de notification*/
ul#M14_notifLastSujet li a.M14_lastNotif
{
width:170px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;  
color:white !important;
font-size: 10px !important;
text-decoration:none !important;
}
/*Premiere lettre en majuscule*/
ul#M14_notifLastSujet li a.M14_lastNotif:first-letter{text-transform: uppercase !important;}
/*Les Pseudos dans la notification*/
ul#M14_notifLastSujet li a[href^="/u"],#M14_notifLastSujet li a[href^="/u"] span
{

color:white !important;
font-size: 10px !important;
text-decoration:none !important;
}


Pensez à valider les modifications en cliquant sur le bouton Valider

Ce style affichera une fenêtre avec un fond foncé et une couleur de police blanche ensuite il y aura une légère opacité
et au survol cette dernière disparaitra.

Si vous désirez avoir un fond blanc et une police foncée:
Voici le style:

Code:
/*La fenetre notification des derniers sujets*/
ul#M14_notifLastSujet
{
background-color: #fff;
border-radius: 5px;
opacity: .7;
padding: 10px;
position:fixed;
top:60px;
right:10px;
width:300px;
min-height:30px;
max-height:300px;
overflow:auto;
transition: opacity 0.5s ease-in;
}
/*Au survol de la fenetre l opacite a 1*/
#M14_notifLastSujet:hover{opacity:1;}
/*L image de notification*/
#M14_notifLastSujet li:before
{
content:'';
background:url(https://i62.servimg.com/u/f62/11/26/21/37/notifi10.png)no-repeat;
position:absolute;
width:24px;
height:24px;
margin-left:-24px;
}
/*Chaque ligne de notification*/
ul#M14_notifLastSujet li
{
margin-left:24px;
display: inline-flex;
color:#333 !important;
line-height:24px;
font-size: 10px !important;
margin-bottom:4px;
}
/*Les espaces sur les differentes balises*/
ul#M14_notifLastSujet li a.M14_lastNotif,ul#M14_notifLastSujet li span,
ul#M14_notifLastSujet li a[href^="/u"],#M14_notifLastSujet li a[href^="/u"] span
{
margin:-4px 2px 0px 2px;
}
/*Les liens de notification*/
ul#M14_notifLastSujet li a.M14_lastNotif
{
width:170px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;  
color:#333 !important;
font-size: 10px !important;
text-decoration:none !important;
}
/*Premiere lettre en majuscule*/
ul#M14_notifLastSujet li a.M14_lastNotif:first-letter{text-transform: uppercase !important;}
/*Les Pseudos dans la notification*/
ul#M14_notifLastSujet li a[href^="/u"],#M14_notifLastSujet li a[href^="/u"] span
{

color:#333 !important;
font-size: 10px !important;
text-decoration:none !important;
}



Voilà,c'est tout pour le moment.
Un soucis?
Direction l'entraide clin oeil
https://www.milouze14.com/f108-entraide-tous-supports


Dernière édition par Milouze14 le Mar 27 Mar 2018 - 4:15, édité 4 fois (Raison : Ajout explication)



-Le respect de nos semblables est la règle de notre conduite.-

Fondateur des forums





petitefeuille
avatar
Animatrice

Messagepetitefeuille

  • 16px
  • 24px
  • Zoom
Ah merci pour ce tuto, je vais m'y mettre de suite :) encore bravo à vous tous fr4


"Imagine all the people living for today".de John Lennon
petitefeuille
avatar
Animatrice

Messagepetitefeuille

  • 16px
  • 24px
  • Zoom
Bonjour, le problème c'est que je dois activer le portail et je ne veux pas m'en servir , est-ce qu'il aurait une autre solution s'il vous plait ?


"Imagine all the people living for today".de John Lennon
fascicularia
avatar
Administrateur

Messagefascicularia

  • 16px
  • 24px
  • Zoom
-Staff du Forum Milouze14-


Pour toute information merci de contacter un Membre du Staff



Administrateur des forums



Kaeyla
avatar
Milouzien

MessageKaeyla

  • 16px
  • 24px
  • Zoom
Bonjour,

Génial super : Merci à Arnaud @NO_WAY et à Phil. @MILOUZE14 .

Bonne fin de journée,

Amicalement, hinhin
Milouze14
avatar
Fondateur

MessageMilouze14

  • 16px
  • 24px
  • Zoom
Hello Invité,

je viens d'ajouter une information afin de pouvoir afficher de façon permanente les derniers sujets hinhin .



-Le respect de nos semblables est la règle de notre conduite.-

Fondateur des forums





EslamLove
avatar
Profil erroné

MessageEslamLove

  • 16px
  • 24px
  • Zoom
Thank you very much !

Voir le sujet précédent Voir le sujet suivant Revenir en haut

Créer un compte ou se connecter pour répondre

Vous devez être membre pour répondre.

S'enregistrer

Rejoignez notre communauté ! C'est facile !


S'enregistrer

Connexion

Vous êtes déjà membre ? Aucun soucis, cliquez ici pour vous connecter.


Connexion

Permission de ce forum:
Vous ne pouvez pas répondre aux sujets dans ce forum