PluginList format control block


The FORMAT control block is used to create individually formatted objects that can then be used in any of the individual OUTPUT methods.

Available filters

Name Description Boolean Sample Tiki Version
default Display a default value or a default file when no value is available no "empty", "1140" (fileId) -
format format the displayed value to something different that the db value (human readable) no "trackerrender", "date", "objectlink", etc. (see format parameters here) -
editable Make the field editable so the value can be changed from the results display. Inline editing (found in admin control panels => trackers) must be enable. Must be used in conjunction with the trackerrender format (see above) and may require mode="raw" when using it with the table output template} editable="inline" -
The jQuery Sortable Tables feature must be activated for the sort feature to work.


Note that in some cases the field that will be displayed has its own behavior and it can clash with the format you selected.
IE: A tracker field that is a "title" is pre-formatted as a link. If you set the format as "objectlink" (or you set the display inside a link) the display will end broken as Tiki will try to display a link inside a link.

For the default parameter, it's important to remember that the tracker field "Files" works a bit differently than the others with this parameter. The tracker field Files expect an Id from the File Gallery. When most of the other fields type will display the text of the default parameters the default for "Files" must be an existing file in a gallery. The file can be an "anonymous" portrait file or a plain white image or an image with only the text "Not Available", etc. Whatever you feel right for your usage.

Basic example

In most of the examples shown in PluginList output control block and PluginList advanced output control block you will see a FORMAT control block have been used. E.g. in the example shown for Table output as below, two FORMAT control blocks are used:

Sample using the default table formatting
Copy to clipboard
{LIST()} {filter type="trackeritem"} {filter content="water"} {OUTPUT(template="table")} {column field="title_link" sort="title" label="Title" mode="raw"} {column field="description" label="Description"} {column field="event_date" sort="tracker_field_18" label="Event Date"} {OUTPUT} {FORMAT(name="title_link")}{display name="title" format="objectlink"}{FORMAT} {FORMAT(name="event_date")}{display name="tracker_field_18" format="date"}{FORMAT} {LIST}


The first FORMAT control block defines an object with the name title_link that is displayed in a specific way - this object reference is then used in the column control block in the body of the table OUTPUT. Similarly the second FORMAT control block defines the event_date object which is also used in a column control block.

A similar use of the FORMAT control block allows the normal set of Smarty variables, eg {user} etc, to be made available in Smarty templates - for example:

Format example to reference a normal smarty variable
Copy to clipboard
{FORMAT(name="theuser")} { {user} } {FORMAT}
 Note
The double brackets ( {{}} ) around user should have no spaces between them. Spaces are used here only to keep the user variable from being interpreted.

This creates a reference object theuser with the userId of the current user which can then be invoked in a server stored smarty template using the variable {$row.theuser}.

Examples of the use of the FORMAT control block (format and default value)

Copy to clipboard
{LIST()} {filter field="tracker_id" content="1"} {filter field="tracker_status" content="o"} {OUTPUT()} {DIV(class="h3")}{display name="name"}{DIV} {display name="photo"}%%% {display name="email"} {OUTPUT} {FORMAT(name="name")}{display name="tracker_field_userName"}{FORMAT} {FORMAT(name="photo")}{display name="tracker_field_userPhoto" format="trackerrender" default="1140"}{FORMAT} {FORMAT(name="location")}{display name="tracker_field_userLocation" format="trackerrender" default="Unknown"}{FORMAT} {LIST}


Default parameter applied on the "photo" field will display a default generic image if not file found.
Default parameter applied on the "location" field will display the text "Unknown" if the field is empty.

Example with comments


You might want to display all comments, and this script will retrieve them:

Wiki Output Sample
Copy to clipboard
{LIST(cache="n")} {filter type="comment"} {pagination max="10"} {OUTPUT( template="table")} {column field="title"} {column field="comment_content"} {column field="object_link" mode="raw"} {column field="date"} {OUTPUT} {FORMAT( name="object_link")} {display name="object_id" format="objectlink"} {FORMAT} {sort mode="date_desc"} {LIST}

The FORMAT control block defines an object with the name object_link which is displayed in such a way that it is object_id which is displayed and formatted as objectlink; which makes the id clickable. This object reference is then used in the column control block in the body of the OUTPUT table.
This gives us the following result:

Title Comment Thread Id Date
Calendar links not accepted It is not possible to use a Calendar link in a Wiki page. The brackets which are required to specify the calendar ID cause the link to not be recognized as a link. [http:tiki-calendar.php?viewlist=list&calIds[]=1|Click here for Calendar] 799 2008-07-11 23:44:44
Easy PHP Download points to SourceForge I got a 404 when using the EasyPHP download link. The EasyPHP site points to Sourceforge for downloads so I added that link. 796 2008-06-30 19:51:40
"Quiz Stats" Automation It would be nice if the user was automatically redirected to "Quiz Stats", or have the "Quiz Stats" appear under the "Result: Thank you for your submission." section 792 2008-05-25 02:38:20
Re: Where is Chat in 1.10Beta? 791 2008-05-17 09:26:32
Where is Chat in 1.10Beta? I know I used Chat in 1.09.x and am experimenting with 1.10Beta - but where did Chat go - how do I activate it? 790 2008-05-16 12:54:13
Use tikiwiki.org forums for support Comments here should be about the documentation itself. For questions about how to use TikiWiki, etc., please post at http://tikiwiki.org/tiki-forums.php . More people will see the questions there. -- Gary 782 2008-04-13 13:58:14
Re: Re: Re: Re: Re: Re: Adding ads to Tikiwiki > > > > > > So how do I do it? > > > > > > Do I use site identity? > > > > > > Do I make a module for each kind of ad? > > > > > > Do I edit the theme? > > > > > > Do I edit something else? > > > > > > > > > > > > I want a half banner at the top. > > > > > > I want some smaller ads on either side. > > > > > > Maybe one somewhere in the center or at the > > > > > > end. > > > > > > > > > > # Create banner zone and put your banner there on Admin → Banners > > > > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > > > > > > > Example code to put in the Content area: > > > > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > > > > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > > > > > > > I got this: > > > > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > > > > > > > Do we need the locations if we are using site identity? > > > > > > it needed id=something > > > I thought that was optional > > Copy to clipboard <div id=htb style="margin-top:2px; margin-right:3px; position:absolute; top:0;right:0; ">{banner zone='home top banner'}</div> apostrophes around 'home top banner' 625 2008-04-12 16:02:55
Re: Re: Re: Re: Re: Adding ads to Tikiwiki > > > > > So how do I do it? > > > > > Do I use site identity? > > > > > Do I make a module for each kind of ad? > > > > > Do I edit the theme? > > > > > Do I edit something else? > > > > > > > > > > I want a half banner at the top. > > > > > I want some smaller ads on either side. > > > > > Maybe one somewhere in the center or at the > > > > > end. > > > > > > > > # Create banner zone and put your banner there on Admin → Banners > > > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > > > > > Example code to put in the Content area: > > > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > > > > > I got this: > > > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > > > > > Do we need the locations if we are using site identity? > > > > it needed id=something > > I thought that was optional > > Copy to clipboard <div id=htb style="margin-top:2px; margin-right:3px; position:absolute; top:0;right:0; ">{banner zone=home top banner}</div> That didn't work either. 624 2008-04-12 15:52:22
Re: Re: Re: Re: Adding ads to Tikiwiki > > > > So how do I do it? > > > > Do I use site identity? > > > > Do I make a module for each kind of ad? > > > > Do I edit the theme? > > > > Do I edit something else? > > > > > > > > I want a half banner at the top. > > > > I want some smaller ads on either side. > > > > Maybe one somewhere in the center or at the > > > > end. > > > > > > # Create banner zone and put your banner there on Admin → Banners > > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > > > Example code to put in the Content area: > > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > > > I got this: > > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > > > Do we need the locations if we are using site identity? > > it needed id=something > I thought that was optional Copy to clipboard <div id=htb style="margin-top:2px; margin-right:3px; position:absolute; top:0;right:0; ">{banner zone=home top banner}</div> 623 2008-04-12 15:49:09
Re: Re: Re: Adding ads to Tikiwiki > > > So how do I do it? > > > Do I use site identity? > > > Do I make a module for each kind of ad? > > > Do I edit the theme? > > > Do I edit something else? > > > > > > I want a half banner at the top. > > > I want some smaller ads on either side. > > > Maybe one somewhere in the center or at the > > > end. > > > > # Create banner zone and put your banner there on Admin → Banners > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > Example code to put in the Content area: > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > I got this: > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > Do we need the locations if we are using site identity? it needed id=something I thought that was optional 622 2008-04-12 15:38:18


We see that this only gives us the information about the object (the comment in this case), but what if I want to have more information before visiting the comment?

One way to do this is to add a column which indicates the item being commented on. It is typically a wiki page or tracker item which is clickable and takes me there.

So let's make some changes and see what we have:

Wiki Output Sample
Copy to clipboard
{LIST(cache="n")} {filter type="comment"} {pagination max="10"} {OUTPUT( template="table")} {column field="contributors"} {column field="title"} {column field="comment_content"} {column field="parent_object_title" mode="raw"} {column field="object_link" mode="raw"} {column field="date"} {OUTPUT} {FORMAT( name="object_link")} {display name="object_id" format="objectlink"} {FORMAT} {FORMAT( name="parent_object_title")} {display name="parent_object_type"}: {display name="wikiplugin_objectlink" format="wikiplugin" type="parent_object_type" id="parent_object_id"} {FORMAT} {sort mode="date_desc"} {LIST}

Here we have just added a new column whose label is "Parent Object".
The new FORMAT control block formats the parent_object_title field, which is the title of the comment's parent object, then with {display} tag we first display the name of the parent object, which is stored in the parent_object_type field. For example, if the parent object is a trackeritem, it will display "trackeritem:", and finally we display the link to the parent object, using the wikiplugin_objectlink plugin. This plugin allows you to create a link to a Tiki object according to its type and its identifier. Here you specify the link format as "wikiplugin", the object type as parent_object_type, and the object id as parent_object_id. For example, if the parent object is a trackeritem with id 1, this will generate a link to "tiki-view_tracker_item.php?itemId=1".
So you get a field that displays the name and link of the comment's parent object. For example, if the comment is linked to an item called "This is my first item", you display "trackeritem: This is my first item".
This gives us the following result:

Title Comment Parent Object Thread Id Date
Calendar links not accepted It is not possible to use a Calendar link in a Wiki page. The brackets which are required to specify the calendar ID cause the link to not be recognized as a link. [http:tiki-calendar.php?viewlist=list&calIds[]=1|Click here for Calendar] wiki page: Wiki-Syntax Links 799 2008-07-11 23:44:44
Easy PHP Download points to SourceForge I got a 404 when using the EasyPHP download link. The EasyPHP site points to Sourceforge for downloads so I added that link. wiki page: Windows Local Install EasyPhp 796 2008-06-30 19:51:40
"Quiz Stats" Automation It would be nice if the user was automatically redirected to "Quiz Stats", or have the "Quiz Stats" appear under the "Result: Thank you for your submission." section wiki page: Quiz User 792 2008-05-25 02:38:20
Re: Where is Chat in 1.10Beta? wiki page: Chat 791 2008-05-17 09:26:32
Where is Chat in 1.10Beta? I know I used Chat in 1.09.x and am experimenting with 1.10Beta - but where did Chat go - how do I activate it? wiki page: Chat 790 2008-05-16 12:54:13
Use tikiwiki.org forums for support Comments here should be about the documentation itself. For questions about how to use TikiWiki, etc., please post at http://tikiwiki.org/tiki-forums.php . More people will see the questions there. -- Gary wiki page: Banners 782 2008-04-13 13:58:14
Re: Re: Re: Re: Re: Re: Adding ads to Tikiwiki > > > > > > So how do I do it? > > > > > > Do I use site identity? > > > > > > Do I make a module for each kind of ad? > > > > > > Do I edit the theme? > > > > > > Do I edit something else? > > > > > > > > > > > > I want a half banner at the top. > > > > > > I want some smaller ads on either side. > > > > > > Maybe one somewhere in the center or at the > > > > > > end. > > > > > > > > > > # Create banner zone and put your banner there on Admin → Banners > > > > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > > > > > > > Example code to put in the Content area: > > > > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > > > > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > > > > > > > I got this: > > > > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > > > > > > > Do we need the locations if we are using site identity? > > > > > > it needed id=something > > > I thought that was optional > > Copy to clipboard <div id=htb style="margin-top:2px; margin-right:3px; position:absolute; top:0;right:0; ">{banner zone='home top banner'}</div> apostrophes around 'home top banner' wiki page: Banners 625 2008-04-12 16:02:55
Re: Re: Re: Re: Re: Adding ads to Tikiwiki > > > > > So how do I do it? > > > > > Do I use site identity? > > > > > Do I make a module for each kind of ad? > > > > > Do I edit the theme? > > > > > Do I edit something else? > > > > > > > > > > I want a half banner at the top. > > > > > I want some smaller ads on either side. > > > > > Maybe one somewhere in the center or at the > > > > > end. > > > > > > > > # Create banner zone and put your banner there on Admin → Banners > > > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > > > > > Example code to put in the Content area: > > > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > > > > > I got this: > > > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > > > > > Do we need the locations if we are using site identity? > > > > it needed id=something > > I thought that was optional > > Copy to clipboard <div id=htb style="margin-top:2px; margin-right:3px; position:absolute; top:0;right:0; ">{banner zone=home top banner}</div> That didn't work either. wiki page: Banners 624 2008-04-12 15:52:22
Re: Re: Re: Re: Adding ads to Tikiwiki > > > > So how do I do it? > > > > Do I use site identity? > > > > Do I make a module for each kind of ad? > > > > Do I edit the theme? > > > > Do I edit something else? > > > > > > > > I want a half banner at the top. > > > > I want some smaller ads on either side. > > > > Maybe one somewhere in the center or at the > > > > end. > > > > > > # Create banner zone and put your banner there on Admin → Banners > > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > > > Example code to put in the Content area: > > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > > > I got this: > > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > > > Do we need the locations if we are using site identity? > > it needed id=something > I thought that was optional Copy to clipboard <div id=htb style="margin-top:2px; margin-right:3px; position:absolute; top:0;right:0; ">{banner zone=home top banner}</div> wiki page: Banners 623 2008-04-12 15:49:09
Re: Re: Re: Adding ads to Tikiwiki > > > So how do I do it? > > > Do I use site identity? > > > Do I make a module for each kind of ad? > > > Do I edit the theme? > > > Do I edit something else? > > > > > > I want a half banner at the top. > > > I want some smaller ads on either side. > > > Maybe one somewhere in the center or at the > > > end. > > > > # Create banner zone and put your banner there on Admin → Banners > > # Put the on SI and enable the checkbox " Site ads and banners " and Publish checkbox > > > > Example code to put in the Content area: > > Copy to clipboard <div style="margin-top: 2px; margin-right: 3px; position: absolute; top: 0; right: 0;">{banner zone=Firefox}</div> > > > > For left/right column you can use another banner zone banners using the in custom module which you have to create on Admin → Modules . > > I got this: > Fatal error: Smarty error: in evaluated template line 1 : syntax error: expecting '=' after attribute name 'top' (Smarty_Compiler.class.php, line 1555) in /home/dogshed/public_html/lib/smarty/libs/Smarty.class.php on line 1095 > > Do we need the locations if we are using site identity? it needed id=something I thought that was optional wiki page: Banners 622 2008-04-12 15:38:18

Using Font Awesome icons instead of content depending on the value of the field content


Tweaking the sample above and using font awesome (integrated in Tiki) you can display corresponding icons for a content.
In this demo case we have a tracker with a "gender" field that hold 2 values, "male" or "female". There is a "male" and a "female" icon in Font Awesome and as both use the same term we can assign it to a div type icon and class.

Copy to clipboard
{LIST()} {filter field="tracker_id" content="42"} {OUTPUT(template="table")} {column label="Title" field="title" sort="title"} {column label="Gender" field="gender"} {OUTPUT} {FORMAT(name="gender")}{DIV(type=i class=fa fa-{display name="tracker_field_gender"})}{DIV}{FORMAT} {LIST}

Editable inline sample using the table template

Copy to clipboard
{column label="First Name" field="firstName" mode=raw} ... {FORMAT(name="firstName")}{display name="tracker_field_firstName" format=trackerrender editable=inline}{FORMAT}

Editable inline sample in a smarty (or wiki) template

In this wikiplugin embedded in a smarty (or wiki) template the field is set to be editable inline (note: format="trackerrender" is required ad well as the Inline editing (found in admin control panels=>trackers)

Copy to clipboard
{wikiplugin _name=list} {literal} {filter content="2" field="tracker_id"} {output(template="mytemplate.tpl")} {ALTERNATE()} empty {ALTERNATE} {FORMAT(name="name")}{display name="tracker_field_name" editable="inline" format="trackerrender" default=""}{FORMAT} {/literal} {/wikiplugin}


So the 2nd column uses a FORMAT plugin where the contents of the field in question, tracker_field_data, is used as the class for a div but the default (used if the data field is empty) is set to be the bootstrap class "hidden" so the contents, the check mark, only appears if there is some data.

Obviously if the data is the name of some other class weird stuff might happen, but for most usual cases, it works as expected and saves having to make a new smarty template just for this simple list.

(Tip and example taken from a message from JonnyB in the developers list - thanks!)

Using Font Awesome icons instead of content depending on the value of the field content


Tweaking the sample above and using font awesome (integrated in Tiki) you can display corresponding icons for a content.
In this demo case we have a tracker with a "gender" field that hold 2 values, "male" or "female". There is a "male" and a "female" icon in Font Awesome and as both use the same term we can assign it to a div type icon and class.

Copy to clipboard
{LIST()} {filter field="tracker_id" content="42"} {OUTPUT(template="table")} {column label="Title" field="title" sort="title"} {column label="Gender" field="gender"} {OUTPUT} {FORMAT(name="gender")}{DIV(type=i class=fa fa-{display name="tracker_field_gender"})}{DIV}{FORMAT} {LIST}

It will display a
if the content of the field = male and a
if the content of the field = female.


When you use a template to display your plugin list you want other item related or linked to the item to open using the same template (or another it doesn't matter) but not to open the trackers built-in system. For this you need to enable the Alias feature and set it to use the template to display the tracker item, "record-" for this sample.

When you use an item link to link an item to other item (related, friend of, etc.) this is a kind of a problem.
Item link has 2 option to display and item link. Value and Link.
Value display the id of the content (ie: 6).
Link display the value of the content linked to the tracker item (ie: Bernard).

Your link should be like:

Copy to clipboard
[record-6|Bernard]

So it open the item "Id6" in the "record-" template showing the value "Bernard" for the link.
To achieve this you need to create and use 2 row.

Copy to clipboard
{FORMAT(name="name")}{display name="tracker_field_contact" format=trackerrender}{FORMAT} {FORMAT(name="id")}{display name="tracker_field_contact"}{FORMAT}


The first one with format=trackerrender will display the content of the tracker Item Link field as it is shown in the tracker (Bernard).
The second one without the format=trackerrender will show the real value for this field (6).

The assemble your link as follow:

Copy to clipboard
[record-{display name="id"}|{display name="name"}]

It will complete the trick and open the item 6 using the record- template while the link displayed will show the right value, Bernard.

All the LIST Plugin control blocks