Loading...
 
Skip to main content

History: PluginList display control block

Source of version: 50 (current)

Copy to clipboard
            !LIST - display
The DISPLAY control block (or block) is used when you want to display something in-place where you put it - either in the body of a ((PluginList FORMAT control block|FORMAT)) block or directly in the body of the ((PluginList OUTPUT control block|OUTPUT)) block or in a referenced custom template (Smarty tpl file or a wiki page).

!!Syntax
DISPLAY block has two possible syntax options similar to ((Wiki-Plugin)) syntax.
For example you could use:
{CODE(colors="tiki")}{DISPLAY(param="foo")}{DISPLAY}{CODE}

But it seems the body of the DISPLAY block is never rendered anyway so it is obviously better to use the ''lowercase'' shortened version without the content part:
{CODE(colors="tiki")}{display param="foo"}{CODE}

The -+param="foo"+- can be e.g. -+format="plain"+-.
It is possible to omit the double quotes but it is recommended to use them for consistency just in case a value contains spaces.

!!!Parameters
* ''name''
+ mandatory parameter where you put the name of the ((Search and List from Unified Index|Indexed Field)) you want to display or an alias which refers to name of the ((PluginList format control block|FORMAT)) block.
* ''default''
+ The DISPLAY 'plugin' can have an additional -+default+- parameter to specify the value to use if the object type does not contain the named value
** use -+default=" "+- to show a blank value instead of -+No value for ...+- when there is no value
* ''format''
+ The DISPLAY 'plugin' can have an additional ''format'' parameter to specify custom display methods
** -+plain+- : as-is, default format (does not work with Arrays as is, you need to add the -+separator=""+- param below on them)
*** Optional -+separator+- attribute
** -+date+- : using the short date format
*** Optional -+dateFormat+- to specify the date format using [https://secure.php.net/manual/en/function.strftime.php|strftime] (since 15.4 approx)
** -+datetime+- : using the short datetime format (Tiki8)
** -+timeago+- : using the timeago.js formatting for more readable dates and times (Tiki16/15.3)
** -+imagegrabber+- : automatically grabs images from a source that is provided. set format="imagegrabber" to use.
*** Mandatory -+name+- attribute is the content for which you're searching
*** Optional -+content_type+- attribute is either -+html+- when searching through html source, or -+forumpost+- (default for backwards compatibility) to search for images in a forum.
*** ''Example use: 
+++ {CODE(colors="tiki")}{FORMAT(name="images")}{display name=article_content format="imagegrabber" content_type="html" width="150" max="3" default="img/icons/synergiq-folder.png"}{FORMAT}{CODE}
*** Return value for -+html+- is in the following format, assuming a return of 3 images: 
+++ {CODE(colors="htmlmixed")}<img src='http://abc/imagea.jpg'>
<img src='http://abc/imageb.jpg'>
<img src='http://abc/imagec.jpg'>{CODE}
** -+objectlink+- : uses the value as the label to a link to the object
** -+slug+- : render values out using the current wiki url scheme ''(Tiki 18.2+)''
** -+ url+- : render urlencoded values. Useful for building URLs ''(Tiki 21.3+)''
** -+snippet+- : to display the initial portion of the a large text
*** Optional -+length+- attribute
*** Optional -+suffix+- attribute
** -+reference+- : to display a link based on the value
*** Mandatory -+type+- attribute
**** Type can be:
***** -+comment+-
***** -+external+- (or -+external_extended+-)
***** -+forumpost+- (or -+forum post+-)
***** -+freetag+-
***** -+group+- (n.b. Nowhere to link, at least, yet.)
***** -+relation_source+-
***** -+relation_target+-
***** -+trackeritem+-
***** -+trackeritemfield+-
***** -+user+-
***** -+wiki+- -+wikipage+- or -+wiki page+-
*** Optional -+separator+- attribute
*** Use -+format=reference+- for tracker fields which are -+page selector+- fields, to assure that you link to the page whose name is contained in the tracker, rather than to the tracker record.
** -+trackerrender+- : to render a tracker field (when using -+trackerrender+- the Smarty variable -+$context.search_render+- will be -+y+- and can be used to have different formatting in the trackeroutput Smarty tpl)
** -+templaterender+- : to use a field as a template ''(Tiki 19)'' - experimental, more info to come...
** -+wikiplugin+- : Renders a wiki plugin in the list output
*** -+name+- : plugin name, e.g. wikiplugin_img
*** -+default+- : fallback values for any parameters in url query format (e.g. -+fileId=42&caption=Not+Found+-) ''(Tiki 11)''
*** -+content+- : plugin content body
*** other plugin params ''(Tiki 11)''
** -+categorylist+-, to display category names instead of category id's. By default, it will display categories in html unordered lists; but you can produce a plain text list of category names when you add the parameter: separator=",". (Tiki =>16.2)+-
** -+number+-, to display formatted number using php number_format function. Accepts parameters: decimals=0 (number of decimal digits), dec_point=. (decimal point character), thousands_sep=, (thousands separator character). (Tiki =>17.0)+-
** -+currency+-, to display currency field in different currency using exchange rates for a given date. Accepts parameters: target_currency=USD (the currency to display data in), date=tracker_field_transactionsDate (permanent name of a tracker field holding date of exchange rate or a formatted date here), symbol=y|n (default y meaning to use currency symbol, n meaning to use currency code). (Tiki =>19.0)+-
* ''list_mode''
+ (Tiki 9+) -+list_mode="y"+- can be added to use the list display settings for that field. e.g. -+{display name="tracker_field_42" format="trackerrender" list_mode="y"}+-; other option is -+list_mode="csv"+- to display as plain text value
* ''pagetitle''
+ (Tiki 9+) -+pagetitle="y"+- will set the browser title to the contents of the field for the first item found in the results with page title set (useful for single item result pages)
* ''pagedescription''
+ (Tiki 11+) -+pagedescription="y"+- will set the page's meta description tag to the contents of the field for the first item found in the results with -+pagedescription+- set if the -+metatag_pagedesc+- preference is enabled.
** __Note:__ For both -+pagedescription+- and -+pagetitle+- no filtering is performed on the content, so use plain text only and avoid non-alphanumeric characters.
* ''editable''
+ (Tiki 11+) -+editable="inline"+- will set the field to be editable for tracker fields when using format -+trackerrender+-. Required: "Inline editing (found in trackers)" and column should be set to mode=raw. e.g:
+{CODE(colors="tiki")}
{column label="First Name" field="firstName" mode=raw}
{FORMAT(name="firstName")}{display name="tracker_field_firstName" format="trackerrender" editable="inline"}{FORMAT}
{CODE}
* The __FORMAT__ 'plugin' allows to apply a wiki template and store it inside a named value. The value can then be used inside an other wiki template, or more usefully inside a smarty template.
*''Action''
**There is no built in "actions" field (edit, delete, etc.) for PluginList yet (March 2021) so you have to use a custom configuration. An example in wiki syntax is listed below.

!!! Examples
!!!! General
{CODE(colors="tiki" theme="default")}Display blog post with title (yes, you can use vanilla HTML code in the OUTPUT)
<h2>{display name="title" format="objectlink"}</h2>
{display name="blog_content"}

Display shortened blog post snippet
{display name="blog_content" format="snippet" length="96" suffix="…"}

Display category links
{display name="categories" format="reference" type="category"}

Display freetag links
{display name=freetags" format="reference" type="freetag"}

Display item link
{display name="tracker_field_42" format="trackerrender"}
{display name="tracker_field_42" format="reference" type="trackeritem"}

Display start of a wiki page
{display name="wiki_content" format="snippet" length="500 " suffix="..."}

Display a username and real name (e.g. for blog posts) with link to user info:
{display name="contributors" format="reference"}
{display name="contributors" format="reference" type="user"}

Display field in FORMAT block referenced via alias "foo"
{display name="foo"}

(Please note FORMAT must be always outside of the OUTPUT)
{OUTPUT()}Preview of the Foo: {display name="foo"}{OUTPUT}
{FORMAT(name="foo")}{display name="wiki_content" format="snippet" length="500 " suffix="..."}{FORMAT}

(Tiki 8) Categories
(n.b. does not seem to work on the mysql engine, checked in Tiki 12 and 14 - not tried Lucene)
{display name="categories" format="categorylist" singleList="y"}
{display name="categories" format="categorylist" requiredParents="15,20" excludeParents="5,6"}
{display name="categories" format="categorylist" singleList="y" separator=", "}

Display a time only
{display name="modification_date" dateFormat="%k:%M"}

Display only the year
{display name="tracker_field_dateOpening" format="date" dateFormat="%Y"}

Display a tracker item's status only
{display name="tracker_status" format="trackerrender"}


Display an 'action'
''Note: this is an example of only displaying 'Delete' Tracker item functionality, other functionality, for example 'edit' will be different''
{DIV(class="btn btn-danger text-white click-modal")}[tiki-tracker-remove_item?trackerId=11&modal=1&itemId={display name="object_id"}|{icon name="delete"}]{DIV}
{CODE}

!!!! Wiki Plugin Formatting
{CODE(colors="tiki" theme="default")}

(Tiki 9) Wiki Plugins
{display name="wikiplugin_addtocart" format="wikiplugin" code="tracker_field_42" description="tracker_field_43" price="tracker_field_44"}

(Tiki 11)
{display name="wikiplugin_img" format="wikiplugin" fileId="tracker_field_pic" thumb="box" default="fileId=42"}

If the wiki plugin needs a body, this goes into the content
{display name="wikiplugin_list" format="wikiplugin" content="{filter type=trackeritem} {filter field=tracker_id exact=4}" }
Note: this makes use of the fact that single-word parameters don't really need to be surrounded by double quotes. The same result is obtained with the more ugly:
{display name="wikiplugin_list" format="wikiplugin" content="{filter type=\"trackeritem\"} {filter field=\"tracker_id\" exact=\"4\"}" }

(Tiki 19 - backported to 18.4)
To replace parts of the content parameter with data from the results surround the field name with %percentages%
This example shows the number of comments on each tracker item
{display name="wikiplugin_list" format="wikiplugin" content="{filter type=comment} {filter field=parent_object_type content=trackeritem}{filter field=parent_object_id content=%object_id%}{output template=count}{ALTERNATE()} 0 {ALTERNATE}"}

{CODE}

!!Related
!!!All the LIST Plugin control blocks
{toc pagename="PluginList"}