How to override the output from the Joomla! core
From Joomla! Documentation
Revision as of 17:13, 26 April 2022 by M-b-o (M-b-o moved page How to override the output from the Joomla! core to Archived:How to override the output from the Joomla! core without leaving a redirect: Part of translatable page "How to override the output from the Joomla! core")
This page has been archived. This page contains information for an unsupported Joomla! version or is no longer relevant. It exists only as a historical reference, it will not be improved and its content may be incomplete and/or contain broken links.
There may be occasions where you would like to change the way a Joomla! Extension (such as a Component or Module, whether from the Joomla! core or produced by a third party) is displayed on your site. Of course, you could recode the Extension from scratch, but that may be a bit ambitious for you! Thankfully, there is another way.
The standard output from any Joomla! Module or Component can be overridden by adding code to the
html directory of your template. It is also possible to override two aspects of core functionality: Module chrome, and pagination.
As of overrides can be created using the Template manager Creating Overrides
Getting a head-start with overrides
If you are new to Joomla! development, then it is probably easiest to start with an existing view, and try modifying it to get what you want. To do this, you should make a copy of the existing view in the
html directory of your template, and then modify the copy.
The directory structure you need is:
For example, if you want to change the way that the '
Article' view displays a
com_content article, then you should copy the file at :
PATH_TO_JOOMLA/components/com_content/views/article/tmpl/default.php to TEMPLATE_NAME/html/com_content/article/default.php
(note the slight difference in directory structure)
Similarly, if you want to change how the
mod_login Module is displayed, then you should copy :
PATH_TO_JOOMLA/modules/mod_login/tmpl/default.php to TEMPLATE_NAME/html/mod_login/default.php
Joomla! comes pre-packaged with a frontend template called Protostar. Protostar utilizes template overrides to produce a table-less layout for faster, smoother, and semantically correct markup. To see how it's done, locate your Joomla! installation's
template directory, and you'll notice the Protostar template. Inside the Protostar template directory, you'll find a directory named
The entire directory structure is as follows:
If you want to try modifying the overrides used in Protostar, you could simply copy and paste the Protostar
html directory into your own template's main directory.
However you choose to make your override files, you will need to ensure that they are correctly installed with your template. To do this, you should add the following code to your template's
templateDetails.xml file (in between the
The above code in essence lets the Joomla! package installer know that there are files to extract, and that they are part of the template as a whole.
You can override Joomla's core images that are stored in the /media/ folder. Put an alternative image with the same name in your template folder. For example, the Breadcrumbs Module uses an orange arrow that is retrieved from /media/system/images/arrow.png. Joomla will use your override version if you put it at /templates/your_template_name/images/system/arrow.png.
Template overrides are almost limitless. They allow you to add, edit, and remove the components of the Joomla! core output. The Template Manager can be used to create override files ready for editing.
Note: All modern browsers ship with high quality debugging tools which are useful for browsing a page's HTML source and matching it up with the PHP code used in template overrides.
More information is available from the following resources: