Before knowing how to create a module in Joomla step-by-step from the backend, you should know the Joomla module.
What is the Joomla module?
Sometimes we need to display a small block of information like the newsflash, Login Form, Slider, etc. So in Joomla, this type of block is called a Module. The Joomla module is paced according to the positions of the template.
Let’s See: How do I install quickstart packages in Joomla?
Create a Module in Joomla, step-by-step
In this tutorial, I will show how you can create a custom module for Joomla3.x and Joomla4.x.
Please follow the following steps –
Step1: Create directory structure with mod_latestposts
There are two ways to create a directory: in your Joomla website module folder or in your computer’s local folder.
If you create it on your local computer, then you will need to create a zip file and install it using the Joomla Extension manager.
Now I am starting from the Joomla website root directory and then selecting the Modules folder.
Let’s create a module: mod_latestposts
Note: Module root folder name must start with “mod_(e.g. mod_modulename) and the main file must follow the same naming convention.
- Create inside the module directory of your Joomla website the following folders:
- /public_html/modules/mod_latestposts
- /public_html/modules/mod_ latestposts /tmpl
- /public_html/modules/mod_ latestposts /language
- /public_html/modules/mod_ latestposts /language/en-GB
The above directories must be followed the same naming convention as this important rule.
Let’s See: How do I enable Joomla PHP error reporting?
Step2: Create file mod_ latestposts.php
This is the main file of the module and its name same as the directory name mod_latestposts.php inside the mod_latestposts.
data:image/s3,"s3://crabby-images/ab11b/ab11b0217993979268edbb54bb97107eabb3676e" alt="Joomla4: How do I create a custom module in Joomla?, How do I create a custom module in Joomla?, How do I create a custom module in Joomla 3, What are the steps to create a module?, How do I create a custom HTML page in Joomla?, how to create module in joomla step by step, create joomla module with database, joomla plugin development, joomla custom html module, joomla 4 template, joomla 4 download, joomla plugin events, joomla 4 github, Joomla3: How do I create a custom module in Joomla?, joomla for beginners video tutorials, joomla 2.5 manual install, joomla upgrade guide, guide joomla k2, manual joomla 2.5, learn joomla in hindi, joomla manual install language, manually upgrade joomla 2.5 to 3, learn joomla 3, joomla tutorials for beginners full 2019, joomla city guide, joomla manual migration, joomla training manual, joomla manual update 2.5 to 3, joomla city guide template, manual joomla 2.5 español pdf, joomla manual module installation, joomla manual pdf free download, manual joomla pdf español, joomla administrator manual, joomla 3 tutorials, joomla guide for beginner, joomla tutorials for beginners full, joomla manual dansk, joomla user manual pdf, joomla 2.5 manual update, joomla manual update 3.4.8, joomla 3.9 manual update, joomla manual install extension, joomla instruction manual, joomla virtuemart manual Joomla Module name file"
The defined directive limits permit the rest of the file or code from any other non-Joomla scripts. In other words, if it’s not from Joomla standard code or out of the Joomla directory, It will “die” or stop all further action.
JLoader::register- This function loads the file that is included in the path. For the example above, the function have helper.php
JLoader::register(‘ModPostsLatestHelper’, __DIR__ . ‘/helper.php’);
You can use require_once() in the place of loader ::register() for example, as below:
require_once dirname(__FILE__).’/helper.php’;
But the latest version of Joomla is using the Loader() function.
Step3: Create file mod_ latestposts.xml
data:image/s3,"s3://crabby-images/6b708/6b708a42adb5afe9304711b745060e30ed428885" alt="Joomla4: How do I create a custom module in Joomla? Joomla Modules xml installation file"
Above the screenshot, there are some important fields, e.g., name, author, creation date, etc
Files Section
To add files in our module, you need to add these fields: <filename></filename>
And to add folders, use this tag <folder></folder>. All these field tags should be inside the <files></files> fieldset.
data:image/s3,"s3://crabby-images/4a9f3/4a9f32092c3e853cb87e615d9bd4e512ff3e8e1a" alt="Module file tag in xml"
Language Section
To add a language file you need to use <languages> directives and inside this use <language></language> directives like the below –
data:image/s3,"s3://crabby-images/07136/0713678d2b52102971cd10aefacf4a3ca66a8434" alt="Language tag in xml"
The section includes language files and a language folder (ex. en-GB). When you install the module, these language files will be placed within the language folder.
For your module, you can also add a custom language folder. The benefit of a custom folder is that it will not be removed by updates, and your module will be self-contained.
Configuration Section
data:image/s3,"s3://crabby-images/6107e/6107ebc5ac1da243037e60c40dccfd3c0a9893ef" alt="How do I create a custom module in Joomla? Joomla4: How do I create a custom module in Joomla?"
Configuration settings start from the config tag, and inside this tag, we can add multiple fieldsets like Basic, Advanced, etc.
In the basic field set, we add parameters for the module function, and the Advanced field set is used for the default options of the Joomla module.
Step #4. Create Module helper.php
In this file, you have to create a helper.php file with a helper class For example, in our module, the helper class is ModPostsLatestHelper
You have to use the Camel case for a naming convention for the class name.
The helper.php file isn’t required to run a module. If you browse the other module folders, you’ll notice that several of them are missing. However, for this example, we’ll need to write one.
What is the use of this helper.php?
You included a line requiring the helper.php file when you wrote the mod_latestposts.php file. We write database action methods in this file.
data:image/s3,"s3://crabby-images/ce750/ce7506e6feea7efbb5cdac9f4008738f4fa12198" alt="How do I create a custom module in Joomla? How do I create a custom module in Joomla?"
If you include this but don’t have it, Joomla is going to give you an error message that the file wasn’t found. If you don’t want to use one, don’t use the need to require in the mod_latestposts.php file.
Helper file methods – in the helper.php file, you have to write your function or methods, which you will need to get data from database tables. In our module, I created the getposts() method to get the latest posts from the content table.
data:image/s3,"s3://crabby-images/e81ec/e81ec00900f7987b3086c84f60835a0cd64acd89" alt="How do I create a custom module in Joomla? Module function in Joomla"
Let’s See: How to create an override for the Joomla layout?
Step #5. Check all files and folders.
data:image/s3,"s3://crabby-images/e46d0/e46d0319dc3583fbd27052877bc070fac2bec9a9" alt="How do I create a custom module in Joomla? Module files structure in joomla3"
Now we can install the module from the administrator. So first, you have to go to the administrator and click on the System menu on the left side. There you can see in the middlebox, Install, where you can see the Discover link and click on it.
data:image/s3,"s3://crabby-images/b9eda/b9edab4c445a54126c60116174d1c3ab75268c99" alt="How do I create a custom module in Joomla? How do I create a custom module in Joomla"
Let’s See: How to create a new module from the backend?
After that, you will see module mod_latestposts there, just click on the Install button, and then it will install in Joomla.
data:image/s3,"s3://crabby-images/9ca6b/9ca6bb5610f62b5ef96966d1290ff4ce6a8fdd48" alt="How do I create a custom module in Joomla? How to install Joomla module from admin"
You have to check the checkbox for which module you want to install. After installation, you will see a successful message.
Now You have to Go to Module Manager=>New Button
In the module type list click module: mod_latestposts
data:image/s3,"s3://crabby-images/8fd84/8fd8437a748c2d33eb011855f89aacba0fc47d8d" alt="How do I create a custom module in Joomla? Create new module from admin"
Like with other modules, you have to enter the module title, select module position, menu assignment, etc.
In our module, we have to set the article (post) category and the number of posts on the front end.
Click on the Save & Close button.
data:image/s3,"s3://crabby-images/972db/972dbd25285d7313df1a6690c304bbdc7a41eefd" alt="How do I create a custom module in Joomla? Display module in the sidebar"
Now, this is the final output of the module. On the right side, you can see posts.
You may like to read these also: What is the Joomla Control Panel?