Go Back   vb.org Archive > vBulletin Modifications > Archive > vB.org Archives > vBulletin 3.6 > vBulletin 3.6 Template Modifications
FAQ Community Calendar Today's Posts Search

Reply
 
Thread Tools
How to create a Ajax Sidebar with Recent Posts Details »»
How to create a Ajax Sidebar with Recent Posts
Version: 1.00, by Mauu Mauu is offline
Developer Last Online: Dec 2006 Show Printable Version Email this Page

Version: 3.6.0 Rating:
Released: 09-12-2006 Last Update: Never Installs: 21
Template Edits
Additional Files Is in Beta Stage  
No support by the author.

At YoungCoders, I recently wrote an ajax enabled recent posts widget, and I thought I would post it here. I do not recommended this for high traffic forums, as you'll be running a lot of queries.

I'm going to forget to check back here and update this with any changes. So, please see here, which is where I will maintain and try to provide support.

I) Setting up the Feed
1) First, you need the improved external.php file from vBulletin.org. The link is here: https://vborg.vbsupport.ru/showthrea...t=fps_external

2) This new external file lacks some of the documented features, and the feature we need is the latest posts (not latest threads). The attached file resolves that and may only be used if you have a valid vBulletin license. The reason we may not use the built-in one is because it does not have support for permissions and will therefore treat every user as a guest. Credit for fps_external.php goes to the original authors; my revision was trivial.

3) Upload fps_external.php into your forum directory.

II) Setting up the Ajax
1) Our threads are going to appear in an unordered list. So, let's setup our default list:
HTML Code:
  <ul id="latestthreads">
   <li>Please wait while the feed updates.</li>
  </ul>
We have to throw in the please wait to make our page validate and also to notify our users that we're fetching the feed.

2) You then need some JavaScript. I'm not going to document this as it's pretty self-explanatory:
Code:
/*
* Ajax sidebar for vBulletin.
* Depends: hacked fps_external.php
* Created for: www.youngcoders.com
*/


function createRequestObject() {
    var ro;
    var browser = navigator.appName;
    if(browser == "Microsoft Internet Explorer"){
        ro = new ActiveXObject("Microsoft.XMLHTTP");
    }else{
        ro = new XMLHttpRequest();
    }
    return ro;
}

var http = createRequestObject();

function updateSidebarResponse() {
    if(http.readyState == 4){
        var length = document.getElementById('latestthreads').getElementsByTagName('li').length;
        for (var y = 0; y < length; y++)
        { 
                document.getElementById('latestthreads').removeChild( document.getElementById('latestthreads').getElementsByTagName('li')[0] );
        }
        
        
        var response = http.responseXML.getElementsByTagName('source')[0].getElementsByTagName('thread');
        var length = response.length;
        for (var x = 0; x < length; x++)
        {
                var id = response[x].getAttribute('id');
                var title = response[x].getElementsByTagName('title')[0].childNodes[0].nodeValue;
                var author = response[x].getElementsByTagName('author')[0].childNodes[0].nodeValue;
                var when = response[x].getElementsByTagName('time')[0].childNodes[0].nodeValue;

                var top = document.createElement('div');
                var bottom = document.createElement('div');

                var option = document.createElement('li');
                var link = document.createElement('a');
                link.href = 'showthread.php?goto=newpost&t=' + id;
                link.appendChild(document.createTextNode(title));
                var by = document.createElement('small');
                by.appendChild(document.createTextNode(' by ' + author + ' at ' + when));

                option.appendChild(link);
                option.appendChild(by);

                document.getElementById('latestthreads').appendChild(option);
        }
    }
}

function updateSidebar() {
    http.open('get', 'fps_external.php?type=xml&qty=20&items=active');
    http.onreadystatechange = updateSidebarResponse;
    http.send(null);
}


updateSidebar();
The above code will fetch the sidebar just once. To make it update, you must have it run through intervals:
Code:
setInterval('updateSidebar()', 60000 * 1); // Update every minute
setInterval('updateSidebar()', 60000 * 3); // Update every 3 minutes
Terms of Use: For each site you deploy this on, you must tell one friend about YoungCoders.com

For a preview and more discussion: http://www.youngcoders.com/showthrea...288&styleid=19

Show Your Support

  • This modification may not be copied, reproduced or published elsewhere without author's permission.

Comments
  #2  
Old 09-13-2006, 01:02 AM
snowlion snowlion is offline
 
Join Date: Mar 2005
Location: STY
Posts: 183
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

sidebar doesn't use for 1024x768 resolution hehe j/k
thanks Mauu
------------------------
November Rain
Reply With Quote
  #3  
Old 09-13-2006, 02:52 PM
SilverSiR SilverSiR is offline
 
Join Date: Sep 2006
Posts: 3
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Thanks for the script, I have a small issue though because I can't modify the link to a directory. It points to www.domain.com, instead of www.domain.com/forum. I put all the files in the forum directory instead of the root to see if that solved it but it didn't.
Reply With Quote
  #4  
Old 09-13-2006, 03:01 PM
SilverSiR SilverSiR is offline
 
Join Date: Sep 2006
Posts: 3
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Actually it doesn't even matter because the

http://www.domain.com/forum/thread4->newpost link throw a 404.
Reply With Quote
  #5  
Old 09-13-2006, 07:38 PM
Mauu Mauu is offline
 
Join Date: Feb 2006
Posts: 19
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Sorry, I had forgotton that we had a special setup on our forum. Change:

Code:
link.href = 'thread' + id + '->newpost'
to

Code:
link.href = '/forum/showthread.php?goto=newpost&t=' + id;
Reply With Quote
  #6  
Old 09-14-2006, 01:15 AM
aveon's Avatar
aveon aveon is offline
 
Join Date: May 2006
Posts: 410
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

could you simplify this better, and then giving the code in which I need to implement into the template ?
Reply With Quote
  #7  
Old 09-14-2006, 10:51 PM
Mauu Mauu is offline
 
Join Date: Feb 2006
Posts: 19
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

It really can't get much simpler: upload patched fps_external, stick HTML in, stick JavaScript in, done. Granted, basic web-design knowledge is required.
Reply With Quote
  #8  
Old 09-14-2006, 10:55 PM
aveon's Avatar
aveon aveon is offline
 
Join Date: May 2006
Posts: 410
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

when i go to the website of you i saw this left bar you cam make it visible and invisible as well so i want to make it just like that if you can help me on it please
Reply With Quote
  #9  
Old 09-15-2006, 03:55 AM
Mauu Mauu is offline
 
Join Date: Feb 2006
Posts: 19
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Hi,
I designed that sidebar specially for our site. My modification here should be easy enough to drop into any sidebar solution; I'm not prepared to release our sidebar code because it still requires extensive testing and polishing.
Reply With Quote
  #10  
Old 09-15-2006, 10:52 AM
aveon's Avatar
aveon aveon is offline
 
Join Date: May 2006
Posts: 410
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

hmm what can i say then all the good mods are not releaseable
Reply With Quote
Reply


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT. The time now is 06:24 PM.


Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.04242 seconds
  • Memory Usage 2,295KB
  • Queries Executed 25 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)ad_showthread_beforeqr
  • (4)bbcode_code
  • (1)bbcode_html
  • (1)footer
  • (1)forumjump
  • (1)forumrules
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (1)modsystem_post
  • (1)navbar
  • (6)navbar_link
  • (120)option
  • (1)pagenav
  • (1)pagenav_curpage
  • (2)pagenav_pagelink
  • (10)post_thanks_box
  • (10)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (10)post_thanks_postbit_info
  • (9)postbit
  • (10)postbit_onlinestatus
  • (10)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open
  • (1)tagbit_wrapper 

Phrase Groups Available:
  • global
  • inlinemod
  • postbit
  • posting
  • reputationlevel
  • showthread
Included Files:
  • ./showthread.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showthread_start
  • showthread_getinfo
  • forumjump
  • showthread_post_start
  • showthread_query_postids
  • showthread_query
  • bbcode_fetch_tags
  • bbcode_create
  • showthread_postbit_create
  • postbit_factory
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • pagenav_page
  • pagenav_complete
  • tag_fetchbit_complete
  • forumrules
  • navbits
  • navbits_complete
  • showthread_complete