Loading...
 
Skip to main content

History: PluginTracker

Source of version: 151

Copy to clipboard
            ! Plugin Tracker
Use this ((wiki plugin)) to create a form for inputting an item into a tracker. You can specify what fields will be included in the form. In ((Tiki6)), this plugin can also be used as a simple way to create custom forms which output the result as preformatted wiki pages instead of tracker items.
{maketoc levels="2,3"}
!! Parameters
{pluginmanager plugin="tracker"}
{REMARKSBOX(type="note",title="Note")}The -+overwrite+- parameter is only to overwrite tracker items (not wiki pages) - not useful when -+discarditem="y"+- {REMARKSBOX}
{REMARKSBOX(type="note",title="Note 2")}When using -+outputwiki+- as template you cannot use Smarty syntax programmatically because the resulting output is static wiki page (not computed against an existing Tracker Item like with Pretty Trackers and TrackerLists) - you can use only -+{$f_XX}+- to indicate the fields values or ((Argument variables)).{REMARKSBOX}
!! Administration
* You can limit the tracker fields that can be used in this plugin in the field admin panel of the tracker: 
+ "Field is public? for use with ((PluginTrackerlist|trackerlist plugin)) option
+ For Tiki 9.x, the User Selector field (the "userId" field in your tracker, perhaps), edit the field, Permissions, Visibility, Visible by All (even though that's counter-intuitive (you want those items private to that use).  
* If you have a tracker that has only one item per user/IP or if you use the plugin with the param view=user, the plugin will automatically the item if already exists. 
{REMARKSBOX(type=warning, title=Warning)}This plugin can not be used on a cached wiki page.{REMARKSBOX}
!! Examples
{CODE(colors="tiki")}
{TRACKER(trackerId="1" fields="1:3:4" action="Send")} Thank for your contribution! {TRACKER}
{CODE}

!!!How to prefill some fields
In some situation you want to go in a TRACKER page (for our example named SubmitOrder ) where fields are automatically prefills. In this case you can use an URL like this:
 -+tiki-index.php?page=SubmitOrder&autosavefields=1&autosavevalues=tikiwiki+-

When in the page SubmitOrder, you click on save the field 1 will be filled with the value tikiwiki. If the field 1 is multivaluated field(ex: category), the value will be added to the potentially additional value the user has selected whatever the user do.
Tip:
The construction of such url can use the feature 'Wiki argument variables'
(see ((Advanced Wiki Syntax usage examples|#How_to_display_URL_param_in_a_page_or_the_page_name_or_the_user_name)))
 -+~np~tiki-index.php?page=SubmitOrder&autosavefields=2:3&autosavevalues={{itemId}}:{{page}}~/np~+-

See also ((PluginTrackerList)) to see how to use the parameter url to transfer an itemId to an URL or ((PluginJQ)) if you want to use jQuery.

!!! How to fill an item in more than one step
If you want to fill some fields of an item in a page and to fill some other ones in another page, you need to use the param ''url'' with the ''itemId'' option.
Example (uses ((SEFUrl)) enabled links):
Page1
{CODE(colors="tiki")}
{tracker trackerId="1" fields="1:2:3" url="Page2?itemId"}
{CODE}
Page2
{CODE(colors="tiki")}
{tracker trackerId="1" fields="4:5:6" url="Page3?itemId"}
{CODE}
Page3 - the final one that will display the currently submitted itemId:
{CODE(colors="tiki")}
{trackerlist trackerId="1" fields="1:2:3:4:5:6"}
{CODE}

!!! How to put multiple tracker plugins into a single transaction?
''New in ((Tiki15))''
Plugin tracker's transaction feature enables a sequence of trackers to be chained into a single transaction, which is submitted only after the user submits the last tracker form. Otherwise the transaction is cancelled.
The easiest way to use the feature is to create a wiki page for each of the steps.
Here is an example.
# wiki page: Register+Step+1
+ {CODE(wrap="1" colors="tiki")}
{tracker trackerId="1" fields="2" action="Next" ignoreRequestItemId="y" registration="y" chosenGroup="Registered" transactionName="RegistrationTransaction" transactionStep="0" transactionFinalStep="n" url="Register+Step+2"}
{CODE}
# wiki page: Register+Step+2
+ {CODE(wrap="1" colors="tiki")}
{tracker trackerId="2" fields="4" action="Finish" ignoreRequestItemId="y" transactionName="RegistrationTransaction" transactionStep="1" transactionFinalStep="y"}
{CODE}
The registration and the tracker records of trackerId 1 and 2 will only get saved after the user presses Finish on Register+Step+2.


!!! How to write a template
As mentioned, in a template, use the -+{$f~095~__id__}+- syntax to insert the value of ''fieldId''=__id__.
It is also possible to insert the ''ItemId'' itself, which is useful to create new wiki pages with tracker plugins inside. To do this you'll have to add an ((Auto-Increment Field)) to your tracker, with the appropriate options to auto-fill it with the ''itemId''. This new field content (''itemId'' value) can then be inserted in the template with the syntax seen above.

Since ((Tiki15|Tiki 15.1)), wiki page templates can be used for email notifications using the "__wiki:page name tpl__" format instead of template_name.tpl files in the templates/mail dir. Tiki will use a page "page name subject tpl" if found.

!!How to go from TRACKERLIST to TRACKER on this item
{CODE(colors="tiki")}
{trackerlist trackerId="1" fields="1:2:3:4:5:6" url="Page1?itemId"}
{CODE}

!!How send email to a recipient when new tracker item is created
You can use the parameter email to send an email once the tracker item has been created.
''To do this it is now (Tiki15) required to have a template placed in your tiki files in the templates/mail directory, or specified as a wiki page as "wiki:page name tpl".''

The format for the parameters is : from|to|template.
*__from__ is the sender email that will be used for the notification. Multiple address can be set (separate multiple addresses with a comma)
*__to__ is the recipient(s). Multiple address can be set (separate multiple addresses with a comma)
* __template__ is the template(s) to be used for email subject and body. (separate template can be used)
+Using several emails and several templates it is possible to send different email (different subject & body) to different people. (see exemple below)

Since ((Tiki15|Tiki 15 .1)), tracker plugin allow ((Items List and Item Link Tracker Fields|Items List fields)) to be used as the __to__ or __from__ fields in the email parameter. They wil be shown in the form as read only labels. This might be useful in cases such as:
* One tracker defines business shops, with it's members to be notified of changes related to that shop. And...
* A second tracker handles data of products from shops, and they have:
** one field as Item link to relate the product with their corresponding shop where they sell it.
** another field from the second tracker is an items list, to indicate the person to be notified, as user defined in the first tracker for that shop. 
* You use the email parameter in a plugin tracker call to tracker 2, using the field corresponding to the person (as field id in tracker 2) as the recipient or sender of the email.


!!!Basic plugin usage (single recipient, single template)
{CODE(colors="tiki")}
{TRACKER(trackerId="1" fields="1:2:3" action="Send" email="sender@domain.com|recipient@domain.com|templatename.tpl")}{TRACKER}
{CODE}

!!!Advanced plugin usage 1 (multiple recipients, single template)
{CODE(colors="tiki")}
{TRACKER(trackerId="1" fields="1:2:3" action="Send" email="sender@domain.com|recipient_1@domain.com,recipient_2@domain.com,recipient_3@domain.com|templatename.tpl")}{TRACKER}
{CODE}

In this case it will be sent the same notification to recipient_1, recipient_2 and recipient_3.

!!!Advanced plugin usage 2 (multiple recipients, multiple templates)
{CODE(colors="tiki")}
{TRACKER(trackerId="1" fields="1:2:3" action="Send" email="sender@domain.com|recipient_1@domain.com,recipient_2@domain.com,recipient_3@domain.com|templatename_a.tpl,templatename_b.tpl,templatename_c.tpl")}{TRACKER}
{CODE}

In this case each recipient will receive a different notification. recipient_1 will receive email using template_a, recipient_2 will receive email using template_b and recipient_3 will receive email using template_3.

!!!Templates 
Each template needs two files, one for the subject one for the body. The subject will be named template_subject.tpl. All the templates must be in the templates/mail directory, or (since Tiki15.1) in wiki pages and specified as "wiki:page name tpl".

!!!!Subject template (template_subject.tpl)
{CODE(colors="tiki")}
Hello, the {tr}item{/tr} "{$f_name}" {tr}was modified at{/tr} {$server_name} in {$mail_trackerName}
{CODE}

Where {$f_name} will the content of the field name, {$server_name} is the domain name and {$mail_trackerName} is the tracker name.

!!!!Body template (template.tpl)
{CODE(colors="tiki")}
{tr}Hello,{/tr}

{tr}Title:{/tr} {$f_name}
{tr}Description:{/tr} {$f_description}

{tr}View the tracker item at:{/tr}
	{$mail_machine_raw}/tiki-view_tracker_item.php?itemId={$mail_itemId}
{CODE}

!!!!Template - variable list
Not all wiki variables works (pretty tracker syntax won’t work).
;$mail_date : The current timestamp
;$mail_user : User login
;$mail_itemId : The tracker itemId
;$mail_item_desc : The item "title"
;$mail_trackerId : Tracker id
;$mail_trackerName : Tracker name
;$mail_machine : URL of the request
;$mail_machine_raw : URL of the site root (??)
;$status : The item's new status (e.g. Open, Pending or Closed, translated)
;$f_123 or $f_permanentName : Values of the fields


!!Related pages
* ((PluginTrackerlist)) - which displays a given tracker items. 
* ((Plugin Tracker Advanced))
        

History

Information Version
luciash d' being πŸ§™ 180
luciash d' being πŸ§™ 179
luciash d' being πŸ§™ Prefer US English 178
Yves Kipondo 177
Torsten Fabricius 176
luciash d' being πŸ§™ added zero-width space ("​") to avoid parsing the argvariables example 175
luciash d' being πŸ§™ I wonder why the params section was commented out by https://doc.tiki.org/user12324 174
Bernard Sfez / Tiki Specialist Corrected tab + url code 173
Bernard Sfez / Tiki Specialist 172
Bernard Sfez / Tiki Specialist 171
Bernard Sfez / Tiki Specialist Adding ?cookietab= case 170
Marc Laporte 169
Jean-Marc Libs 168
Jean-Marc Libs 167
Jonny Testing test 166
luciash d' being πŸ§™ 165
luciash d' being πŸ§™ 164
Xavier de Pedro Edit restored by rescue script 2017-04-24T18:09:12+00:00 163
Bernard Sfez / Tiki Specialist Edit restored by rescue script 2017-04-24T18:09:12+00:00 162
Xavier de Pedro 161
Torsten Fabricius minor formatting 160
Torsten Fabricius 159
Torsten Fabricius added createdBy documentation and new examles 158
Torsten Fabricius added info and recommendation to 'Hw to write a template' 157
Xavier de Pedro 156
Xavier de Pedro 155
Xavier de Pedro improved a bit (hopefully, thanks jonnyb for tips and feedback) 154
Xavier de Pedro 153
Marc Laporte 152
Xavier de Pedro 151
Xavier de Pedro 150
Xavier de Pedro 149
Xavier de Pedro 148
Jonny Bradley 147
Bernard Sfez / Tiki Specialist 146
Bernard Sfez / Tiki Specialist 145
DavidBright Fix typo 144
lindon 143
lindon 142
lindon 141
Marc Laporte fix typos 140
Gergely + tracker transaction 139
Xavier de Pedro 138
Xavier de Pedro added tip from jonny (thanks!) 137
Xavier de Pedro attempting to fix defective example? (missing the end of the example) 136
lindon 135
Nelson Ko 134
Nelson Ko 133
Nelson Ko 132
Geoff Brickell 131