SlideShare a Scribd company logo
How to create a Joomla
 component from scratch
           Tim Plummer
             @bfsurvey
Presented at Sydney JUG 12/06/2012
About me
              • I’ve developed over 24 Joomla
                extensions including…
Tim Plummer
 @bfsurvey
              •   Member of bug squad
              •   Contributed code to Joomla core
              •   Convenor of the Sydney JUG (2012)
              •   Co-organiser of Sydney JoomlaDay
My Joomla Development Story
What is a component?
What is a module?
What is a plugin?
Can we make a component in an hour?




   Yes    (if we cheat)
Tools you need
 • Web Server & PHP & MySQL
   (XAMPP)
 • Text editor or IDE (Textpad /
   Notepad++ or Eclipse / Netbeans)
 • Web browser (Firefox with firebug)
What license?
• GNU GPL (if you want to
  be listed on the JED)
• Free as in “Freedom” not
  free as in “Free Beer”
Set Error Reporting to Maximum
Security

Never EVER trust your user

ALWAYS sanitise user input!
Let’s fork com_helloworld
File Structure
Demo time…
Batch rename files
@echo off
setlocal enabledelayedexpansion
for /R %%j in (*.*) do (
  set filename=%%~nj
  set filename=!filename:helloworld=sjug!
  if not !filename!==%%~nj ren %%j
!filename!%%~xj
)
Find and replace text
com_helloworld     com_sjug
HelloWorld         Sjug
COM_HELLOWORLD     COM_SJUG
helloworld         sjug
HELLOWORLD         SJUG
Hello World        Sjug
hello              sjug
Hello              Sjug
World              Sjug
grepWin (free tool – windows only)
Xml file
• Change date, author, version etc
Zip it up
• I like 7-zip (http://www.7-zip.org/)
Now let’s install it
Now let’s try it
Demo time…
Add more fields to the form
Add more fields to the form
/administrator/components/com_sjug/models/forms/sjug.xml
Add more fields to the form
/administrator/language/en-GB/en-GB.com_sjug.ini
Add more fields to the form
 Use phpMyAdmin




You should also add these fields to
/administrator/components/com_sjug/sql/install.mysql.utf8.sql
Adding toolbar buttons
• http://docs.joomla.org/JToolBarHelper
    JToolBarHelper::publish(‘sjugs.publish', 'JTOOLBAR_PUBLISH', true);


    JToolBarHelper::unpublish(‘sjugs.unpublish', 'JTOOLBAR_UNPUBLISH', true);



    JToolBarHelper::archiveList(‘sjugs.archive');
Add published column to list view
Add published column to list view
/administrator/components/com_sjug/views/sjugs/tmpl/default_head.php
<th width="5%">
         <?php echo JText::_('JSTATUS'); ?>
</th>

/administrator/components/com_sjug/views/sjugs/tmpl/default_body.php
<td>
         <?php echo JHtml::_('jgrid.published', $item->published, $i, ‘sjugs.', '', 'cb',
$item->publish_up, $item->publish_down); ?>
</td>

/administrator/components/com_sjug/models/sjugs.php
$query->select('id,greeting,published,publish_up,publish_down');

/administrator/components/com_sjug/views/sjugs/tmpl/default_foot.php
<td colspan="4">
Fix menu icon
/media/com_sjug/images/tux-16x16.png
Fix Toolbar Image
/media/com_sjug/images/tux-48x48.png
Add link to title in list view
/administrator/components/com_sjug/views/sjugs/tmpl/default_body.php
Status Filter


/administrator/components/com_sjug/views/sjugs/tmpl/default.php




/administrator/components/com_sjug/views/sjugs/view.html.php
Status Filter
/administrator/components/com_sjug/models/sjugs.php
Change delete to trash


/administrator/components/com_sjug/views/sjugs/view.html.php
Now it looks like a Joomla Component
Now you are ready to start creating
     your own components
Questions?
Tim Plummer
       @bfsurvey
tim@tamlyncreative.com.au

More Related Content

What's hot (20)

PPTX
Rapid application development using Akeeba FOF and Joomla 3.2
Tim Plummer
 
PDF
Behaviour Driven Development con Behat & Drupal
sparkfabrik
 
ODP
Problemen oplossen in Joomla - Joomladagen 2014
Peter Martin
 
PPTX
Joomla! Pizza Bugs and Fun 2014 pre-event Seminar
Gunjan Patel
 
ODT
Easy Blogging With Emacs
Dashamir Hoxha
 
PPT
Joomla 3 JLayout's - Joomladay Netherlands 2014 #jd14nl
Philip Locke
 
DOC
Creating a multilingual site in Joomla 3 (Joomla 3 Beginner's Guide)
Eric Tiggeler
 
PPTX
WordPress Structure and Best Practices
markparolisi
 
PPTX
Custom Template for Joomla! 3
Carly Willats
 
PDF
PloneNG: What's new in Plone 4.2, 4.3, and beyond
David Glick
 
PDF
ElggCamp Santiago - Dev Edition
Brett Profitt
 
PDF
Development Setup of B-Translator
Dashamir Hoxha
 
PDF
Using Drupal Features in B-Translator
Dashamir Hoxha
 
ODP
JUG Utrecht 2013 - Have you tried turning it off and on again? Problemen oplo...
Peter Martin
 
PDF
Plone 5 theming unleashed
sneridagh
 
PDF
Troubleshooting Joomla! problems - Joomladay Germany 2014
Peter Martin
 
PPT
Joomla english for the work group
Vicent Selfa
 
PDF
Bootstrap 3 in Joomla!
Hans Kuijpers
 
PPT
Django, What is it, Why is it cool?
Tom Brander
 
KEY
CakePHP 2.0 - It'll rock your world
Graham Weldon
 
Rapid application development using Akeeba FOF and Joomla 3.2
Tim Plummer
 
Behaviour Driven Development con Behat & Drupal
sparkfabrik
 
Problemen oplossen in Joomla - Joomladagen 2014
Peter Martin
 
Joomla! Pizza Bugs and Fun 2014 pre-event Seminar
Gunjan Patel
 
Easy Blogging With Emacs
Dashamir Hoxha
 
Joomla 3 JLayout's - Joomladay Netherlands 2014 #jd14nl
Philip Locke
 
Creating a multilingual site in Joomla 3 (Joomla 3 Beginner's Guide)
Eric Tiggeler
 
WordPress Structure and Best Practices
markparolisi
 
Custom Template for Joomla! 3
Carly Willats
 
PloneNG: What's new in Plone 4.2, 4.3, and beyond
David Glick
 
ElggCamp Santiago - Dev Edition
Brett Profitt
 
Development Setup of B-Translator
Dashamir Hoxha
 
Using Drupal Features in B-Translator
Dashamir Hoxha
 
JUG Utrecht 2013 - Have you tried turning it off and on again? Problemen oplo...
Peter Martin
 
Plone 5 theming unleashed
sneridagh
 
Troubleshooting Joomla! problems - Joomladay Germany 2014
Peter Martin
 
Joomla english for the work group
Vicent Selfa
 
Bootstrap 3 in Joomla!
Hans Kuijpers
 
Django, What is it, Why is it cool?
Tom Brander
 
CakePHP 2.0 - It'll rock your world
Graham Weldon
 

Viewers also liked (15)

PPTX
Developing Custom Applications with Joomla! and Fabrik
Tessa Mero
 
PDF
Build custom applications with fabrik
Rodger Fields
 
PPTX
What’s new in joomla 3.7
Tim Plummer
 
PPTX
Simplify your Joomla user registration form
Tim Plummer
 
PPTX
JDeveloper - create component
jcmsdevelopment
 
PDF
Building Custom Applications with Fabrik
Robbie Adair
 
PPTX
JDeveloper - table relations
jcmsdevelopment
 
PDF
ACL no Joomla! 3 - Criando uma regra na prática
Júlio Coutinho
 
PPTX
Custom fields in joomla
Tim Plummer
 
PPTX
Fabrik - Joomla app builder
Florian Pinard
 
PPT
Joomla componenten bouwen met Component Creator
René Kreijveld
 
PPTX
The development workflow of git github for beginners
Gunjan Patel
 
PPTX
How to customise Joomla
Tim Plummer
 
PPTX
DevNet 1056 WIT Spark API and Chat Bot Workshop
Tessa Mero
 
PPTX
Joomla 4.0 what's coming in future
Tim Plummer
 
Developing Custom Applications with Joomla! and Fabrik
Tessa Mero
 
Build custom applications with fabrik
Rodger Fields
 
What’s new in joomla 3.7
Tim Plummer
 
Simplify your Joomla user registration form
Tim Plummer
 
JDeveloper - create component
jcmsdevelopment
 
Building Custom Applications with Fabrik
Robbie Adair
 
JDeveloper - table relations
jcmsdevelopment
 
ACL no Joomla! 3 - Criando uma regra na prática
Júlio Coutinho
 
Custom fields in joomla
Tim Plummer
 
Fabrik - Joomla app builder
Florian Pinard
 
Joomla componenten bouwen met Component Creator
René Kreijveld
 
The development workflow of git github for beginners
Gunjan Patel
 
How to customise Joomla
Tim Plummer
 
DevNet 1056 WIT Spark API and Chat Bot Workshop
Tessa Mero
 
Joomla 4.0 what's coming in future
Tim Plummer
 
Ad

Similar to How to create a joomla component from scratch (20)

PPTX
Techgig Webinar: Joomla Introduction and Module Development June 2012
Vishwash Gaur
 
PDF
Joomla 101
Rodger Fields
 
PPTX
How to Build a Website using Joomla
Mamunur Rashid
 
PPT
Joomla overview via catchy snaps
BUDNET
 
PPTX
Joomla-Content Management System
silenceIT Inc.
 
PPT
Joomla Day Austin Part 4
Kyle Ledbetter
 
ODP
Joomla Basics
emiliedaniel
 
ODP
FAT.Seminar.FOSS_Joomla!
Nguyễn Việt Khoa
 
PPTX
1 all about joomla!
Kyo Uya
 
PDF
Joomla Explained - As Easy as 1, 2, 3
Rod Martin
 
PPT
Intro to Joomla!
Rob McBryde
 
PDF
A complete guide to Joomla 2.5
Deepak K.C.
 
PDF
Basics of Joomla!
Saurabh Shah
 
PPTX
Joomla Tutorial: Joomla 2.5 a first look
Tim Plummer
 
PDF
Joomla2 5-afirstlook-120214054019-phpapp01
Deepak Sangramsingh
 
PDF
Building websites-with-joomla-1-5-sample-chapter-chapter-7-the-menus-menu
Giang Nguyễn
 
KEY
Joomla 3 - An overview
Andrew Eddie
 
PPTX
JOOMLA
Akhil Kumar
 
PDF
Joomla 2.5 Made Easy | Free ebook
JoomlaShine
 
PPT
Joomla Overview
guest01babb
 
Techgig Webinar: Joomla Introduction and Module Development June 2012
Vishwash Gaur
 
Joomla 101
Rodger Fields
 
How to Build a Website using Joomla
Mamunur Rashid
 
Joomla overview via catchy snaps
BUDNET
 
Joomla-Content Management System
silenceIT Inc.
 
Joomla Day Austin Part 4
Kyle Ledbetter
 
Joomla Basics
emiliedaniel
 
FAT.Seminar.FOSS_Joomla!
Nguyễn Việt Khoa
 
1 all about joomla!
Kyo Uya
 
Joomla Explained - As Easy as 1, 2, 3
Rod Martin
 
Intro to Joomla!
Rob McBryde
 
A complete guide to Joomla 2.5
Deepak K.C.
 
Basics of Joomla!
Saurabh Shah
 
Joomla Tutorial: Joomla 2.5 a first look
Tim Plummer
 
Joomla2 5-afirstlook-120214054019-phpapp01
Deepak Sangramsingh
 
Building websites-with-joomla-1-5-sample-chapter-chapter-7-the-menus-menu
Giang Nguyễn
 
Joomla 3 - An overview
Andrew Eddie
 
JOOMLA
Akhil Kumar
 
Joomla 2.5 Made Easy | Free ebook
JoomlaShine
 
Joomla Overview
guest01babb
 
Ad

More from Tim Plummer (20)

PPTX
Aujug 2020 joomla 4 workflow
Tim Plummer
 
PPTX
TinyMCE for Joomla
Tim Plummer
 
PPTX
Joomla 4 custom fields and workflow
Tim Plummer
 
PPTX
How to fix a hacked site and harden June 2019
Tim Plummer
 
PPTX
Creating your own joomla templates April 2019
Tim Plummer
 
PPTX
Custom fields in Joomla March 2019
Tim Plummer
 
PPTX
Whats new in Joomla 3.9
Tim Plummer
 
PPTX
Lessons from the other side
Tim Plummer
 
PPTX
Getting the most from your social media posts on facebook and instagram
Tim Plummer
 
PPTX
Tips for site builders and administrators
Tim Plummer
 
PPTX
Maintaining a joomla website - Canberra
Tim Plummer
 
PPTX
Whats new in joomla 3.5 & whats coming in future
Tim Plummer
 
PPTX
Joomla SEO basics 2016
Tim Plummer
 
PPTX
What's new in joomla! 3.5 - 8th Nov 2015
Tim Plummer
 
PPTX
Cross CMS plugin development using AWF
Tim Plummer
 
PPTX
Growing your business by hiring an offshore staff member
Tim Plummer
 
PPTX
Mautic landing page setup & case study
Tim Plummer
 
PPTX
Joomla SEO June 2015 - Sydney Joomla User Group
Tim Plummer
 
PPTX
State of play for Joomla - Nov 2014
Tim Plummer
 
PPTX
Extension developer secrets - How to make money with Joomla
Tim Plummer
 
Aujug 2020 joomla 4 workflow
Tim Plummer
 
TinyMCE for Joomla
Tim Plummer
 
Joomla 4 custom fields and workflow
Tim Plummer
 
How to fix a hacked site and harden June 2019
Tim Plummer
 
Creating your own joomla templates April 2019
Tim Plummer
 
Custom fields in Joomla March 2019
Tim Plummer
 
Whats new in Joomla 3.9
Tim Plummer
 
Lessons from the other side
Tim Plummer
 
Getting the most from your social media posts on facebook and instagram
Tim Plummer
 
Tips for site builders and administrators
Tim Plummer
 
Maintaining a joomla website - Canberra
Tim Plummer
 
Whats new in joomla 3.5 & whats coming in future
Tim Plummer
 
Joomla SEO basics 2016
Tim Plummer
 
What's new in joomla! 3.5 - 8th Nov 2015
Tim Plummer
 
Cross CMS plugin development using AWF
Tim Plummer
 
Growing your business by hiring an offshore staff member
Tim Plummer
 
Mautic landing page setup & case study
Tim Plummer
 
Joomla SEO June 2015 - Sydney Joomla User Group
Tim Plummer
 
State of play for Joomla - Nov 2014
Tim Plummer
 
Extension developer secrets - How to make money with Joomla
Tim Plummer
 

Recently uploaded (20)

PPT
Ericsson LTE presentation SEMINAR 2010.ppt
npat3
 
PDF
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
DOCX
Python coding for beginners !! Start now!#
Rajni Bhardwaj Grover
 
PDF
“Voice Interfaces on a Budget: Building Real-time Speech Recognition on Low-c...
Edge AI and Vision Alliance
 
PDF
[Newgen] NewgenONE Marvin Brochure 1.pdf
darshakparmar
 
DOCX
Cryptography Quiz: test your knowledge of this important security concept.
Rajni Bhardwaj Grover
 
PPTX
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
PDF
NLJUG Speaker academy 2025 - first session
Bert Jan Schrijver
 
PDF
POV_ Why Enterprises Need to Find Value in ZERO.pdf
darshakparmar
 
PDF
AI Agents in the Cloud: The Rise of Agentic Cloud Architecture
Lilly Gracia
 
PPTX
New ThousandEyes Product Innovations: Cisco Live June 2025
ThousandEyes
 
PDF
“Squinting Vision Pipelines: Detecting and Correcting Errors in Vision Models...
Edge AI and Vision Alliance
 
PPTX
MuleSoft MCP Support (Model Context Protocol) and Use Case Demo
shyamraj55
 
PDF
Reverse Engineering of Security Products: Developing an Advanced Microsoft De...
nwbxhhcyjv
 
PDF
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
PDF
Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
PDF
Go Concurrency Real-World Patterns, Pitfalls, and Playground Battles.pdf
Emily Achieng
 
PDF
NASA A Researcher’s Guide to International Space Station : Physical Sciences ...
Dr. PANKAJ DHUSSA
 
PDF
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
PPTX
The Project Compass - GDG on Campus MSIT
dscmsitkol
 
Ericsson LTE presentation SEMINAR 2010.ppt
npat3
 
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
Python coding for beginners !! Start now!#
Rajni Bhardwaj Grover
 
“Voice Interfaces on a Budget: Building Real-time Speech Recognition on Low-c...
Edge AI and Vision Alliance
 
[Newgen] NewgenONE Marvin Brochure 1.pdf
darshakparmar
 
Cryptography Quiz: test your knowledge of this important security concept.
Rajni Bhardwaj Grover
 
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
NLJUG Speaker academy 2025 - first session
Bert Jan Schrijver
 
POV_ Why Enterprises Need to Find Value in ZERO.pdf
darshakparmar
 
AI Agents in the Cloud: The Rise of Agentic Cloud Architecture
Lilly Gracia
 
New ThousandEyes Product Innovations: Cisco Live June 2025
ThousandEyes
 
“Squinting Vision Pipelines: Detecting and Correcting Errors in Vision Models...
Edge AI and Vision Alliance
 
MuleSoft MCP Support (Model Context Protocol) and Use Case Demo
shyamraj55
 
Reverse Engineering of Security Products: Developing an Advanced Microsoft De...
nwbxhhcyjv
 
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
Go Concurrency Real-World Patterns, Pitfalls, and Playground Battles.pdf
Emily Achieng
 
NASA A Researcher’s Guide to International Space Station : Physical Sciences ...
Dr. PANKAJ DHUSSA
 
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
The Project Compass - GDG on Campus MSIT
dscmsitkol
 

How to create a joomla component from scratch