All eazyBI for Jira eazyBI for Confluence Private eazyBI

Custom JavaScript code
eazyBI for Jira

You can use custom JavaScript code in the eazyBI account to modify Jira issues field values during import. The JavaScript code will modify the issue JSON object before importing issues into eazyBI account. 

Custom Javascript code can not be used to create new custom fields for eazyBI. It updates existing fields only. If you need to create a new custom field, please refer to JavaScript calculated custom fields page

On this page:

How to add and validate custom JavaScript code

Custom JavaScript code should be added to each account where you would like to make data modifications. Open Jira import options of the account, in tab Additional options click Add custom JavaScript code to show the code editor.

Then add some Javascript code in the code editor [1]. You can test the code for one sample issue key in the validation area [2]  and see results in the results pane [3] [4].

JavaScript code should be ES5 compliant, ES6 syntax is not supported.

You can use issue variable to access received Jira REST API issue JSON object properties and modify or add additional properties. eazyBI will use only custom fields imported into the account. You can see the full Jira issue REST API in the browser. Please open JIRA_BASE_URL/rest/api/latest/issue/PPP-NNN?expand=changelog in your browser (where PPP-NNN is issue key) to see sample issue JSON. 

Save import options after the testing is done and JavaScript works as expected. eazyBI will detect changes in import options and apply the JavaScritp code for any imported issue. 

Import Summary as an empty string

Here is an example of JavaScript code that will replace the issue summary property with an empty string for issues with issue type bug

if (issue.fields.issuetype && 
    issue.fields.issuetype.name == "Bug") {
  issue.fields.summary = "";
}

Delete custom field values for bug issues

If you would like to delete some field values and do not import them in eazyBI then use undefined.

if (issue.fields.issuetype && 
    issue.fields.issuetype.name == "Bug") {
  issue.fields.customfield_NNNNN = undefined;
}

Use custom field ID instead of NNNNN in the example above.

Calculate resolution date 

eazyBI creates a default set of measures based on the issue resolution date, for example, Issues resolved, Story Points resolved, etc. If the resolution date is missing in issues in Jira but you would like to have it in eazyBI you can use custom JavaScript code to calculate one. The example below will calculate the missing resolution date for completed issues based on status.

// Resolution date
var resolvedStatuses = ["Done","Resolved","Closed","Complete","Fixed"]; // list all statuses representing resolved or closed issue
if (!issue.fields.resolutiondate && resolvedStatuses.indexOf(issue.fields.status.name) > -1) { // validations when there is no resolution date for issues in resolved status
  var resolutionDate = null;
  var stillOpen = true
  issue.changelog.histories.forEach(function(history){
    history.items.forEach(function(historyItem){
      if (historyItem.field == "status") {
        statusFrom = historyItem.fromString;
        statusTo = historyItem.toString
        if (stillOpen && resolvedStatuses.indexOf(statusTo) > -1 && resolvedStatuses.indexOf(statusFrom) == -1) {
           stillOpen = false;
           resolutionDate = history.created;
        }
        else if (!stillOpen && resolvedStatuses.indexOf(statusFrom) > -1 && resolvedStatuses.indexOf(statusTo) == -1) {
          stillOpen = true // reopened
          resolutionDate = null
        }
      }
     });
  });

// completed status at the issue creation
	if (resolutionDate === null && resolvedStatuses.indexOf(issue.fields.status.name) > -1 ) {
		resolutionDate = issue.fields.created;
	}

  if (resolutionDate) {
  issue.fields.resolutiondate = resolutionDate;
  }
} 
// resolution date ends

Eliminate all user dimensions for GDPR compliance

You may disable data analytics from the user perspective who created or worked on the issues by eliminating data in dimensions Assignee, Reporter, Transition Author and Logged by. These dimensions will remain in the eazyBI cube but all metrics will show up for the (unassigned) or (none) user.

issue.fields.assignee=null; //eliminate assignee
issue.fields.reporter=null; //elimenate reporter
for (i=0; i<issue.changelog.histories.length;i++) {
  hist = issue.changelog.histories[i];
  hist.author=null; //eliminate transition author
  for (j=0;j<hist.items.length;j++) {
    if (hist.items[j].field=="assignee") { //eliminate assignee history
      hist.items[j].from=null;
      hist.items[j].to=null;
    }
  };
};
//eliminate logged by
if (issue.fields.worklog) {
issue.fields.worklog.worklogs.forEach(function(worklogitem){
  if (worklogitem.author) {
    worklogitem.author=null;
  }
})
}

Erase status transition duplicates.

You can erase from eazyBI issue changelog status transition duplicates from Jira (when the same status is "From" and "To" value) which often leads to wrong historical calculation reports when using "Issues history" or other historical measures.
In some cases, Jira automation generates status change duplicates, which causes the wrong sequence of transitions in the eazyBI data cube.

//delete duplicate status transitions
if (issue.changelog && issue.changelog.histories && issue.changelog.histories.length > 0) {
  var histories = issue.changelog.histories;
  var prevString = null;
  for (var i = 0; i < histories.length; i++) {
    var history = histories[i];
    if (history.items && history.items.length > 0) {
      for (var n = 0; n < history.items.length; n++) {
        var item = history.items[n];
        if (item.field == 'status') {
          if (item.from == item.to) {     
          history.items.splice(n,1);
          }
      } } } } }

Please contact eazyBI support if you need help to write a custom JavaScript code for your specific needs.