Go Back   vb.org Archive > vBulletin Modifications > Archive > vB.org Archives > vBulletin 2.x > vBulletin 2.x Full Releases

Closed Thread
 
Thread Tools
vB3 Similar Threads Details »»
vB3 Similar Threads
Version: 1.00, by Velocd Velocd is offline
Developer Last Online: Nov 2023 Show Printable Version Email this Page

Version: 2.2.x Rating:
Released: 08-16-2002 Last Update: Never Installs: 53
 
No support by the author.

vB3 Similar Threads for 2.2.x
Clone version | by Velocd

This hack, as well all my other vB2 hacks, I no longer provide support for (being I run vB3 and it's too much hassel to debug vB2). When vB3 Release Candidate comes out, by request I might convert some of my hacks.

Install time: 6 minutes
File edits: 1 (showthread.php)
Template edits: 1 (showthread)
New templates: 2 (showthread_similarthreads, showthread_similarthreadbits)




What is it?
Basically this hack will check for other similar thread titles within the forum of the thread you are viewing, then it will display the most similar threads, based on a similar-priority setting you choose, at the bottom of that thread.

Why did I make it?
This hack instantly drew my attention when I first saw it at the Jupiter vB3 forums. I figured it couldn't be that bad to make, and why wait when it's such a simple feature to integrate as a standalone hack? So, I opened up my TextPad and started coding.

Personally, I HIGHLY doubt the method and coding I used in my hack is at all similar to the one at Jupiter vB3, but it seems to work just as fine. Even on my small forum the results on some threads look good, while for a large forum such as vB.org the results would look 3x as better.

Features:
  • Displays everything that the vB3 similar threads does.
  • Also gives a description of the thread, only if you have the thread-description hack installed. (source: here)

Bugs?
Depending on the priority level you pick, some threads that you are "dead sure" to have a similar result might not show. You might have to toggle the priority level at first, to get it set just right. Other than this, it's fairly clean.
See a demo at this thread, scroll to bottom:
http://beta.vbulletin.com/vb3/showth...p?threadid=990

Screenshots? Demo's?
See the next post for a screenshot. Want a demo? Visit the similar thread feature at the Jupiter vB3 forums


------------- Installation -------------

#1. In showthread.php, find:
PHP Code:
if ($noshutdownfunc) {
  
$DB_site->query("UPDATE thread SET views=views+1 WHERE threadid='$threadid'");
} else {
  
$shutdownqueries[]="UPDATE LOW_PRIORITY thread SET views=views+1 WHERE threadid='$threadid'";
}

if (
$bbuserinfo[cookieuser]) {
  
vbsetcookie("bbthreadview[$threadid]",time(),0);

Above it place:
PHP Code:
//////////////////////////////////////////////////
// vBulletin3 Similar Threads "clone" by Velocd //
//////////////////////////////////////////////////

//////////////////////////// CONFIGURE ////////////////////////////////
$description_option 0//1 = on, 0 = off. (use only if you have THREAD descriptions installed)
if($description_option){ $desc ",description"; }
$limit 4//Set the limit to the maximum amount of results to display
$priority 60//KEY: [less accurate, more results <0 --- 25 ---- 50 ---- 75 --- 100> more accurate, less results]
$previewcharacters 150//Amount of characters shown in the preview
///////////////////////////////////////////////////////////////////////

$rthreads=$DB_site->query("SELECT threadid,title,postusername,replycount,lastpost,postuserid,dateline$desc
            FROM thread
            WHERE forumid='
$thread[forumid]'
            ORDER BY dateline"
);

$validtitle trim(strtolower($thread[title])," \t.");
$count 0;

while (
$rthread $DB_site->fetch_array($rthreads)) {
    
$validthread trim(strtolower($rthread[title])," \t.");

    
similar_text($validtitle$validthread, &$similarity);

    if(
$similarity $priority){
        
$similar[title] = $rthread[title];
        
$similar[threadid] = $rthread[threadid];
        
$similar[postusername] = $rthread[postusername];
        
$similar[postuserid] = $rthread[postuserid];
        
$similar[replycount] = $rthread[replycount];
        
$similar[date] = vbdate($dateformat,$rthread[lastpost]);
        
$similar[description] = $rthread[description];


        if (
strlen($similar[description]) > 150) {
            
$similar[description] = substr($similar[description], 0$previewcharacters) . "..."; } else {
            
$similar[description] = $similar[description];
        }

        if(
$similar[threadid] != $thread[threadid] && $count $limit){
        
$count++;
        eval(
"\$similarthreadbits .= \"".gettemplate("showthread_similarthreadbits")."\";"); } 
    }
}

if(
$count != 0){
eval(
"\$similarthreads .= \"".gettemplate("showthread_similarthreads")."\";"); }

////////////////////////////
// End Similar Threads /////
//////////////////////////// 
Now look at this block of code from above:
PHP Code:
//////////////////////////// CONFIGURE ////////////////////////////////
$description_option 0//1 = on, 0 = off. (use only if you have THREAD descriptions installed)
if($description_option){ $desc ",description"; }
$limit 4//Set the limit to the maximum amount of results to display
$priority 60//KEY: [less accurate, more results <0 --- 25 ---- 50 ---- 75 --- 100> more accurate, less results]
$previewcharacters 150//Amount of characters shown in the preview
/////////////////////////////////////////////////////////////////////// 
As detailed, those variables change how this hack works. The main thing you need to notice is $priority, which at default is set at 60, which I've found on my forums to be good. As said in the KEY in comments, a higher priority will get you more accurate similar threads, but less results. Ofcourse, a high priority is ideal for a large forum. Lower priority vice versa.


#2. Create a new template called
showthread_similarthreads
, and place inside:
Code:
<table cellpadding="{_tableouterborderwidth}" cellspacing="0" border="0" bgcolor="{_tablebordercolor}" {_tableouterextra} width="{_contenttablewidth}" align="center">
<tr><td>
<table cellpadding="4" cellspacing="{_tableinnerborderwidth}" border="0" {_tableinnerextra} width="100%">
<tr>
	<td bgcolor="{_tableheadbgcolor}" width="{_tablewidth}" colspan="4" align="center">
<normalfont color="{_tableheadtextcolor}">
<b>Similar Threads</b></normalfont></td>
</tr>
<tr align="center" bgcolor="{_categorybackcolor}" background="https://vborg.vbsupport.ru/images/catagory_backing.gif">
	<td align="center" nowrap><span><smallfont><b>Thread</b></smallfont></span></td>
	<td nowrap><span><b><smallfont>Thread Starter</smallfont></b></span></td>
	<td nowrap><span><smallfont><b>Replies</b></smallfont></span></td>
	<td nowrap><span><smallfont><b>Last Post</b></smallfont></span></td>
</tr>
$similarthreadbits
</table>
</td></tr></table>
<br>
In the code above, take out all the underscores (ie. _) out of the replacement variables, such as {_tablewidth}, or else they will not work.

#3. Create a new template called showthread_similarthreadbits, and place inside:
Code:
<tr align="center">	
<td width="60%" align="left" bgcolor="{_firstaltcolor}"><normalfont>
<a href="showthread.php?s=$session[sessionhash]&forumid=$thread[forumid]&threadid=$similar[threadid]" 
title="$similar[description]">$similar[title]
</a></normalfont></td>
	<td width="20%" bgcolor="{_secondaltcolor}" nowrap="nowrap"><normalfont>
<a href="member.php?s=$session[sessionhash]&action=getinfo&userid=$similar[postuserid]">$similar[postusername]
</a></normalfont></td>
	<td bgcolor="{_firstaltcolor}"><normalfont>$similar[replycount]</normalfont></td>
	<td bgcolor="{_secondaltcolor}" width="20%"><normalfont>$similar[date]</normalfont>
</td>
</tr>
In the code above, take out all the underscores (ie. _) out of the replacement variables, such as {_secondaltcolor}, or else the colors wont show.

#4. In the template showthread, find:
Code:
<!-- thread options links -->
<table cellpadding="0" cellspacing="0" border="0" bgcolor="#0A293E"   align="center"><tr><td>
On the line above it place:
Code:
$similarthreads

------------- End -------------

That's it! Pretty easy and quick to install, which is the nicest part about it.

If you use this hack remember, please click install! Without it, you might have had to wait till vB3

Show Your Support

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

Comments
  #22  
Old 08-17-2002, 02:22 PM
Kars10's Avatar
Kars10 Kars10 is offline
 
Join Date: Jun 2002
Location: Germany/Franken
Posts: 748
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Thanx VeloCD!!
This Feature rules. install was very easy on 2.2.5, and works like a charm
/me klicks installed!!
  #23  
Old 08-17-2002, 02:32 PM
xug xug is offline
 
Join Date: Oct 2001
Location: The Grand Strand, SC
Posts: 339
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I have this hack installed and have seen it workings only once, I did refresh my browser and looked at another thread and this new hacks doesn't show up anymore.

Very strange.

Please does somebody knows what happen or what I did wrong?
  #24  
Old 08-17-2002, 03:06 PM
kenny@ecn kenny@ecn is offline
 
Join Date: Apr 2002
Posts: 75
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Alright, I screwed up big time somewhere along the lines when I installed this... When I try to view a thread now- its shows this:

<see next post>

Yeah, I don't know what to do... Where did I go wrong? How can I fix this? Can someone help me!?!?

Thanks...

-Kenny
  #25  
Old 08-17-2002, 03:09 PM
kenny@ecn kenny@ecn is offline
 
Join Date: Apr 2002
Posts: 75
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

hmmmm... Now I get:


Quote:
Parse error: parse error in /home/virtual/site57/fst/var/www/html/showthread.php on line 96
  #26  
Old 08-17-2002, 03:09 PM
kenny@ecn kenny@ecn is offline
 
Join Date: Apr 2002
Posts: 75
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Here is my showthread.php BTW:

<Do not post entire files. -Mike>
  #27  
Old 08-17-2002, 03:47 PM
kenny@ecn kenny@ecn is offline
 
Join Date: Apr 2002
Posts: 75
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Now I get :

Quote:
Fatal error: Call to a member function on a non-object in /home/virtual/site57/fst/var/www/html/showthread.php on line 91
  #28  
Old 08-17-2002, 03:52 PM
Gamingforce's Avatar
Gamingforce Gamingforce is offline
 
Join Date: Oct 2001
Location: New York City
Posts: 128
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Good to see you releasing more hacks Velocd . I won't release this mainly because of the performance hit it generates on our board of a bit more than 850k posts. Great job! I never knew there even was a similar_text(); function LOL.
  #29  
Old 08-17-2002, 05:21 PM
Velocd's Avatar
Velocd Velocd is offline
 
Join Date: Mar 2002
Location: CA University
Posts: 1,696
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally posted by xware
Good hack.
But a problem is this hack use a whole thread table sql ....slowly.
I have 10000+ threads in thread table.
Before installed this hack ,my showthread page generated in 0.06433198 seconds ,after installed it this same Page generated in 1.26433198 seconds .
Would there be a better way to do this?
Quote:
Originally posted by Gamingforce
Good to see you releasing more hacks Velocd . I won't release this mainly because of the performance hit it generates on our board of a bit more than 850k posts. Great job! I never knew there even was a similar_text(); function LOL.
Yea, I know the only problem is the performance issue for larger forums. Since this hack does check all threads within that particular forum. I'm going to look into the hack, to possible see if there is a fix for this. I wonder what vB3 does

Quote:
Originally posted by xiphoid
Please put the code etc in a .txt file, so unlicenced members can't view it?
Unlicensed members can't even view the "full releases" forum anyway, so it shouldn't matter too much. I usually only put things in text files if the hack is very long.

Quote:
Originally posted by xug
I have this hack installed and have seen it workings only once, I did refresh my browser and looked at another thread and this new hacks doesn't show up anymore.

Very strange.

Please does somebody knows what happen or what I did wrong?
Depending if you have a small forum or not will determine how many results you get from similar threads. Ofcourse if you set the priority level to very low, like 20, more results will show, although they might not be all that related to the thread.

I'm not too sure what you mean by refreshing and the hack disappearing...maybe you accidentally set the priority level to very high.


Quote:
Originally posted by kenny@ecn
hmmmm... Now I get:
Quote:
Fatal error: Call to a member function on a non-object in /home/virtual/site57/fst/var/www/html/showthread.php on line 91
Uninstall the hack, and reinstall it again carefully. I'm not sure what your error is because I'm sure our files are different. If you are getting a parse error, you may have not copied my code exactly, or may have modified it and dropped something out.

  #30  
Old 08-17-2002, 05:46 PM
kenny@ecn kenny@ecn is offline
 
Join Date: Apr 2002
Posts: 75
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:

Uninstall the hack, and reinstall it again carefully. I'm not sure what your error is because I'm sure our files are different. If you are getting a parse error, you may have not copied my code exactly, or may have modified it and dropped something out.



I did do this, and I still have no idea... help me!!! Any ideas?
  #31  
Old 08-17-2002, 06:25 PM
kenny@ecn kenny@ecn is offline
 
Join Date: Apr 2002
Posts: 75
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Alright, found a backup showthread.php... Starting ALL over again (Will keep you updated about whether it works or not...)
Closed Thread

Thread Tools

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 10:38 PM.


Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2024, vBulletin Solutions Inc.
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.05270 seconds
  • Memory Usage 2,352KB
  • 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
  • (3)bbcode_php
  • (9)bbcode_quote
  • (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
  • (4)pagenav_pagelink
  • (11)post_thanks_box
  • (11)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (11)post_thanks_postbit_info
  • (10)postbit
  • (11)postbit_onlinestatus
  • (11)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_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