Go Back   vb.org Archive > vBulletin Article Depository > Read An Article > vBulletin 4 Articles
FAQ Community Calendar Today's Posts Search

Reply
 
Thread Tools
[HOW TO - vB4] Create your own vBulletin page
Lynne's Avatar
Lynne
Join Date: Sep 2004
Posts: 41,180

 

California/Idaho
Show Printable Version Email this Page Subscription
Lynne Lynne is offline 11-15-2009, 10:00 PM

This is an updated article on how to create your own vbulletin powered page. It's only for use with vB4.

This is NOT my work. I'm posting this from another thread where vB Style took the time to write this out. And his work is based on the article by Gary King here - How to create your own vBulletin-powered page! (uses vB templates)

Instructions to Create your Own Page:


1. Create the php page:
- Create a new file, whatever you want to call it (let's say test.php).
- Open up test.php and add the following (replace TEST with whatever template you want to show - WARNING: the template name is CASE SENSITIVE!!!):
Code:
<?php

// ####################### SET PHP ENVIRONMENT ###########################
error_reporting(E_ALL & ~E_NOTICE);

// #################### DEFINE IMPORTANT CONSTANTS #######################

define('THIS_SCRIPT', 'test');
define('CSRF_PROTECTION', true);  
// change this depending on your filename

// ################### PRE-CACHE TEMPLATES AND DATA ######################
// get special phrase groups
$phrasegroups = array();

// get special data templates from the datastore
$specialtemplates = array();

// pre-cache templates used by all actions
$globaltemplates = array('TEST',
);

// pre-cache templates used by specific actions
$actiontemplates = array();

// ######################### REQUIRE BACK-END ############################
// if your page is outside of your normal vb forums directory, you should change directories by uncommenting the next line
// chdir ('/path/to/your/forums');
require_once('./global.php');

// #######################################################################
// ######################## START MAIN SCRIPT ############################
// #######################################################################

$navbits = construct_navbits(array('' => 'Test Page'));
$navbar = render_navbar_template($navbits);

// ###### YOUR CUSTOM CODE GOES HERE #####
$pagetitle = 'My Page Title';

// ###### NOW YOUR TEMPLATE IS BEING RENDERED ######

$templater = vB_Template::create('TEST');
$templater->register_page_templates();
$templater->register('navbar', $navbar);
$templater->register('pagetitle', $pagetitle);
print_output($templater->render());

?>
- Be sure to change 'TEST' to the actual template name (WARNING: the template name is CASE SENSITIVE!!!), and change 'test' to the filename or a unique name for the page. Also, change 'Test Page' and 'My Page Title' to whatever you want to show in the navbits, such as 'Viewing Member Profile' (just an example).

2. Create the Template:
- If you are in debug mode, create the template in your MASTER STYLE so it shows up in all your styles, otherwise make sure you create the template in the style you are using. If following the page above, call the template TEST (WARNING: the template name is CASE SENSITIVE!!!) with the following content:
HTML Code:
{vb:stylevar htmldoctype}
<html xmlns="http://www.w3.org/1999/xhtml" dir="{vb:stylevar textdirection}" lang="{vb:stylevar languagecode}" id="vbulletin_html">
  <head>
    <title>{vb:raw vboptions.bbtitle} - {vb:raw pagetitle}</title>
    {vb:raw headinclude}
    {vb:raw headinclude_bottom}
  </head>
  <body>
    
    {vb:raw header}
    
    {vb:raw navbar}
    
    <div id="pagetitle">
      <h1>{vb:raw pagetitle}</h1>
    </div>
    
    <h2 class="blockhead">Title</h2>
    <div class="blockbody">
      <div class="blockrow">
        Text
      </div>
    </div>
    
    {vb:raw footer}
  </body>
</html>
.
Instructions to Add your Page to the Who's Online List (WOL):
Create two plugins using the following hooks. Replace mypage and similar with your information.

1. hook location - online_location_process:
Code:
switch ($filename)
{
    case 'test.php':
        $userinfo['activity'] = 'mypage';
        break;
// add more cases here if you have more than one custom page. no need for multiple plugins. one plugin can handle all.
}
.
2. hook location online_location_unknown:
Code:
switch ($userinfo['activity'])
{
    case 'mypage':
        $userinfo['where'] = '<a href="test.php?'.$vbulletin->session->vars[sessionurl].'">My Page</a>';
        $userinfo['action'] = "Viewing My Page";
        $handled = true;
        break;
// add more cases here if you have more than one custom page. no need for multiple plugins. one plugin can handle all.
}
.
The colored part in the code above shows what you need to change in the plugins (both reds should be the same and both blues should be the same, whereas green can be whatever you want).


Please see this article for help with rendering templates - [vB4] Rendering templates and registering variables - a short guide
Reply With Quote
  #832  
Old 06-01-2012, 09:14 PM
Dave-ahfb Dave-ahfb is offline
 
Join Date: Mar 2002
Posts: 117
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Works great, thanks!

This will help maintaining different ads per category
Reply With Quote
  #833  
Old 06-02-2012, 07:47 AM
cellarius's Avatar
cellarius cellarius is offline
 
Join Date: Aug 2005
Posts: 1,987
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by kh99 View Post
BTW, nice solution, cellarius. Maybe this should be added to the article.
Well, I'll return the applause After all, the idea came from you, and you've been the one refining it :up:
Reply With Quote
  #834  
Old 06-02-2012, 10:56 AM
kh99 kh99 is offline
 
Join Date: Aug 2009
Location: Maine
Posts: 13,185
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by cellarius View Post
Well, I'll return the applause After all, the idea came from you, and you've been the one refining it :up:
Well, not to go on too long with the mutual admiration, but the thing that bothered me about using a plugin was having a bunch of checks for THIS_SCRIPT and coding in styleids, but your scheme puts the styleid in the script. (...and all I really did was to debug it).
Reply With Quote
  #835  
Old 06-05-2012, 02:40 PM
stb74 stb74 is offline
 
Join Date: Nov 2008
Posts: 23
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I have been able to create my custom pages ok and use the following code for my templates

Code:
// ###### When do == 'xxx' #####
if ($_REQUEST['do'] == 'players')
{
$pagetitle = 'NI Football Fantasy League Players';

$templater = vB_Template::create('fantasy_players');
$templater->register_page_templates();
$templater->register('navbar', $navbar);
$templater->register('pagetitle', $pagetitle);
print_output($templater->render());
}

// ###### When do == 'yyy' #####
if ($_REQUEST['do'] == 'rules')
{
$pagetitle = 'NI Football Fantasy League Rules';

$templater = vB_Template::create('fantasy_rules');
$templater->register_page_templates();
$templater->register('navbar', $navbar);
$templater->register('pagetitle', $pagetitle);
print_output($templater->render());
}

// ###### When do does not equal 'xxx' or 'yyy' #####

$pagetitle = 'NI Football Fantasy League';

$templater = vB_Template::create('fantasy_index');
$templater->register_page_templates();
$templater->register('navbar', $navbar);
$templater->register('pagetitle', $pagetitle);
print_output($templater->render());
I am using v 4.2 and I have created a manin menu using the Navigation Manager and also sub menus. The main menu gets selected ok and highlighted but my sub menus are not. I have looked around the forums for an answer but can't find any. Any ideas or links to how I do this thanks.
Reply With Quote
  #836  
Old 06-05-2012, 02:43 PM
Lynne's Avatar
Lynne Lynne is offline
 
Join Date: Sep 2004
Location: California/Idaho
Posts: 41,180
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by stb74 View Post
I have been able to create my custom pages ok and use the following code for my templates

I am using v 4.2 and I have created a manin menu using the Navigation Manager and also sub menus. The main menu gets selected ok and highlighted but my sub menus are not. I have looked around the forums for an answer but can't find any. Any ideas or links to how I do this thanks.
Sounds to me like you are having problems setting up your tab in the Navigation Manager, not that you are having problems with your page itself. I'd suggest you post in the main forums for help with your NM settings.
Reply With Quote
  #837  
Old 06-16-2012, 03:35 AM
fotoking fotoking is offline
 
Join Date: Jun 2010
Posts: 2
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Hello everyone,

I'm new here and I'm urgently looking for help in regards to this topic. Here's my issue:

1: I have created a custom page with a .php uploaded to the root folder as per the instructions.

2: Both of this I have created a template on the Default Style and Mobile Style.

3: The issue is I can view the page normally on the desktop version and Andriod devices and mobile version via the desktop however when I open it on an IPhone ie IPhone 4, the entire screen goes blank and stays blank.

I appreciate all the help I can get. Thanks Guys
Reply With Quote
  #838  
Old 06-16-2012, 05:21 PM
Lynne's Avatar
Lynne Lynne is offline
 
Join Date: Sep 2004
Location: California/Idaho
Posts: 41,180
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by fotoking View Post
3: The issue is I can view the page normally on the desktop version and Andriod devices and mobile version via the desktop however when I open it on an IPhone ie IPhone 4, the entire screen goes blank and stays blank.

I appreciate all the help I can get. Thanks Guys
I'd suggest checking your error_logs (if you don't know where they are, ask your host). Here is a page from the manual about troubleshooting blank or 'white' pages: https://www.vbulletin.com/docs/html/blank_pages
Reply With Quote
  #839  
Old 06-21-2012, 04:29 PM
kkinsey kkinsey is offline
 
Join Date: Oct 2011
Posts: 32
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Well, Lynne, I want to thank you very much for the article; I've used it with success here @work (up to a point), but I'm very sorry I have to chime in with YAQ (Yet another question).

On our sites, I can't seem to get the site footer to work.

Here's the relevant section of my PHP script:
PHP Code:

$navbits 
construct_navbits($navbits);
$navbar render_navbar_template($navbits);
//$templater = vB_Template::create('footer');
//if (!is_object($templater)) { die("template not object!"); }
//$footer = $templater->render();
//if (!is_object($footer)) { die("footer not object!"); }
$templater vB_Template::create('pfs');
        
$templater->register_page_templates();
        
$templater->register('navbar'$navbar);
        
$templater->register('checked'$checked);
//        $templater->register('footer',$footer);
print_output($templater->render()); 
You can see I've been fudging around trying to figure this out. I even read about 24 pages of this thread before giving in to the temptation to bug you about it. Not that's that would be any consolation for you, I'm afraid.

I suppose what's really confusing is that the $templater object does contain the footer code as it's supposed to. So is this some sort of rendering issue? It doesn't appear in the HTML source code of the resulting page --- no footer HTML in there at all.

Here's the 'pfs' template code:
Code:
{vb:stylevar htmldoctype}
<html xmlns="http://www.w3.org/1999/xhtml"<vb:if condition="$vboptions['enablefacebookconnect']"> xmlns:fb="http://www.facebook.com/2008/fbml"</vb:if> dir="{vb:stylevar textdirection}" lang="{vb:stylevar languagecode}">
<head>
	{vb:raw headinclude}
	<title>My Page Title</title>
	{vb:cssfile faq.css}
	{vb:raw headinclude_bottom}
</head>
<body>

{vb:raw header}

{vb:raw navbar}

<div id="pagetitle">
	<h1 style="font-family:sans-serif,arial;text-align:center;margin-bottom:25px;margin-top:20px;font-size:20px;background:#448ccb;width:960px;color:white;font-weight:bold;">A Big Header</h1>
	</div>
        <iframe style="border:0px;margin-left:100px;" src="http://somesite.com/myscript.php" width="760" height="1600" scrolling="no"></iframe>

<!-- FOOTER TEMPLATE IS INCLUDED BELOW THIS LINE -->
<vb:raw footer>
</body>
</html>
I can comment out the IFrame, but it doesn't seem to matter; the footer's not output/shown regardless. I do see the closing /BODY and /HTML tags.

I you don't mind to help me close this bug, I'd be quite appreciative. Whacks w/the clue stick are appreciated as well
Reply With Quote
  #840  
Old 06-21-2012, 07:08 PM
kh99 kh99 is offline
 
Join Date: Aug 2009
Location: Maine
Posts: 13,185
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by kkinsey View Post
I suppose what's really confusing is that the $templater object does contain the footer code as it's supposed to. So is this some sort of rendering issue? It doesn't appear in the HTML source code of the resulting page --- no footer HTML in there at all.
You've got the wrong kind of brackets for the tag where you're inserting the footer. They should be curly braces.
Reply With Quote
  #841  
Old 06-21-2012, 08:20 PM
kkinsey kkinsey is offline
 
Join Date: Oct 2011
Posts: 32
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Doh! Too much stuff this week for brain to function properly! Thanks much!

Where do you want your cookies sent?
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 07:09 AM.


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.08696 seconds
  • Memory Usage 2,387KB
  • Queries Executed 26 (?)
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
  • (5)bbcode_code
  • (1)bbcode_html
  • (1)bbcode_php
  • (5)bbcode_quote
  • (1)footer
  • (1)forumjump
  • (1)forumrules
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (1)modsystem_article
  • (1)navbar
  • (4)navbar_link
  • (120)option
  • (1)pagenav
  • (1)pagenav_curpage
  • (4)pagenav_pagelink
  • (3)pagenav_pagelinkrel
  • (11)post_thanks_box
  • (58)post_thanks_box_bit
  • (11)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit
  • (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
  • fetch_musername
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • post_thanks_function_fetch_thanks_bit_start
  • post_thanks_function_show_thanks_date_start
  • post_thanks_function_show_thanks_date_end
  • post_thanks_function_fetch_thanks_bit_end
  • post_thanks_function_fetch_post_thanks_template_start
  • post_thanks_function_fetch_post_thanks_template_end
  • 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