Your project contains tables.
A table in the builder does not represent only the SQL structure.
Here in builder, a table represent a triad.
data:image/s3,"s3://crabby-images/33a60/33a60e85b728975ab4026183b4987010172d1046" alt="Joomla tables"
Tables
The list tables of your selected project.
Create a new table
1. Click the [ + ] button, then New table.
data:image/s3,"s3://crabby-images/ffa34/ffa34de3f189a3165afee99a3bc792d56b167193" alt="Cook create new table"
2. Give a plural name. (Accept all characters ad spaces)
data:image/s3,"s3://crabby-images/3bcbd/3bcbd62d0f52187070766f548c65b71f02a6590b" alt="Cook Builder create table edit name"
3, Press Enter a click the save icon.
Naming
data:image/s3,"s3://crabby-images/c35e8/c35e8e2ad96e7ba5606e82045548b322d0c3f867" alt="Cook Builder Table properties"
A table (triad) is made of 2 types: plural, singular
- Table title : Table default label. Accept all caracters and spaces (ex: Items)
- Table alias : File name and MVC plural class name. Only [a-z] caracters. Must be unique. (ex: items)
- Item title : Default label for singular record. Accept all caracters and spaces (ex: Item)
- Item alias : File name and MVC class name. Only [a-z] caracters. Must be different than Table alias. (ex: item)
Forbidden names
Some aliases are not allowed for your table alias. Cook does not accept the following names :
model, dev, fork, result, print, xxxx, xxxxs, yyyy, yyyys, zzzz, zzzzs
Entry point :
Determines if this triad is the default view.
Note: Deprecated feature since CPanel.
data:image/s3,"s3://crabby-images/30be7/30be769f87801e100174594ce0800f1bf85baf81" alt="Cook Builder Fields types"
Fields
Create a new field in table:
- From the Data types tab, drag a field type to the Data fields droppable list.
- Give a name, and an alias.
data:image/s3,"s3://crabby-images/273ad/273ada8f4b769d34a167987848a5978704c69100" alt="Cook add new field edit field"
Warning : Some aliases are not allowed.
(complete list to come)
Known issue : sometimes you can experience some difficulties to edit in the builder interface.
Workaroun: Save and edit again the field.
Default field
The default field is the field to choose as fallback when label key is not specified. It should be setted for a text readable field. (when possible)
For example, the modal pickers are using the default field to show the item label (or title, description, ...)
To define a field as default, click on the star : data:image/s3,"s3://crabby-images/00dac/00dac648d539a02c4c241f1d7f5363340eb30e68" alt="Cook default field in SQL table"
Create a Foreign Key:
- Instance a Foreign Key field type.
- Name the field (Label + name)
- Drag the foreign Table in the droppable area of the instancied field.
ex : Country table is referenced in the country field of the Cities table
data:image/s3,"s3://crabby-images/ba7d4/ba7d4201e20b03fce75930c926796cff77e8fc5a" alt="Create Foreign Key in your SQL table"
Wizardsdata:image/s3,"s3://crabby-images/8e91e/8e91edc54769837b7474a195cca76f5b57e532b2" alt="Cook Self Service wizards"
Wizards are automated functionalities. Cook can instance basic Joomla features such as authoring infos, publishing states, creation infos, holder (checked_in), ordering, accesses, aliasing (slug), hits, defaulting, ...
Instance a new wizard:
- From the Wizards tab, drag the wizard you want to create.
- Link the fields to work with. To do it automatically, click to the green (+) button.
data:image/s3,"s3://crabby-images/7c511/7c51144d30da635629b4827f508c96f823edc6ac" alt="Create a new wizard"
Once the fields are correctly linked to a wizard, an orange arrow is displayed on the top-left corner of the field:
data:image/s3,"s3://crabby-images/67ca2/67ca2150276b02fcae94450ac1e786d14fe5de94" alt="Cook linked field to wizard"
Warning : Some wizards can be instancied only once time per table. Some others can be instancied both times.
Warning : Some wizards lock the name of the field. In this case, you cannot change the name of the field.
data:image/s3,"s3://crabby-images/4819d/4819dc939ddeaec744402c5dc1f733f2d9f9fe88" alt="Field name locked by a wizard"
Generated files
For each table, your component will contain :
- Database
- back-end
- Table class
- Controllers
- plural controller
- singular controler
- Models
- plural model
- singular model
- XML JForms file
- Views (when needed)
- front-end
Controllers
- plural controller
- singular controler
- Models
- plural model
- singular model
- Views (when needed)