Changes to Issues are registered in the Issue History, but it is not known in advance how many changes are going to be made.
You can iterate a section over all the History entries of an Issue. This allows you to create a table that dynamically grows according to the number of changes done.
The notation is:
Field | Description | ||||||||
---|---|---|---|---|---|---|---|---|---|
HistoryEntriesCount | The number of changes made | ||||||||
Author | The user who made the change | ||||||||
Created | Date of the change | ||||||||
ChangedItemsCount | The number of fields changed in the current change | ||||||||
ChangedItems |
|
#{for historyEntries} ${fullname:HistoryEntries[n].Author} made changes ${dateformat("dd-MM-yyyy HH:mm:ss"):HistoryEntries[n].Created} #{for ch=HistoryEntries[n].ChangedItemsCount} Field Name: ${HistoryEntries[n].ChangedItems[ch].Field} Old Value: ${HistoryEntries[n].ChangedItems[ch].From} New Value: ${HistoryEntries[n].ChangedItems[ch].To} #{end} #{end} or #{for <VariableName>=HistoryEntriesCount} Content and Issue History Mappings. Example:${fullname:HistoryEntries[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue comments.
Changes related to Xray fields in Xray Issues are registered in a separate tab named Xray History, as changes to these fields can not be included with the Issue changes. For this reason, there is another way of iterating Xray history changes. Just like with Issue changes, you can iterate a section over all the Xray history entries of an Issue. This allows you to create a table that dynamically grows according to the number of changes done.
The notation is:
Field | Description | ||||||
---|---|---|---|---|---|---|---|
XrayHistoryEntriesCount | The number of changes made | ||||||
Action | The action that originated the changes | ||||||
User | The user who made the change | ||||||
Date | Date of the change | ||||||
Version | The Xray Test Version where the changes were made (if applicable) | ||||||
XrayChangedItemsCount | The number of fields changed in the current change | ||||||
XrayChangedItems |
|
#{for XrayHistoryEntries} ${fullname:XrayHistoryEntries[n].User} made changes ${dateformat("dd-MM-yyyy HH:mm:ss"):XrayHistoryEntries[n].Date} #{for ch=XrayHistoryEntries[n].XrayChangedItemsCount} Field Name: ${XrayHistoryEntries[n].XrayChangedItems[ch].Field} Changes: ${XrayHistoryEntries[n].XrayChangedItems[ch].Changes} #{end} #{end} or #{for <VariableName>=XrayHistoryEntriesCount} Content and Xray Issue History Mappings. Example:${fullname:XrayHistoryEntries[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue comments.
Iterating_Xray_Issue_History.docx
Iterating_Xray_Issue_History.xlsx
Because it is not known in advance how many comments exist for an Issue, you can iterate a section over all the comments on an Issue. This allows you to create a table that dynamically grows according to the number of existing comments.
The notation is:
Comments Fields | Description |
---|---|
Author | The author of the comment |
AuthorFullName | The full name of the author of the comment |
Body | The comment |
Created | The date the comment was posted |
GroupLevel | The group level of the comment |
#{for comments} ${Comments[n].Author} ${Comments[n].AuthorFullName} ${Comments[n].Body} ${dateformat("dd-MM-yyyy HH:mm:ss"):Comments[n].Created} ${Comments[n].GroupLevel} #{end} or #{for <VariableName>=CommentsCount} Content and Issue Mappings. Example: ${Comments[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue comments.
Because it is not known in advance how many worklogs exist for an Issue, you can iterate a section over all the work logs of an Issue. This allows you to create a table that dynamically grows according to the number of existing worklogs.
The notation is:
Worklogs Fields | Description |
---|---|
Author | The author of the worklog |
AuthorFullName | The full name of the author of the worklog |
Comment | The comment of the worklog |
Created | The date the worklog was created |
Date Started | The date the worklog was started |
Time Spent | The time spent in seconds |
TimeSpentFormatted | The time spent as displayed on Jira |
#{for worklogs} ${Worklogs[n].Author} ${Worklogs[n].AuthorFullName} ${Worklogs[n].Comment} ${dateformat("dd-MM-yyyy HH:mm:ss"):Worklogs[n].Created} ${dateformat("dd-MM-yyyy HH:mm:ss"):Worklogs[n].Date Started} ${Worklogs[n].Time Spent} ${Worklogs[n].TimeSpentFormatted} #{end} or #{for <VariableName>=WorklogsCount} Content and Worklog Mappings. Example: ${Worklogs[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue worklogs.
Because it is not known in advance how many components exist for an Issue, you can iterate a section over all the components of an Issue. This allows you to create a table that dynamically grows according to the number of existing components.
The notation is:
Components Fields | Description |
---|---|
Name | The name of the component |
Description | The description of the component |
Lead | The name of the component lead |
Id | The ID of the component |
ProjectId | The project ID of the component |
AssigneeType | The assignee type of the component |
#{for components} ${Components[n].Name} ${Components[n].Description} ${fullname:Components[n].Lead} ${Components[n].Id} ${Components[n].ProjectId} ${Components[n].AssigneeType} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue components.
Iterating_Issue_Components.docx
Iterating_Issue_Components.xlsx
Because it is not known in advance how many Status Transitions exist for an Issue, you can iterate a section over all the Status Transitions of an Issue. This allows you to create a table that dynamically grows according to the number of existing status transitions.
The notation is:
Status Transitions Fields | Description |
---|---|
Author | The author of the status transition |
Created | The date the status transition was performed |
OldStatus | The old status of the status transition |
NewStatus | The new status of the status transition |
#{for statusTransitions} ${StatusTransitions[n].Author} ${dateformat("dd-MM-yyyy HH:mm:ss"):StatusTransitions[n].Created} ${StatusTransitions[n].OldStatus} ${StatusTransitions[n].NewStatus} #{end} or #{for <VariableName>=StatusTransitionsCount} Content and StatusTransitions Mappings. Example: ${StatusTransitions[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue status transitions.
Iterations_StatusTransitions.docx
Iterations_StatusTransitions.xlsx
Because it is not known in advance how many images can exist on an Issue (as an attachment), you can iterate a section over all the attached images of an Issue to get some metadata about them. This allows you to create a table that dynamically grows according to the number of existing images.
The notation is:
Attachments Images Fields | Description |
---|---|
ID | The ID of the attached image |
Image | The image of the attached image |
Name | The name of the attached image |
Size | The size of the attached image |
HumanReadableSize | The size of the attached image |
Author | The author of the attached image |
Created | The date the attached image was created |
MimeType | The type of the attached image |
ThumbnailURL | The image thumbnail URL. |
#{for images} ${Images[n].Image|maxwidth=150|maxheight=150} ${Images[n].Name} ${Images[n].ID} ${Images[n].Size} ${Images[n].HumanReadableSize} ${Images[n].Author} ${dateformat("dd-MM-yyyy HH:mm:ss"):Images[n].Created} ${Images[n].MimeType} ${Images[n].ThumbnailURL} #{end} or #{for <VariableName>=ImagesCount} Content and Images Mappings. Example: ${Images[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue attached images.
Iterations_AttachedImages.docx
Iterations_AttachedImages.xlsx
Document Generator will automatically read the EXIF orientation property of an image and rotate it to its correct orientation. You can turn this off by adding |
You can use the mappings width
and height
to define the exact width and height of the printed image.
#{for images} ${Images[n].Image|width=150|height=150} #{end} |
These values are in pixels and if you only define one of them the image will be rescaled.
If you use the |
Because it is not known in advance how many attachments exist in an Issue, you can iterate a section over all the attachments of an Issue. This allows you to create a table that dynamically grows according to the number of existing attachments.
The notation is:
Attachments Fields | Description |
---|---|
ID | The ID of the attachment |
Name | The name of the attachment |
Author | The author of the attachment |
AuthorFullName | The full name of the author of the attachment |
Created | The date the attachment was created |
Size | The size of the attachment |
HumanReadableSize | The formatted size of the attachment |
MimeType | The type of attachment |
#{for attachments} ${Attachments[n].ID} ${Attachments[n].Name} ${Attachments[n].Author} ${Attachments[n].AuthorFullName} ${dateformat("dd-MM-yyyy HH:mm:ss"):Attachments[n].Created} ${Attachments[n].Size} ${Attachments[n].HumanReadableSize} ${Attachments[n].MimeType} #{end} or #{for <VariableName>=AttachmentsCount} Content and Issue Mappings. Example: ${Attachments[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue attachments.
Because it is not known in advance how many labels exist in an Issue, you can iterate a section over all the labels of an Issue.
The notation is:
Attachments Fields | Description |
---|---|
Name | The name of the label |
#{for labels} ${Labels[n].Name} #{end} or #{for <VariableName>=LabelsCount} ${Labels[VariableName].Name} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue comments.
You can iterate over all fix versions that the Issue belongs to.
The notation is:
Versions Fields | Description |
---|---|
Name | The version name |
Description | The version description |
Start date | Starting date of the version |
Release date | Release date of the version |
Archived | Boolean that indicates if the version is archived or not |
Released | Boolean that indicates if the version is released or not |
#{for FixVersions} ${FixVersions[n].Name} ${FixVersions[n].Description} ${dateformat(“dd-MM-yyyy”):FixVersions[n].Start date} ${dateformat(“dd-MM-yyyy”):FixVersions[n].Release date} ${FixVersions[n].Archived} ${FixVersions[n].Released} #{end} or #{for <VariableName>=FixVersionsCount} Content and Versions Issue Mappings. Example: ${FixVersions[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue fix versions.
Iterating_Issue_FixVersions.docx
Iterating_Issue_FixVersions.xlsx
You can iterate over all affected versions that the Issue belongs to.
The notation is:
Versions Fields | Description |
---|---|
Name | The version name |
Description | The version description |
Start date | Starting date of the version |
Release date | Release date of the version |
Archived | Boolean that indicates if the version is archived or not |
Released | Boolean that indicates if the version is released or not |
#{for AffectedVersions} ${AffectedVersions[n].Name} ${AffectedVersions[n].Description} ${dateformat(“dd-MM-yyyy”):AffectedVersions[n].Start date} ${dateformat(“dd-MM-yyyy”):AffectedVersions[n].Release date} ${AffectedVersions[n].Archived} ${AffectedVersions[n].Released} #{end} or #{for <VariableName>=AffectedVersionsCount} Content and Versions Issue Mappings. Example: ${AffectedVersions[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue-affected versions.
Iterating_Issue_AffectedVersions.docx
Iterating_Issue_AffectedVersions.xlsx
You can iterate over all project versions that the Issue belongs to.
The notation is:
Project Versions Fields | Description |
---|---|
Name | The version name |
Description | The version description |
Start date | Starting date of the version |
Release date | Release date of the version |
Archived | Boolean that indicates if the version is archived or not |
Released | Boolean that indicates if the version is released or not |
#{for projectVersions} ${ProjectVersions[n].Name} ${ProjectVersions[n].Description} ${dateformat(“dd-MM-yyyy”):ProjectVersions[n].Start date} ${dateformat(“dd-MM-yyyy”):ProjectVersions[n].Release date} ${ProjectVersions[n].Archived} ${ProjectVersions[n].Released} #{end} or #{for <VariableName>=ProjectVersionsCount} Content and Project Versions Mappings. Example: ${ProjectVersions[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue project versions.
Iterations_ProjectVersions.docx
Iterations_ProjectVersions.xlsx
Because it is not known in advance how many linked Issues exist for an issue, you can iterate a section over all the linked Issues of an Issue. This allows you to create a table that dynamically grows according to the number of existing linked Issues.
The notation is:
Links Fields | Description |
---|---|
LinkType | The type of the link |
Key | The key to the linked Issue |
Summary | The summary of the linked Issue |
URL | The URL of the link |
#{for links} ${Links[n].LinkType} ${Links[n].Key} ${Links[n].Summary} ${Links[n].URL} #{end} or #{for <VariableName>=LinksCount} Content and Linked Issue Mappings. Example: ${Links[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue links.
Because it is not known in advance how many subtasks exist for an Issue, you can iterate a section over all the subtasks of an Issue. This allows you to create a table that dynamically grows according to the number of existing subtasks.
The notation is:
Subtasks Fields | Description |
---|---|
Key | The key to the subtasks |
Summary | The summary of the subtasks |
AssigneeUserDisplayName | The assignee user of the subtasks |
#{for subtasks} ${Subtasks[n].Key} ${Subtasks[n].Summary} ${Subtasks[n].AssigneeUserDisplayName} #{end} or #{for <VariableName>=SubtasksCount} Content and Issue Mappings. Example: ${Subtasks[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over all the Issue subtasks.
All fields listed here are available on IssuesInEpic[n]
because they represent an Issue.
Because it is not known in advance how many Issues exist for an epic, you can iterate a section over all the Issues of an epic Issue. This allows you to create a table that dynamically grows according to the number of existing Issues.
The notation is:
#{for IssuesInEpic} ${IssuesInEpic[n].Key} ${IssuesInEpic[n].Summary} ${IssuesInEpic[n].Description} ${IssuesInEpic[n].Epic Link.Key} #{end} or #{for <VariableName>=IssuesInEpicCount} Content and Issue Mappings. Example: ${IssuesInEpic[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over the Issues in epic.
You can iterate over all project components.
The notation is:
#{for ProjectComponents} ${ProjectComponents[n].Name} ${ProjectComponents[n].Description} ${fullname:ProjectComponents[n].Lead} ${ProjectComponents[n].Id} ${ProjectComponents[n].ProjectId} ${ProjectComponents[n].AssigneeType} #{end} #{for <VariableName>=ProjectComponentsCount} Content and Components Mappings. Example: ${ProjectComponents[VariableName].Field} #{end} |
The documents below demonstrate examples both in Word and Excel templates that iterate over the project components.
Iterating_Issue_ProjectComponents.docx
Iterating_Issue_ProjectComponents.xlsx
If you want to take the previous iterations over comments, subtasks, and Issue links to another level of control, you can use a JavaScript filter to define over which Issues the iteration will be made.
This can be useful in the following scenarios:
The notation for applying filters to the iterations is:
#{for <VariableName>=<LinksCount|SubtasksCount|CommentsCount|WorklogsCount>|filter=%{<Javascript>}} Content here #{end} |
LinksCount|SubtasksCount|CommentsCount indicates over which type of entities you want to iterate.
The filter is evaluated as a JavaScript expression, which provides flexibility in defining the conditions. You can use |
It is also possible to format fields inside iteration filters.
The documents below demonstrate examples of templates that iterate over Issue links and comments with filters being applied.
Links Bugs with High Priority:
Nested Iterations:
Links_with_nested_Iterations.docx
Links_with_nested_Iterations.xlsx
For a working example of this functionality, check the template Sample Iterations in the Template Store.
You can also iterate values in the same line of the document. This can be useful if you want to display a list of subtasks on linked Issues in the same line, separated by commas or spaces.
Users that added comments to this issue: #{for comments}${Comments[n].Author} #{end} Subtasks of this issue: #{for j=SubtasksCount}${Subtasks[j].Key};#{end} Linked issues this issue duplicates: #{for j=LinksCount|filter=%{'${Links[j].LinkType}'.equals('duplicates')}}${Links[j].Key} #{end} |
You can also iterate values in the same cell in an Excel document. You can achieve this by simply making your Iteration inside the same cell.
You can use all the Iterations that you are used to and construct them in the exact same way, the difference being that you only use one cell to do them.
Issue iteration as a demonstration. Copy this iteration below and paste it into a cell. &{for issues} ${Key} &{end} |
You can iterate anything, set up a Conditional expression, and then utilize the BREAK and CONTINUE statements.
The way to do this is by doing a normal Conditional expression and using the mapping #{break}
or #{continue}
inside it.
Imagine that you have a Jira Issue that contains these comments: - Hello - World - Greetings - Hi For the Break functionality, lets say that you want to stop the iteration if the current comment is "World". Here is the template for that: #{for comments} Current Comment: ${Comments[n].Body} #{if (%{'${Comments[n].Body}'.equals('World')})} #{break} #{end} Current Comment Author: ${Comments[n].Author} #{end} For the Continue functionality, lets say that you want to skip to the next iteration if the current comment is "World", bypassing the Author mapping for this iteration. Here is the template for that: #{for comments} Current Comment: ${Comments[n].Body} #{if (%{'${Comments[n].Body}'.equals('World')})} #{continue} #{end} Current Comment Author: ${Comments[n].Author} #{end} In this case, Xporter for Jira will print the comment "Hello" and it´s author. Next, it will print the comment Body "World" but since the Conditional expression is true, it will continue to the next iteration, not printing the Author of the "World" comment. |
Imagine that you have an iteration and want to sort it by any field that it can export normally.
This will be the header for such an iteration:
#{for comments|sortby=<Iteration mapping>} |
The mapping after the |
Example
This iteration will be sorted by the Body of all the comments in the issue. #{for comments|sortby=Body} ${Comments[n].Author} ${Comments[n].Body} #{end} |
The sortby
can also be used to sort a &{for issues}
iteration on a Bulk Export.
&{for issues|sortby=IssueTypeName} ${Key} - ${IssueTypeName} &{end} |
|
If you have questions or technical issues, please contact the Support team via the Customer Portal (Jira service management) or send us a message using the in-app chat. |