problème messenger forumactif

2 participants

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

Résolu problème messenger forumactif

Message par panic station Ven 02 Sep 2022, 13:26

Détails techniques


Version du forum : phpBB2
Poste occupé : Administrateur
Navigateur(s) concerné(s) : Google Chrome
Personnes concernées par le problème : Tous les utilisateurs
Problème apparu depuis : fin août
Lien du forum : https://basique.forumactif.com/

Description du problème

Bonjour,

J'ai décidé d'ajouter le script "messenger" sur mon forum.

Cependant, cela ne met pas l'antécédent des conversations, je ne parviens pas à trouver le problème. Lorsqu'on l'ouvre, cela fait directement une page blanche et les messages précédemment rédigés n'y apparaissent pas.

Merci à vous ! Smile
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.
  • 0

Résolu Re: problème messenger forumactif

Message par Oka.mi Sam 03 Sep 2022, 11:02

Bonjour,

Cela est sûrement dû au fait que vous avez modifié vos templates, les noms des éléments sur vos pages diffèrent de ceux des templates d'origine et donc les chemins empruntés par le javascript pour s’exécuter ne correspondent plus.
Exemple de problème similaire : résolu https://forum.forumactif.com/t406978-probleme-fa-messenger-et-templates-modifies
Je vous propose donc de nous communiquer le script en place, ainsi que votre template viewtopic_body étant donné que vous parlez d'un problème situé au niveau des messages antérieurs.

Merci d'avance Smile


problème messenger forumactif 1213Donnez un titre explicite problème messenger forumactif VTzsyWB à votre sujet pour améliorer son référencement

Remerciez problème messenger forumactif 976083691 le message qui vous a aidé pour le mettre en évidence

Cochez résolu lorsque votre problème est résolu pour faciliter le travail des modérateurs

L'aide par MP problème messenger forumactif FsAeGeb n'est pas autorisée pour que celle-ci puisse bénéficier au plus grand nombre
Oka.mi

Oka.mi
Aidactive
Aidactive

Messages : 2777
Inscrit(e) le : 06/01/2011

https://deus-academia.forumactif.com/
Oka.mi a été remercié(e) par l'auteur de ce sujet.

Résolu Re: problème messenger forumactif

Message par panic station Sam 03 Sep 2022, 21:32

Bonsoir !
Merci pour cet éclaircissement.

Voici le viewtopicbody
Code:
<script type="text/javascript">
//<![CDATA[
var multiquote_img_off = '{JS_MULTIQUOTE_IMG_OFF}', multiquote_img_on = '{JS_MULTIQUOTE_IMG_ON}', _atr = '{JS_DIR}addthis/', _ati = '{PATH_IMG_FA}addthis/'{ADDTHIS_LANG}, addthis_localize = { share_caption: "{L_SHARE_CAPTION}", email: "{L_EMAIL}", email_caption: "{L_EMAIL_CAPTION}", favorites: "{L_SHARE_BOOKMARKS}", print: "{L_PRINT}", more: "{L_MORE}" };
$(function(){
   _atc.cwait = 0;
   $('.addthis_button').mouseup(function(){
      if ($('#at15s').css('display') == 'block') {
         addthis_close();
      }
   });
});

var hiddenMsgLabel = { visible:'{JS_HIDE_HIDDEN_MESSAGE}', hidden:'{JS_SHOW_HIDDEN_MESSAGE}' };
showHiddenMessage = function(id)
{
    try
    {
        var regId = parseInt(id, 10);
        if( isNaN(regId) ) { regId = 0; }
        
        if( regId > 0)
        {
            $('.post--' + id).toggle(0, function()
         {
            if( $(this).is(":visible") )
            {
               $('#hidden-title--' + id).html(hiddenMsgLabel.visible);
            }
            else
            {
               $('#hidden-title--' + id).html(hiddenMsgLabel.hidden);
            }
         });
        }
    }
    catch(e) { }
    
   return false;
};

//]]>
</script>
<table width="100%" border="0" cellspacing="2" cellpadding="0">
  <tr>
      <td align="left" valign="middle" nowrap="nowrap">
        <span class="nav">
        <!-- BEGIN switch_user_authpost -->
        <a href="{U_POST_NEW_TOPIC}" rel="nofollow"><img src="{POST_IMG}" id="{POST_IMG_ID}one" alt="{L_POST_NEW_TOPIC}" align="middle" border="0" /></a>  
        <!-- END switch_user_authpost -->
        <!-- BEGIN switch_user_authreply -->
        <a href="{U_POST_REPLY_TOPIC}"><img src="{REPLY_IMG}" id="i_reply" alt="{L_POST_REPLY_TOPIC}" align="middle" border="0" /></a>
        <!-- END switch_user_authreply -->
        </span>
      </td>
      <td align="left" valign="middle" nowrap="nowrap">
        <!-- BEGIN switch_twitter_btn -->
        <span id="twitter_btn" style="margin-left: 6px; ">
        <a href="https://twitter.com/share" class="twitter-share-button" data-count="horizontal">Tweet</a>
        <script type="text/javascript" src="https://platform.twitter.com/widgets.js"></script>
        </span>
        <!-- END switch_twitter_btn -->
        <!-- BEGIN switch_fb_likebtn -->
        <span id="fb_likebtn" style="margin-left: 6px; ">
            <iframe src="https://www.facebook.com/plugins/like.php?href={FORUM_URL}{TOPIC_URL}&layout=button_count&show_faces=false&width=100&action=like&colorscheme=light&height=21" scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:100px; height:21px;" allowTransparency="true"></iframe>
        </span>
        <!-- END switch_fb_likebtn -->
      </td>
      <td class="nav" valign="middle" width="100%"><span class="nav"><a class="nav" href="{U_INDEX}">{L_INDEX}</a>{NAV_SEP}<a class="nav" href="{U_ALBUM}">{L_ALBUM}</a>{NAV_CAT_DESC_SECOND}</span></td>
      <td align="right" valign="bottom" nowrap="nowrap" width="100%">
        <span class="gensmall bold">
            <a class="addthis_button" href="https://www.addthis.com/bookmark.php?v=250&pub=forumotion">{L_SHARE}</a>
            <!-- BEGIN switch_plus_menu -->
            |
            <script type="text/javascript">//<![CDATA[
              var url_favourite = '{U_FAVOURITE_JS_PLUS_MENU}';
              var url_newposts = '{U_NEWPOSTS_JS_PLUS_MENU}';
              var url_egosearch = '{U_EGOSEARCH_JS_PLUS_MENU}';
              var url_unanswered = '{U_UNANSWERED_JS_PLUS_MENU}';
              var url_watchsearch = '{U_WATCHSEARCH_JS_PLUS_MENU}';
              
              insert_plus_menu('f{FORUM_ID}&t={TOPIC_ID}','{JS_SESSION_ID}', {JS_AUTH_FAVOURITES});
            //]]>
            </script>
            <!-- END switch_plus_menu -->
        </span>
      </td>
  </tr>
</table>

<table class="forumline" width="100%" border="0" cellspacing="1" cellpadding="0" style="border-bottom: 0px;">
  <tr align="right">
      <td class="catHead" colspan="3" height="28">
        <table width="100%" border="0" cellspacing="0" cellpadding="0">
            <tr>
              <td width="9%" class="noprint"> </td>
              <td align="center" class="t-title">
                  <h1 class="cattitle"> {TOPIC_TITLE}</h1>
              </td>
              <td align="right" width="9%" class="browse-arrows"><a href="{U_VIEW_OLDER_TOPIC}">{L_VIEW_PREVIOUS_TOPIC}</a> <a href="{U_VIEW_NEWER_TOPIC}">{L_VIEW_NEXT_TOPIC}</a> <a href="#bottom">{L_GOTO_DOWN}</a> </td>
            </tr>
        </table>
      </td>
  </tr>
  <!-- BEGIN topicpagination -->

  <tr>
      <td class="row1 pagination" colspan="2" align="right" valign="top"><span class="gensmall">{PAGINATION}</span></td>
  </tr>
  <!-- END topicpagination -->
  {POLL_DISPLAY}
  <!-- BEGIN postrow -->
  <!-- BEGIN displayed -->
    <tr class="post">
      <td class="{postrow.displayed.ROW_CLASS}"{postrow.displayed.THANK_BGCOLOR} valign="top" width="150">
        <div class="profilentour"><span class="name"><a name="{postrow.displayed.U_POST_ID}"></a>{postrow.displayed.POSTER_AVATAR}<div class="profilname">{postrow.displayed.POSTER_NAME}</div></span>
          <span class="postdetails poster-profile"></span>
 <div class="descrp"><span class="postdetails poster-profile"><!-- BEGIN profile_field --><div class="textp">{postrow.displayed.profile_field.LABEL}{postrow.displayed.profile_field.CONTENT}  {postrow.displayed.profile_field.SEPARATOR}</div>
   <!-- END profile_field --></span></div>
          <br/><center><div class="profilrang">{postrow.displayed.POSTER_RANK}</div></center><div="descrp"><center>{postrow.displayed.ONLINE_IMG}{postrow.displayed.PROFILE_IMG}{postrow.displayed.PM_IMG}{postrow.displayed.contact_field.CONTENT}</center></div></div></td>
      <td class="{postrow.displayed.ROW_CLASS}"{postrow.displayed.THANK_BGCOLOR} valign="top" width="100%" height="28" colspan="2">
        <table width="100%" border="0" cellspacing="0" cellpadding="0">
            <tr>
              <td><span class="postdetails"><img src="{postrow.displayed.MINI_POST_IMG}" alt="{postrow.displayed.L_MINI_POST_ALT}" title="{postrow.displayed.L_MINI_POST_ALT}" border="0" />{L_POST_SUBJECT}: {postrow.displayed.POST_SUBJECT}  <img src="{postrow.displayed.MINI_TIME_IMG}" alt="" border="0" />{postrow.displayed.POST_DATE}<a href="#{postrow.displayed.U_POST_ID}">#</a></span></td>
              <td valign="top" nowrap="nowrap" class="post-options">
                  {postrow.displayed.THANK_IMG} {postrow.displayed.MULTIQUOTE_IMG} {postrow.displayed.QUOTE_IMG} {postrow.displayed.EDIT_IMG} {postrow.displayed.DELETE_IMG} {postrow.displayed.IP_IMG} {postrow.displayed.REPORT_IMG}
              </td>
            </tr>
            <tr>
              <td colspan="2" class="hr">
                  <hr />
              </td>
            </tr>
            <tr>
              <td colspan="2">
                  <!-- BEGIN switch_vote_active -->
                  <div class="vote gensmall">
                     <!-- BEGIN switch_vote -->
                     <div class="vote-button"><a href="{postrow.displayed.switch_vote_active.switch_vote.U_VOTE_PLUS}">+</a></div>
                     <!-- END switch_vote -->

                     <!-- BEGIN switch_bar -->
                     <div class="vote-bar" title="{postrow.displayed.switch_vote_active.L_VOTE_TITLE}">
                        <!-- BEGIN switch_vote_plus -->
                        <div class="vote-bar-plus" style="height:{postrow.displayed.switch_vote_active.switch_bar.switch_vote_plus.HEIGHT_PLUS}px;"></div>
                        <!-- END switch_vote_plus -->

                        <!-- BEGIN switch_vote_minus -->
                        <div class="vote-bar-minus" style="height:{postrow.displayed.switch_vote_active.switch_bar.switch_vote_minus.HEIGHT_MINUS}px;"></div>
                        <!-- END switch_vote_minus -->
                     </div>
                     <!-- END switch_bar -->

                     <!-- BEGIN switch_no_bar -->
                     <div title="{postrow.displayed.switch_vote_active.L_VOTE_TITLE}" class="vote-no-bar">----</div>
                     <!-- END switch_no_bar -->

                     <!-- BEGIN switch_vote -->
                     <div class="vote-button"><a href="{postrow.displayed.switch_vote_active.switch_vote.U_VOTE_MINUS}">-</a></div>
                     <!-- END switch_vote -->
                  </div>
                  <!-- END switch_vote_active -->

                  <div class="postbody">

                     <div>{postrow.displayed.MESSAGE}</div>

                     <!-- BEGIN switch_attachments -->
                     <dl class="attachbox">
                        <dt>{postrow.displayed.switch_attachments.L_ATTACHMENTS}</dt>
                        <dd>
                           <!-- BEGIN switch_post_attachments -->
                           <dl class="file">
                              <dt>
                                 <img src="{postrow.displayed.switch_attachments.switch_post_attachments.U_IMG}" />

                                 <!-- BEGIN switch_dl_att -->
                                 <a class="postlink" href="{postrow.displayed.switch_attachments.switch_post_attachments.switch_dl_att.U_ATTACHMENT}">{postrow.displayed.switch_attachments.switch_post_attachments.switch_dl_att.ATTACHMENT}</a> {postrow.displayed.switch_attachments.switch_post_attachments.switch_dl_att.ATTACHMENT_DEL}
                                 <!-- END switch_dl_att -->

                                 <!-- BEGIN switch_no_dl_att -->
                                 {postrow.displayed.switch_attachments.switch_post_attachments.switch_no_dl_att.ATTACHMENT} {postrow.displayed.switch_attachments.switch_post_attachments.switch_no_dl_att.ATTACHMENT_DEL}
                                 <!-- END switch_no_dl_att -->
                              </dt>

                              <!-- BEGIN switch_no_comment -->
                              <dd>
                                 <em>{postrow.displayed.switch_attachments.switch_post_attachments.switch_no_comment.ATTACHMENT_COMMENT}</em>
                              </dd>
                              <!-- END switch_no_comment -->

                              <!-- BEGIN switch_no_dl_att -->
                              <dd>
                                 <em><strong>{postrow.displayed.switch_attachments.switch_post_attachments.switch_no_dl_att.TEXT_NO_DL}</strong></em>
                              </dd>
                              <!-- END switch_no_dl_att -->

                              <dd>({postrow.displayed.switch_attachments.switch_post_attachments.FILE_SIZE}) {postrow.displayed.switch_attachments.switch_post_attachments.NB_DL}</dd>
                           </dl>
                           <!-- END switch_post_attachments -->
                        </dd>
                     </dl>
                     <!-- END switch_attachments -->

                     <div class="clear"></div>
                     <!-- BEGIN switch_signature -->
                     <div class="signature_div">
                        {postrow.displayed.SIGNATURE}
                     </div>
                     <!-- END switch_signature -->

                  </div>
                  <span class="gensmall">{postrow.displayed.EDITED_MESSAGE}</span>
               </td>
            </tr>
         </table>
      </td>
   </tr>
   <tr class="post--{postrow.displayed.U_POST_ID}" style="{postrow.displayed.DISPLAYABLE_STATE}">
      <td class="{postrow.displayed.ROW_CLASS} browse-arrows"{postrow.displayed.THANK_BGCOLOR} align="center" valign="middle" width="150">
         <a href="#top">{L_BACK_TO_TOP}</a> <a href="#bottom">{L_GOTO_DOWN}</a>
      </td>
      <td class="{postrow.displayed.ROW_CLASS} messaging gensmall"{postrow.displayed.THANK_BGCOLOR} width="100%" height="28">
         <table border="0" cellspacing="0" cellpadding="0">
            <tr>
               <td valign="middle">
                                              
                                          </td>
            </tr>
         </table>
      </td>
   </tr>
   <!-- BEGIN first_post_br -->
</table>
<br />
<table class="forumline" width="100%" border="0" cellspacing="1" cellpadding="0">
   <tr>
      <th class="thLeft" nowrap="nowrap" width="150px" height="26">{L_AUTHOR}</th>
      <th class="thRight" nowrap="nowrap" colspan="2">{L_MESSAGE}</th>
   </tr>
   <!-- END first_post_br -->
   <!-- END displayed -->
   <!-- END postrow -->
   <!-- BEGIN no_post -->
   <tr align="center">
      <td class="row1" colspan="3" height="28">
         <span class="genmed">{no_post.L_NO_POST}</span>
      </td>
   </tr>
   <!-- END no_post -->
   <tr align="right">
      <td class="catBottom" colspan="3" height="28">
         <table width="100%" border="0" cellspacing="0" cellpadding="0">
            <tr>
               <td width="9%" class="noprint"> </td>
               <td align="center" class="t-title"><a name="bottomtitle"></a><h1 class="cattitle">{TOPIC_TITLE}</h1></td>
               <td align="right" nowrap="nowrap" width="9%" class="browse-arrows"><a href="{U_VIEW_OLDER_TOPIC}">{L_VIEW_PREVIOUS_TOPIC}</a> <a href="{U_VIEW_NEWER_TOPIC}">{L_VIEW_NEXT_TOPIC}</a> <a href="#top">{L_BACK_TO_TOP}</a> </td>
            </tr>
         </table>
      </td>
   </tr>
</table>
<table class="forumline noprint" width="100%" border="0" cellspacing="0" cellpadding="0" style="margin: 0 0 1px 0; border-top: 0px;">
   <tr>
      <td class="row2" valign="top" {COLSPAN_PAGINATION} width="150"><span class="gensmall">{PAGE_NUMBER}</span></td>
      <!-- BEGIN topicpagination -->
      <td class="row1" align="right" valign="top" ><span class="gensmall">{PAGINATION}</span></td>
      <!-- END topicpagination -->
   </tr>
   <!-- BEGIN switch_user_logged_in -->
   <!-- BEGIN watchtopic -->
   <tr>
      <td class="row2" colspan="2" align="right" valign="top"><span class="gensmall">{S_WATCH_TOPIC}</span></td>
   </tr>
   <!-- END watchtopic -->
   <!-- END switch_user_logged_in -->
</table>

<!-- BEGIN promot_trafic -->
<table class="forumline" width="100%" border="0" cellpadding="1" cellspacing="0" id="ptrafic_close" style="display:none;margin: 1px 0px 1px 0px">
   <tr>
      <td class="catBottom" height="28">
         <table width="100%" border="0" cellspacing="0" cellpadding="0">
            <tr>
               <td valign="top"><h1 class="cattitle"> {PROMOT_TRAFIC_TITLE}</h1></td>
               <td align="right" valign="middle" width="10"><span class="gensmall"><a href="javascript:ShowHideLayer('ptrafic_open','ptrafic_close');"><img src="{TABS_MORE_IMG}" alt="+" align="middle" border="0" /></a></span></td>
            </tr>
         </table>
      </td>
   </tr>
</table>

<table class="forumline" width="100%" border="0" cellpadding="1" cellspacing="0" id="ptrafic_open" style="display:'';margin: 1px 0px 1px 0px">
   <tr>
      <td class="catBottom" height="28">
         <table width="100%" border="0" cellspacing="0" cellpadding="0">
            <tr>
               <td valign="top"><h1 class="cattitle"> {PROMOT_TRAFIC_TITLE}</h1></td>
               <td align="right" valign="middle" width="10"><span class="gensmall"><a href="javascript:ShowHideLayer('ptrafic_open','ptrafic_close');"><img src="{TABS_LESS_IMG}" alt="-" align="middle" border="0" /></a></span></td>
            </tr>
         </table>
      </td>
   </tr>
   <tr>
      <td class="row2 postbody" valign="top">
         <!-- BEGIN link -->
         » <a style="text-decoration:none" href="{promot_trafic.link.U_HREF}" title="{promot_trafic.link.TITLE}">{promot_trafic.link.TITLE}</a><br />
         <!-- END link -->
      </td>
   </tr>
</table>
<!-- END promot_trafic -->

<!-- BEGIN switch_forum_rules -->
<table id="forum_rules" class="forumline" width="100%" border="0" cellspacing="0" cellpadding="0" style="margin: 1px 0px 1px 0px">
   <tbody>
      <tr>
         <td class="catBottom">
            <table width="100%" border="0" cellspacing="0" cellpadding="0">
               <tbody>
                  <tr>
                     <td valign="top">
                        <h1 class="cattitle"> {L_FORUM_RULES}</h1>
                     </td>
                  </tr>
               </tbody>
            </table>
         </td>
      </tr>
      <tr>
         <td class="row1 clearfix">
            <table>
               <tr>
                  <!-- BEGIN switch_forum_rule_image -->
                  <td class="logo">
                     <img src="{RULE_IMG_URL}" />
                  </td>
                  <!-- END switch_forum_rule_image -->
                  <td class="rules postbody">
                     {RULE_MSG}
                  </td>
               </tr>
            </table>
         </td>
      </tr>
   </tbody>
</table>
<!-- END switch_forum_rules -->

<table class="forumline noprint" width="100%" border="0" cellspacing="0" cellpadding="0">
   <tr>
      <td class="row2" colspan="2" align="center" style="padding:0px">
         <!-- BEGIN switch_user_logged_in -->
         <a name="quickreply"></a>
         {QUICK_REPLY_FORM}<br />
         <!-- END switch_user_logged_in -->
      </td>
   </tr>
   <tr>
      <td style="margin:0; padding: 0;" colspan="2">
         <table border="0" cellpadding="0" width="100%" cellspacing="0" id="info_open" style="display:''">
            <tbody>
      <!-- BEGIN show_permissions -->
      <tr>
         <td class="row2" valign="top" width="25%"><span class="gensmall">{L_TABS_PERMISSIONS}</span></td>
         <td class="row1" valign="top" width="75%"><span class="gensmall">{S_AUTH_LIST}</span></td>
      </tr>
      <!-- END show_permissions -->
      <tr>
         <td class="catBottom" colspan="2" height="28">
            <table width="100%" border="0" cellspacing="0" cellpadding="0">
               <tr>
                  <td valign="middle" width="100%"><span class="nav"><a class="nav" href="{U_INDEX}">{L_INDEX}</a>{NAV_SEP}<a class="nav" href="{U_ALBUM}">{L_ALBUM}</a>{NAV_CAT_DESC_SECOND}</span></td>
                  <!-- BEGIN show_permissions -->
                  <td align="right" valign="middle"><span class="gensmall"><a href="javascript:ShowHideLayer('info_open','info_close');"><img src="{TABS_LESS_IMG}" alt="-" align="middle" border="0" /></a></span></td>
                  <!-- END show_permissions -->
               </tr>
            </table>
         </td>
      </tr>
   </tbody>
         </table>
      </td>
   </tr>
   <tr>
      <td style="margin:0; padding: 0;" colspan="2">
         <table border="0" cellpadding="0" cellspacing="0" width="100%" id="info_close" style="display:none;">
            <tbody>
      <tr>
         <td class="catBottom" colspan="2" height="28">
            <table width="100%" border="0" cellspacing="0" cellpadding="0">
               <tr>
                  <td valign="middle" width="100%"><span class="nav"><a class="nav" href="{U_INDEX}">{L_INDEX}</a>{NAV_SEP}<a class="nav" href="{U_ALBUM}">{L_ALBUM}</a>{NAV_CAT_DESC_SECOND}</span></td>
                  <td align="right" valign="middle"><span class="gensmall"><a href="javascript:ShowHideLayer('info_open','info_close');"><img src="{TABS_MORE_IMG}" alt="+" align="middle" border="0" /></a></span></td>
               </tr>
            </table>
         </td>
      </tr>
   </tbody>
         </table>
      </td>
   </tr>
</table>

<form action="{S_JUMPBOX_ACTION}" method="get" name="jumpbox" onsubmit="if(document.jumpbox.f.value == -1){return false;}">
<table class="noprint" width="100%" border="0" cellspacing="2" cellpadding="0" align="center">
   <tr>
      <td align="left" valign="middle" nowrap="nowrap" {WIDTH_GALLERY}>
         <span class="nav">
            <!-- BEGIN switch_user_authpost -->
            <a href="{U_POST_NEW_TOPIC}" rel="nofollow"><img src="{POST_IMG}" id="{POST_IMG_ID}Newtopic" alt="{L_POST_NEW_TOPIC}" align="middle" border="0" /></a>  
            <!-- END switch_user_authpost -->
            <!-- BEGIN switch_user_authreply -->
            <a href="{U_POST_REPLY_TOPIC}"><img src="{REPLY_IMG}" alt="{L_POST_REPLY_TOPIC}" align="middle" border="0" /></a>
            <!-- END switch_user_authreply -->
         </span>
      </td>

      <!-- BEGIN viewtopic_bottom -->
      <td align="right" nowrap="nowrap"><span class="gensmall">{L_JUMP_TO}: {S_JUMPBOX_SELECT} <input class="liteoption" type="submit" value="{L_GO}" /></span></td>
      <!-- END viewtopic_bottom -->

      <!-- BEGIN moderation_panel -->
      <td align="center">
         <span class="gensmall">{moderation_panel.U_YOUR_PERSONAL_MODERATE}</span>
      </td>
      <td align="center" width="250">
         <span class="gensmall"> </span>
      </td>
      <!-- END moderation_panel -->
   </tr>
</table>
</form>

<!-- BEGIN viewtopic_bottom -->
<table class="noprint" width="100%" border="0" cellspacing="2" cellpadding="0" align="center">
   <tr>
      <td colspan="2" align="left" valign="top" nowrap="nowrap"><br />{S_TOPIC_ADMIN}<br />
         <form name="action" method="get" action="{S_FORM_MOD_ACTION}">
            <input type="hidden" name="t" value="{TOPIC_ID}" />

            <!-- <input type="hidden" name="sid" value="{S_SID}" /> -->
            <input type="hidden" name="{SECURE_ID_NAME}" value="{SECURE_ID_VALUE}" />

            <span class="gen">{L_MOD_TOOLS}<br />{S_SELECT_MOD}&nbsp;<input class="liteoption" type="submit" value="{L_GO}" /></span>
         </form>
      </td>
   </tr>
</table>
<!-- END viewtopic_bottom -->

<!-- BEGIN switch_image_resize -->
<script type="text/javascript">
//<![CDATA[
$(resize_images({ 'selector' : '.postbody', 'max_width' : {switch_image_resize.IMG_RESIZE_WIDTH}, 'max_height' : {switch_image_resize.IMG_RESIZE_HEIGHT} }));
//]]>
</script>
<!-- END switch_image_resize -->
<script src="{JS_DIR}addthis/addthis_widget.js" type="text/javascript"></script>

et je vais devoir faire un double poste car mon JS prend beaucoup de place !
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.

Résolu Re: problème messenger forumactif

Message par panic station Sam 03 Sep 2022, 21:34

je dois découper mon JS en plusieurs morceaux Shocked il est véritablement très long !

Code:
!window.FAM && (function() {
  'use strict';
 
  window.FAM = {

    // General Configuration of Forumactif Messenger
    // See : https://github.com/SethClydesdale/forumactif-messenger/wiki/Config
    config : {
  "chat_page": "https://basique.forumactif.com/f14-phones",
  "chat_permission": "all",
  "main_title": "Select a Group",
  "embed": "",
  "update_channel": "production",
  "tabs": true,
  "initial_tabs": [],
  "refresh": 7500,
  "timeout": 600000,
  "flood_control": 5000,
  "max_attachments": "10",
  "ignore_announcements": false,
  "ignore_firstpost": false,
  "hide_menu_avatar": false,
  "sound_notif_auto_enabled": false,
  "sound_notif_file": "https://illiweb.com/fa/fdf/zelda.mono.mp3",
  "no_avatar": "https://2img.net/i/fa/invision/pp-blank-thumb.png",
  "no_name": "Anonymous",
  "lang": {
    "loading": "Loading...",
    "idle": "Forumactif Messenger has fallen asleep due to inactivity. Click here to start chatting again.",
    "message_notif_singular": "$N new message",
    "message_notif_plural": "$N new messages",
    "new_messages": "New Messages",
    "new_topic": "New topic",
    "start_topic": "Start topic",
    "msg_placeholder": "Enter message",
    "title_placeholder": "Topic title",
    "not_found": "No forums or topics could be found.",
    "not_found_offline": "You may need to <a href=\"/login\">login</a> or <a href=\"/register\">register</a> to view this forum.",
    "load_older": "Load older messages",
    "delete_message": "Are you sure you want to delete this message?",
    "actions_error": "An error occurred while retreiving the message.",
    "topic_no_subject": "You must specify a subject for your topic.",
    "topic_no_message": "You must enter a message when submitting a new topic.",
    "no_tabs_title": "Open a new tab",
    "no_tabs": "Uh-oh! You have no tabs opened! Click here to open a new one.",
    "no_tabs_initial": "Would you like to open the initial startup tabs?",
    "login_username": "Username",
    "login_password": "Password",
    "login_auto": "Log in automatically : ",
    "login_sign_in": "Sign in",
    "login_forgot": "I forgot my password.",
    "login_error": "You have specified an invalid username or password.",
    "login_logged_in": "You are already logged into an account on this forum. <a href=\"javascript:FAM.page.profile.open();\">Click here</a> to view your profile or <a href=\"javascript:FAM.history.back(true);\">click here</a> to return to the index.",
    "profile_posts": "Posts : ",
    "profile_PMs": "PMs : ",
    "profile_reputation": "Reputation : ",
    "profile_sign_out": "Sign out",
    "profile_confirm_sign_out": "Are you sure you want to sign out?",
    "profile_logged_out": "You must be logged in to view your profile. <a href=\"javascript:FAM.page.login.open();\">Click here</a> to log in or <a href=\"javascript:FAM.history.back(true);\">click here</a> to return to the index.",
    "profile_my_topics": "View your topics",
    "profile_my_posts": "View your posts",
    "profile_mark_read": "Mark all forums read",
    "profile_confirm_mark_read": "This will mark all the forums and their topics read. Do you want to continue?",
    "profile_forums_marked": "All the forums and topics have successfully been marked read.",
    "profile_delete_cookies": "Delete the forum cookies",
    "profile_confirm_delete_cookies": "This will delete all the cookies for the forum and log you out. Do you want to continue?",
    "profile_cookies_deleted": "All cookies for the forum have been deleted.",
    "about_releases": "Releases",
    "about_latest": "Latest Release",
    "about_sync": "Sync",
    "about_update": "Update",
    "about_updated": "Forumactif Messenger is up to date!",
    "about_new_update": "A new version of Forumactif Messenger is available!",
    "about_update_info": "Replace your current Forumactif Messenger script with the one below.<br>It should be applied in <strong>Admin Panel > Modules > JavaScript codes management</strong>.",
    "about_help": "How to Update",
    "about_bug": "Report Bug",
    "settings_fullscreen": "Full Screen : ",
    "settings_width": "Window Width : ",
    "settings_height": "Window Height : ",
    "settings_color": "Theme Color : ",
    "settings_color_reset": "This will reset the primary color to the theme's default. Do you want to continue?",
    "settings_theme": "Theme : ",
    "settings_theme_default": "Messenger Light (Default)",
    "settings_theme_dark": "Messenger Dark",
    "settings_sound_notif": "Sound Notification : ",
    "settings_default": "Reset Default Settings",
    "settings_default_confirm": "Are you sure you want to restore Forumactif Messenger's default settings? Your personal settings will be lost.",
    "settings_guide": "View Settings Guide",
    "settings_admin": "Admin Configuration",
    "settings_title_window": "Window Settings",
    "settings_title_themes": "Theme Settings",
    "settings_title_notifications": "Notification Settings",
    "config_title_general": "General",
    "config_title_tabs": "Tabs",
    "config_title_limits": "Limitations",
    "config_title_exclude": "Exclusion",
    "config_title_notifications": "Notifications",
    "config_title_placeholders": "Placeholders",
    "config_title_lang": "Language",
    "config_chat_page": "Chat Page : ",
    "config_chat_permission": "Chat Permission : ",
    "config_permission_all": "all",
    "config_permission_member": "member",
    "config_permission_staff": "staff",
    "config_main_title": "Main Title : ",
    "config_embed": "Embed Container : ",
    "config_update_channel": "Update Channel : ",
    "config_channel_production": "production (stable)",
    "config_channel_developer": "developer (beta)",
    "config_tabs": "Enable Tabs : ",
    "config_initial_tabs": "Initial Tabs : ",
    "config_remove_tab": "You are about to delete this tab. Do you want to continue?",
    "config_refresh": "Refresh Rate : ",
    "config_timeout": "Chat Timeout : ",
    "config_flood_control": "Flood Control : ",
    "config_max_attachments": "Max Attachments : ",
    "config_ignore_announcements": "Exclude Announcements : ",
    "config_ignore_firstpost": "Exclude First Post : ",
    "config_hide_menu_avatar": "Hide Menu Avatar : ",
    "config_sound_notif_auto_enabled": "Auto-Enable Sound Notification : ",
    "config_sound_notif_file": "Sound Notification File : ",
    "config_no_avatar": "No Avatar Placeholder : ",
    "config_no_name": "No Name Placeholder : ",
    "config_update": "Update Configuration",
    "config_toggle_lang": "Toggle Language Data",
    "config_import_lang": "Import Language : ",
    "config_import_lang_select": "Select a Language Pack",
    "config_import_lang_confirm": "You are about to import the $LANG language pack for Forumactif Messenger. Do you want to continue?",
    "config_import_lang_success": "The $LANG language pack has been imported successfully.",
    "config_export_lang": "Export Language Data",
    "config_export_lang_success": "Your language data for Forumactif Messenger has been exported successfully. Copy the contents below to share or save it.",
    "search_view": "View all results",
    "search_searching": "Searching...",
    "search_no_results": "No results were found.",
    "search_tip": "Use the search bar above to find a topic.",
    "search_help": "View Search Guide",
    "search_last_visit": "View posts since last visit",
    "search_active": "View today's active topics",
    "search_my_posts": "View your posts",
    "search_unanswered": "View unanswered posts",
    "attach_image": "Add an Image",
    "attach_gif": "Add a GIF",
    "attach_video": "Add a Video",
    "attach_remove": "Manage Attachments",
    "attach_upload": "Upload",
    "attach_uploading": "The image uploader is already open.",
    "attach_searchYT": "Search YouTube",
    "attach_searchingYT": "Youtube is already open.",
    "attach_max": "You have reached the maximum number of attachments for this message.",
    "attach_success": "Attachment Added!",
    "attach_none": "There are no attachments",
    "giphy_search": "Search for a GIF...",
    "giphy_searching": "Searching...",
    "giphy_not_found": "No results found.",
    "tooltip_openFAM": "Forumactif Messenger",
    "tooltip_back": "Click to go back",
    "tooltip_menu": "Open menu",
    "tooltip_home": "Home",
    "tooltip_login": "Log in",
    "tooltip_profile": "Profile",
    "tooltip_search": "Search",
    "tooltip_settings": "Settings",
    "tooltip_config": "Forumactif Messenger Configuration",
    "tooltip_about": "About",
    "tooltip_attachments": "Add attachment",
    "tooltip_emoji": "Add emoticon",
    "tooltip_send": "Send message",
    "tooltip_msg_quote": "Quote",
    "tooltip_msg_edit": "Edit",
    "tooltip_msg_delete": "Delete",
    "error_sending": "An error occurred that prevented your message from being sent. Do you want to resend it?",
    "error_resend": "Resend",
    "error_delete": "Delete",
    "error_report": "Report",
    "guest": "Guest",
    "yes": "Yes",
    "no": "No",
    "send": "Send",
    "cancel": "Cancel",
    "reset": "Reset"
  }
}, // config_end


    // toggles Forumactif Messenger
    toggle : function () {
      if (FAM.cache.chat.dataset.hidden == 'true') {
        FAM.cache.chat.dataset.hidden = false;

        if (!FAM.history.restore()) {
          FAM.tab.initial();
          FAM.tab.loaded = true;
        }

        if (FAM.fullscreen) {
          document.body.style.overflow = 'hidden';
        }

      } else {
        FAM.cache.chat.dataset.hidden = true;

        if (FAM.fullscreen) {
          document.body.style.overflow = '';
        }
      }
    },


    // encode strings for sending over AJAX
    encode : function (string) {
      return /UTF-8/i.test(document.characterSet) ?
        encodeURIComponent(string) :
        // URI encoding for NON-UTF8 forums
        encodeURIComponent(escape(string).replace(/%u[A-F0-9]{4}/g, function(match) {
          return '&#' + parseInt(match.substr(2), 16) + ';'
        })).replace(/%25/g, '%')
    },
   
   
    // updates userdata and lang values using page data received via AJAX
    updateUserdata : function (data) {
      var script = document.createElement('SCRIPT');
      script.type = 'text/javascript';
      script.text = data.replace(/[\s\S]*?(if\(typeof\(_userdata\) == "undefined"\)[\s\S]*?)if\(typeof\(_board\) == "undefined"\)[\s\S]*/, '$1');
      document.body.appendChild(script);
    },


    // abort ongoing requests
    clearRequest : function () {
      if (FAM.request) {
        if (!FAM.request.statusText) {
          FAM.request.abort();
        }

        delete FAM.request;
      }
     
      // remove message notifications
      if (FAM.cache.chat.querySelector('#FAM-new-msg-notif')) {
        FAM.message.markRead(true, true);
      }
    },


    // get the specified page and load the contents into FAM
    get : function (url, title, noHistory) {
      var type = /\/c\d+/.test(url) ? 'category' :
                /\/f\d+/.test(url) ? 'forum' :
                /\/t\d+/.test(url) ? 'topic' :
                /\/search|\/st\/|\/sta\//.test(url) ? 'search' : 'category';

      // push new entry to history
      if (!noHistory) {
        FAM.history.update({
          url : url,
          title : title
        });
      }

      FAM.clearRequest(); // abort ongoing requests
      FAM.message.listener.stop(); // stop listening for message changes
      FAM.history.toggleBack(); // show / hide back button
      FAM.tab.title(title); // update the main title

      // display loading texts and change content class
      FAM.cache.content.className = 'FAM-viewing-' + type;
      FAM.cache.content.innerHTML =
      '<div class="FAM-loading">'+
        '<i class="fa fa-circle-o-notch fa-spin fa-3x fa-fw"></i>'+
        '<span class="sr-only">' + FAM.config.lang.loading + '</span>'+
      '</div>';
      FAM.cache.actions.innerHTML = '';

      // reset the message log
      if (type == 'topic') {
        FAM.message.log = {};
      }

      // get the page
      FAM.request = $.get(url, function (data) {
        var a = $(FAM.select[type == 'topic' ? 'post' : 'forumtitle'], data),
            form = type == 'topic' ? $('form[action="/post"]', data)[0] : null,
            i = 0,
            j = a.length,
            html = '';

        // create message / forum structure
        for (; i < j; i++) {
          html += type == 'topic' ?
            FAM.message.log[a[i].className.replace(/.*?(post--\d+).*/, '$1')] = FAM.message.parse(a[i], i) :
            FAM.topic.parse(a[i]);
        }

        // add message actions if the opened url is a topic
        if (type == 'topic') {
          var postReply = $(FAM.select.post_reply, data)[0],
              back = $(FAM.select.page_back, data)[0];

          FAM.cache.content.innerHTML = (
            back ? // adds button for loading older messages
              '<button id="FAM-load-older" class="FAM-button" onclick="FAM.message.loadOlder(\'' + (back.tagName == 'A' ? back : back.parentNode).href + '\');" type="button">' + FAM.config.lang.load_older + '</button>'
              : ''
          ) + html;

          if (postReply) {
            FAM.cache.content.className += ' FAM-reply-open';
            FAM.cache.actions.innerHTML =
            '<button id="FAM-attachment" type="button" onclick="FAM.attachments.open(this);" title="' + FAM.config.lang.tooltip_attachments + '" type="button"><i class="fa fa-paperclip"></i><span id="FAM-attachment-total">0</span></button>'+
            '<button id="FAM-emoji" type="button" onclick="FAM.message.emoji(this);" title="' + FAM.config.lang.tooltip_emoji + '" type="button"><i class="fa fa-smile-o"></i></button>'+
            '<span id="FAM-msg-container">'+
              '<textarea id="FAM-msg" placeholder="' + FAM.config.lang.msg_placeholder + '" onkeydown="FAM.message.handleKeys(event);" oninput="FAM.message.validate(this.value);"></textarea>'+
              '<span id="FAM-timeout-bar"></span>'+
            '</span>'+
            '<button id="FAM-send" type="button" onclick="FAM.message.send();" data-disabled="true" title="' + FAM.config.lang.tooltip_send + '" type="button"><i class="fa fa-paper-plane"></i></button>'+
            ( form ? form.outerHTML.replace(/id=".*?"|name=".*?"/, '').replace('<form', '<form id="FAM-post-data" name="fampost" style="display:none"') : '<div id="FAM-post-data-placeholder"></div>' );

            // authorize the guest for replies
            if (!_userdata.session_logged_in) {
              FAM.message.replyPage = (FAM.fVersion == 5 ? postReply : postReply.parentNode).href;
              FAM.message.authorizeGuest();
            }
          } else {
            FAM.cache.actions.innerHTML = '';
          }

          FAM.message.scroll(); // scroll to the newest message
          FAM.message.listener.start(); // listen for new posts and changes to existing messages

          // parse servimg data for use in uploading
          var servImgData = {
            account : data.match(/servImgAccount = '(.*?)'/),
            id : data.match(/servImgId = '(.*?)'/),
            f : data.match(/servImgF = '(.*?)'/),
            mode : data.match(/servImgMode = '(.*?)'/)
          },
          authorization = 'multiupload.php?',
          denied = false, i;

          for (i in servImgData) {
            if (servImgData[i] && servImgData[i][0] && servImgData[i][1]) {
              authorization += i + '=' + servImgData[i][1] + '&';
            } else {
              denied = true;
              break;
            }
          }

          FAM.message.servImgData = denied ? '' : authorization;

        // standard forum / category view
        } else {
          var pagination = /forum|search/.test(type) ? $(FAM.select.pagination, data)[0] : null;

          FAM.cache.content.innerHTML = (
            pagination ?
            '<div class="FAM-pagination">' +
              (FAM.fVersion == 0 ? pagination.parentNode : pagination).innerHTML // insert pages
              .replace(/&nbsp;|•|<br>|,|:|<span class="page-sep">.*?<\/span>|<a.*?href=".*?mark=topics">.*?<\/a>|<a.*?href="javascript:Pagination\(\);"[^>]*?>.*?<\/a>|<a[^>]*?><img.*?><\/a>/g, '') // cleanup unnecessary elements
              .replace(/>\d+<\/(.*?)>/g, function (match, $1) {
                // adds event handler and class to page numbers
                return ' class="FAM-page-link"' + (
                  $1.toUpperCase() == 'A' ? ' onclick="FAM.get(this.href, \'' + title + '\'); return false;"' : ''
                ) + match;

              }).replace(/>\s+</g, '><') + // removes whitespace between tags
            '</div>' : ''
          ) + html ||
          '<div class="FAM-loading FAM-noclick">'+
            '<p class="FAM-clickable"><i class="fa fa-frown-o fa-3x"></i>' + FAM.config.lang.not_found + ( _userdata.session_logged_in ? '' : ' ' + FAM.config.lang.not_found_offline ) + '</p>'+
          '</div>';
          FAM.cache.actions.innerHTML = '';

          // add new topic icon if available
          if (type == 'forum') {
            var newTopic = $(FAM.select.new_topic, data)[0];

            if (newTopic) {
              FAM.cache.actions.innerHTML =
              '<span id="FAM-new-topic" class="fa-stack fa-2x" onclick="FAM.topic.create(\'' + ( FAM.fVersion == 5 ? newTopic : newTopic.parentNode ).href + '\');" title="' + FAM.config.lang.new_topic + '">'+
                '<i class="fa fa-circle fa-stack-2x"></i>'+
                '<i class="fa fa-plus fa-stack-1x fa-inverse"></i>'+
              '</span>';
            }
          }

        }

        FAM.clearRequest();
      });
    },


    // message methods and data
    message : {
      // insert text into the message input
      insert : function (string, pad) {
        var msg = FAM.cache.actions.querySelector('#FAM-msg'),
            addedText = (pad ? ' ' : '') + string + (pad ? ' ' : ''),
            position = 0;

        if (msg) {

          try {
            position = msg.selectionEnd;
            msg.value = msg.value.slice(0, position) + addedText + msg.value.slice(position, msg.length);
            msg.selectionEnd = position + addedText.length;
          } catch (e) {
            msg.value += addedText;
          }

          msg.focus();
          FAM.message.validate(msg.value);
        }
      },


      // inserts the user @handle into the textarea after clicking a username
      mention : function (caller) {
        FAM.message.insert('@"' + caller.innerText + '"', true);
      },


      // interact with the specifed message
      interact : function (caller, post) {
        var old = {
          fn : caller.onclick,
          html : caller.innerHTML
        };

        caller.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>';
        caller.onclick = null;


        $.get(post, function (data) {
          var form = $('form[action="/post"]', data)[0],
              mode = post.split('=').pop();

          caller.innerHTML = old.html;
          caller.onclick = old.fn;

          if (form) {

            switch (mode) {
              case 'quote' :
                FAM.message.insert(form.message.value);
                break;

              case 'editpost' :
                caller = $(caller).closest('.FAM-msg')[0];

                if (FAM.message.edit.placeholder) {
                  FAM.message.edit.cancel();
                }

                FAM.message.edit.form = form;
                FAM.message.edit.backup = caller.outerHTML;
               
                FAM.message.edit.placeholderSettings = {
                  id : 'FAM-msg-editing',
                  avatar : caller.querySelector('.FAM-msg-avatar').innerHTML,
                  username : caller.querySelector('.FAM-msg-name').innerHTML,
                  notMine : caller.className.indexOf('FAM-my-msg') == -1
                };
               
                FAM.message.edit.placeholder = FAM.message.write(
                  '<textarea class="FAM-inputbox">' + form.message.value + '</textarea>'+
                  '<div class="FAM-row FAM-center FAM-inline-buttons">'+
                    '<button class="FAM-button" onclick="FAM.message.edit.confirm();">' + FAM.config.lang.send + '</button>'+
                    '<button class="FAM-button" onclick="FAM.message.edit.cancel();">' + FAM.config.lang.cancel + '</button>'+
                  '</div>',
                  FAM.message.edit.placeholderSettings,
                caller);

                break;

              case 'delete' :
                if (confirm(FAM.config.lang.delete_message)) {
                  caller = $(caller).closest('.FAM-msg')[0];
                  caller.className += ' FAM-msg-placeholder';
                  caller.querySelector('.FAM-msg-content').innerHTML = '<div class="FAM-msg-text"><i class="fa fa-circle-o-notch fa-spin fa-fw"></i></div>';

                  $.post('/post', $(form).serialize() + '&confirm=1', function () {
                    FAM.cache.content.removeChild(caller);
                    delete FAM.message.log['post--' + form.p.value];
                  });
                }
                break;
            }

          } else {
            alert(FAM.config.lang.actions_error);
          }
        });
      },


      // edit actions
      edit : {
        // send the updated message
        confirm : function () {
          if (FAM.message.edit.placeholder) {
            FAM.message.backup = FAM.message.edit.placeholder.querySelector('.FAM-inputbox').value;
            FAM.message.send(true, FAM.message.edit.form, {
              replacement : FAM.message.edit.placeholder,
             
              placeholderSettings : {
                id : 'FAM-msg-placeholder',
                avatar : FAM.message.edit.placeholderSettings.avatar,
                username : FAM.message.edit.placeholderSettings.username,
                notMine : FAM.message.edit.placeholderSettings.notMine
              }
            });
           
            delete FAM.message.edit.placeholder;
          }
        },

        // cancel message editing
        cancel : function () {
          if (FAM.message.edit.placeholder) {
            if (FAM.message.edit.placeholder.parentNode) {
              FAM.message.edit.placeholder.insertAdjacentHTML('afterend', FAM.message.edit.backup);
              FAM.cache.content.removeChild(FAM.message.edit.placeholder);
            }

            delete FAM.message.edit.placeholder;
          }
        }
      },


      // write a custom message into the chat for alerts and placeholders
      write : function (message, data, replacement) {
        data = data || {};
       
        var msg = document.createElement('DIV');
        msg.className = 'FAM-msg ' + ( data.notMine ? '' : 'FAM-my-msg' ) + ' ' + (data.id || '');
        msg.innerHTML =
        '<div class="FAM-msg-avatar">' + (data.avatar || _userdata.avatar) + '</div>'+
        '<div class="FAM-msg-box">'+
          '<div class="FAM-msg-name">' + (data.username || '') + '</div>'+
          '<div class="FAM-msg-content">'+
            '<div class="FAM-msg-text">' + (message || '') + '</div>'+
          '</div>'+
          '<div class="FAM-msg-date"></div>'+
        '</div>';

        if (replacement) {
          FAM.cache.content.insertBefore(msg, replacement);
          FAM.cache.content.removeChild(replacement);
        } else {
          FAM.cache.content.appendChild(msg);
          FAM.message.scroll();
        }

        return msg;
      },


      // handles key events for the message field
      handleKeys : function (e) {
        if (e) {
          var key = e.key || e.which || e.keyCode;

          // handle ENTER key
          if ({
            'Enter' : 1,
            '13' : 1
          }[key] && !e.shiftKey) {
            FAM.cache.actions.querySelector('#FAM-send').dataset.disabled != 'true' && FAM.message.send();
            e.preventDefault();
          }

        }
      },


      // validate a message to make sure there's enough content to post it
      validate : function (message) {
        message = message || FAM.attachments.list.length || null;

        var send = FAM.cache.actions.querySelector('#FAM-send'),
            disabled = send.dataset.disabled == 'true';

        if (message && disabled) {
          send.dataset.disabled = false;

        } else if (!message && !disabled) {
          send.dataset.disabled = true;
        }
      },


      // send a message to the topic
      send : function (resend, form, msgData) {
        msgData = msgData || {};
       
        if (FAM.message.sending) {
          return false;
        } else {
          FAM.message.sending = true;
        }

        FAM.message.clearError(); // removes error messages

        var msg = document.getElementById('FAM-msg'),
            placeholder = FAM.message.write('<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>', msgData.placeholderSettings || { id : 'FAM-msg-placeholder' }, msgData.replacement), // show placeholder message until the sent message is ready
            val = resend ? FAM.message.backup : msg.value,
            attachments = '',
            i = 0,
            j = FAM.attachments.list.length;

        // add attachments to message value
        if (!resend) {
          if (j) {
            for (; i < j; i++) {
              attachments += '[tr][td]' + FAM.attachments.list[i] + '[/td][/tr]';
            }

            val += '\n[table class="FAM-attachment"]' + attachments + '[/table]';

            FAM.attachments.list = [];
            FAM.cache.actions.querySelector('#FAM-attachment-total').innerText = 0;
          }

          // reset message field value
          msg.value = '';
          FAM.message.validate();
          FAM.message.backup = val; // backup the current message in case of errors
        }

        // post the message to the topic
        $.post('/post', $(form || document.fampost).serialize().replace(
          /message=.*?(?:&|$)/,
          'message=' + FAM.encode(val) + '&'
        ) + '&post=1&prevent_post=1', function (data) {
          var success = $('a[href^="/viewtopic"]', data)[0],
              captcha = $('#funcaptcha', data);
         
          // update placeholderSettings
          if (msgData.placeholderSettings) {
            var settings = msgData.placeholderSettings;
            settings.id = 'FAM-msg-error';
          }

          // get the new message and remove the placeholder + sending restriction
          if (success) {
            FAM.message.check(function () {

              // update message replacement
              if (msgData.replacement) {
                $.get(success.href, function (data) {
                  var post = $('.post--' + form.p.value, data)[0];

                  if (post) {
                    placeholder.insertAdjacentHTML('afterend', FAM.message.log[form.p.value] = FAM.message.parse(post, 1));
                    FAM.cache.content.removeChild(placeholder);
                  }
                });

                // remove placeholder and add new message
              } else {
                FAM.cache.content.removeChild(placeholder);
                FAM.message.scroll();
              }

              // wait the specified time before sending another message
              // and display an indicator so the user knows when the timeout is over
              var bar = FAM.cache.actions.querySelector('#FAM-timeout-bar'),
                  progress = FAM.config.flood_control;

              bar.style.height = '100%';

              FAM.message.timeoutBar = setInterval(function () {
                if ((progress -= 50) <= 0 || !FAM.message.sending) {
                  clearInterval(FAM.message.timeoutBar);

                  FAM.message.sending = false;
                  bar.style.height = '0%';

                } else {
                  bar.style.height = progress / FAM.config.flood_control * 100 + '%';
                }
              }, 40);

              // update form data for the guest
              if (!_userdata.session_logged_in) {
                FAM.message.authorizeGuest();
              }
            });

          // insert the captcha form if it's what prevented the message from being sent
          } else if (captcha.length) {
            FAM.cache.content.removeChild(placeholder);

            // cleanup the noscript captcha form for usage
            FAM.message.error = FAM.message.write(
              '<div class="FAM-center"><i class="fa fa-exclamation-circle fa-2x"></i></div>'+
              captcha.closest('form')[0].outerHTML.replace(/<noscript>(.*?)<\/noscript>/g, function (match, $1) {
                return $1.replace(/&lt;|&gt;/g, function (match) {
                  return {
                    '&lt;' : '<',
                    '&gt;' : '>'
                  }[match];
                });
              })
              .replace(/class="gensmall"/g, '')
              .replace(/<div style="[^"]*?">/, '<div class="FAM-row">')
              .replace(/<input([^>]*?)style="[^"]*?"([^>]*?)>/, '<input class="FAM-inputbox" $1 $2>')
              .replace(/<input[^>]*?type="submit"[^>]*?value="(.*?)"[^>]*?>/, '<button class="FAM-button" type="button">$1</button>')
              .replace('<form', '<form class="FAM-center FAM-captcha"'),
            settings || { id : 'FAM-msg-error' });

            // submits the captcha form
            FAM.message.error.querySelector('.FAM-button').onclick = function () {
              FAM.message.sending = false;
              FAM.message.send(true, $(this).closest('form').clone()[0], msgData);
              return false;
            };
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.

Résolu Re: problème messenger forumactif

Message par panic station Sam 03 Sep 2022, 21:35

Code:

          // ask to resend if the message was not sent successfully
          } else {
            FAM.message.sending = false;
            FAM.cache.content.removeChild(placeholder);
            FAM.message.error = FAM.message.write(
              '<div class="FAM-center"><i class="fa fa-exclamation-circle fa-2x"></i></div>'+
              FAM.config.lang.error_sending+
              '<textarea id="FAM-resend-message" class="FAM-inputbox">' + FAM.message.backup + '</textarea>'+
              '<a onclick="FAM.message.send(true);">' + FAM.config.lang.error_resend + '</a> | '+
              '<a onclick="FAM.message.clearError();">' + FAM.config.lang.error_delete + '</a>'+
              '<a href="https://github.com/SethClydesdale/forumactif-messenger/wiki/Reporting-Bugs" target="_blank" style="float:right;">' + FAM.config.lang.error_report + '</a>',
            settings || { id : 'FAM-msg-error' });

            console.log(data); // log response data for debugging
          }
        });
      },

      // removes unsent message error
      clearError : function () {
        if (FAM.message.error) {
          if (FAM.cache.content.querySelector('.FAM-msg-error')) {
            var txt = FAM.message.error.querySelector('#FAM-resend-message');
            if (txt) {
              FAM.message.backup = txt.value;
            }

            FAM.cache.content.removeChild(FAM.message.error);
          }

          delete FAM.message.error;
        }
      },


      // loads older messages
      loadOlder : function (page) {
        var button = FAM.cache.content.querySelector('#FAM-load-older');

        button.setAttribute('onclick', '');
        button.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-2x fa-fw"></i>';

        $.get(page, function (data) {
          var back = $(FAM.select.page_back, data)[0],
              post = $('.post' + (FAM.fVersion == 6 ? '-wrap' : '') + '[class*="post--"]', data),
              html = '',
              i = 0,
              j = post.length,
              load,
              pid;

          // parse messages
          for (; i < j; i++) {
            pid = post[i].className.replace(/.*?(post--\d+).*/, '$1');

            if (!FAM.message.log[pid]) {
              html += FAM.message.log[pid] = FAM.message.parse(post[i], i);
            }
          }

          // restore the load more button functionality or hide it depending if more pages can be loaded
          if (back) {
            button.setAttribute('onclick', "FAM.message.loadOlder('" + ( back.tagName == 'A' ? back : back.parentNode ).href + "')");
            button.innerHTML = FAM.config.lang.load_older;

          } else {
            button.style.display = 'none';
          }

          // add older messages to the message list
          button.insertAdjacentHTML('afterend', html + '<div id="page-load"></div>');
          load = FAM.cache.content.querySelector('#page-load');
          
          FAM.message.scroll(load.previousSibling.offsetTop - 60); // scroll to the bottom of the old messages
          FAM.cache.content.removeChild(load);
        });
      },


      // returns the parsed message
      parse : function (post, index) {
        // filter out sponsored content, since the message is empty
        if (post.className.indexOf('post--0') != -1) {
          return '';
        }
        
        // ignore first post
        if (FAM.config.ignore_firstpost && index == 0) {
          var indicator = $(FAM.select.post_message + ' > strong:first-child', post)[0];

          if (indicator && /&nbsp;/.test(indicator.innerHTML)) {
            return '';
          }
        }

        var avatar, name, pLink, group, date, online, msg, quote, edit, remove;

        quote = $('a[href$="mode=quote"]', post)[0];
        edit = $('a[href$="mode=editpost"]', post)[0];
        remove = $('a[href$="mode=delete"]', post)[0];

        avatar = $(FAM.select.post_avatar, post)[0];

        // get username
        name = $(FAM.select.post_name, post)[0];

        // check if the user link is available
        pLink = name ? name.querySelector('a[href]') : null;
        pLink = pLink ? '<a href="' + pLink.href + '">' : null;

        // check if the user is in a group
        group = name ? name.getElementsByTagName('SPAN')[0] : null;
        group = group ? '<span style="' + group.getAttribute('style') + '"><strong>' : null;

        // check if the username is available
        name = name ? name.innerText : FAM.config.no_name;

        // check if the user is online
        online = post.className.indexOf('online') != -1 ||
                 (FAM.fVersion == 2 && post.querySelector('.i_icon_online')) ||
                 (FAM.fVersion == 0 && post.nextSibling && post.nextSibling.querySelector('.i_icon_online'));
        
        // date and message elements
        date = $(FAM.select.post_date, post)[0];
        msg = $(FAM.select.post_message, post)[0];

        return '<div class="FAM-msg' + ( online ? ' FAM-msg-online' : '' ) + ( (name == _userdata.username || !_userdata.session_logged_in && name == FAM.config.lang.guest) ? ' FAM-my-msg' : '' ) + ' ' + post.className.replace(/.*?(post--\d+).*/, '$1') + '">'+
          '<div class="FAM-msg-avatar">'+
            (pLink ? pLink : '')+
            '<img src="' + ( avatar ? avatar.src : FAM.config.no_avatar ) + '" alt="avatar">'+
            (pLink ? '</a>' : '')+
          '</div>'+

          '<div class="FAM-msg-box">'+
            '<div class="FAM-msg-name">'+
              '<span class="FAM-name-mention" onclick="FAM.message.mention(this);">'+
                (pLink ? pLink : '').replace('<a', '<a onclick="return false;"')+
                  (group ? group : '')+
                    name+
                  (group ? '</strong></span>' : '')+
                (pLink ? '</a>' : '')+
              '</span>'+
            '</div>'+
            '<div class="FAM-msg-content">'+
              '<div class="FAM-msg-text">' + (
                msg ? msg.innerHTML
                // replace break tags with line breaks
                // and remove unnecessary white-space / breaks at the beginning / end of messages
                .replace(/<br>/g, '\n')
                .replace(/^\n+|\n+$|^\s+|\s+$/g, '')
                .replace(/\n/g, '<br>')

                // add unique classes to codeboxes and quotes
                .replace(/class="(.*?)"/g, function (match, $1) {
                  return $1.indexOf('FAM-') == -1 ? 'class="FAM-' + $1.split(' ').join(' FAM-') + '"' : match;
                })
                .replace(/<blockquote>/g, '<blockquote class="FAM-codebox">')

                // add events to media so they open the media viewer on click
                .replace(/<img/g, '<img onclick="FAM.modal.open(this);"')
                .replace(/<table class="FAM-attachment">([\s\S]*?)<\/table>/, function (match, $1) {
                  return '<table class="FAM-attachment">' + $1.replace(/<td/g, '<td onclick="FAM.modal.open(this);"') + '</table>';
                }) : ''
              ) + '</div>'+
              '<div class="FAM-msg-actions">'+
                (quote ? '<span class="FAM-msg-button" onclick="FAM.message.interact(this, \'' + quote.href + '\');" title="' + FAM.config.lang.tooltip_msg_quote + '"><i class="fa fa-quote-left"></i></span>' : '' )+
                (edit ? '<span class="FAM-msg-button" onclick="FAM.message.interact(this, \'' + edit.href + '\');" title="' + FAM.config.lang.tooltip_msg_edit + '"><i class="fa fa-pencil"></i></span>' : '' )+
                (remove ? '<span class="FAM-msg-button" onclick="FAM.message.interact(this, \'' + remove.href + '\');" title="' + FAM.config.lang.tooltip_msg_delete + '"><i class="fa fa-times"></i></span>' : '' )+
              '</div>'+
            '</div>'+
            '<div class="FAM-msg-date">' + ( date ? (FAM.fVersion == 5 ? date.innerHTML.split('<').shift() : date.innerHTML.split('>').pop()).replace(/^\s+|\s+$/g, '') : '' ) + '</div>'+
          '</div>'+
        '</div>';
      },


      // check for new messages / edits and update the message list
      check : function (callback) {
        FAM.request = $.get(FAM.history.log['tab' + FAM.tab.active][FAM.history.log['tab' + FAM.tab.active].length - 1].url, function (data) {

          for (var a = $('.post' + (FAM.fVersion == 6 ? '-wrap' : '') + '[class*="post--"]', data), i = 0, j = a.length, pid, msg, row; i < j; i++) {
            pid = a[i].className.replace(/.*?(post--\d+).*/, '$1');
            msg = FAM.message.parse(a[i], i);

            if (msg) {
              // check for edited messages and update them
              if (FAM.message.log[pid]) {
                if (FAM.message.log[pid] != msg) {
                  FAM.message.log[pid] = msg;
                  row = FAM.cache.content.querySelector('.FAM-msg.' + pid);

                  if (row) {
                    row.outerHTML = msg;
                  }

                }

              // add in new messages if there are any
              } else {
                FAM.message.log[pid] = msg;
                FAM.cache.content.insertAdjacentHTML('beforeend', msg);
                
                if (msg.indexOf('FAM-my-msg') == -1) {
                  // display a message notification if the user is viewing older messages
                  FAM.message.notify(FAM.cache.content.lastChild);
                  
                  // play a sound notification if enabled
                  if (FAM.cache.audio && FAM.message.sound) {
                    FAM.cache.audio.play();
                  }
                }
              }
            }

          }

          // optional callback to execute, mainly used for send()
          if (typeof callback === 'function') {
            callback();
          }
        });
      },
      
      
      // unread message list
      unread : [],
      
      // notify the user of new messages
      notify : function (newMsg) {
        
        // scroll to the newest message if the last few messages are visible
        if (FAM.message.isVisible(newMsg.previousSibling, 5)) {
          FAM.message.scroll();
          
        } else {
          FAM.message.unread.unshift(newMsg);
          
          var notif = FAM.cache.chat.querySelector('#FAM-new-msg-notif'),
              notifMsg = FAM.config.lang['message_notif_' + (FAM.message.unread.length == 1 ? 'singular' : 'plural')].replace('$N', FAM.message.unread.length);
          
          // insert the new message notif and divider
          if (!notif) {
            FAM.cache.content.insertAdjacentHTML('beforebegin', '<div id="FAM-new-msg-notif" onclick="FAM.message.markRead();">' + notifMsg + '</div>');
            newMsg.insertAdjacentHTML('beforebegin', '<div id="FAM-new-msg-divider">' + FAM.config.lang.new_messages + '</div>');
            
          } else {
            notif.innerHTML = notifMsg;
          }
        }
      },
      
      
      // marks unread messages as read
      markRead : function (noScroll, skipTimeout) {
        var divider = FAM.cache.content.querySelector('#FAM-new-msg-divider'),
            notif = FAM.cache.chat.querySelector('#FAM-new-msg-notif');
        
        if (!noScroll) {
          FAM.message.scroll(divider ? divider.offsetTop - 90 : null);
        }
        
        // hide notif before removing
        notif.style.display = 'none';
        
        // wait a few seconds before removing the divider and notif
        window.setTimeout(function () {
          if (divider && divider.parentNode) {
            divider.parentNode.removeChild(divider);
          }
          
          if (notif) {
            FAM.cache.chat.removeChild(notif);
          }
        }, skipTimeout ? 1 : 10000);
        
        // clear unread messages
        FAM.message.unread = [];
      },
      
      
      // reads messages when the user scrolls
      read : function (caller) {
        if (caller.className.indexOf('FAM-viewing-topic') != -1 && FAM.message.unread.length) {
          
          if (caller.scrollTop / (caller.scrollHeight - caller.clientHeight) == 1 || FAM.message.isVisible('unread', FAM.message.unread.length - 1)) {
            FAM.message.markRead(true);
          }
          
        }
      },
      
      
      // checks if a message is visible
      // lookBack = how many prev messages we should check the visibility state
      isVisible : function (msg, lookBack) {
        if (typeof lookBack == 'undefined') {
          lookBack = 1;
        }
        
        var visible = false,
            initial = true,
            loopUnread = msg == 'unread',
            rect;
        
        // set the first unread message
        if (loopUnread) {
          msg = FAM.message.unread[lookBack];
        }
        
        // loop over the specified messages
        while (lookBack --> 0) {
          // don't switch the msg param on the initial run
          if (initial == true) {
            initial = false;
            
          } else {
            msg = loopUnread ? FAM.message.unread[lookBack] :
                  msg ? msg.previousSibling : null;
          }
          
          // check if the message is visible
          if (msg) {
            rect = msg.getBoundingClientRect();

            // if the message is visible we break out of this loop
            if (rect.top >= 0 && rect.left >= 0 && rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && rect.right <= (window.innerWidth || document.documentElement.clientWidth)) {
              visible = true;
              break;
            }
            
          // break out of the loop if the msg is null
          } else {
            break;
          }
        }
        
        return visible;
      },


      // methods that listen for message changes and user activity
      listener : {
        // start listening for changes
        start : function () {
          FAM.message.listener.listening = setInterval(function () {
            if (!FAM.message.sending) {
              FAM.message.check();
            }
          }, FAM.config.refresh < 3000 ? 3000 : FAM.config.refresh);

          FAM.message.listener.idle();
          $(document).on('mousemove keypress click', FAM.message.listener.idle);
        },


        // kill the message listener if it's active
        stop : function () {
          if (FAM.message.listener.listening) {
            FAM.message.sending = false;
            clearInterval(FAM.message.listener.listening);
            delete FAM.message.listener.listening;
          }

          if (FAM.message.listener.idling) {
            clearTimeout(FAM.message.listener.idling);
            delete FAM.message.listener.idling;

            $(document).off('mousemove keypress click', FAM.message.listener.idle);
          }
        },


        // kill listener after a specified period of inactivity
        idle : function () {
          if (FAM.message.listener.idling) {
            clearTimeout(FAM.message.listener.idling);
          }

          FAM.message.listener.idling = setTimeout(function () {
            FAM.message.listener.stop();
            FAM.cache.chat.insertAdjacentHTML('beforeend',
              '<div id="FAM-idle" class="FAM-loading" onclick="FAM.message.listener.resume();">'+
                '<p><i class="fa fa-moon-o fa-3x"></i>' + FAM.config.lang.idle + '</p>'+
              '</div>'
            );
          }, FAM.config.timeout > 15*60*1000 ? 15*60*1000 : FAM.config.timeout);
        },


        // resume listening after a period of inactivity
        resume : function () {
          var idle = FAM.cache.chat.querySelector('#FAM-idle');

          if (idle) {
            FAM.cache.chat.removeChild(idle);
          }

          FAM.message.check(FAM.message.listener.start);
        }
      },


      // scroll to the newest message or specified amount
      scroll : function (amount) {
        FAM.cache.content.scrollTop = amount || (FAM.cache.content.lastChild ? FAM.cache.content.lastChild.offsetTop - 60 : 0);
      },


      // call the emoji list to the specified element (caller)
      emoji : function (caller) {
        var active = FAM.cache.actions.querySelector('#FAM-emoji-list'),
            selector;

        if (active) {
          active.style.visibility = active.style.visibility == 'hidden' ? 'visible' : 'hidden';

        } else {
          selector = document.createElement('IFRAME');
          selector.src = '/post?mode=smilies';
          selector.id = 'FAM-emoji-list';
          selector.className = 'FAM-dropdown';

          selector.onload = function () {
            try {
              var doc = this.contentDocument || this.contentWindow.document,
                  emoji = doc.querySelectorAll('a[href*="insert_chatboxsmilie"]'),
                  close = doc.querySelector('a[href="javascript:window.close();"]'),
                  select = doc.getElementById('smilies_categ'),
                  i = 0,
                  j = emoji.length;
              
              for (; i < j; i++) {
                emoji[i].dataset.emoji = emoji[i].href.replace(/.*?'(.*?)'.*/, '$1');
                emoji[i].href = '#';
                emoji[i].onclick = function () {
                  FAM.message.insert(this.dataset.emoji, true);
                  return false;
                };
              }

              // remove the close button
              if (close) {
                close.parentNode.removeChild(close);
              }
              
              // removes unnecessary contents from the emoji category selector
              if (select) {
                select.innerHTML = select.categ.outerHTML + select.mode.outerHTML;
                select.setAttribute('style', 'text-align:center;padding:3px;');
              }

            } catch (e) {
              console.log(e);
            }
          };

          caller.parentNode.insertBefore(selector, caller);
        }

      },


      // gets the form data for guests
      authorizeGuest : function () {
        $.get(FAM.message.replyPage, function (data) {
          var form = $('form[action="/post"]', data)[0];

          if (form) {
            FAM.cache.actions.querySelector('#FAM-post-data-placeholder').innerHTML = form.outerHTML.replace(/id=".*?"|name=".*?"/, '').replace('<form', '<form id="FAM-post-data" name="fampost" style="display:none"');
            document.fampost.username.value = _userdata.username;
          }
        });
      }
    },


    // attachment methods and data
    attachments : {
      list : [], // list of attachments to add

      // opens the attachment drop down
      open : function (caller) {
        var active = FAM.cache.actions.querySelector('#FAM-attach-options'),
            attach;

        if (active) {
          active.style.visibility = active.style.visibility == 'hidden' ? 'visible' : 'hidden';

        } else {
          attach = document.createElement('DIV');
          attach.id = 'FAM-attach-options';
          attach.className = 'FAM-dropdown';
          attach.innerHTML =
          '<div class="FAM-dropdown-title">' + FAM.config.lang.tooltip_attachments + '</div>'+
          '<div class="FAM-block-option" onclick="FAM.attachments.addImage();"><span class="FAM-option-icon"><i class="fa fa-camera"></i></span> ' + FAM.config.lang.attach_image + '</div>'+
          '<div class="FAM-block-option" onclick="FAM.attachments.addGIF();"><span class="FAM-option-icon FAM-text-icon">GIF</span> ' + FAM.config.lang.attach_gif + '</div>'+
          '<div class="FAM-block-option" onclick="FAM.attachments.addVideo();"><span class="FAM-option-icon"><i class="fa fa-film"></i></span> ' + FAM.config.lang.attach_video + '</div>'+
          '<div class="FAM-block-option" onclick="FAM.attachments.manage();"><span class="FAM-option-icon"><i class="fa fa-wrench"></i></span> ' + FAM.config.lang.attach_remove + '</div>';

          caller.parentNode.insertBefore(attach, caller);
        }
      },


      // completely deletes the old attachment drop down
      close : function () {
        var attach = FAM.cache.actions.querySelector('#FAM-attach-options');

        if (attach) {
          FAM.cache.actions.removeChild(attach);
        }
      },


      // go back to the attachments page
      back : function () {
        FAM.attachments.close();
        FAM.attachments.open(FAM.cache.actions.querySelector('#FAM-attachment'));
      },


      // adds an attachment to the attachment list
      add : function (caller, tag) {
        if (FAM.attachments.list.length >= FAM.config.max_attachments) {
          return alert(FAM.config.lang.attach_max);
        }

        var value = caller.tagName == 'INPUT' ? caller.value :
                    caller.tagName == 'IMG' ? caller.src :
                    null;

        // change tags and edit values based on video host
        if (tag == 'video') {
          if (/youtube/.test(value)) {
            tag = 'youtube';

          } else if (/dailymotion/.test(value)) {
            tag = 'dailymotion';
            value = value.split('_')[0].split('/').pop();

          } else {
            tag = 'url';
          }
        }

        if (value) {
          FAM.attachments.list.push('[' + tag + ']' + ( /giphy/.test(value) ? value.replace('200w.gif', 'giphy.gif') : value) + '[/' + tag + ']');
          FAM.message.validate();

          if (caller.tagName == 'INPUT') {
            caller.value = '';
          }

          FAM.cache.actions.querySelector('#FAM-attachment-total').innerText = FAM.attachments.list.length;

          // show success notification so the user knows the attachment was added
          if (!FAM.cache.actions.querySelector('#FAM-attach-success')) {
            FAM.cache.actions.querySelector('#FAM-attach-options').insertAdjacentHTML('beforeend',
              '<div id="FAM-attach-success"><i class="fa fa-check-circle"></i>' + FAM.config.lang.attach_success + '</div>'
            );

            // remove success message after 300ms
            setTimeout(function () {
              var success = FAM.cache.actions.querySelector('#FAM-attach-success');

              if (success) {
                success.parentNode.removeChild(success);
              }
            }, 300);
          }
        }
      },


      // remove an attachment from the attachment list
      remove : function (caller) {
        var row = caller.parentNode,
            parent = row.parentNode,
            index = Array.prototype.indexOf.call(parent.children, row);

        FAM.attachments.list.splice(index, 1);
        FAM.message.validate();
        FAM.cache.actions.querySelector('#FAM-attachment-total').innerText = FAM.attachments.list.length;

        parent.removeChild(row);

        if (!parent.children.length) {
          parent.innerHTML = '<p class="FAM-center">' + FAM.config.lang.attach_none + '</p>';
        }
      },


      // update the selected attachment when its value changes
      update : function (caller) {
        var thumb = caller.previousSibling,
            row = caller.parentNode,
            index = Array.prototype.indexOf.call(row.parentNode.children, row),
            val = caller.value,
            tag = 'img';

        if (thumb.tagName == 'IMG') {
          thumb.src = val.replace('giphy.gif', '100w_s.gif');

        } else {
          if (/youtube/.test(val)) {
            tag = 'youtube';

          } else if (/dailymotion/.test(val)) {
            tag = 'dailymotion';
            val = val.split('_')[0].split('/').pop();

          } else {
            tag = 'url';
          }

          thumb.href = (tag == 'dailymotion' ? 'https://www.dailymotion.com/video/' : '') + val;
          thumb.firstChild.className = thumb.firstChild.className.replace(/fa-.*/,
            'fa-' + (tag == 'dailymotion' ? 'film' : tag == 'youtube' ? 'youtube-play' : 'external-link')
          );
        }

        FAM.attachments.list[index] = '[' + tag + ']' + val + '[/' + tag + ']';
      },


      // opens the image manager for attaching images
      addImage : function () {
        var attach = FAM.cache.actions.querySelector('#FAM-attach-options');

        attach.innerHTML =
        '<div class="FAM-dropdown-inner">'+
          '<div class="FAM-dropdown-title"><span class="FAM-toolbar-button FAM-dropdown-back" onclick="FAM.attachments.back();"><i class="fa fa-arrow-left"></i></span>' + FAM.config.lang.attach_image + '</div>'+
          '<div class="FAM-button-input FAM-row">'+
            '<input type="text" class="FAM-inputbox" placeholder="' + FAM.config.lang.attach_image + '">'+
            '<button class="FAM-button" onclick="FAM.attachments.add(this.previousSibling, \'img\');" type="button"><i class="fa fa-plus"></i></button>'+
          '</div>'+
          '<div class="FAM-row">'+
            '<button id="FAM-upload" class="FAM-button" onclick="FAM.attachments.upload();" type="button"><i class="fa fa-upload"></i> ' + FAM.config.lang.attach_upload + '</button>'+
          '</div>'+
        '</div>';
      },


      // opens Giphy search for attaching a GIF
      addGIF : function () {
        var attach = FAM.cache.actions.querySelector('#FAM-attach-options');

        attach.innerHTML =
        '<div class="FAM-dropdown-inner">'+
          '<div class="FAM-dropdown-title"><span class="FAM-toolbar-button FAM-dropdown-back" onclick="FAM.attachments.back();"><i class="fa fa-arrow-left"></i></span>' + FAM.config.lang.attach_gif + '</div>'+
          '<div class="FAM-row">'+
            '<input type="text" id="FAM-giphy-search" class="FAM-inputbox" onkeyup="FAM.attachments.giphy.keyHandler(this, event);" placeholder="' + FAM.config.lang.giphy_search + '">'+
          '</div>'+
          '<div class="FAM-row">'+
            '<div id="FAM-giphy-results" onscroll="FAM.attachments.giphy.scrolling(this);"></div>'+
            '<div id="FAM-giphy-mark"></div>'+
          '</div>'+
        '</div>';

        attach.querySelector('#FAM-giphy-search').focus();
      },


      // opens the video manager for attaching videos
      addVideo : function () {
        var attach = FAM.cache.actions.querySelector('#FAM-attach-options');

        attach.innerHTML =
        '<div class="FAM-dropdown-inner">'+
          '<div class="FAM-dropdown-title"><span class="FAM-toolbar-button FAM-dropdown-back" onclick="FAM.attachments.back();"><i class="fa fa-arrow-left"></i></span>' + FAM.config.lang.attach_video + '</div>'+
          '<div class="FAM-button-input FAM-row">'+
            '<input type="text" class="FAM-inputbox" placeholder="' + FAM.config.lang.attach_video + '">'+
            '<button class="FAM-button" onclick="FAM.attachments.add(this.previousSibling, \'video\');" type="button"><i class="fa fa-plus"></i></button>'+
          '</div>'+
          '<div class="FAM-row">'+
            '<button id="FAM-youtube" class="FAM-button" onclick="FAM.attachments.openYoutube();" type="button"><i class="fa fa-search"></i> ' + FAM.config.lang.attach_searchYT + '</button>'+
          '</div>'+
        '</div>';
      },


      // opens the attachment manager so the user can delete attachments
      manage : function () {
        var attach = FAM.cache.actions.querySelector('#FAM-attach-options'),
            i = 0,
            j = FAM.attachments.list.length,
            attachments = '',
            manager,
            dmotion,
            val;

        attach.innerHTML =
        '<div class="FAM-dropdown-inner">'+
          '<div class="FAM-dropdown-title"><span class="FAM-toolbar-button FAM-dropdown-back" onclick="FAM.attachments.back();"><i class="fa fa-arrow-left"></i></span>' + FAM.config.lang.attach_remove + '</div>'+
          '<div id="FAM-attachment-manager"></div>'+
        '</div>';

        manager = attach.querySelector('#FAM-attachment-manager');

        if (j) {
          for (attachments = ''; i < j; i++) {
            val = FAM.attachments.list[i].replace(/\[.*?\]/g, '');
            dmotion = ( /dailymotion/.test(FAM.attachments.list[i]) ? 'https://www.dailymotion.com/video/' : '' );

            attachments +=
            '<div id="FAM-attachment-' + i + '" class="FAM-row">'+
              (/\[img\]/.test(FAM.attachments.list[i]) ?
                '<img class="FAM-attachment-thumb" src="' + val.replace('giphy.gif', '100w_s.gif') + '" alt="attachment ' + i + '" onmouseover="this.src=this.src.replace(\'100w_s.gif\', \'100w.gif\')" onmouseout="this.src=this.src.replace(\'100w.gif\', \'100w_s.gif\')">' :
                '<a href="' + dmotion + val + '" class="FAM-attachment-thumb" target="_blank"><i class="fa fa-' + ( dmotion ? 'film' : /youtube/.test(val) ? 'youtube-play' : 'external-link' ) + '"></i></a>'
              )+
              '<input class="FAM-inputbox" type="text" value="' + dmotion + val + '" onkeyup="FAM.attachments.update(this);">'+
              '<span class="FAM-attachment-delete fa-stack" onclick="FAM.attachments.remove(this);">'+
                '<i class="fa fa-circle fa-stack-2x"></i>'+
                '<i class="fa fa-times fa-stack-1x fa-inverse"></i>'+
              '</span>'+
            '</div>';
          }

        } else {
          attachments = '<p class="FAM-center">' + FAM.config.lang.attach_none + '</p>';
        }

        manager.innerHTML = attachments;
      },


      // opens youtube in a new window
      openYoutube : function (caller) {
        if (FAM.attachments.youtube && !FAM.attachments.youtube.closed) {
          return alert(FAM.config.lang.attach_searchingYT);
        }

        FAM.attachments.youtube = window.open('https://www.youtube.com/', '', 'scrollbars=yes,resizable=yes,width=780,height=530');
      },


      // call the servimg image uploader
      upload : function () {
        if (FAM.attachments.uploader && !FAM.attachments.uploader.closed) {
          return alert(FAM.config.lang.attach_uploading);
        }

        FAM.attachments.uploader = window.open('https://servimg.com/' + FAM.message.servImgData, '', 'scrollbars=yes,resizable=yes,width=780,height=530');
      },


      // giphy search methods and data
      giphy : {
        key : 'dc6zaTOxFJmzC', // PUBLIC BETA KEY
        limit : 26, // max image results
        delay : 200, // delay before searches commence (200ms)

        // search for a GIPHY gif
        search : function (query) {
          if (FAM.attachments.giphy.timeout) {
            FAM.attachments.giphy.abort(); // abort ongoing searches and requests
          }

          if (query) {

            // set a small timeout in case the user is still typing
            FAM.attachments.giphy.timeout = setTimeout(function () {
              FAM.attachments.giphy.reset(true, FAM.config.lang.giphy_searching);
              FAM.attachments.giphy.query = encodeURIComponent(query);

              FAM.attachments.giphy.request = $.get('http://api.giphy.com/v1/gifs/search?q=' + FAM.attachments.giphy.query + '&limit=' + FAM.attachments.giphy.limit + '&rating=pg-13&api_key=' + FAM.attachments.giphy.key, function(data) {
                // update global data such as page offsets for scrolling
                FAM.attachments.giphy.request = null;
                FAM.attachments.giphy.offset = data.pagination.offset + FAM.attachments.giphy.limit;
                FAM.attachments.giphy.offset_total = data.pagination.total_count;

                FAM.attachments.giphy.reset(true); // reset HTML content
                FAM.attachments.giphy.addGIF(data); // send data to be parsed
              });

            }, FAM.attachments.giphy.delay);

          } else {
            FAM.attachments.giphy.reset(true);
          }
        },


        // abort ongoing searches and requests
        abort : function () {
          if (FAM.attachments.giphy.timeout) {
            clearInterval(FAM.attachments.giphy.timeout);
            FAM.attachments.giphy.timeout = null;
          }

          if (FAM.attachments.giphy.request) {
            FAM.attachments.giphy.request.abort();
            FAM.attachments.giphy.request = null;
          }
        },


        // add gifs to the result list
        addGIF : function (data, loadMore) {
          // setup data and begin parsing results
          var gif = data.data,
              i = 0,
              j = gif.length,
              list = $('<div class="FAM-giphy-imagelist" />')[0];

          if (j) {
            for (; i < j; i++) {
              list.appendChild($('<img id="' + gif[i].id + '" src="' + gif[i].images.fixed_width.url + '" />').click(function() {
                FAM.attachments.add(this, 'img');
              })[0]);
            }
          } else if (!loadMore) {
            FAM.attachments.giphy.reset(true, FAM.config.lang.giphy_not_found);
          }

          // add results to the result list
          $('#FAM-giphy-results', FAM.cache.actions).append(list);
        },


        // listen to the scrolling so we can add more gifs when the user reaches the bottom
        scrolling : function (that) {
          if (that.scrollHeight - that.scrollTop === that.clientHeight) {
            FAM.attachments.giphy.loadMore();
          }
        },


        // load more results once the user has scrolled through the last results
        loadMore : function () {
          if (FAM.attachments.giphy.offset < FAM.attachments.giphy.offset_total) {
            FAM.attachments.giphy.request = $.get('http://api.giphy.com/v1/gifs/search?q=' + FAM.attachments.giphy.query + '&offset=' + FAM.attachments.giphy.offset + '&limit=' + FAM.attachments.giphy.limit + '&rating=pg-13&api_key=' + FAM.attachments.giphy.key, function (data) {
              FAM.attachments.giphy.request = null;
              FAM.attachments.giphy.offset = data.pagination.offset + FAM.attachments.giphy.limit;
              FAM.attachments.giphy.offset_total = data.pagination.total_count;

              FAM.attachments.giphy.addGIF(data, true); // send data to be parsed
            });
          }
        },


        // reset the dropdown fields
        reset : function (resultsOnly, newContent) {
          $('#FAM-giphy-results', FAM.cache.actions).html(newContent ? newContent : '');

          if (!resultsOnly) {
            $('#FAM-giphy-search', FAM.cache.actions).val('');
          }
        },


        // key handler for search input
        keyHandler : function (caller, e) {
          var k = e.which || e.keyCode;

          // ignore specific key inputs to prevent unnecessary requests
          if (k && (k == 16 || k == 17 || k == 18 || k == 20 || k == 37 || k == 38 || k == 39 || k == 40)) {
            return;
          } else {
            FAM.attachments.giphy.search(caller.value);
          }
        }
      }
    },


    // topic methods
    topic : {
      // open the topic creation page
      create : function (url, noHistory) {
        if (!noHistory) {
          FAM.history.update({
            url : url,
            title : 'New topic',
            recall : {
              path : 'topic.create',
              args : [url, true]
            }
          });
        }

        FAM.clearRequest();
        FAM.history.toggleBack();
        FAM.tab.title(FAM.config.lang.new_topic);

        FAM.cache.content.className = 'FAM-viewing-newtopic';
        FAM.cache.content.innerHTML =
        '<div class="FAM-loading">'+
          '<i class="fa fa-circle-o-notch fa-spin fa-3x fa-fw"></i>'+
          '<span class="sr-only">' + FAM.config.lang.loading + '</span>'+
        '</div>';
        FAM.cache.actions.innerHTML = '';

        FAM.request = $.get(url, function (data) {
          var form = $('form[action="/post"]', data)[0];

          FAM.cache.content.innerHTML =
          '<div id="FAM-newtopic-box" class="FAM-content-block">'+
            '<form name="fampost">'+
              '<div class="FAM-row"><input id="FAM-topic-subject" class="FAM-inputbox" type="text" placeholder="' + FAM.config.lang.title_placeholder + '" name="subject"></div>'+
              '<div class="FAM-row"><textarea id="FAM-topic-message" class="FAM-inputbox" name="message" placeholder="' + FAM.config.lang.msg_placeholder + '"></textarea></div>'+
              '<div class="FAM-row FAM-center"><button class="FAM-button" type="button" onclick="FAM.topic.publish()" type="button"><i class="fa fa-share"></i> ' + FAM.config.lang.start_topic + '</button></div>'+
              '<div style="display:none">' + $('input[name="auth[]"]', form)[0].parentNode.innerHTML + '</div>'+
            '</form>'+
          '</div>';
          
          // restore topic data
          if (FAM.topic.backup) {
            document.fampost.subject.value = FAM.topic.backup.subject;
            document.fampost.message.value = FAM.topic.backup.message;
            
            if (!FAM.topic.backup.subject) {
              document.fampost.subject.insertAdjacentHTML('afterend', '<p class="FAM-error FAM-center">' + FAM.config.lang.topic_no_subject + '</p>');
            }
            
            if (!FAM.topic.backup.message) {
              document.fampost.message.insertAdjacentHTML('afterend', '<p class="FAM-error FAM-center">' + FAM.config.lang.topic_no_message + '</p>');
            }
            
            delete FAM.topic.backup;
          }
        });
      },


      // posts the topic to the forum
      publish : function () {
        // backup topic data in case of error
        FAM.topic.backup = {
          subject : document.fampost.subject.value,
          message : document.fampost.message.value
        };
        
        var formData = $(document.fampost).serialize().replace(/(subject|message)=.*?&/g, function (match, key) {
          return key + '=' + FAM.encode({
            subject : FAM.topic.backup.subject,
            message : FAM.topic.backup.message
          }[key]) + '&';
        }) + '&post=1';

        // display loading placeholder
        FAM.cache.content.innerHTML =
        '<div class="FAM-loading">'+
          '<i class="fa fa-circle-o-notch fa-spin fa-3x fa-fw"></i>'+
          '<span class="sr-only">' + FAM.config.lang.loading + '</span>'+
        '</div>';

        // post the topic
        $.post('/post', formData, function (data) {
          var success = $('a[href^="/viewtopic?t="]', data)[0];
          
          if (success) {
            FAM.get('/t' + success.href.replace(/.*?t=(\d+)&.*/, '$1') + '-' + encodeURIComponent(FAM.topic.backup.subject.toLowerCase().replace(/\s/g, '-')) + '?view=newest', FAM.topic.backup.subject);
            delete FAM.topic.backup;
            
          } else {
            var history = FAM.history.log['tab' + FAM.tab.active];
            FAM.topic.create(history[history.length - 1].url, true);
          }

        });
      },


      // returns parsed forum topics and categories
      parse : function (forumtitle) {
        if (FAM.config.ignore_announcements && $(forumtitle).closest(FAM.select.forum_info).find((FAM.fVersion == 4 ? '.topic-type ' : '> ') + ' strong').length) {
          return '';
        }

        var row = $(forumtitle).closest(FAM.select.row);

        if (!row.find('.AD_LastPA')[0]) { // exclude ad forums
          row = row[0];

          var avatar = $(FAM.fVersion == 6 ? '.avatar-default img' : '.lastpost-avatar img', row)[0],
          date = $(FAM.select.row_date, row)[0],
          type2 = /c\d+-/.test(forumtitle.href) ? 'category' :
                  /f\d+-/.test(forumtitle.href) ? 'forum' :
                  /t\d+-/.test(forumtitle.href) ? 'topic' : 'unknown';

          // remove dfn/i texts on phpbb3, modernbb, and awesomebb
          if (date && (FAM.fVersion == 1 || FAM.fVersion == 5) && /dfn/.test(date.innerHTML)) {
            date.querySelector('dfn').innerText = '';
          } else if (date && FAM.fVersion == 6 && /<i/.test(date.innerHTML)) {
            date.innerHTML = date.innerHTML.replace(/<i.*?\/i>/g, '');
          }

          // build the markup for forum and topic containers
          return '<div class="FAM-chat FAM-' + type2 + '" onclick="FAM.get(\'' + forumtitle.href.replace(/\?.*$/, '') + ( type2 == 'topic' ? '?view=newest' : '' ) + '\', this.querySelector(\'.FAM-chat-title\').innerText);">'+
            '<span class="FAM-chat-icon ' + ( $('a[href$="view=newest"]', row)[0] ? 'FAM-new-post' : '' ) + ' fa-stack fa-lg">'+
              '<i class="fa fa-circle fa-stack-2x"></i>'+
              '<i class="fa fa-' + ( type2 == 'topic' ? 'comments' : 'folder' ) + ' fa-stack-1x fa-inverse"></i>'+
            '</span>'+

            '<div class="FAM-chat-avatar">'+
              '<img src="' + ( avatar ? avatar.src : FAM.config.no_avatar ) + '" alt="avatar">'+
            '</div>'+

            '<div class="FAM-chat-title">' + forumtitle.innerText + '</div>'+

            '<div class="FAM-chat-date">' + ( date ? date.innerText.split('\n').join('<span class="FAM-separator"></span>').replace(/^\s+|\s+$/g, '').replace(/\s+/g, ' ') : '' ) + '</div>'+
          '</div>';
        } else {
          return '';
        }
      }
    },


    // github pages
    page : {
      // pages directory
      dir : 'https://raw.githubusercontent.com/SethClydesdale/forumactif-messenger/master/pages/',
      
  
        
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.

Résolu Re: problème messenger forumactif

Message par panic station Sam 03 Sep 2022, 21:36

suite du JS (encore), il doit y avoir un soucis de longueur !

Code:
   // information about Forumactif Messenger
      about : {
        open : function (noHistory) {
          FAM.page.setup('about', noHistory);

          FAM.request = $.get(FAM.page.dir + 'about' + FAM.config.update_channel + '.html', function (data) {
            FAM.cache.content.innerHTML = FAM.page.parse(data, {
              client_version : '<a href="https://github.com/SethClydesdale/forumactif-messenger/releases/tag/' + FAM.version + '" target="_blank">' + FAM.version + '</a>'

            }).replace('<textarea', '<textarea style="display:none;"');

            var status = FAM.cache.content.querySelector('#FAM-version-status'),
                icon = FAM.cache.content.querySelector('#FAM-version-status-icon'),
                update = FAM.cache.content.querySelector('#FAM-update');
            
            // hides the sync/update button for non-admins
            if (_userdata.user_level != 1) {
              update.style.display = 'none';
            }

            // display the version status of FAM
            if (FAM.version == FAM.cache.content.querySelector('#FAM-version-github').innerHTML) {
              status.innerHTML = FAM.config.lang.about_updated;
              icon.innerHTML = '<i class="fa fa-check-circle"></i>';

            } else {
              status.innerHTML = FAM.config.lang.about_new_update;
              icon.innerHTML = '<i class="fa fa-exclamation-circle"></i>';
              update.innerHTML = '<i class="fa fa-arrow-circle-up"></i> ' + FAM.config.lang.about_update;
            }

          });
        },


        // get the latest version of Forumactif Messenger from Github
        update : function () {
          FAM.cache.content.querySelector('#FAM-update').outerHTML = '<p id="FAM-update" style="text-align:center;"><i class="fa fa-circle-o-notch fa-spin fa-2x fa-fw"></i></p>';

          $.get('https://raw.githubusercontent.com/SethClydesdale/forumactif-messenger/master/fam' + FAM.config.update_channel + '.js', function (data) {
            var config = data.replace(/[\s\S]*?(config.*?:.*?\{[\s\S]*?\},)[\s\S]*/, '$1').replace(/config.*?:/, 'window.fam_new_config = ').replace(/,$/, ';'),
                lang = data.replace(/[\s\S]*?(lang.*?:.*?\{[\s\S]*?\})[\s\S]*/, '$1').replace(/lang.*?:/, 'window.fam_new_lang = '),
                script = document.createElement('SCRIPT'),
                update = FAM.cache.content.querySelector('#FAM-update-code'),
                k;

            script.type = 'text/javascript';
            script.text = config + '\n' + lang;
            document.body.appendChild(script);

            for (k in fam_new_lang) {
              if (typeof FAM.config.lang[k] === 'undefined') {
                FAM.config.lang[k] = fam_new_lang[k];
              }
            }

            for (k in fam_new_config) {
              if (typeof FAM.config[k] === 'undefined') {
                FAM.config[k] = fam_new_config[k];
              }
            }

            FAM.cache.content.querySelector('#FAM-update').outerHTML = '<div class="FAM-row">' + FAM.config.lang.about_update_info + '</div>';

            update.value = data.replace(/config.*?:.*?\{[\s\S]*?\},/, 'config : ' + JSON.stringify(FAM.config, null, 2) + ',');
            update.style.display = '';
          });
        }
      },


      // general settings for Forumactif Messenger that the user can personalize
      settings : {
        // opens the settings page
        open : function (noHistory) {
          FAM.page.setup('settings', noHistory);

          FAM.request = $.get(FAM.page.dir + 'settings.html', function (data) {
            var settings =  window.JSON && window.localStorage && localStorage.fam_settings ? JSON.parse(localStorage.fam_settings) : {},
                theme = 'value="' + settings.fam_active_theme + '"';

            FAM.cache.content.innerHTML = FAM.page.parse(data, {
              fam_fullscreen : settings.fam_fullscreen || '',
              fam_window_width : settings.fam_window_width || '',
              fam_window_height : settings.fam_window_height || '',
              fam_theme_color : settings.fam_theme_color || '#3399FF',
              fam_sound_notif : typeof settings.fam_sound_notif != 'undefined' ? settings.fam_sound_notif : (FAM.config.sound_notif_auto_enabled == true ? 'checked' : '')
              
            }).replace(
              theme,
              theme + ' selected'
            );
            
            // show admin config for admins only
            if (_userdata.user_level == 1) {
              FAM.cache.content.querySelector('#FAM-settings-admin').style.display = '';
            }

          });
        },


        // update FAM settings when changes are made
        update : function (caller, noCache) {
          var id = caller ? caller.id.replace(/-/g, '_').toLowerCase() : '';

          // take action depending on the setting that was changed
          switch (id) {
            case 'fam_fullscreen' :
              if (caller.checked) {
                FAM.fullscreen = true;
                FAM.cache.chat.className += ' FAM-fullscreen';
                document.body.style.overflow = 'hidden';

              } else {
                FAM.fullscreen = false;
                FAM.cache.chat.className = FAM.cache.chat.className.replace('FAM-fullscreen', '');
                document.body.style.overflow = '';
              }
              break;

            case 'fam_window_width' :
              FAM.cache.chat.style.width = caller.value ? (caller.value + '%') : '';
              break;

            case 'fam_window_height' :
              FAM.cache.chat.style.height = caller.value ? (caller.value + '%') : '';
              break;
              
            case 'fam_active_theme' :
              FAM.page.settings.changeTheme(caller.value);
              break;
              
            case 'fam_theme_color' :
              FAM.page.settings.changeColor(caller.value);
              break;
              
            case 'fam_sound_notif' :
              FAM.message.sound = caller.checked;
              break;
          }

          // cache user settings to localStorage
          if (!noCache && window.JSON && window.localStorage) {
            var settings = localStorage.fam_settings ? JSON.parse(localStorage.fam_settings) : {};

            settings[id] = caller.type == 'checkbox' ? caller.checked ? 'checked' : '' : caller.value;

            localStorage.fam_settings = JSON.stringify(settings);
          }
        },


        // reset FAM settings to their default states
        reset : function () {
          if (confirm(FAM.config.lang.settings_default_confirm)) {
            // reset fields to their default value
            FAM.cache.content.querySelector('#FAM-fullscreen').checked = false;
            FAM.cache.content.querySelector('#FAM-window-width').value = '';
            FAM.cache.content.querySelector('#FAM-window-height').value = '';
            FAM.cache.content.querySelector('#FAM-active-theme').firstChild.selected = true;
            FAM.cache.content.querySelector('#FAM-sound-notif').checked = FAM.config.sound_notif_auto_enabled;

            // update the settings
            for (var a = FAM.cache.content.querySelectorAll('input, select'), i = 0, j = a.length; i < j; i++) {
              switch (a[i].id) {
                case 'FAM-theme-color' :
                  FAM.page.settings.resetColor(a[i].nextSibling, true);
                  break;
                  
                default :
                  FAM.page.settings.update(a[i], true);
                  break;
              }
            }

            // delete locally cached settings
            if (window.localStorage && localStorage.fam_settings) {
              localStorage.removeItem('fam_settings');
            }
          }
        },


        // applies cached settings on startup
        apply : function () {
          
          // auto enable sound notif if setting is unset
          function applySoundNotif (settings) {
            settings = settings || {};
            
            if (typeof settings.fam_sound_notif == 'undefined' && FAM.config.sound_notif_auto_enabled) {
              FAM.message.sound = true;
            }
          };
          
          // apply all settings
          if (window.JSON && window.localStorage && localStorage.fam_settings) {
            var settings = JSON.parse(localStorage.fam_settings), i;

            for (i in settings) {
              switch (i) {
                case 'fam_fullscreen' :
                  if (settings[i] == 'checked' && !FAM.config.embed) {
                    FAM.cache.chat.className += ' FAM-fullscreen';
                    FAM.fullscreen = true;
                  }
                  break;

                case 'fam_window_width' :
                  FAM.cache.chat.style.width = settings[i] ? settings[i] + '%' : '';
                  break;

                case 'fam_window_height' :
                  FAM.cache.chat.style.height = settings[i] ? settings[i] + '%' : '';
                  break;
                  
                case 'fam_active_theme' :
                  FAM.page.settings.changeTheme(settings[i]);
                  break;

                case 'fam_theme_color' :
                  FAM.page.settings.changeColor(settings[i]);
                  break;
                  
                case 'fam_sound_notif' :
                  FAM.message.sound = settings[i] == 'checked';
                  break;
              }
            }

            applySoundNotif(settings);
          } else {
            applySoundNotif();
          }
        },
        
        
        // changes the main theme for Forumactif Messenger
        changeTheme : function (theme) {
          var oldTheme = document.getElementById('FAM-theme-stylesheet'),
              
              // parses cached theme data from localStorage
              themeData = (window.JSON && window.localStorage && localStorage.fam_theme) ? JSON.parse(localStorage.fam_theme) : {},
              
              // applies theme CSS to the document
              applyTheme = function (css) {
                $('head').append('<style id="FAM-theme-stylesheet" type="text/css">' + css + '</style>');
              };
          
          // remove the old theme
          if (oldTheme) {
            document.head.removeChild(oldTheme);
          }
          
          // since light is default we wont apply theme CSS for it
          if (theme != 'light') {
            
            // get and apply the new theme from Github or localStorage
            if (themeData.title == theme) {
              applyTheme(themeData.css);

            } else {
              $.get('https://raw.githubusercontent.com/SethClydesdale/forumactif-messenger/master/themes/' + theme + '.css', function (data) {
                applyTheme(data);

                // cache the theme to localStorage to improve performance when changing pages
                if (window.JSON && window.localStorage) {
                  localStorage.fam_theme = JSON.stringify({
                    title : theme,
                    css : data
                  });
                }
              });
            }
            
          } else if (window.localStorage && localStorage.fam_theme) {
            localStorage.removeItem('fam_theme');
          }
          
        },
        
        
        // changes the primary color of Forumactif Messenger
        changeColor : function (color) {
          var palette = [color.toUpperCase()],
              oldColor = document.getElementById('FAM-color-stylesheet'),
              
              // gets the rgb value of the selected color
              // it'll help find a text color that contrasts well w/the selected color
              rgb = [
                parseInt(color.slice(1, 3), 16),
                parseInt(color.slice(3, 5), 16),
                parseInt(color.slice(5, 7), 16),
              ],
              bright = Math.round(((parseInt(rgb[0]) * 299) + (parseInt(rgb[1]) * 587) + (parseInt(rgb[2]) * 114)) /1000) > 125,
              
              // determine what fontColor to use based on the lightness of the selected color
              fontColor = [
                bright ? '#333' : '#FFF',
                bright ? '#444' : '#EEE',
                bright ? '#555' : '#DDD'
              ],
              
              // components used for subtracting the color
              hex = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'A', 'B', 'C', 'D', 'E', 'F'],
              letter = { 'F' : 15, 'E' : 14, 'D' : 13, 'C' : 12, 'B' : 11, 'A' : 10 },
              i = 2,
              k,
              rawColor;
          
          // subtracts the selected color twice
          while (i --> 0) {
            rawColor = palette[palette.length - 1].split('');
            
            for (k = 1; k < 7; k++) {
              rawColor[k] = letter[rawColor[k]] || +rawColor[k];
              
              if (--rawColor[k] < 0) {
                rawColor[k] = 0;
              }
              
              rawColor[k] = hex[rawColor[k]];
            }
            
            palette.push(rawColor.join(''));
          }
          
          // removes the old color stylesheet
          if (oldColor) {
            document.body.removeChild(oldColor);
          }
          
          // adds the new theme color to the document
          $('body').append(
            '<style id="FAM-color-stylesheet" type="text/css">'+
              '#FAM-button, #FAM-toolbar, .FAM-maintitle, .FAM-toolbar-button, #FAM-idle, .FAM-button, #FAM-attachment-total, #FAM-attach-success, .FAM-dropdown-title, #FAM a.FAM-page-link, .FAM-page-link, .FAM-my-msg .FAM-msg-content { color:' + fontColor[0] + '; }'+
              '#FAM.FAM-fullscreen[data-hidden="false"] + #FAM-button:hover, .FAM-toolbar-button i:hover { color:' + fontColor[1] + '; }'+
              '#FAM.FAM-fullscreen[data-hidden="false"] + #FAM-button:active, .FAM-toolbar-button i:active { color:' + fontColor[2] + '; }'+
              '#FAM a, #FAM-new-topic .fa-circle, .FAM-chat-icon.FAM-new-post .fa-circle, #FAM-tab-add:hover, #FAM-version-status-icon .fa-check-circle, .FAM-section-title { color:' + palette[0] + '; }'+
              '#FAM a:hover, #FAM-new-topic:hover .fa-circle { color:' + palette[1] + '; }'+
              '#FAM a:active, #FAM-new-topic:active .fa-circle { color:' + palette[2] + '; }'+
              '#FAM-button, #FAM-toolbar, .FAM-button, #FAM .FAM-list li:before, #FAM-attachment-total, .FAM-dropdown-title, #FAM a.FAM-page-link, .FAM-page-link, .FAM-tab.FAM-tab-active:after, .FAM-my-msg .FAM-msg-content { background-color:' + palette[0] + '; }'+
              '#FAM-button:hover, .FAM-button:hover, #FAM a.FAM-page-link:hover, #FAM .FAM-list li:hover:before { background-color:' + palette[1] + '; }'+
              '#FAM-button:active, .FAM-button:active, #FAM a.FAM-page-link:active { background-color:' + palette[2] + '; }'+
              '#FAM .FAM-inputbox:focus, .FAM-msg-online .FAM-msg-avatar { border-color:' + palette[0] + '; }'+
              '.FAM-my-msg .FAM-msg-content:before { border-left-color:' + palette[0] + '; }'+
              '.FAM-section-title { border-bottom-color:' + palette[0] + '; }'+
              '#FAM-toolbar { border-bottom-color:' + palette[1] + '; }'+
            '</style>'
          );
          
        },

       
        // resets the primary theme color
        resetColor : function (caller, skipConfirmation) {
          if (skipConfirmation || confirm(FAM.config.lang.settings_color_reset)) {
            var oldColor = document.getElementById('FAM-color-stylesheet');
           
            if (oldColor) {
              document.body.removeChild(oldColor);
            }
           
            caller.previousSibling.value = '#3399FF';
           
            if (window.JSON && window.localStorage) {
              var settings = localStorage.fam_settings ? JSON.parse(localStorage.fam_settings) : {};

              delete settings.fam_theme_color;

              localStorage.fam_settings = JSON.stringify(settings);
            }
          }
        }

      },
     
     
      // opens the internal configuration page of Forumactif Messenger
      config : {
        // open the configuration page
        open : function (noHistory) {
          FAM.page.setup('config', noHistory);

          FAM.request = $.get(FAM.page.dir + 'config.html', function (data) {
            var config = {},
                permission = 'value="' + FAM.config.chat_permission + '"',
                channel = 'value="' + (FAM.config.update_channel == '-dev' ? 'developer' : 'production') + '"',
               
                check = {
                  tabs : 1,
                  ignore_announcements : 1,
                  ignore_firstpost : 1,
                  hide_menu_avatar : 1,
                  sound_notif_auto_enabled : 1
                },
               
                int = {
                  refresh : 1000,
                  timeout : 60*1000,
                  flood_control : 1000
                },
               
                i, lang = '', q;
           
            // setup config variables for the config page
            for (i in FAM.config) {
              config['fam_' + i] = check[i] ? FAM.config[i] ? 'checked' : '' :
                                  int[i] ? FAM.config[i] / int[i] :
                                  FAM.config[i];
            }
           
            // apply page html
            FAM.cache.content.innerHTML = FAM.page.parse(
              data,
              config
            ).replace(permission, permission + ' selected')
            .replace(channel, channel + ' selected');
           
            // add help icons
            for (var a = FAM.cache.content.querySelectorAll('label'), i = 0, j = a.length, id; i < j; i++) {
              id = a[i].getAttribute('for');
             
              if (id) {
                a[i].nextSibling.insertAdjacentHTML('beforeend', '<a class="FAM-icon-link" href="https://github.com/SethClydesdale/forumactif-messenger/wiki/Config#' + id.replace('FAM-config-', '') + '" target="_blank"><i class="fa fa-question-circle"></i></a>');
              }
            }
           
            // insert initial tabs if there are any
            if (FAM.config.initial_tabs.length) {
              FAM.page.config.addInitialTab(FAM.config.initial_tabs);
            }
           
            // insert lang fields
            for (i in FAM.config.lang) {
              q = FAM.config.lang[i].indexOf('"') != -1 ? "'" : '"';
              lang +=
              '<div class="FAM-row">'+
                '<label for="FAM-lang-' + i + '" class="FAM-label">' + i + ' : </label>'+
                '<div class="FAM-label-value">'+
                  '<input id="FAM-lang-' + i + '" class="FAM-inputbox" type="text" value=' + q + FAM.config.lang[i] + q + '>'+
                '</div>'+
              '</div>';
            }
           
            FAM.cache.content.querySelector('#FAM-config-lang-data').firstChild.insertAdjacentHTML('afterend', lang);
          });
        },
       
       
        // imports the selected language file
        importLang : function () {
          var select = FAM.cache.content.querySelector('#FAM-config-lang-import'),
              lang = select.value,
              langName = select.querySelector('[value="' + lang + '"]').innerText;
         
          if (lang && confirm(FAM.config.lang.config_import_lang_confirm.replace('$LANG', langName))) {
            var button = FAM.cache.content.querySelector('#FAM-config-lang-import-confirm'),
                html = button.innerHTML,
                click = button.getAttribute('onclick');
           
            // show a placeholder while loading the lang file
            button.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>';
            button.setAttribute('onclick', '');
           
            // get the language file from github
            $.get('https://raw.githubusercontent.com/SethClydesdale/forumactif-messenger/master/lang/' + lang + '.js', function (data) {
              var script = document.createElement('SCRIPT'),
                  newAlias = '',
                  alias,
                  i,
                  q;
             
              script.type = 'text/javascript';
              script.text = data;
              document.body.appendChild(script);
             
              for (i in fam_lang_import) {
                alias = FAM.cache.content.querySelector('#FAM-lang-' + i);
               
                // change alias value
                if (alias) {
                  alias.value = fam_lang_import[i];
                 
                // create a new alias if it doesn't exist
                } else {
                  q = fam_lang_import[i].indexOf('"') != -1 ? "'" : '"';
                  newAlias +=
                  '<div class="FAM-row">'+
                    '<label for="FAM-lang-' + i + '" class="FAM-label">' + i + ' : </label>'+
                    '<div class="FAM-label-value">'+
                      '<input id="FAM-lang-' + i + '" class="FAM-inputbox" type="text" value=' + q + fam_lang_import[i] + q + '>'+
                    '</div>'+
                  '</div>';
                }
              }
             
              // add the new aliases to the list
              if (newAlias) {
                FAM.cache.content.querySelector('#FAM-config-lang-data').firstChild.insertAdjacentHTML('afterend', newAlias);
              }

              // restore button state and display a success message
              button.innerHTML = html;
              button.setAttribute('onclick', click);
              alert(FAM.config.lang.config_import_lang_success.replace('$LANG', langName));
            });
          }
        },
       
       
        // exports the admin's lang file for sharing
        exportLang : function () {
          var a = FAM.cache.content.querySelectorAll('#FAM-config-lang-data .FAM-inputbox[id^="FAM-lang-"]'),
              textarea = FAM.cache.content.querySelector('#FAM-config-lang-file'),
              lang = {},
              i = 0,
              j = a.length;

          for (; i < j; i++) {
            lang[a[i].id.replace('FAM-lang-', '')] = a[i].value;
          }
         
          FAM.cache.content.querySelector('#FAM-config-lang-success').innerHTML = FAM.config.lang.config_export_lang_success;
          textarea.value = JSON.stringify(lang, null, 2);
          textarea.style.display = '';
        },
       
       
        // adds an initial tab to the list
        addInitialTab : function (tabList, scroll) {
          tabList = tabList || [{
            title : '',
            url : '',
            html : ''
          }];
         
          var list = FAM.cache.content.querySelector('#FAM-config-initial_tabs'),
              tabs = '',
              i = 0,
              j = tabList.length,
              // returns a row for the tab fields
              addRow = function (label, value) {
                return '<div class="FAM-row">'+
                  '<label class="FAM-label">' + label + ' : </label>'+
                  '<div class="FAM-label-value">'+
                    '<input class="FAM-inputbox FAM-init-tab-' + label + '" type="text" value="' + ( value || '' ) + '">'+
                  '</div>'+
                '</div>';
              };
         
          // put together the tab fields
          for (; i < j; i++) {
            tabs +=
            '<div class="FAM-init-tab FAM-border-box">'+
              addRow('title', tabList[i].title)+
              addRow('url', tabList[i].url)+
              addRow('html', tabList[i].html)+
              '<div class="FAM-init-tab-controls FAM-center">'+
                '<a href="#" class="FAM-icon-link" onclick="FAM.page.config.moveInitialTab(this, \'up\'); return false;"><i class="fa fa-arrow-circle-up"></i></a>'+
                '<a href="#" class="FAM-icon-link" onclick="FAM.page.config.moveInitialTab(this, \'down\'); return false;"><i class="fa fa-arrow-circle-down"></i></a>'+
                '<a href="#" class="FAM-icon-link" onclick="FAM.page.config.removeInitialTab(this); return false;"><i class="fa fa-times-circle"></i></a>'+
              '</div>'+
            '</div>';
          }
         
          list.insertAdjacentHTML('beforeend', tabs);
         
          if (scroll) {
            FAM.cache.content.scrollTop = list.lastChild.offsetTop - 80;
          }
        },
       
       
        // moves a tab in the initial tab list
        moveInitialTab : function (caller, direction) {
          var tab = caller.parentNode.parentNode,
              tabList = tab.parentNode;
         
          switch (direction) {
            case 'up' :
              var next = tab.previousSibling;
              if (next && next.className.indexOf('FAM-init-tab') != -1) {
                tabList.insertBefore(tab, tab.previousSibling);
               
              } else {
                tabList.appendChild(tab);
              }
             
              break;
             
            case 'down' :
              var next = tab.nextSibling,
                  nextNext = next ? next.nextSibling : null;
             
              if (!next) {
                tabList.insertBefore(tab, tabList.querySelector('.FAM-init-tab'));
               
              } else if (nextNext) {
                tabList.insertBefore(tab, nextNext);
               
              } else if (!nextNext) {
                tabList.appendChild(tab);
              }
              break;
          }
         
          FAM.cache.content.scrollTop = tab.offsetTop - 80;
        },
       
       
        // removes a tab from the initial tab list
        removeInitialTab : function (caller) {
          if (confirm(FAM.config.lang.config_remove_tab)) {
            var tab = caller.parentNode.parentNode;
            tab.parentNode.removeChild(tab);
          }
        },
       
       
        // update the configuration
        update : function () {
          var button = FAM.cache.content.querySelector('#FAM-config-update'),
              update = FAM.cache.content.querySelector('#FAM-config-code'),
              click = button.getAttribute('onclick');
         
          // display a spinner while things load
          button.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-2x fa-fw"></i>';
          button.setAttribute('onclick', '');

          // get the latest version of FAM
          $.get('https://raw.githubusercontent.com/SethClydesdale/forumactif-messenger/master/fam' + FAM.config.update_channel + '.js', function (data) {
            var configClone = Object.assign({}, FAM.config),
                int = {
                  refresh : 1000,
                  timeout : 60*1000,
                  flood_control : 1000
                },
                field,
                i;

            // update the configuration object
            for (i in configClone) {
              field = FAM.cache.content.querySelector('#FAM-config-' + i);
             
              if (field) {
                configClone[i] = field.type == 'checkbox' ? field.checked :
                                int[i] ? +field.value * int[i] :
                                field.value;
              }
            }
           
            // update initial tabs
            configClone.initial_tabs = [];
            for (var a = FAM.cache.content.querySelectorAll('.FAM-init-tab'), i = 0, j = a.length; i < j; i++) {
              configClone.initial_tabs.push({
                title : a[i].querySelector('.FAM-init-tab-title').value,
                url : a[i].querySelector('.FAM-init-tab-url').value,
                html : a[i].querySelector('.FAM-init-tab-html').value
              });
            }
           
            // update lang data
            for (i in configClone.lang) {
              field = FAM.cache.content.querySelector('#FAM-lang-' + i);
             
              if (field) {
                configClone.lang[i] = field.value;
              }
            }

            // return the button's normal state
            button.innerHTML = FAM.config.lang.config_update;
            button.setAttribute('onclick', click);

            // display the updated code with a help message
            FAM.cache.content.querySelector('#FAM-config-code-success').innerHTML = FAM.config.lang.about_update_info;
            update.value = data.replace(/config.*?:.*?\{[\s\S]*?\},/, 'config : ' + JSON.stringify(configClone, null, 2) + ',');
            update.style.display = '';
          });
        }
      },


      // search page that allows the user to search for specific topics
      search : {
        // opens the search page
        open : function (noHistory) {
          FAM.page.setup('search', noHistory);

          FAM.request = $.get(FAM.page.dir + 'search.html', function (data) {
            FAM.cache.content.innerHTML = FAM.page.parse(data);
            FAM.page.search.button = FAM.cache.content.querySelector('#FAM-search-view');
            FAM.page.search.results = FAM.cache.content.querySelector('#FAM-search-results');
          });
        },


        // performs an AJAX search with the given string
        query : function (str) {
          FAM.page.search.clear();
          FAM.page.search.data = {
            URI : '/search?search_keywords=' + encodeURIComponent(str) + '*',
            key : str
          };

          // only perform search with 3 letter (or greater) words
          if (str.length >= 3) {
            FAM.page.search.results.innerHTML = '<p class="FAM-center">' + FAM.config.lang.search_searching + '</p>';

            // show view search button
            if (FAM.page.search.button.style.display == 'none') {
              FAM.page.search.button.style.display = '';
            }

            // wait a few seconds before sending the request
            FAM.page.search.wait = setTimeout(function () {

              // perform a search with the specified keywords
              FAM.page.search.request = $.get(FAM.page.search.data.URI, function (data) {
                var a = $(FAM.select.forumtitle, data),
                    i = 0,
                    j = a.length,
                    html = '';

                for (; i < j; i++) {
                  html += FAM.topic.parse(a[i]);
                }

                FAM.page.search.results.innerHTML = html ? html : '<p class="FAM-center">' + FAM.config.lang.search_no_results + '</p>';
              });

            }, 100);

          } else if (FAM.page.search.button.style.display != 'none') {
            FAM.page.search.button.style.display = 'none';
            FAM.page.search.results.innerHTML = '<p class="FAM-center">' + FAM.config.lang.search_tip + '</p>';
          }

        },


        // bring up the search results as a normal page
        get : function () {
          FAM.page.search.clear();
          FAM.get(FAM.page.search.data.URI, FAM.config.lang.tooltip_search + ' - ' + FAM.page.search.data.key);
        },


        // clear ongoing queues and searches
        clear : function () {
          // clear ongoing timeout
          if (FAM.page.search.wait) {
            clearTimeout(FAM.page.search.wait);
            delete FAM.page.search.wait;
          }

          // clear ongoing requests
          if (FAM.page.search.request) {
            FAM.page.search.request.abort();
            delete FAM.page.search.request;
          }
        }
      },
     
     
      // allows the user to sign into their account if logged out
      login : {
        // opens the login page
        open : function (noHistory) {
          FAM.page.setup('login', noHistory);
          FAM.page.login.submitting = false;

          // get the login form if the user is logged out
          if (!_userdata.session_logged_in) {
            FAM.request = $.get(FAM.page.dir + 'login.html', function (data) {
              FAM.cache.content.innerHTML = FAM.page.parse(data);
              FAM.cache.content.querySelector('#FAM-login-username').focus();
            });
           
          } else { // otherwise show an error message
            FAM.cache.content.innerHTML = '<div class="FAM-content-block FAM-center"><p>' + FAM.config.lang.login_logged_in + '</p></div>';
          }

        },
       
       
        // submits the login information to the server to sign the user in
        submit : function () {
          if (!FAM.page.login.submitting) {
            var button = document.getElementById('FAM-login-submit'),
                error = document.getElementById('FAM-login-error');
           
            FAM.clearRequest();
            FAM.page.login.submitting = true;
            button.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-2x fa-fw"></i>';
            error.style.display = 'none';
           
            FAM.request = $.post('/login', $(document.fam_form_login).serialize() + '&login=1', function (data) {
              FAM.page.login.submitting = false;
              button.innerHTML = FAM.config.lang.login_sign_in;
             
              // check for successful login by searching for session_logged_in status
              if (/_userdata\["session_logged_in"\] = 1/.test(data)) {
                // update userdata and lang values
                FAM.updateUserdata(data);
               
                // change the menu avatar
                if (!FAM.config.hide_menu_avatar) {
                  document.getElementById('FAM-menu-avatar').innerHTML = _userdata.avatar;
                }
               
                // open the profile page
                FAM.page.profile.open();
                FAM.page.login.toggleMenuActions();
               
              } else { // show an error message if login is unsuccessful
                error.style.display = '';
              }
            });
          }
        },
       
       
        // toggles the login and profile menu actions
        toggleMenuActions : function () {
          document.getElementById('FAM-menu-login').style.display = _userdata.session_logged_in ? 'none' : '';
          document.getElementById('FAM-menu-profile').style.display = _userdata.session_logged_in ? '' : 'none';
        }
      },
     
     
      // let's the user view their profile and log out of their account
      profile : {
        // opens the profile page
        open : function (noHistory) {
          FAM.page.setup('profile', noHistory);
          FAM.page.profile.logging_out = false;

          // get the user profile if logged in
          if (_userdata.session_logged_in) {
            FAM.request = $.get(FAM.page.dir + 'profile.html', function (data) {
              FAM.cache.content.innerHTML = FAM.page.parse(data, {
                fam_profile_avatar : _userdata.avatar,
                fam_profile_username : _userdata.username,
                fam_profile_rank : _lang.rank_title || '',
                fam_profile_posts : _userdata.user_posts,
                fam_profile_PMs : _userdata.user_nb_privmsg,
                fam_profile_reputation : _userdata.point_reputation || 0,
                username : _userdata.username
              });

            });
           
          } else { // otherwise show an error message
            FAM.cache.content.innerHTML = '<div class="FAM-content-block FAM-center"><p>' + FAM.config.lang.profile_logged_out + '</p></div>';
          }
        },
       
       
        // log out of the current profile
        logout : function () {
          if (!FAM.page.profile.logging_out && confirm(FAM.config.lang.profile_confirm_sign_out)) {
            var logout = document.getElementById('logout'),
                button = document.getElementById('FAM-profile-logout');
           
            FAM.clearRequest();
            FAM.page.profile.logging_out = true;
            button.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-2x fa-fw"></i>';
           
            // if the default login link is present we can get the data from the href attribute. (FASTER)
            FAM.request = $.get('/login?logout=true&change_version=prosilver', function (data) {
              var form = $('form[action^="/login?logout"]', data)[0];

              // if the logout form is preset we can proceed with logging the user out
              if (form) {
                FAM.request = $.get(form.action + '&key=' + form.key.value, function (data) {
                  FAM.updateUserdata(data);
                  FAM.page.profile.logging_out = false;
                  FAM.page.login.open();
                  FAM.page.login.toggleMenuActions();
                });

              } else { // otherwise we should send them to the logout page directly
                window.location.href = '/login?logout=1';
              }
            });
          }
        },
       
       
        // process specific actions, such as marking forums read and deleting cookies
        process : function (caller, action) {
          if (confirm(FAM.config.lang['profile_confirm_' + action])) {
            // store old values so they can be restored later
            var click = caller.getAttribute('onclick'),
                html = caller.innerHTML;
           
            // show loading spinner
            caller.setAttribute('onclick', 'return false;');
            caller.innerHTML = '<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>';
           
            $.get(caller.href, function (data) {
             
              switch (action) {
                case 'mark_read' :
                  alert(FAM.config.lang.profile_forums_marked);
                 
                  // restores the caller state
                  if (caller) {
                    caller.setAttribute('onclick', click);
                    caller.innerHTML = html;
                  }
                  break;
                 
                case 'delete_cookies' :
                  var form = $('form[action="/?mode=delete_cookies"]', data)[0];
                 
                  // post the cookie deletion form
                  if (form) {
                    $.post(form.action, $(form).serialize() + '&confirm=1', function (data) {
                      alert(FAM.config.lang.profile_cookies_deleted);
                     
                      // open the login page since this essentially logs the user out
                      _userdata.username = 'Anonymous';
                      _userdata.session_logged_in = 0;
                      _userdata.user_level = 0;
                      FAM.page.login.open();
                    });
                  }
                  break;
              }
             
            });
          }
        }
      },


      // sets up various settings for custom pages
      setup : function (pageName, noHistory) {
        // open a new tab if no tab is currently open
        if (!FAM.tab.active) {
          FAM.tab.add();
        }
       
        // update history
        if (!noHistory) {
          FAM.history.update({
            url : '',
            title : FAM.config.lang['tooltip_' + pageName],
            recall : {
              path : 'page.' + pageName.replace(/\s/g, '_') + '.open',
              args : [true]
            }
          });
        }

        FAM.clearRequest();
        FAM.history.toggleBack();
        FAM.message.listener.stop();
        FAM.tab.title(FAM.config.lang['tooltip_' + pageName]);

        FAM.cache.content.className = 'FAM-viewing-github';
        FAM.cache.content.innerHTML =
        '<div class="FAM-loading">'+
          '<i class="fa fa-circle-o-notch fa-spin fa-3x fa-fw"></i>'+
          '<span class="sr-only">' + FAM.config.lang.loading + '</span>'+
        '</div>';
      },


      // parses a page retreived from github
      parse : function (data, vars) {
        var i;
       
        vars = vars || {};
        data = data.replace(/\n\s*?</g, '<')
                  .replace(/<a/g, '<a target="_blank"')
                  // show new release content
                  .replace(/style="\/\*v1\.0\.0\*\/display:none;"/g, '');

        // parse custom variables
        for (i in vars) {
          data = data.replace(new RegExp('{' + i + '}', 'g'), vars[i]);
        }

        // parse language variables
        for (i in FAM.config.lang) {
          data = data.replace(new RegExp('{' + i + '}', 'g'), FAM.config.lang[i]);
        }

        return data;
      }

    },


    // history methods and data
    history : {
      log : {}, // log history so the user can go back


      // save history to localStorage
      save : function () {
        if (window.JSON && window.localStorage) {
          localStorage.fam_data = JSON.stringify({
            active : FAM.tab.active,
            total : FAM.tab.total,
            history : FAM.history.log
          });
        }
      },


      // restore history
      restore : function () {
        if (window.JSON && window.localStorage && localStorage.fam_data) {

          if (!FAM.tab.loaded) {
            var data = JSON.parse(localStorage.fam_data), i;

            FAM.tab.total = data.total;
            FAM.history.log = data.history;

            for (i in FAM.history.log) {
              FAM.tab.add(i.replace('tab', ''), FAM.history.log[i][FAM.history.log[i].length - 1].title);
            }

            if (data.active) {
              FAM.tab.focus(data.active);
            } else {
              FAM.tab.initial();
            }

            FAM.tab.loaded = true;
          }

          return true;
        } else {
          return false;
        }
      },


      // update history with new entry
      update : function (history) {
        FAM.history.log['tab' + FAM.tab.active].push(history);

        // save user tabs
        FAM.history.save();
      },


      // goes back in history to the beginning or by 1
      back : function (begin) {
        var history = FAM.history.log['tab' + FAM.tab.active][begin ? 0 : FAM.history.log['tab' + FAM.tab.active].length - 2];

        begin ? FAM.history.log['tab' + FAM.tab.active] = FAM.history.log['tab' + FAM.tab.active].slice(0, 1) : FAM.history.log['tab' + FAM.tab.active].pop();

        if (history.recall) {
          FAM.history.recall(history.recall);

        } else {
          FAM.get(history.url, history.title, true);
        }

        // stop listening for message changes
        FAM.message.listener.stop();

        // save user tabs
        FAM.history.save();
      },


      // recall a page opened by a function
      recall : function (data) {
        var path = data.path.split('.'),
            open = FAM,
            i = 0,
            j = path.length;

        for (; i < j; i++) {
          open = open[path[i]];
        }

        open.apply(null, data.args);
      },


      // toggles the back button
      toggleBack : function () {
        if (FAM.history.log['tab' + FAM.tab.active]) {
          if (FAM.history.log['tab' + FAM.tab.active].length > 1 && FAM.cache.back.style.display == 'none') {
            FAM.cache.back.style.display = '';

          } else if (FAM.history.log['tab' + FAM.tab.active].length <= 1 && FAM.cache.back.style.display != 'none') {
            FAM.cache.back.style.display = 'none';
          }
         
        } else {
          FAM.cache.back.style.display = 'none';
        }
      }
    },


    // tab methods and data
    tab : {
      active : 0, // currently active tab
      total : 0, // total tabs created (used for assigning unique ids)

      // sets up the initial tabs for Forumactif Messenger
      initial : function () {
        FAM.tab.add(); // initial chat_page tab

        for (var i = 0, j = FAM.config.initial_tabs.length, id, title; i < j; i++) {
          id = ++FAM.tab.total; // unique tab id

          // initial history entry
          FAM.history.log['tab' + id] = [{
            url : FAM.config.chat_page,
            title : FAM.config.main_title
          }];

          // custom history entry
          FAM.config.initial_tabs[i].url = FAM.config.initial_tabs[i].url || '';
          FAM.config.initial_tabs[i].title = FAM.config.initial_tabs[i].title || 'Tab ' + id;
          FAM.history.log['tab' + id].push(FAM.config.initial_tabs[i]);

          // creates a new tab w/the custom history entry via the "restore" method
          FAM.tab.add(id, FAM.config.initial_tabs[i].title);
        }
      },


      // add a new tab
      add : function (restore, title) {
        var id = restore || ++FAM.tab.total;

        // general tab markup
        FAM.cache.tabs.insertAdjacentHTML('beforeend',
          '<div id="FAM-tab-' + id + '" class="FAM-tab">'+
            '<span class="FAM-tab-name" onclick="FAM.tab.focus(' + id + ')">' + ( title ? title : FAM.config.lang.loading ) + '</span>'+
            '<i class="FAM-tab-close fa fa-times" onclick="FAM.tab.close(' + id + ')"></i>'+
          '</div>'
        );

        // doesn't log history or focus the tab if it was "restored" from localStorage
        if (!restore) {
          FAM.history.log['tab' + id] = [];
          FAM.tab.focus(id);
        }
      },


      // close the specified tab
      close : function (id) {
        var dead = FAM.cache.tabs.querySelector('#FAM-tab-' + id),
            survivor = dead.previousSibling ? dead.previousSibling :
                      dead.nextSibling ? dead.nextSibling :
                      null;

        if (survivor && id == FAM.tab.active) {
          FAM.tab.focus(survivor.id.replace('FAM-tab-', ''));

        } else if (!survivor) {
          FAM.clearRequest();
          FAM.message.listener.stop();

          FAM.tab.title(FAM.config.lang.no_tabs_title);
          FAM.cache.content.innerHTML =
          '<div id="FAM-no-tabs" class="FAM-loading" onclick="FAM.tab.prompt(this);">'+
            '<p><i class="fa fa-plus fa-3x"></i>' + FAM.config.lang.no_tabs + '</p>'+
          '</div>';
          FAM.cache.actions.innerHTML = '';

          FAM.tab.active = 0;
        }

        dead.parentNode.removeChild(dead);
        delete FAM.history.log['tab' + id];
        FAM.history.save();
        FAM.history.toggleBack();
      },


      // focus the specified tab
      focus : function (id) {
        if (id == FAM.tab.active) {
          return false;
        }

        var active = FAM.cache.tabs.querySelector('#FAM-tab-' + FAM.tab.active),
            tab = FAM.cache.tabs.querySelector('#FAM-tab-' + id),
            history = FAM.history.log['tab' + id];

        if (active) {
          active.className = 'FAM-tab';
        }
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.

Résolu Re: problème messenger forumactif

Message par panic station Sam 03 Sep 2022, 21:36

et encore, le reste !
Code:

        tab.className = 'FAM-tab FAM-tab-active';
        FAM.cache.tabs.scrollLeft = tab.offsetLeft - tab.getBoundingClientRect().width;
        FAM.tab.active = id;

        if (history.length) {
          history = history[history.length - 1];

          if (history.html) {
            FAM.cache.content.innerHTML = history.html;
            FAM.clearRequest();
          } else {
            history.recall ? FAM.history.recall(history.recall) : FAM.get(history.url, history.title, true);
          }

          FAM.history.save();

        } else {
          FAM.get(FAM.config.chat_page || '/forum', FAM.config.main_title);
        }
      },


      // bring up a prompt that asks the user if they want to load the initial tabs
      prompt : function (caller) {
        if (FAM.config.initial_tabs.length) {
          caller.style.cursor = 'auto';
          caller.onclick = null;
          caller.innerHTML =
          '<div class="FAM-row">'+
            '<p><i class="fa fa-question-circle fa-3x"></i>' + FAM.config.lang.no_tabs_initial + '</p>'+
            '<div class="FAM-inline-buttons">'+
              '<button class="FAM-button" onclick="FAM.tab.initial();" type="button">' + FAM.config.lang.yes + '</button>'+
              '<button class="FAM-button" onclick="FAM.tab.add();" type="button">' + FAM.config.lang.no + '</button>'+
            '</div>'+
          '</div>';

        } else {
          FAM.tab.add();
        }
      },


      // changes the main title and focused tab title
      title : function (string) {
        FAM.cache.toolbar.querySelector('.FAM-maintitle').innerText = string;
        FAM.cache.tabs.querySelector('#FAM-tab-' + FAM.tab.active + ' .FAM-tab-name').innerText = string;
      }
    },


    // modal methods and data
    modal : {
      // opens the modal
      open : function (caller) {
        // closes media modal if it's already open
        if (FAM.modal.box) {
          FAM.modal.close();
        }

        // selects the media element inside the attachment cell
        if (caller.tagName == 'TD') {
          caller = caller.querySelector('img, iframe, a') || caller;
        }

        var box = document.createElement('DIV'),
            attachments = $(caller).closest('.FAM-attachment')[0];

        box.id = 'FAM-modal';
        box.innerHTML =
        '<div id="FAM-modal-overlay"></div>'+
        '<div id="FAM-modal-content">'+
          '<div id="FAM-media-viewer">'+
            '<i id="FAM-modal-prev" class="FAM-modal-controls FAM-modal-arrows fa fa-arrow-left fa-2x" onclick="FAM.modal.showMedia(-1, true);" style="display:none;"></i>'+
            '<i id="FAM-modal-next" class="FAM-modal-controls FAM-modal-arrows fa fa-arrow-right fa-2x" onclick="FAM.modal.showMedia(+1, true);" style="display:none;"></i>'+
            '<i id="FAM-modal-close" class="FAM-modal-controls fa fa-times fa-2x" onclick="FAM.modal.close();"></i>'+
            '<a id="FAM-view-media" class="FAM-modal-controls" href="#" target="_blank"><i class="fa fa-external-link-square fa-2x"></i></a>'+
            '<div id="FAM-media-list"></div>'+
          '</div>'+
        '</div>';

        FAM.modal.box = box;
        FAM.modal.list = box.querySelector('#FAM-media-list');
        FAM.modal.view = box.querySelector('#FAM-view-media');
        FAM.modal.media = [];
        FAM.modal.mediaIndex = 0;

        if (attachments) {
          for (var a = attachments.querySelectorAll('img, iframe, a'), i = 0, j = a.length; i < j; i++) {
            FAM.modal.addMedia(a[i]);

            if (a[i] == caller) {
              FAM.modal.mediaIndex = i;
            }
          }

        } else {
          FAM.modal.addMedia(caller);
        }

        if (FAM.modal.media.length) {
          FAM.modal.showMedia(FAM.modal.mediaIndex);
          document.body.appendChild(FAM.modal.box);

          if (!FAM.fullscreen) {
            document.body.style.overflow = 'hidden';
          }

        } else {
          delete FAM.modal.box;
        }
      },


      // closes the modal
      close : function () {
        if (FAM.modal.box) {
          document.body.removeChild(FAM.modal.box);

          if (!FAM.fullscreen) {
            document.body.style.overflow = '';
          }

          delete FAM.modal.box;
        }
      },


      // adds media to the media list
      addMedia : function (media) {
        media = media.cloneNode(true);
        media.style.display = 'none';
        media.onclick = null;

        FAM.modal.media.push(media);
        FAM.modal.list.appendChild(media);
      },


      // show the specified media
      showMedia : function (id, arrow) {
        var back = FAM.modal.box.querySelector('#FAM-modal-prev'),
            next = FAM.modal.box.querySelector('#FAM-modal-next'),
            max = FAM.modal.media.length - 1;

        FAM.modal.media[FAM.modal.mediaIndex].style.display = 'none'; // hide the old media
        FAM.modal.mediaIndex = arrow ? FAM.modal.mediaIndex + id : id; // update media index

        // hide arrows and reset index if it has reached the max or min value
        if (FAM.modal.mediaIndex >= max) {
          next.style.display = 'none';
          FAM.modal.mediaIndex = max;
        } else if (FAM.modal.mediaIndex <= 0) {
          back.style.display = 'none';
          FAM.modal.mediaIndex = 0;
        }

        // show arrows if they're hidden
        if (next.style.display == 'none' && FAM.modal.mediaIndex < max) {
          next.style.display = '';
        }

        if (back.style.display == 'none' && FAM.modal.mediaIndex > 0) {
          back.style.display = '';
        }

        // update view media link
        FAM.modal.view.href = FAM.modal.media[FAM.modal.mediaIndex][/IMG|IFRAME/.test(FAM.modal.media[FAM.modal.mediaIndex].tagName) ? 'src' : 'href'];

        // show newly active media
        FAM.modal.media[FAM.modal.mediaIndex].style.display = '';
      }
    },


    // initial setup of FAM
    init : function () {
      var initialized = false;

      // add view=newest query to topic urls if it's not there
      if (/\/t\d+/.test(FAM.config.chat_page) && !/view=newest/.test(FAM.config.chat_page)) {
        FAM.config.chat_page = FAM.config.chat_page.replace(/#\d+$/, '') + '?view=newest';
      }
     
      // parse the update channel
      FAM.config.update_channel = FAM.config.update_channel == 'developer' ? '-dev' : '';

      // builds the necessary chat elements
      function build () {
        // delete FAM if the user does not meet the required permissions
        if (!{
          'all' : 1,
          'member' : _userdata.session_logged_in,
          'staff' : _userdata.user_level
        }[FAM.config.chat_permission.toLowerCase()]) {
          return;
        }

        var button = document.createElement('A'),
            chat = document.createElement('DIV'),
            audio = document.createElement('AUDIO'),
            frag = document.createDocumentFragment(),
            embed = FAM.config.embed ? document.querySelector(FAM.config.embed) : null;

        chat.id = 'FAM';
        chat.className = FAM.config.embed ? 'FAM-embedded' : '';
        chat.dataset.hidden = FAM.config.embed ? false : true;
        chat.innerHTML =
        '<div id="FAM-toolbar">'+
          '<div id="FAM-toolbar-inner">'+
            '<span id="FAM-back" class="FAM-toolbar-button" onclick="FAM.history.back()" style="display:none" title="' + FAM.config.lang.tooltip_back + '"><i class="fa fa-arrow-left"></i></span>'+
            '<h1 class="FAM-maintitle"></h1>'+
            '<span id="FAM-menu-toggle" class="FAM-toolbar-button" title="' + FAM.config.lang.tooltip_menu + '"><i class="fa fa-ellipsis-h"></i></span>'+
            '<div id="FAM-menu" style="visibility:hidden;">'+
              '<div id="FAM-menu-home" class="FAM-menu-option" onclick="FAM.history.back(true);" title="' + FAM.config.lang.tooltip_home + '"><i class="fa fa-home"></i></div>'+
              '<div id="FAM-menu-login" class="FAM-menu-option" onclick="FAM.page.login.open();" title="' + FAM.config.lang.tooltip_login + '"' + ( _userdata.session_logged_in ? ' style="display:none"' : '' ) + '><i class="fa fa-sign-in"></i></div>'+
              '<div id="FAM-menu-profile" class="FAM-menu-option" onclick="FAM.page.profile.open();" title="' + FAM.config.lang.tooltip_profile + '"' + ( !_userdata.session_logged_in ? ' style="display:none"' : '' ) + '>' + ( !FAM.config.hide_menu_avatar ? '<span id="FAM-menu-avatar">' + _userdata.avatar + '</span>' : '<i class="fa fa-user"></i>' ) + '</div>'+
              '<div id="FAM-menu-search" class="FAM-menu-option" onclick="FAM.page.search.open();" title="' + FAM.config.lang.tooltip_search + '"><i class="fa fa-search"></i></div>'+
              '<div id="FAM-menu-settings" class="FAM-menu-option" onclick="FAM.page.settings.open();" title="' + FAM.config.lang.tooltip_settings + '"><i class="fa fa-cog"></i></div>'+
              '<div id="FAM-menu-about" class="FAM-menu-option" onclick="FAM.page.about.open();" title="' + FAM.config.lang.tooltip_about + '"><i class="fa fa-question-circle"></i></div>'+
            '</div>'+
          '</div>'+
        '</div>'+
        '<div id="FAM-tab-container" ' + ( FAM.config.tabs ? '' : 'style="display:none"' ) + '>'+
          '<div id="FAM-tabs"></div>'+
          '<div id="FAM-tab-add" onclick="FAM.tab.add()"><i class="fa fa-plus"></i></div>'+
        '</div>'+
        '<div id="FAM-content" onscroll="FAM.message.read(this);"></div>'+
        '<div id="FAM-actions"></div>';
        frag.appendChild(chat);

        // create button if the chat is not embedded
        if (!FAM.config.embed) {
          button.id = 'FAM-button';
          button.title = FAM.config.lang.tooltip_openFAM;
          button.innerHTML = '<i class="fa fa-comment"></i>';
          button.onclick = FAM.toggle;
          frag.appendChild(button);
        }
       
        // setup audio element for notifications
        audio.src = FAM.config.sound_notif_file;
       
        if (audio.canPlayType) {
          audio.id = 'FAM-audio-notif';
          frag.appendChild(audio);
         
        } else {
          audio = null;
        }

        // cache nodes
        FAM.cache = {
          button : button,
          chat : chat,
          audio : audio,
          back : chat.querySelector('#FAM-back'),
          toolbar : chat.querySelector('#FAM-toolbar'),
          tabs : chat.querySelector('#FAM-tabs'),
          content : chat.querySelector('#FAM-content'),
          actions : chat.querySelector('#FAM-actions')
        };

        // toggle FAM menu on click
        chat.querySelector('#FAM-menu-toggle').onclick = function () {
          var menu = FAM.cache.toolbar.querySelector('#FAM-menu');
          menu.style.visibility = menu.style.visibility == 'hidden' ? 'visible' : 'hidden';
          return false;
        };


        // set forum version
        FAM.fVersion = document.querySelector('.bodylinewidth') ? 0 :
                      document.getElementById('phpbb') ? 1 :
                      document.querySelector('div.pun') ? 2 :
                      document.getElementById('ipbwrapper') ? 3 :
                      document.getElementById('fa_edge') ? 4 :
                      document.getElementById('modernbb') ? 5 :
                      document.getElementById('dimmer') ? 6 :
                      'badapple';

        // css selectors by version
        FAM.select = {
          forumtitle : (FAM.fVersion == 6 ? '.forum-description h3 a[href^="/f"], .posts-description h3 a[href^="/t"]' :
                        'a.forum' + ( FAM.fVersion == 0 ? 'link' : 'title' ) + ', a.topictitle'),
          post : '.post' + (FAM.fVersion == 6 ? '-wrap' : '') + '[class*="post--"]',

          row : [
            'tr', // phpbb2
            '.row', // phpbb3
            'tr', // punbb
            'tr', // invision
            '.forum-block', // forumactif edge
            '.row', // modernbb
            '.forum-section, .posts-section' // awesomebb
          ][FAM.fVersion],

          row_date : [
            '.row3Right .postdetails, .row3.over .gensmall', // phpbb2
            '.lastpost span:not(.lastpost-avatar)', // phpbb3
            '.tcr', // punbb
            '.lastaction, td:last-child > span:last-child', // invision
            '.forum-lastpost', // forumactif edge
            '.lastpost > span:not(.lastpost-avatar)', // modernbb
            '.forum-lastpost-inner > span, .posts-lastpost-inner > span' // awesomebb
          ][FAM.fVersion],

          forum_info : [
            '.topictitle', // phpbb2
            '.dterm', // phpbb3
            '.tdtopics', // punbb
            '.row1', // invision
            '.forum-info', // forumactif edge
            '.topic-title-container', // modernbb
            '.forum-description, .posts-description' // awesomebb
          ][FAM.fVersion],

          new_topic : [
            '#i_post', // phpbb2
            '.i_post', // phpbb3
            '.i_post', // punbb
            '.i_post', // invision
            '.i_post', // forumactif edge
            'a.ion-edit[href$="mode=newtopic"]', // modernbb
            'a.btn.btn-default[href$="mode=newtopic"]' // awesomebb
          ][FAM.fVersion],

          post_reply : [
            '#i_reply', // phpbb2
            '.i_reply', // phpbb3
            '.i_reply', // punbb
            '.i_reply', // invision
            '.i_reply', // forumactif edge
            'a.ion-reply[href$="mode=reply"]', // modernbb
            'a.btn.btn-default[href$="mode=reply"]' // awesomebb
          ][FAM.fVersion],

          post_avatar : [
            '.postdetails.poster-profile img', // phpbb2
            '.postprofile dt img', // phpbb3
            '.user-basic-info img', // punbb
            '.postprofile dt img', // invision
            '.user-avatar img', // forumactif edge
            '.postprofile-avatar img', // modernbb
            '.post-author-avatar img' // awesomebb
          ][FAM.fVersion],

          post_name : [
            '.name', // phpbb2
            '.postprofile dt strong', // phpbb3
            '.username', // punbb
            '.postprofile dt strong', // invision
            '.username', // forumactif edge
            '.postprofile-name', // modernbb
            '.post-author-name' // awesomebb
          ][FAM.fVersion],

          post_date : [
            '.postdetails:not(.poster-profile)', // phpbb2
            '.author', // phpbb3
            '.posthead h2', // punbb
            '.author', // invision
            '.author', // forumactif edge
            '.topic-date', // modernbb
            '.post-date' // awesomebb
          ][FAM.fVersion],

          post_message : [
            '.postbody > div', // phpbb2
            '.content > div', // phpbb3
            '.entry-content > div:not(.vote) > div', // punbb
            '.post-entry > div:not(.clear, .vote)', // invision
            '.content > div', // forumactif edge
            '.content > div', // modernbb
            '.post-content' // awesomebb
          ][FAM.fVersion],

          pagination : [
            'a[href="javascript:Pagination();"]', // phpbb2
            '.pagination:not(strong)', // phpbb3
            'p.paging', // punbb
            'div.pagination', // invision
            '.pagination:not(strong)', // forumactif edge
            '.pagination:not(strong)', // modernbb
            '.pagination:not(strong)' // awesomebb
          ][FAM.fVersion],

          page_back : [
            '.pagination .sprite-arrow_subsilver_left', // phpbb2
            '.pag-img:first-child', // phpbb3
            '.sprite-arrow_prosilver_left', // punbb
            '.sprite-arrow_prosilver_left', // invision
            '.pag-img:first-child', // forumactif edge
            '.pag-img:first-child', // modernbb
            '.pag-img:first-child' // awesomebb
          ][FAM.fVersion]
        };
       
        // FAM styles
        // NOTE : this is getting pretty big.. we should consider looking for a CDN.
        $('head').append('<style type="text/css" id="FAM-main-stylesheet">@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css);.FAM-button,.FAM-title{text-transform:uppercase}#FAM,#FAM .FAM-inputbox,#FAM-msg{font-family:Arial,sans-serif}.FAM-clear,.FAM-msg-date,.FAM-msg:after{clear:both}#modernbb #FAM i.fa,#modernbb #FAM-button i.fa,#modernbb #FAM-send{margin:initial;vertical-align:initial}#FAM a{color:#06D;text-decoration:none}#FAM a:hover{color:#04A;text-decoration:underline}#FAM a:active{color:#028}#FAM,#FAM *{box-sizing:border-box;transition:0ms}#FAM{color:#333;font-size:13px;background:#FFF;border:1px solid #DDD;position:fixed;height:70%;width:40%;min-height:400px;min-width:300px;right:3px;z-index:99999;visibility:visible;opacity:1;bottom:35px;transition-property:top,right,bottom,left,height,width,margin,opacity,visibility;transition-duration:500ms}#FAM-button,.FAM-maintitle{text-align:center;font-size:18px}#FAM[data-hidden=true]{visibility:hidden;opacity:0;bottom:-100%}#FAM.FAM-embedded{position:relative;bottom:0;right:0;width:100%;height:500px;margin:12px auto;z-index:1}#FAM.FAM-fullscreen{position:fixed;right:0!important;bottom:0!important;margin:0!important;height:100%!important;width:100%!important;z-index:99999}#FAM-button{color:#FFF;background:#39F;position:fixed;width:30px;height:30px;right:3px;bottom:3px;cursor:pointer;z-index:99999;transition-property:right;transition-duration:500ms}#FAM-button i{line-height:30px}#FAM-toolbar,.FAM-toolbar-button i{line-height:40px}#FAM-button:hover{background-color:#28E}#FAM-button:active{background-color:#17D}#FAM.FAM-fullscreen[data-hidden=false]+#FAM-button{background:0 0;top:5px;right:35px;bottom:auto}#FAM.FAM-fullscreen[data-hidden=false]+#FAM-button:hover{color:#EEE}#FAM.FAM-fullscreen[data-hidden=false]+#FAM-button:active{color:#DDD}#FAM-toolbar{color:#FFF;background:#39F;border-bottom:1px solid #28E;height:40px;margin:-1px -1px 0}.FAM-maintitle{color:#FFF;width:70%;margin:0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.FAM-toolbar-button{color:#FFF;font-size:24px;position:absolute;top:-1px;height:40px;cursor:pointer}.FAM-toolbar-button i:hover{color:#EEE}.FAM-toolbar-button i:active{color:#DDD}#FAM-back{left:10px}#FAM-menu-toggle{right:10px}#FAM-menu{color:#666;background:#FFF;border:1px solid #CCC;position:absolute;right:-1px;top:39px;min-width:75px;z-index:2}#FAM-idle,.FAM-button{color:#FFF;cursor:pointer}.FAM-menu-option{font-size:30px;text-align:center;padding:4px;cursor:pointer}.FAM-menu-option:hover{opacity:.9;background:#EEE}.FAM-menu-option:active{opacity:.8;background:#DDD}#FAM-back[style*=none]~#FAM-menu .FAM-menu-option:first-child{display:none}#FAM-content{height:90%;height:calc(100% - 69px);overflow-y:auto;overflow-x:hidden}#FAM-attach-success,.FAM-block-option{text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}#FAM-content.FAM-reply-open{height:calc(100% - 110px)}#FAM-tab-container[style*=none]+#FAM-content{height:calc(100% - 39px)}#FAM-tab-container[style*=none]+#FAM-content.FAM-reply-open{height:calc(100% - 80px)}.FAM-content-block{font-size:14px;padding:12px}.FAM-border-box{border:1px solid #DDD;border-radius:5px;padding:3px;margin:12px 6px}.FAM-loading,.FAM-loading p{font-size:18px;font-weight:700}.FAM-loading{display:flex;justify-content:center;align-items:center;text-align:center;position:absolute;top:0;left:0;right:0;bottom:0}.FAM-loading i{display:block;margin-bottom:12px}#FAM-no-tabs{top:69px;cursor:pointer}#FAM-tab-container[style*=none]+#FAM-content #FAM-no-tabs{top:39px}#FAM-idle{background:rgba(0,0,0,.7);z-index:10;transition:300ms}#FAM-idle:hover{background:rgba(0,0,0,.6)}.FAM-button{font-size:16px;font-weight:700;background:#39F;border:none;border-radius:4px;display:block;height:40px;padding:0 12px;margin:3px auto;outline:0}.FAM-button:hover{background:#28E}.FAM-button:active{background:#17D}.FAM-inline-buttons .FAM-button{display:inline-block;margin:3px}#FAM .FAM-inputbox{color:#333;font-size:14px;background:#FFF;border:1px solid #DDD;border-radius:4px;padding:8px;width:100%;vertical-align:baseline;cursor:text;outline:0;height:auto;line-height:normal}#FAM .FAM-inputbox[type=color],#FAM select.FAM-inputbox{cursor:pointer}#FAM textarea.FAM-inputbox{height:150px;resize:none}#FAM .FAM-inputbox:hover{border-color:#CCC}#FAM .FAM-inputbox:focus{border-color:#39F}#FAM .FAM-button-input .FAM-inputbox{width:79%;width:calc(100% - 40px);height:40px;margin:0;border-radius:4px 0 0 4px}#FAM .FAM-button-input .FAM-button{font-size:24px;vertical-align:-4px;width:40px;height:40px;display:inline-block;margin:0;padding:0;border-radius:0 4px 4px 0}#FAM .FAM-button-input-small .FAM-inputbox{width:50px;height:30px;padding:0 2px;vertical-align:top}#FAM .FAM-button-input-small .FAM-button{font-size:18px;width:30px;height:30px;padding:0}.FAM-title{font-size:24px;font-weight:700;margin-bottom:12px}.FAM-title a{text-decoration:none!important}.FAM-title i{font-size:36px;vertical-align:-2px;margin-right:3px}.FAM-section-title{color:#39F;font-size:18px;font-weight:700;border-bottom:2px solid #39F;margin:12px auto;padding-bottom:3px}hr.FAM-hr{border:none;border-top:2px solid #DDD;margin:24px 0}.FAM-icon-link{font-size:18px;vertical-align:middle;display:inline-block;margin:0 6px}#FAM .FAM-list{margin:0;padding:0 0 0 40px;list-style-type:none}#FAM .FAM-list li{margin:0;padding:3px 0;position:relative}#FAM .FAM-list li:before{content:"";background:#39F;position:absolute;width:8px;height:8px;left:-16px;top:50%;margin-top:-4px;border-radius:100%}#FAM .FAM-list li:hover:before{background:#06C}#FAM .FAM-connected-buttons a{color:#333;background:#FFF;border:1px solid #DDD;display:inline-block;height:30px;line-height:28px;padding:0 12px;margin-left:-1px;text-decoration:none}#FAM .FAM-connected-buttons a:hover{background:#EEE;border-color:#CCC;position:relative}#FAM .FAM-connected-buttons a:active{background:#DDD;border-color:#BBB;position:relative}#FAM .FAM-connected-buttons>a:first-child,#FAM .FAM-connected-buttons>span:first-child>a{border-radius:4px 0 0 4px;margin-left:0}#FAM .FAM-connected-buttons>a:last-child,#FAM .FAM-connected-buttons>span:last-child>a{border-radius:0 4px 4px 0}#FAM .FAM-connected-buttons i{font-size:20px;margin-right:3px;vertical-align:-2px}.FAM-label{font-weight:700;text-align:right;vertical-align:top;word-wrap:break-word;display:inline-block;width:30%;padding-right:6px;margin:0}.FAM-label-value{display:inline-block;width:70%}#FAM .FAM-label-value .FAM-inputbox:not([type=color]){width:60%}#FAM .FAM-label-value .FAM-init-tab.FAM-border-box .FAM-inputbox{width:90%;padding:8px}.FAM-init-tab-controls .FAM-icon-link{font-size:24px}.FAM-symmetrical-label .FAM-label,.FAM-symmetrical-label .FAM-label-value{width:50%}.FAM-left,.FAM-symmetrical-label .FAM-label-value{text-align:left}.FAM-right{text-align:right}#FAM-attach-success,#FAM-giphy-results,.FAM-center,.FAM-dropdown-title,.FAM-option-icon,.FAM-pagination{text-align:center}.FAM-float-left{float:left}.FAM-float-right{float:right}.FAM-clear:after{content:"";display:table;clear:both}#FAM p,.FAM-row{margin:12px 0}#FAM .FAM-center-block{width:50%;margin-left:auto;margin-right:auto}.FAM-error{color:#F66;font-weight:700}.FAM-noclick{pointer-events:none}.FAM-clickable{pointer-events:all}.FAM-separator:after{content:" ";color:#CCC}.FAM-forum .FAM-separator:after{content:" | "}.FAM-msg-content:before,.FAM-msg-text .FAM-attachment td:after,.FAM-msg:after{content:""}#FAM ::-webkit-scrollbar{width:8px;height:8px}#FAM ::-webkit-scrollbar-track{background-color:#DDD}#FAM ::-webkit-scrollbar-thumb{background-color:rgba(0,0,0,.1);border:none}#FAM ::-webkit-scrollbar-button:single-button{height:0;width:0}#FAM ::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.2)}#FAM ::-webkit-scrollbar-thumb:active{background-color:rgba(0,0,0,.3)}#FAM-actions{height:41px;border-top:1px solid #DDD;display:none}.FAM-viewing-forum+#FAM-actions,.FAM-viewing-topic+#FAM-actions{display:block}.FAM-viewing-forum+#FAM-actions{height:0;border:none}#FAM-actions:empty{display:none}#FAM-new-topic{position:absolute;right:8px;bottom:3px;cursor:pointer}#FAM-new-topic .fa-plus{line-height:57px}#FAM-new-topic .fa-circle{color:#39F}#FAM-new-topic:hover .fa-circle{color:#28E}#FAM-new-topic:active .fa-circle{color:#17D}#FAM-actions>button{color:#333;font-size:18px;background:#FFF;border:none;border-left:1px solid #DDD;height:40px;width:40px;cursor:pointer;outline:0}#FAM-actions>button:hover{background:#EEE}#FAM-actions>button:active{background:#DDD}#FAM-actions>button[data-disabled=true]{pointer-events:none}#FAM-actions>button[data-disabled=true]>*{opacity:.5}#FAM-actions>button#FAM-attachment{border:none;position:relative}#FAM-attachment-total{color:#FFF;font-size:12px;font-weight:700;background:#39F;border-radius:4px;position:absolute;bottom:1px;left:1px;padding:1px 3px}#FAM-attach-success{color:#FFF;font-size:16px;background:#8B5;position:absolute;top:-1px;left:-1px;right:-1px;height:40px;line-height:40px;padding:0 6px}#FAM-attach-success i{font-size:26px;margin-right:6px;vertical-align:-3px}#FAM-actions .FAM-dropdown{background:#FFF;border:1px solid #DDD;position:absolute;left:0;bottom:40px;width:300px;height:400px;z-index:2}.FAM-block-option,.FAM-dropdown-title,.FAM-option-icon{line-height:40px;height:40px}.FAM-dropdown .FAM-dropdown-inner{padding:6px}.FAM-dropdown-title{color:#FFF;font-weight:700;font-size:18px;background:#39F;padding:0 6px;margin:-1px -1px 0}.FAM-dropdown-back{left:3px}.FAM-dropdown-inner .FAM-dropdown-title{margin:-7px -7px 12px}.FAM-block-option{color:#666;font-size:16px;border-bottom:1px solid #DDD;width:100%;cursor:pointer}.FAM-block-option:hover{color:#333;background:#EEE}.FAM-block-option:active{color:#000;background:#DDD}.FAM-option-icon{font-size:20px;font-weight:400;display:inline-block;width:50px;float:left}.FAM-option-icon i{line-height:40px}.FAM-option-icon.FAM-text-icon{font-size:18px;font-weight:700;font-stretch:condensed}#FAM-giphy-results{height:260px;margin:10px auto;overflow-x:hidden;overflow-y:auto}.FAM-giphy-imagelist{line-height:0;column-count:2;column-gap:3px}.FAM-giphy-imagelist img{width:100%;margin-bottom:3px;cursor:pointer}#FAM #FAM-giphy-mark{background:url(https://i.servimg.com/u/f35/18/21/60/73/powere11.png) 50% 50% no-repeat;height:22px;width:100%}#FAM-attachment-manager{height:340px;overflow-y:auto;overflow-x:hidden}#FAM-attachment-manager .FAM-inputbox{width:65%}.FAM-attachment-thumb{text-align:center;border:1px solid #DDD;border-radius:4px;display:inline-block;width:50px;height:50px;margin-right:6px;object-fit:cover;vertical-align:-20px}a.FAM-attachment-thumb{vertical-align:-5px}.FAM-attachment-thumb i{font-size:24px;line-height:50px}.FAM-attachment-delete{margin-left:6px;cursor:pointer}.FAM-attachment-delete:hover .fa-circle{color:#F33}#FAM-msg{color:#333;font-size:14px;background:0 0;border:none;height:40px;width:100%;margin:0;padding:6px;outline:0;resize:none}.FAM-chat,.FAM-pagination{border-bottom:2px solid #DDD}#FAM-msg-container{border-left:1px solid #DDD;display:inline-block;height:40px;width:calc(100% - 120px);vertical-align:top;position:relative}#FAM-timeout-bar{background:#CCC;position:absolute;left:0;bottom:0;width:5px;z-index:-1}.FAM-chat{color:#333;position:relative;padding:12px;height:80px;cursor:pointer}.FAM-chat:hover{background-color:#EEE}.FAM-chat-icon{position:absolute;left:1px;bottom:0;z-index:1}.FAM-chat-icon .fa-circle{color:#999}.FAM-chat-icon.FAM-new-post .fa-circle{color:#39F}.FAM-chat-avatar{position:absolute;left:10px;top:50%;margin-top:-20px;height:40px;width:40px;overflow:hidden}.FAM-chat-avatar img{height:100%;width:100%}.FAM-chat-date,.FAM-chat-title{position:absolute;left:0;width:100%;padding:0 12px 0 60px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.FAM-chat-title{font-size:14px;font-weight:700;top:20px}.FAM-chat-date{bottom:20px}.FAM-pagination:empty{display:none}#FAM a.FAM-page-link,.FAM-page-link{color:#FFF;font-size:18px;font-weight:700;text-decoration:none;background:#39F;display:inline-block;height:25px;line-height:26px;padding:0 8px;margin:3px 1px}#FAM a.FAM-page-link:hover{background:#28E}#FAM a.FAM-page-link:active{background:#17D}b.FAM-page-link,strong.FAM-page-link{background:#999}.FAM-msg{position:relative;padding:12px}.FAM-msg:after{display:table}.FAM-msg-avatar{border:2px solid #CCC;width:48px;height:48px;padding:2px;margin-top:16px;border-radius:100%;overflow:hidden;float:left}.FAM-msg-online .FAM-msg-avatar{border-color:#39F}.FAM-msg-avatar img{height:100%;width:100%;border-radius:100%}.FAM-my-msg .FAM-msg-avatar{margin-top:-4px;float:right}.FAM-msg-box{float:right;width:80%;width:calc(100% - 48px);padding-left:15px}.FAM-my-msg .FAM-msg-box{float:left;padding:0 15px 0 0}.FAM-msg-content{color:#000;background:#DDD;border-radius:4px;padding:8px 12px;margin:3px 0;min-height:36px;max-width:80%;position:relative;float:left}.FAM-msg-editing .FAM-msg-content{width:100%}.FAM-msg-content:before{height:0;width:0;border-top:5px solid transparent;border-bottom:5px solid transparent;border-right:10px solid #DDD;position:absolute;top:13px;left:-10px}.FAM-my-msg .FAM-msg-content{color:#FFF;background:#07C;float:right}.FAM-my-msg .FAM-msg-content:before{border-right:none;border-left:10px solid #07C;top:12px;left:auto;right:-10px}.FAM-msg-text{font-size:14px;line-height:20px;white-space:pre-wrap;word-wrap:break-word}.FAM-msg-text .fa-circle-o-notch{font-size:20px}#FAM .FAM-msg-text a{color:inherit!important;text-decoration:underline;cursor:pointer}#FAM .FAM-msg-text a:hover{text-decoration:none}.FAM-msg-text *{max-width:100%}.FAM-msg-text img{max-height:200px}.FAM-msg-date,.FAM-msg-name{font-size:12px;width:100%;height:20px;line-height:20px;padding:0 3px;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.FAM-name-mention{cursor:pointer}.FAM-my-msg .FAM-msg-name{display:none}.FAM-my-msg .FAM-msg-date{text-align:right}.FAM-msg-error .FAM-msg-content{background:#F33}.FAM-msg-error .FAM-msg-content:before{border-left-color:#F33}.FAM-msg-text .FAM-attachment,.FAM-msg-text .FAM-attachment *{display:block}.FAM-msg-text .FAM-attachment tbody{line-height:0;column-count:2;column-gap:5px}.FAM-msg-text .FAM-attachment tr{background:#FFF;width:100%;max-height:200px;padding:3px;margin-bottom:5px;border-radius:4px;overflow:hidden;-webkit-column-break-inside:avoid;page-break-inside:avoid;break-inside:avoid}.FAM-msg-text .FAM-attachment tr:only-child{column-span:all;margin:0}.FAM-msg-text .FAM-attachment td{color:#333;font-size:18px;min-height:20px;line-height:20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.FAM-msg-text .FAM-attachment td *{width:100%;object-fit:cover}.FAM-msg-text .FAM-attachment td,.FAM-msg-text .FAM-attachment td *{border-radius:4px;max-height:194px}#FAM .FAM-msg-actions{background:inherit;border-radius:4px;position:absolute;left:0;bottom:0;height:25px;white-space:nowrap;visibility:hidden;opacity:0;transition:300ms}#FAM .FAM-msg:hover .FAM-msg-actions{visibility:visible;opacity:1;bottom:-20px}#FAM .FAM-my-msg .FAM-msg-actions{left:auto;right:0}.FAM-msg-button{font-size:16px;padding:0 6px;cursor:pointer}.FAM-msg-button:hover{opacity:.7}.FAM-msg-button i{line-height:25px}#FAM-tab-add i,.FAM-tab{line-height:30px}.FAM-msg-text .FAM-attachment td:after{position:absolute;top:0;left:0;right:0;bottom:0;cursor:pointer}#FAM [onclick="FAM.modal.open(this);"]{cursor:pointer}.FAM-msg-text .FAM-attachment td a{overflow:hidden;text-overflow:ellipsis}.FAM-msg-text ol,.FAM-msg-text ul{padding-left:30px;margin:12px 0}.FAM-msg-text ol>br:first-child,.FAM-msg-text ul>br:first-child{display:none}.FAM-codebox,.FAM-spoiler{color:#333;background:#FFF;border:1px solid #CCC;border-radius:4px;padding:0;margin:12px 0;overflow:hidden}.FAM-codebox cite a,.FAM-codebox dt a{color:#333!important}.FAM-codebox cite,.FAM-codebox dt,.FAM-spoiler dt{color:#333;font-size:14px;font-weight:700;background:#CCC;padding:3px;margin:0;cursor:auto!important}#FAM-tab-add,.FAM-tab{height:30px;cursor:pointer}.FAM-codebox dd,.FAM-spoiler dd{padding:3px;margin:0}.FAM-codebox code{display:block;max-height:150px;max-width:none;padding:3px;margin:-3px;overflow:auto}#FAM-new-msg-divider,#FAM-tabs{white-space:nowrap;overflow:hidden}blockquote.FAM-codebox{padding:3px}blockquote.FAM-codebox cite{margin:-3px -3px 0;max-width:none}blockquote.FAM-codebox>div{margin:0}.FAM-hidecode>dt:after{content:"Hidden:"}.FAM-codebox:before{content:""}.FAM-attachbox>dt:before,.FAM-codebox cite:before,.FAM-codebox>dt:before,.FAM-spoiler dt:before{content:"\\f086";font-family:FontAwesome;margin-right:3px}.FAM-codebox cite:before{content:"\\f10d"}.FAM-codebox>dt:before{content:"\\f121"}.FAM-spoiler>dt:before{content:"\\f071"}.FAM-hidecode>dt:before{content:"\\f070"}.FAM-attachbox>dt:before{content:"\\f0c6"}.FAM-spoiler_content{position:relative;display:inline-block}.FAM-spoiler_content:after{content:"";background:#000;position:absolute;top:0;left:0;right:0;bottom:0;visibility:visible}.FAM-spoiler_content:hover:after{visibility:hidden}.FAM-msg-text .FAM-post-content,.FAM-msg-text font[color]{color:inherit}#fc-token.FAM-inputbox{width:308px}.FAM-captcha p:first-child b,.FAM-captcha p:first-child strong{font-size:24px;display:inline-block;margin-bottom:6px}#FAM-new-msg-notif{color:#FFF;font-size:14px;font-weight:700;text-align:center;background:#39F;position:absolute;height:30px;line-height:30px;left:0;right:0;z-index:1;opacity:.8;cursor:pointer}#FAM-new-msg-notif:after{content:"\\f00d";font-size:18px;font-weight:400;font-family:FontAwesome;position:absolute;right:6px}#FAM-new-msg-notif:hover{opacity:1}#FAM-new-msg-notif+#FAM-content{padding-top:30px}#FAM-new-msg-divider{color:#39F;font-size:18px;text-align:center;margin:12px}#FAM-new-msg-divider:after,#FAM-new-msg-divider:before{content:"";background:#39F;display:inline-block;width:25%;height:2px;position:relative;top:-4px}#FAM-new-msg-divider:before{margin-right:12px}#FAM-new-msg-divider:after{margin-left:12px}#FAM-tab-container{height:30px;position:relative;border-bottom:1px solid #DDD}#FAM-tab-add{font-size:18px;text-align:center;border-left:1px solid #DDD;position:absolute;right:0;top:0;width:30px}#FAM-tab-add:hover{color:#39F}#FAM-tabs{width:80%;width:calc(100% - 30px)}#FAM-tabs:hover{overflow-x:auto;position:relative;z-index:2}#FAM-menu-avatar,#FAM-profile-avatar,.FAM-tab-name{display:inline-block;overflow:hidden}.FAM-tab{background:#EEE;border:1px solid #DDD;border-left:none;border-top:none;position:relative;display:inline-block;width:120px}.FAM-tab:hover{background:#FFF}.FAM-tab.FAM-tab-active{font-weight:700;background:#FFF;cursor:default}.FAM-tab.FAM-tab-active:after{content:"";background:#39F;position:absolute;left:0;right:0;bottom:-1px;height:4px}.FAM-tab-name{font-size:12px;padding:0 3px;width:80%;width:calc(100% - 16px);white-space:nowrap;text-overflow:ellipsis}.FAM-tab-close{font-size:16px;position:absolute;top:50%;margin-top:-8px!important;right:3px;cursor:pointer}.FAM-tab-close:hover{color:#F33}#FAM-profile-username{font-size:18px;font-weight:700}#FAM-profile-rank{font-weight:700}#FAM-profile-avatar{width:108px;height:108px;padding:2px;border:2px solid #DDD;border-radius:100px}#FAM-menu-avatar{height:30px;width:30px;border-radius:30px}#FAM-menu-avatar img,#FAM-profile-avatar img{width:100%;height:100%;border-radius:100%}#FAM #FAM-service-title a{color:#333;font-weight:400}#FAM-service-title b,#FAM-service-title i{color:#39C}#FAM-service-title b:last-child,#FAM-version-status-icon .fa-check-circle{color:#39F}#FAM-version-card{border:1px solid #DDD;border-radius:4px;text-align:left;width:80%;margin:30px auto 12px;white-space:nowrap;overflow-x:auto;position:relative}#FAM-version-status-icon{text-align:center;position:absolute;width:50px;left:0;top:50%;margin-top:-18px}#FAM-version-status-icon i{font-size:36px}#FAM-version-status-icon .fa-exclamation-circle{color:#F93}#FAM-version-info{width:100%;padding-left:50px}#FAM-version-info>div{margin:10px 0}#FAM-version-status{font-weight:700}#FAM-creator-info{text-align:center;margin-top:30px}#FAM-creator-info i{font-size:18px;vertical-align:middle}#FAM #FAM-search-keywords{font-size:18px;height:40px;padding:0 8px}#FAM-search-results{border:1px solid #DDD;max-height:300px;overflow:auto}#FAM-search-results .FAM-chat-avatar,.FAM-viewing-search .FAM-chat-avatar{display:none}#FAM-search-results .FAM-chat-icon,.FAM-viewing-search .FAM-chat-icon{left:10px;top:50%;margin-top:-17px}#FAM-modal-content,#FAM-modal-overlay{position:fixed;z-index:999999;top:0;left:0;right:0;bottom:0}#FAM-modal-overlay{background:rgba(0,0,0,.8)}#FAM-media-viewer,#FAM-modal-content,.FAM-modal-arrows{display:flex;justify-content:center;align-items:center;text-align:center}#FAM-media-viewer{background:#FFF;border-radius:8px;position:relative;min-width:100px;min-height:100px;max-width:100%;max-width:calc(100% - 96px);max-height:100%;max-height:calc(100% - 96px);padding:16px}#FAM-media-list{width:100%;max-height:100vh;max-height:calc(100vh - 96px);overflow:hidden}#FAM-media-list>iframe,#FAM-media-list>img{max-width:100%;max-height:100vh;max-height:calc(100vh - 96px)}#FAM-media-list>a{font-size:24px;max-width:90%;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.FAM-modal-controls{color:#999;position:absolute;cursor:pointer;opacity:1}.FAM-modal-controls:hover{color:#FFF}.FAM-modal-arrows{top:0;bottom:0;width:41px}#FAM-modal-prev{left:-25px;justify-content:flex-start}#FAM-modal-next{right:-25px;justify-content:flex-end}#FAM-modal-close{top:0;right:-25px;z-index:1}#FAM-view-media{top:30px;right:-26px;z-index:1}</style>');

        // add Forumactif Messenger to the document
        if (FAM.config.embed) {
          if (embed) {
            embed.appendChild(frag);
           
          } else {
            return;
          }
         
        } else {
          document.body.appendChild(frag);
        }
       

        // apply cached settings
        FAM.page.settings.apply();

        // embedded initialization
        if (FAM.config.embed) {
          !FAM.history.restore() && FAM.tab.initial();

          // reset fullscreen setting when embedded
          if (window.JSON && window.localStorage && localStorage.fam_settings) {
            var settings = JSON.parse(localStorage.fam_settings);
            settings.fam_fullscreen = '';
            localStorage.fam_settings = JSON.stringify(settings);
          }
        }

        // close drop downs that are left open
        $(document).on('mousedown', function (e) {
          // drop down should be the first element in the arrays, other elements are those that should be excluded
          var close = [
            [FAM.cache.toolbar.querySelector('#FAM-menu'), FAM.cache.toolbar.querySelector('#FAM-menu-toggle')],
            [FAM.cache.actions.querySelector('#FAM-emoji-list'), FAM.cache.actions.querySelector('#FAM-emoji')],
            [FAM.cache.actions.querySelector('#FAM-attach-options'), FAM.cache.actions.querySelector('#FAM-attachment')]
          ], i = 0, j = close.length, a;

          for (; i < j; i++) {
            if (close[i][0] && close[i][0].style.visibility != 'hidden') {
              a = $(close[i]);

              if (!a.is(e.target) && !a.has(e.target)[0]) {
                close[i][0].style.visibility = 'hidden';
              }
            }
          }
        });

        delete FAM.init; // delete this function as to not initialize FAM again
      };


      try {
        // wait for the doc to be interactive / complete
        function ready () {
          if (!initialized && /interactive|complete/.test(document.readyState)) {
            build();
            initialized = true;
          }
        };

        ready();

        if (!initialized) {
          document.addEventListener('readystatechange', ready);
        }

      } catch (error) {
        $(build); // jQuery fallback
      }
    },

    version : 'v1.0.3'
  };

  FAM.init(); // setup FAM
}());
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.
  • 0

Résolu Re: problème messenger forumactif

Message par Oka.mi Sam 03 Sep 2022, 22:22

Re,

Alors pour votre cas, nous allons plutôt modifier le template. Smile
Ligne 113, vous avez ceci
Code:
<tr class="post">
Remplacez-le par
Code:
<tr class="post post--{postrow.displayed.U_POST_ID}" id="p{postrow.displayed.U_POST_ID}" style="{postrow.displayed.DISPLAYABLE_STATE}">
En effet, c'est le tr qui contient chaque post, et chaque post a une identité (un numéro) déterminée par la variable. Si vous la retirez, le script, qui se base sur ces ID pour récupérer les posts, ne sait plus lesquels chercher. Il le fait par exemple ici :
Code:
$('.post' + (FAM.fVersion == 6 ? '-wrap' : '') + '[class*="post--"]', data)
Puisqu'il n'y a plus de class "post--..." quand vous retirez la variable, il ne trouve plus les messages.

Donc corrigez simplement le template et cela devrait fonctionner.

N'oubliez pas, une fois la modification faite :
problème messenger forumactif 2705 de publier votre template
problème messenger forumactif 2705 de vider votre cache


problème messenger forumactif 1213Donnez un titre explicite problème messenger forumactif VTzsyWB à votre sujet pour améliorer son référencement

Remerciez problème messenger forumactif 976083691 le message qui vous a aidé pour le mettre en évidence

Cochez résolu lorsque votre problème est résolu pour faciliter le travail des modérateurs

L'aide par MP problème messenger forumactif FsAeGeb n'est pas autorisée pour que celle-ci puisse bénéficier au plus grand nombre
Oka.mi

Oka.mi
Aidactive
Aidactive

Messages : 2777
Inscrit(e) le : 06/01/2011

https://deus-academia.forumactif.com/
Oka.mi a été remercié(e) par l'auteur de ce sujet.

Résolu Re: problème messenger forumactif

Message par panic station Dim 04 Sep 2022, 08:58

OH c'est super vraiment merci.
Bon dimanche Hi
panic station

panic station
Nouveau membre

Féminin
Messages : 12
Inscrit(e) le : 20/08/2022

https://basique.forumactif.com/
panic station a été remercié(e) par l'auteur de ce sujet.

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

- Sujets similaires

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