How to determine which page you are on from within a Joomla! 1.5 template
Written by Cory |
April 17, 2008
|
(22)
One thing I often need to do while developing a template is change certain parts of the template depending on which page I am on. For example, let's say I am developing a template for a site that runs Virtuemart, and I want to have 3 columns on every non-Virtuemart page, and 2 columns on every Virteumart page. A solution that I often like to use is to make the column "collapsable" when the value of "option" is "com_virtuemart". When "option" is equal to "com_virtuemart", that simply means that the Virtuemart component is loaded.
Where is the value of "option", and how do I get it?
If you are not using SEF URL's, you can easily see where the value of "option" comes from. For a Virtuemart page, the URL will look something like this:
"index.php?option=com_virtuemart&Itemid=3"
You'll notice that in the URL, the value of "option" is "com_virtuemart". This is the most common way of passing parameters from one page to another in Joomla! It is called a GET request, which simply means that parameters are passed at the end of the URL. (Another type of request is POST, which passes parameters without appending them to the URL. The technique I will show you in this article will get the parameter whether is is passed through a GET or a POST request.)
That's great, but how do I get that value in my template?
I'm glad you asked, because this is the most important part of determining what page you are on from within the template. At the top of your template "index.php" file, add the following code:
<?php $pageoption = JRequest::getVar( 'option', '' ); ?>
"JRequest" is a Joomla! object that is used for getting variables passed through an HTML request (GET, POST, or SESSION). The "getVar" method returns the desired value as a string. The first parameter in the "getVar" is the name of the value we want to retrieve. In this case, we want to get the value of "option", so we set the first parameter to 'option'. The second parameter is a default value, just in case the parameter we are looking for has no value. I usually set that to an empty string, but you could put just about anything you want there. For example, if there is no "option" (not likely in Joomla), then the value of $pageoption in the code above will just be an empty string ('').
Yes, but what do we do with this information?
Now that we know the value of "option", we have a lot of flexibility to modify the layout of our template depending on which component is loaded. Here is how you might do it:
<?php if ($pageoption == 'com_virtuemart') { ?> <!-- Put some HTML here that you want to show while Virtuemart is loaded --> <?php } else { ?> <!-- Put some HTML here that you want to show while Virtuemart is not loaded --> <?php } ?>
Hiding a module position
Here is how you use this concept to hide a module position when Virtuemart is loaded:
<?php if ( $pageoption != 'com_virtuemart' && $this->countModules('moduleposition') ) { ?> <div class="collapsiblecolumn"> <jdoc:include type="modules" name="moduleposition" /> </div> <?php } ?>
In plain English, this code basically says if Virtuemart is not loaded and there are modules published for "moduleposition", then show the modules in "moduleposition". The name "moduleposition" can be any name you choose.
Questions/Comments
As always, questions and comments are welcome.
Trackback(0)
Comments (22)
written by Lisa, May 19, 2008
Thank you by the way for an excellent blog - both entertaining and educational!
/Lisa
written by links, May 25, 2008
On top of page :
On body :
written by links, May 25, 2008
On top of page :
On body :
written by links, May 25, 2008
[? $pageoption = JRequest::getVar( 'option', '' ); ?]
[? $pageview = JRequest::getVar( 'view', '' ); ?]
On body :
[? if ($pageoption == 'com_virtuemart') {echo "";}
elseif ($pageview == 'article') {echo "";}
else { ?]
[ } ?]
* change [ ] to < >
written by Fernando, May 27, 2008
written by Zee, July 03, 2008
written by jairp heinrich, July 09, 2008
written by Gijs, July 18, 2008
I want a set of articles (not all articles) to have a different headers (h1, h2 etc. ).
Is there a clever to change the template within the article component?
Or should I better crate a copy of the component? (If so, do you know which?)
Thanks in advance,
Gijs
written by Sam, August 18, 2008
Cheers,
Sam
written by Doug, October 28, 2008
Thanks!
written by Mohsin, November 21, 2008
i wanted the value for $view and $option but when SEF was turned ON
my whole template was GONE wild :-), as i was getting values from the URL... but thanks for your tips regrading JRequest!
Mohsin
written by Christian Skauge, December 15, 2008
/Chris
written by Dan Walker, January 08, 2009
Then you can change the getVar to whatever you want without creating a new variable every time.
written by luke, March 16, 2009
$menu = &JSite::getMenu();
$activeMenu = $menu->getActive();
$activeMenuName = $activeMenu->name;
if ($activeMenuName=="somepage"){
do something
}
written by Elkin, May 06, 2009
I hope this code can help others that may need this...and saves them time.
I put this at the top of my index page:
I put this in the body of my code:
some stuff here.
some stuff here.
Write comment
Join the HowToJoomla Community!
- Create a profile
- Connect with other members
of the community - All for FREE
Already a member? Login here.



One question I have though, since I'm new to Joomla 1.5 I'm finding it hard to figure out if I'm on the frontpage. In 1.0.x $option would equal com_frontpage, but in Joomla 1.5 com_content is used for the frontpage as well as regular content.
Do you know of a simple way to distinguish the frontpage from within the template?