Loading...
 
Skip to main content

History: Sublist

Source of version: 10

Copy to clipboard
            ! PluginList sublist
New in ((Tiki27)), permitting to improve ((PluginList)), and fixes/enhancements are being backported to the ((Tiki26)) branch. Once it is more stable/robust, it may also be backported to ((Tiki24)).

This was one of the recommendations from this large project: [https://fosdem.org/2024/schedule/event/fosdem-2024-3484-pushing-tiki-to-its-limits/|FOSDEM 2024]

__Related Merge request__: [https://gitlab.com/tikiwiki/tiki/-/merge_requests/4353|PluginList SUBLIST MR]

!!Example Usage
 PluginList SUBLIST gives the ability to join several trackers and get mixed results into a single array, greatly optimizing the performance when subqueries and sub-list plugins are needed.
__Steps to follow__:
# Create a tracker called __Region__ with ID, Name as fields
# Create an other tracker called __Hospital__  with ID, Name and Region (Item Link pointing to region tracker)
# Fill all trackers with data as well 
# Apply this code:
{CODE()}
!!! Stock table template
{LIST()}
  {filter type="trackeritem"}
  {filter field="tracker_id" exact="1"} 
  {SUBLIST(name="region")}
    {filter field="tracker_id" exact="2"} 
    {filter field="object_id" exact="$parent.tracker_field_hospitalRegion$"}
    {FORMAT(name="name")}{display name="tracker_field_regionName" default=""}{FORMAT}
  {SUBLIST}
  {OUTPUT(template="table")}
    {column field="hospital" label="Hospital" mode="raw"}
    {column field="region" label="Region" mode="raw"}
  {OUTPUT}
  {FORMAT(name="hospital")}{display name="tracker_field_hospitalName"  default="" }{FORMAT}
  {FORMAT(name="region")}{display name="region.name" default=""}{FORMAT}
{LIST}
{CODE}
First List Plugin joins tracker 1 (tracker hospital) and tracker 2 (tracker region) with an Item Link field in tracker 1 (tracker hospital) pointing to tracker 2 (tracker region) called __tracker_field_hospitalRegion__....Sublist filters the results by the ID of the record coming from the parent tracker(here tracker region). 
__Note:__ The underlying implementation makes sure to execute only one query for all the records found in the parent list block and then distributes the results to the relevant resultset rows.
Output template is using the stock table template with wiki formatting the name field of tracker 2 (tracker region) and then wiki formatting the table column for region name using nested keys like 'region.name'.
Region is the key name in SUBLIST block, so it adds an array of records in the parent row under the 'region' key. Then, it formats and adds the tracker 2 (tracker region) field(s) to that key for each parent record.
''The given above code in step 4, would produce (accordingly to the data filled in trackers...step 3 )'': 
{img src="display2015" link="display2015" width="400" rel="box[g]" imalign="center" desc="Click to expand" align="center" styleimage="border"}

!!Example Using Pivot table
You can use SUBLIST in pivottable as you normally would in a plugin list - define the SUBLIST and either format some of the columns there or leave all columns (skip formatting blocks in sublist). In order for the results to appear in the main pivottable array of data, you must include the fields in the display blocks in the main pivottable. 
__Assure__ that you have the two trackers as documented above, then apply this code:
{CODE()}
{PIVOTTABLE(data="tracker:1" cols="hospital.regionName" vals="hospitalName" colOrder="key_a_to_z" rowOrder="key_a_to_z" rendererName="Table" aggregatorName="List Unique Values" inclusions="{}" menuLimit="500" aggregateDetails="object_type" highlightMine="n" highlightGroup="n" chartHoverBar="y")}
{display name="tracker_field_hospitalName"}
{display name="hospital.tracker_field_regionName"}
{SUBLIST(name="hospital" required="1")}
  {filter field="tracker_id" exact="2"}
  {filter field="object_id" exact="$parent.tracker_field_hospitalRegion$"}
{SUBLIST}
{PIVOTTABLE}
{CODE}
This example shows how to include 2 remote tracker fields (tracker_field_hospitalName, tracker_field_regionName) in the parent result set using the keys 'tracker_field_hospitalName' and 'hospital.tracker_field_regionName'. These 2 will appear as fields in the ((PluginPivotTable)) and you would be able to use them as normal fields.
__Note__ that this works for non-multiple use-cases. If you have multiple results, they will appear as an array and there might be problems handling the data in pivottable.
__Also note__ that the required="1" parameter filters out all of the parent tracker entries that don't have at least one sublist element.
''The given above code would produce'':
{img src="display2028" link="display2028" width="400" rel="box[g]" imalign="center" desc="Click to expand" align="center" styleimage="border"}
!! Related
See also:
* ((PluginTrackerList))
* ((PluginTrackerList To PluginList Converter))
* ((PluginTracker))
* ((PluginList))
* ((PluginPivotTable))
        

History

Advanced
Information Version
Bernard Sfez / Tiki Specialist 17
Jean-Marc Libs 16
luciash d' being 🧙 separate the notes a bit 15
Baraka Kinywa Trackers order creation, Tracker Region id 1 and Tracker Hospital id 2 14
Jean-Marc KADIMBA 13
Jean-Marc KADIMBA The tracker Region must be the tracker 1 and Hospital the tracker 2, because Region is created before Hospital. In the SUBLIST we use the tracker Region (Tracker 1) 12
Jean-Marc KADIMBA The tracker Region must be the tracker 1 and Hospital the tracker 2, because Region is created before Hospital 11
Baraka Kinywa 10
Marc Laporte Cosmetic 9
Baraka Kinywa 8
Baraka Kinywa 7
Marc Laporte 6
Baraka Kinywa 5
Marc Laporte 4
Marc Laporte 3
Marc Laporte 2
Marc Laporte 1