View Full Version : 0-9 Link?
Chadi
04-24-2009, 11:37 PM
Hi folks. Need some little help here.
I have this mod I released that shows an ABC link nav menu for any specific forum the code is placed into.
https://vborg.vbsupport.ru/showthread.php?t=211939
The letters are linked like this:
<a rel="nofollow" href="http://www.yourdomain.com/forumdisplay.php?f=2&letter=a">A</a>
However, I'd like to add another link for numbers, but one link for any number: 0-9 and the link would be "#" not "0-9". Clicking the link would show all threads that begin with any number.
How can I achieve this?
Thanks.
Dead Eddie
04-25-2009, 12:40 AM
I don't remember the code for that one, but at some point it hooked into a query with code like :
where $something = $letter
You'll need to do a conditional. If $letter == '#', your query is going to look like:
where $something BETWEEN 0 AND 9
I'm rebuilding my computer at the moment, so I didn't look at the mod. If you need more help, I'll reinstall that and take a second look. Also, I didn't test it, but in theory it should work. :)
Chadi
04-25-2009, 01:27 AM
Thanks Eddie, but I don't know anything about programming past the assistance I was given. If you can figure it out, great thanks.
Dead Eddie
04-25-2009, 02:50 AM
Untested...so try it on a test install first:
if(isset($_GET['letter'])) {
$vbulletin->input->clean_GPC('r', 'letter', 'TYPE_STR);
$letter = $db->escape_string($vbulletin->GPC['letter']);
if($letter == '#') {
$hook = " AND LEFT(thread.title, 1) BETWEEN 0 AND 9";
}
else {
$hook = " AND LEFT(thread.title, 1) = '$letter'";
}
$hook_query_where .= $hook;
}
Also, change the hook location in the file you've released to forumdisplay_query_threadid. That might solve some people's problems.
Chadi
04-25-2009, 03:54 PM
Thanks, but what am I supposed to do with that code? Where does it go in the plugin file?
Dead Eddie
04-25-2009, 05:25 PM
That's the updated code. It replaces what's in the plugin.
Also, I looked at the vbseo version, and it doesn't look like it was changed (except that it uses the correct hook). So, I'm wondering if there's either a change that didn't get picked up with the plugin, or if there really needs to be two different files.
Chadi
04-27-2009, 03:30 AM
Thanks Ed. Still confused though.
The plugin now is this:
<?xml version="1.0" encoding="ISO-8859-1"?>
<product productid="asp_thread_listing" active="1">
<title>Thread Listing by Letter</title>
<description>Listing of threads by the first letter of the title</description>
<version>.1</version>
<url />
<versioncheckurl />
<dependencies>
</dependencies>
<codes>
</codes>
<templates>
</templates>
<plugins>
<plugin active="1" executionorder="5">
<title>Add Where Letter</title>
<hookname>forumdisplay_query</hookname>
<phpcode><![CDATA[if(isset($_GET['letter'])){
$vbulletin->input->clean_GPC('r', 'letter', TYPE_STR);
$letter = $db->escape_string($vbulletin->GPC['letter']);
$hook_query_where .= " AND LEFT(thread.title, 1) = '$letter'";
}]]></phpcode>
</plugin>
</plugins>
<phrases>
</phrases>
<options>
</options>
<helptopics>
</helptopics>
<cronentries>
</cronentries>
<faqentries>
</faqentries>
</product>
With your changes, is it supposed to look like this?
<?xml version="1.0" encoding="ISO-8859-1"?>
<product productid="asp_thread_listing" active="1">
<title>Thread Listing by Letter</title>
<description>Listing of threads by the first letter of the title</description>
<version>.1</version>
<url />
<versioncheckurl />
<dependencies>
</dependencies>
<codes>
</codes>
<templates>
</templates>
<plugins>
<plugin active="1" executionorder="5">
<title>Add Where Letter</title>
<hookname>forumdisplay_query</hookname>
<phpcode><![CDATA[if(isset($_GET['letter'])) {
$vbulletin->input->clean_GPC('r', 'letter', 'TYPE_STR);
$letter = $db->escape_string($vbulletin->GPC['letter']);
if($letter == '#') {
$hook = " AND LEFT(thread.title, 1) BETWEEN 0 AND 9";
}
else {
$hook = " AND LEFT(thread.title, 1) = '$letter'";
}
$hook_query_where .= $hook;
}]]></phpcode>
</plugin>
</plugins>
<phrases>
</phrases>
<options>
</options>
<helptopics>
</helptopics>
<cronentries>
</cronentries>
<faqentries>
</faqentries>
</product>
I'll look into the vbseo thing again.
--------------- Added 1240808021 at 1240808021 ---------------
Just wanted to give you a heads up. Tested your code on a fresh install, non-vbseo. It always displayed all threads regardless of the letter clicked.
Dismounted
04-27-2009, 05:57 AM
This line is incorrect (PHP Tags "fix" it):
$vbulletin->input->clean_GPC('r', 'letter', 'TYPE_STR);
Change it to:
$vbulletin->input->clean_GPC('r', 'letter', TYPE_STR);
Also, you should be using the Admin CP to generate the XML - it will remove any structural errors.
Dead Eddie
04-27-2009, 11:20 AM
This line is incorrect:
$vbulletin->input->clean_GPC('r', 'letter', 'TYPE_STR);
Change it to:
$vbulletin->input->clean_GPC('r', 'letter', 'TYPE_STR');
Also, you should be using the Admin CP to generate the XML - it will remove any structural errors.
Hm, I thought those TYPE_* were constants.
Just wanted to give you a heads up. Tested your code on a fresh install, non-vbseo. It always displayed all threads regardless of the letter clicked.
You didn't make this change yet:
Also, change the hook location in the file you've released to forumdisplay_query_threadid. That might solve some people's problems.
If after making that change, you're still having problems, let me know. I should be able to install a test board today after work.
Chadi
04-27-2009, 11:30 AM
Thanks, that works now.
I have two issues now:
One, I'm trying to figure out the proper code replacement for "forum-path" so a person can copy/past this into forumdisplay template to use the mod globally, not per forum (as I currently have it linked directly to one specific forum).
Example:
http://www.talkjesus.com/scriptural-bible-answers/?letter=a"
That's the link for letter A.
What should be the vbseo replacement for the forum title/path which for me here is "scriptural-bible-answers"? My vbseo panel shows
[forum_title]
I tried that like this, it did not work.
Talk Jesus | Christian Forums & Chat - Powered by vBulletin (http://www.vbseo.com/redirect-to/?redirect=http%3A%2F%2Fwww.talkjesus.com%2F)[forum_title]/?letter=a"
I even added a $ before [forum and still does not work. Just redirects back to home page.
Second question is, I'd like to add a 0-9 # link as well, before the letter A table column.
Example:
Scriptural Bible Answers - Talk Jesus | Christian Forums & Chat (http://www.vbseo.com/redirect-to/?redirect=http%3A%2F%2Fwww.talkjesus.com%2Fscriptu ral-bible-answers%2F)
So I want a link like this:
"0-9"
The question is, how can I properly link it so it shows all threads in that forum that begin with any number? What would the link code look like for a singe link for "0-9" or better yet, just "#"?
Thanks!
--------------- Added 1240864909 at 1240864909 ---------------
Would appreciate if anyone can help me on this, thanks.
I'm trying to make the template versions to one version, vbseo or non-vbseo since vbseo changes it automatically.
Regarding 0-9 numbered threads listing:
I tried this, does not work, shows no threads but I do have one thread that begins with a letter, "144,000..."
<a rel="nofollow" href="http://www.talkjesus.com/scriptural-bible-answers/?letter=#">#</a>
Regarding the template code:
I'm using this in a test forum (fresh install) without vbseo
<table class="tborder" cellpadding="6" cellspacing="1" border="0" width="100%" align="center">
<td colspan="30" height="16" class="thead">
<strong>Search topics by first letter</strong><tr align="center">
<td class="alt1" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]">All</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=a">A</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=b">B</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=c">C</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=d">D</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=e">E</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=f">F</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=g">G</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=h">H</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=i">I</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=j">J</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=k">K</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=l">L</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=m">M</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=n">N</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=o">O</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=p">P</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=q">Q</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=r">R</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=s">S</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=t">T</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=u">U</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=v">V</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=y">Y</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=x">X</a></td>
<td class="alt2" width="3%">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=y">Y</a></td>
<td class="alt1" style="padding:5px;text-align:center">
<a rel="nofollow" href="http://www.talkjesus.com/test/forumdisplay.php?f=$foruminfo[forumid]&letter=Z">Z</a></td>
</tr>
</table>
<br />
I tried the same code above in my default install with vbseo enabled, does not work. Says invalid links.
Dismounted
04-28-2009, 07:14 AM
Hm, I thought those TYPE_* were constants.
It isn't that - they are constants. In the posted code, there was a single quote in front of it. I removed this in the second one, but the PHP highlighter seems to like to "fix" things, making it not shown.
Chadi
04-29-2009, 03:36 AM
I'd like to send an update on the mod so, please someone help me out.
Thanks :)
Chadi
05-01-2009, 12:02 PM
Would appreciate help on this please
vBulletin® v3.8.12 by vBS, Copyright ©2000-2025, vBulletin Solutions Inc.