What is Hash Variable?
A hash variable is a special hash-escaped keyword that can be used in :
- Form Builder
- Datalist Builder
- Userview Builder
- Supported plugin configuration properties
- Activity name in Workflow Designer
- External Form URL when mapping an activity to an external form
to return the value of some useful runtime variables from Joget components.
Download the tutorial app on Hash Variables from Joget Workflow Marketplace to learn more about Hash Variable.
Nested Hash Variable
Since version 3.0.3, a Hash Variable can be used inside another Hash Variable to form a Nested Hash Variable.
The syntax for the inner Hash Variable is wrapped by a pair of curly bracket.
#prefix.{prefix.variableKey}#
#date.{envVariable.dateFormat}#
#user.{variable.username}.firstName#
#form.tableChild.field1[{form.tableParent.childId}]#
Escaping the Resultant Hash Variable
The parsed/returned Hash Variable may cause incompatibility with the current context/environment such as syntax error in a script. Therefore, one may pass in additional parameters into the hash variable declared to escape certain characters.
Before ending a hash variable with a hash "#", add a question mark character "?" followed by the required format. You may include multiple by defining semicolon ";" separated values.
- regex - Used to escape regular expression special characters
- json - Used to escape JSON special characters
- javascript - Used to escape Javascript special characters
- html - Used to escape HTML special characters
- xml - Used to escape XML special characters
- java - Used to escape Java special characters
- sql - Used to escape SQL special characters
- url - Used to escape URL special characters
- nl2br - Used to convert new line character to <br> HTML tag
- separator(SEPARATOR_CHARS) - Used to change the default separator ";" to the SEPARATOR_CHARS. eg. ?separator(, ) resulted "abc, def" instead of "abc;def".
#envVariable.script?java# #envVariable.script?nl2br;json# #form.table.users?separator(, )#
nl2br and separator are new features in Joget Workflow v6.
List of Hash Variables
  
 
Workflow Assignment Hash Variable
| Name | Description | 
|---|---|
| Prefix | assignment | 
| Description | To get workflow activity information of the current assignment. | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | To display the assignee's name: #user.{assignment.assigneeId}.firstName# #user.{assignment.assigneeId}.lastName# | 
Current User Hash Variable
| Name | Description | 
|---|---|
| Prefix | currentUser | 
| Description | To retrieve currently logged in user information. | 
| Attributes | 
 In Joget Enterprise edition, these additional attributes are available:- User Meta 
 Organization 
 Department 
 Grade 
 HOD 
 Group 
 Employment 
 Department HOD 
 | 
| Scope of Use | 
 | 
Date Hash Variable
| Name | Description | 
|---|---|
| Prefix | date | 
| Description | To get date time according to a specified format. Localization In Joget Workflow v5, the returned value would follow current logged in user's timezone. If user's information is not available, then it will use server's timezone. | 
| Attributes | 
 Options dateFormat 
 dateUnit 
 integerValue 
 | 
| Scope of Use | 
 | 
| Sample Attributes | #date.h:mm a# // 12:08 PM#date.EEE,d MMM yyyy h:mm:ss a# // Wed, 4 Jul 2014 12:08:56 PM#date.DAY+7.EEE,d MMM yyyy h:mm:ss a# // Add 7 days on top of current date time - Wed, 11 Jul 2014 12:08:56 PM#date.DAY-1.EEE,d MMM yyyy h:mm:ss a# // Minus 1 days on top of current date time - Wed, 3 Jul 2014 12:08:56 PM | 
Environment Variable Hash Variable
| Name | Description | 
|---|---|
| Prefix | envVariable | 
| Description | To retrieve Environment Variable value. Learn more about Environment Variables . | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | #envVariable.smtpServer##envVariable.smtpPort# | 
Form Data Hash Variable
| Name | Description | 
|---|---|
| Prefix | form | 
| Description | To get field value from form table. | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | #form.registration.registeredDate# //will use the current record ID#form.registration.registeredDate[0001]# //0001 is the record ID to seek for  #form.registration.registeredDate[{variable.recordId}]# //using nested Hash Variable with curly bracket. | 
Form Binder Hash Variable
This is a new feature in Joget Workflow v6.
| Name | Description | 
|---|---|
| Prefix | binder | 
| Description | To get field value or field value label from the binder of a form via its form definition id . The 'binder' prefix retrieves the field value, while the 'binder.options' prefix retrieves the lookup field (eg. select box, checkbox & radio button) option label. The field value or field value label can also be obtained from other apps by including the APP_ID, else it uses the current app context. By providing the PRIMARY_KEY argument, field value or field value label from a different record can be retrieved, else data from the current record id is retrieved instead. | 
| Attributes | 
 
 
 
 
 
 
 
 | 
| Scope of Use | 
 | 
| Sample Attributes | #binder.addCard.title# #binder.cardViewer.addCard.title# #binder.cardViewer.addCard.title[b30bce20-c0a82095-14976e70-fded1735]# #binder.options.addCard.title# #binder.options.cardViewer.addCard.title# #binder.options.cardViewer.addCard.title[b30bce20-c0a82095-14976e70-fded1735]# | 
App Message Hash Variable (Internationalization)
| Name | Description | 
|---|---|
| Prefix | i18n | 
| Description | To support language localization on application level. | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | #i18n.logout# | 
| Example | Please see Add Message. | 
Performer Hash Variable
| Name | Description | 
|---|---|
| Prefix | performer | 
| Description | To get user information of the performer of an activity. | 
| Attributes | 
 | 
| Scope of Use | 
 To get activityDefId (activity definition ID), mouseover the activity name in the Activity Mapping tab (Workflow Management Console); there will be an overlay showing the ID. The activity chosen must had already been performed. | 
| Sample Attributes | 
 | 
Request Parameter Hash Variable
| Name | Description | 
|---|---|
| Prefix | requestParam | 
| Description | To access request parameter' values. | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | 
 | 
User Hash Variable
| Name | Description | 
|---|---|
| Prefix | user | 
| Description | To get user information based on username. | 
| Attributes | 
 In Joget Enterprise edition, these additional attributes are available:- User Meta 
 Organization 
 Department 
 Grade 
 HOD 
 Group 
 Employment 
 Department HOD 
 | 
| Scope of Use | 
 | 
| Sample Attributes | 
 | 
Userview Key Hash Variable
| Name | Description | 
|---|---|
| Prefix | userviewKey | 
| Description | Userview Key Hash Variable is used solely for the purpose of accessing the current Userview key's value. Typical use case for this hash variable are:- 
 | 
| Attributes | 
 | 
| Scope of Use | 
Workflow Variable Hash Variable
| Name | Description | 
|---|---|
| Prefix | variable | 
| Description | To get the value of a workflow variable in a Process Flow. | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | #variable.approvalStatus# | 
Request Hash Variable
| Name | Description | 
|---|---|
| Prefix | request | 
| Description | To get the value from the current HttpServletRequest object of the page view. | 
| Attributes | 
 | 
| Scope of Use | 
 | 
| Sample Attributes | To retrieve the "Referer" header attribute value in the screenshot above, one may use the following hash variable. Hash Variable #request.header.Referer# | 
Platform Hash Variable
This is a new feature in Joget Workflow v6.
| Name | Description | 
|---|---|
| Prefix | platform | 
| Description | To retrieve platform specific information. | 
| Attributes | 
 In Joget Enterprise edition, these additional attributes are available:- 
 | 
| Scope of Use | 
 | 
Users Hash Variable
This is a new feature in Joget Workflow v6.
| Name | Description | 
|---|---|
| Prefix | users | 
| Description | To retrieve information of all the users in the selected group, grade, department and organization. Multiple results will be separated by semicolon. | 
| Attributes | 
 
 
 
 
 | 
| Scope of Use | 
 | 
| Sample Attributes | To return all the users in the current user's groups id: 
 | 
Bean Shell Hash Variable
This is a new feature in Joget Workflow v6.
| Name | Description | 
|---|---|
| Prefix | beanshell | 
| Description | Using environment variable to execute bean shell script. Passing parameter using URL query string syntax. | 
| Attributes | 
 
 | 
| Scopeof Use | 
 | 
| Sample Attributes | To execute a script stored in "welcome" environment variable with parameter "username" and "dept": if (username != null && username.length == 1 && !username[0].isEmpty()) {
       return "Welcome " + username[0] + " (" + dept[0] + "),";
} else {
       return "";
}
 
 | 
 

