For some developers, there is nothing like seeing a real-life application in action to get those creative fabrik juices flowing! On this page is a list of advanced Fabrik applications with tutorials on how some of the advanced parts of the application were accomplished.
The tutorials on this page assume that you are completely familiar with fabrik concepts like tables/
Lists,
Forms, group and
Elements and know SQL and how fabrik relates to the underlying database. They also assume a basic level of knowledge of php and
Javascript and css and how to edit and post these files to your joomla/fabrik server.
With that caveat, here are the tutorials!
SkyRun Vacation Rentals
A back-end reservation system for holiday rentals in resorts.
- The first video should be viewed before viewing any of the following tutorials to understand the business application being shown and see the front-end:
- coming soon - Tutorial 1 - Modifying table row appearence using row-specifric CSS (easy)
- coming soon - Tutorial 2 - Using SQL views with fabrik to show summarized data in a table (medium)
- coming soon - Tutorial 3 - Creating a custom template for your table with buttons (medium)
- coming soon - Tutorial 4 - Hiding and showing form fields (no coding required)
- coming soon - Tutorial 5 - Ajax to fill out form fields based on another form fields (medium)
- coming soon - Tutorial 6 - Using form submission plug-ins to create a simple process/workflow for handling multi-step actions like refunding a credit card payment where you type the amount to refund, then process the form - (hard)
Customer Management
A Back-end system for manage customers and a Frontend system for customers information.
This is a hands-on experience. Still a work in progress. This is my step-by-step tutorial on what i'm currently developing in my company. Please comment or give your thoughts. If you would do differently please feel free to help ... ( send message to
nusilmar )
First of all i'm trying to have a system for backend management and a frontend system for customers get some info.
Create customer list/form/elements
- To begin, let's create a list for customers. Nothing special here, just create a list labeled "Customer" and in the data tab put in the data table name eg "fab_customers". The form, group and base Elements are created (no change required, for now).
- Now go to Elements and create the following Elements ( I believe that i don't need to explain step-by-step how to create a simple element, so only if needed i will explain that element) :
- Go to Elements and filter by Customers Group
- As you can see the base Elements are already there, and to avoid them to show in List disable them ( click on the button in Show in List column)
- Create the following fields (I'll assume most default settings. May change according to your needs.):
- Name ( field plugin )
- Address (field plugin)
- City ( field plugin)
- Postal code ( field plugin)
- email (field plugin, may activate a Validation for the e-mail)
- phone (field plugin)
- customer internal code ( field plugin - to be used in connection with the ERP, to fetch pending values, related to unpaid invoices. To be checked later in this tutorial)
- geomap (googlemap plugin - to later create a visualization of customers distribution in google map. If you need help on this plugin check the wiki about it or ask in the foruns)
- Further fields could be created , ( like VAT number, Country, Payment terms, ...) so please feel free to add your own
- Insert some data ( create some customers)
Create a customer/joomla link table
- The purpose of this list / table is to be able to connect joomla users to one or more companies. Since this application can be used by customers, technicians and administrators, it makes sense that there may be multiple employees of a company / client with access to company data they work, using the joomla account to enter, and in the case of technical (support, marketing, sales) can access various companies / clients they have on their purview. I hope this explanation was clear, otherwise correct it or come in contact with me (see link above).
- This table/list is going to be used in pre-filters for all the other tables/Lists in both the frontend and in the backend, although it could be used only on frontend.
- Create a list labeled "User/Customer" and in the data tab put in the data table name eg "fab_usercust". The form, group and base Elements are created (no change required, for now).
- Now go to Elements and create the following Elements :
- Go to Elements and filter by User/Customer Group
- As above disable list View for base fields ( id and date)
- Create the following fields :
- customer ( database join plugin - Render as Dropdown, connect to fab_customers , value "id" and label "name")
- usercustomer ( user plugin - if you wish could set this Options : User Data : Name ; Update on edit : Yes )
- Insert some data. You could select a company and then start to add joomla users to that company. Attention : Access privileges still apply
How to add a Pre-filter to filter customer tables that a joomla user may access
- What I have currently implemented is to create pre-filters in menu entries for fabrik Lists, but can create the same pre-filters for backoffice, although I think the ideal is to always use the menus in frontoffice, even for managers. This way i believe you will get more control on what you do.
- To use the pre-filter create a menu entry of fabrik list type, choose the fabrik list to show (as of now the customer list will be the only one that could be used, but as we create new Lists, provided they have the customer ID field we will be able to use these instructions).
- Go to Options and select fabrik list pre-filter (attention : should save first the menu before you access the pre-filter because only after saving the Options will be available).
- Add a new prefilter with this configuration:
- choose in first option ?AND?
- In Elements choose the one that referred the customer code (which in the existing table is the id field)
- In Condition choose IN
- In Value put SELECT customer FROM fab_usercust WHERE usercustomer = {$my-> id}
- In Type choose Query
- In Access choose what applies (can choose Public)
Create List of Software Versions Installed on Clients
- This list is used to proceed with the record of software installed on the client , including billing software for various software houses, where there are several different software (multiple brands and multiple lines) and each line of software that has several versions (with corrections or tax updates). Since this option is very targeted to the area where i work you may take some ideas for your own projects. Then we need to create a list where we will launch the installed versions. Since I intend to create something with this Structure (client, software, line, version, is updated?) we can see that we need some auxiliary tables to help us in creating the list, including customer (existing, if you follow this tutorial) , software, software line and software version.
- Although it is probably overkill, I created the following auxiliary Lists:
- Software House - Where to put the various software houses that work
- Software Line - Where to put the various lines of software from those software houses
- Versions - Where to put all the versions of the software lines.
- Create Software House list/form/elements
- Create a list labeled "Software House" and in the data tab put in the data table name eg "fab_softwarehouse". The form, group and base elements are created (no change required, for now).
- Now go to elements and create the following elements ( filter by Software House group)
- Create the following fields (I'll assume most default settings. May change according to your needs.maintain default fields (id and date)):
- Software_House ( field plugin )
- Further fields could be created , ( like Address, Country, ...) so please feel free to add your own
- Insert some data ( create some Software Houses)
- Create Software Line list/form/elements
- Create a list labeled "Software Line" and in the data tab put in the data table name eg "fab_softwareline". The form, group and base elements are created (no change required, for now).
- Now go to elements and create the following elements ( filter by Software Line group)
- Create the following fields (I'll assume most default settings. May change according to your needs.Maintain default fields (id and date)):
- Software_Line ( field plugin )
- Software_House ( databasejoin plugin, on data tab : render as dropdown, connection site_database, list fab_softwarehouse, Value id, Label Software_House)
- Insert some data ( create some Software Line)
- Create Software Versions list/form/elements
- Create a list labeled "Software Versions" and in the data tab put in the data table name eg "fab_softwareversion". The form, group and base elements are created (no change required, for now).
- Now go to elements and create the following elements ( filter by Software Versions group)
- Create the following fields (I'll assume most default settings. May change according to your needs. Maintain default fields (id and date)):
- Software House ( databasejoin, Render as Dropdown, connect to fab_softwarehouse , value "id" and label "Software House")
- Software Line ( cascadingdropdown, on data tab : (process as dropdown box, link site database, list Software Line, id : id, label Software Line), on observe tab : element to observe : Software House, External Key : Software House))
- Version ( field plugin)
- Is Updated (yesno plugin)
- Due to my lack of expertise on Fabrik i still cannot figure how to automaticaly set the last version of a certain software Line as the updated one so what i have to do is : every time a new version is released i need to go to the previous version of that software line and mark NO in the Is Updated field and YES on the latest version. When i or when someone figure out how to do it, this wiki will be updated.
- Further fields could be created , so please feel free to add your own
- Insert some data ( create some Software Versions)
- Create Installed Versions List/form/elements
- Create a list labeled "Installed Versions" and in the data tab put in the data table name eg "fab_installedversion". The form, group and base elements are created (no change required, for now).
- Now go to elements and create the following elements ( filter by Install Versions group)
- Create the following fields (I'll assume most default settings. May change according to your needs. Maintain default fields (id and date)):
- Customer ( databasejoin, Render as Dropdown, connect to fab_customers , value "id" and label "Customer")
- Software_House ( databasejoin, on data tab : Render as Dropdown, connect to fab_softwarehouse , value "id" and label "Software_House")
- Software_Line ( cascadingdropdown , on data tab : (process as dropdown box, link site database, list Software Line, id : id, label Software Line), on observe tab : element to observe : Software House, External Key : Software House))
- Version ( cascadingdropdown , on data tab : (process as dropdown box, link site database, list Software Versions, id : id, label Version), on observe tab : element to observe : Software Line, External Key : Software Line))
- Is Updated (yesno plugin)
- This one is not to be edited, but there is a lack in Fabrik to disable editing on this type of field ( at least i can't find it). This field is updated automaticaly by running a cron job that updates every record on Installed Versions List to the value in Software Versions List
- Further fields could be created , so please feel free to add your own
- Insert some data ( create some Installed Versions)
- Create the Cron Job on Schedule
- In order to the Installed Version be updated automaticaly ( it doesn't matter what value you put in {fab_installedversion___is_updated} field , every time a new version is released it would be very time consuming to update every single record in Installed Version List, so the best way is to automaticaly update that field) you have to create a schedule job, so you have to :
- Create a new Schedule
- Label : Version Update
- Every 1 minute ( change this to a realistic value, i've defined to 1 minute but you could set it as you want)
- Link : Site database
- List : Installed Versions
- Plugin : PHP
- Script PHP : no Choice
- Setup PHP : put this code :
-
PHP:
// Get the db object
$db = JFactory::getDbo();
// Build the query ? Tables names = CASE SENSITIVE
$query = $db->getQuery(true);
$query
-> update('fab_installedversion AS a')
-> join('LEFT','fab_softwareversion AS b ON a.Version=b.id')
-> set('a.isupdated = b.isupdated');
$db->setQuery($query);
// Run the query
$found = (int) $db->execute();
- Check the Lists and fields in the code to make sure they match on what you've created
- Remember that schedule jobs only run manualy on Schedule-Run or after a view is made on your site ( if i'm wrong correct me)
Create other tables. (coming soon , and i really mean soon ( not like the other example here ...))
Since this application is mainly oriented for my area and for my needs ,possibly some concepts are not understood.
The tables to be developed are:
- Services Sheet (registration services performed on the client)
- Software Licenses (Registration of software Licenses registered on the client (used mainly because of ERP Software))
- Contracts (contracts of renewal of software support)
- Pending values (indication of the amounts pending payment from the customer)
Please wait some time, as i'm trying to write the full tutorial ... Will update soon.