Create Issue from Agile Board throws exception

Hi all,

We updated JIRA recently to the Jira Version: v5.2.6. The GreenHopper Version is: 6.1.3.1

When we create Issue from the Agile Board (Plan) page, we get an exception like:

Exception: TypeError: $ is undefined.

at this huge line:

GH.BacklogController={};GH.BacklogController.visible=false;GH.BacklogController.rapidViewData=undefined;GH.BacklogController.rapidViewConfig=undefined;GH.BacklogController.backlogData=undefined;GH.BacklogController.lastExecutedSearchFilter=undefined;GH.BacklogController.issueCreatedCallbacks={};GH.BacklogController.init=function(){GH.BacklogSelectionController.init();GH.SprintBacklogController.init();GH.PlanRankController.init();AJS.$(GH).bind("issueUpdated",GH.BacklogController.handleIssueUpdated);AJS.$(GH).bind("issueCreated",GH.BacklogController.handleIssueCreated);AJS.$(GH).bind("issuesRemovedFromSprint",GH.BacklogController.handleIssuesRemovedFromSprint);AJS.$(document).delegate(".js-sprint-start","click",GH.BacklogController.openStartSprintDialog);AJS.$(GH).bind(GH.Dialogs.StartSprintDialog.EVENT_SPRINT_STARTED,GH.BacklogController.handleSprintStarted);AJS.$(GH).bind(GH.Components.EVENT_SPRINT_UPDATED,GH.BacklogController.handleSprintUpdated);AJS.$(GH.PlanControls.quickfilters).bind("quickFilterChange",function(){if(GH.BacklogController.visible){GH.BacklogController.loadData()}})};GH.BacklogController.setRapidView=function(A){GH.BacklogController.rapidViewData=A};GH.BacklogController.setRapidViewConfig=function(A){GH.BacklogController.rapidViewConfig=A};GH.BacklogController.show=function(A){if(!GH.BacklogController.rapidViewData){return false}GH.BacklogController.visible=true;GH.BacklogController.loadData().done(A)};GH.BacklogController.hide=function(){GH.EpicView.hide();GH.BacklogController.visible=false};GH.BacklogController.loadData=function(){var B={rapidViewId:GH.BacklogController.rapidViewData.id,activeQuickFilters:GH.PlanControls.quickfilters.getActiveQuickFilters()};if(_.isEmpty(B.activeQuickFilters)){delete B.activeQuickFilters}GH.PlanView.showLoadingBacklog();var A=GH.Ajax.get({url:GH.Ajax.buildRestUrl("/xboard/plan/backlog/data.json"),data:B,onGlobalError:function(){GH.PlanView.hideLoadingBacklog();GH.PlanController.hide()},jiraRestFormat:true},"backlogDataModel");A.done(function(C){GH.log("loaded data for backlog",GH.Logger.Contexts.ajax);GH.BacklogController.processData(C)});return A.promise()};GH.BacklogController.processData=function(B){if(!GH.BacklogController.visible){return }GH.BacklogController.lastExecutedSearchFilter=undefined;GH.BacklogController.backlogData=B;GH.BacklogModel.setRankCustomFieldId(B.rankCustomFieldId);GH.BacklogModel.setEstimationStatistic(GH.BacklogController.rapidViewConfig.estimationStatistic);GH.BacklogModel.setTrackingStatistic(GH.BacklogController.rapidViewConfig.trackingStatistic);GH.BacklogModel.setData(B);GH.SprintBacklogModel.setData(B);GH.BacklogModel.setCanManageSprints(B.canManageSprints);GH.BacklogSelectionController.validateCurrentSelection();GH.EpicView.registerEpicsCount(B.epicData);GH.EpicView.show();var A=GH.EpicController.getFilteredEpicKey();var C=A===GH.BacklogModel.EPIC_FILTER_KEY_NONE&&GH.BacklogModel.getIssueListForEpics().getNumVisibleIssues()>0||GH.BacklogModel.getIssueListForEpics().isIssueValid(A);if(C){GH.BacklogController.updateEpicFiltering(A,true)}else{GH.EpicController.setFilteredEpicKey(undefined);GH.RapidBoard.UrlState.replaceState()}GH.BacklogView.draw();GH.PlanView.updateDetailsViewVisibility();GH.PlanControls.searchFilter.clearLastSearch();GH.PlanControls.searchFilter.searchQuery();GH.PlanControls.setSprintData(B.openSprints,B.canManageSprints);GH.PlanView.hideLoadingBacklog();GH.PlanController.updateDetailsView(GH.BacklogSelectionController.getSelectedIssueKey());GH.BacklogView.updateIssueSelectionState(true)};GH.BacklogController.updateUIAfterSelectionChange=function(A){GH.BacklogView.updateIssueSelectionState(A.doScroll);GH.PlanController.updateDetailsView(GH.BacklogSelectionController.getSelectedIssueKey(),A.openDetailsView)};GH.BacklogController.reloadSingleIssue=function(B){var A={rapidViewId:GH.BacklogController.rapidViewData.id,issueId:B};GH.Ajax.get({url:GH.Ajax.buildRestUrl("/xboard/plan/backlog/issue.json"),data:A,success:function(C){GH.log("loaded data for single issue with id "+B,GH.Logger.Contexts.ajax);GH.BacklogController.updateIssues(C)},jiraRestFormat:true},"updateSingleIssue")};GH.BacklogController.updateIssues=function(B){if(!_.isArray(B)){B=[B]}var F=false;var C=[];var E=false;var D=false;_.each(B,function(G){var H=GH.BacklogModel.findListWithIssues(G.key);if(!H){return }if(GH.BacklogModel.isBacklogIssueList(H)){if(G.typeId===GH.EpicConfig.getEpicIssueTypeId()){H.removeIssues(G.key);D=true}else{H.updateIssue(G);E=true}}else{if(GH.BacklogModel.isEpicIssueList(H)){H.updateIssue(G);F=true}else{if(GH.BacklogModel.isSprintIssueList(H)){H.updateIssue(G);C.push(GH.BacklogModel.getSprintIdForSprintIssueList(H))}}}});GH.BacklogModel.reapplySearchFilter();C=_.unique(C);_.each(C,function(H){var G=GH.BacklogModel.getOpenSprint(H);GH.BacklogView.updateOpenSprint(G)});if(D){GH.BacklogSelectionController.validateCurrentSelection();GH.BacklogController.updateEpicData();GH.BacklogView.redrawBacklogIssueList();var A=GH.BacklogSelectionController.getSelectedIssueKey();GH.DetailsView.setSelectedIssueKey(A);GH.PlanController.reloadDetailView()}else{if(E){GH.BacklogView.redrawBacklogIssueList()}if(F){}}};GH.BacklogController.updateOpenSprint=function(A,B){if(!GH.BacklogController.visible){return }B=_.isUndefined(B)?true:B;var C={rapidViewId:GH.BacklogController.rapidViewData.id,activeQuickFilters:GH.PlanControls.quickfilters.getActiveQuickFilters(),sprintId:A};if(_.isEmpty(C.activeQuickFilters)){delete C.activeQuickFilters}return GH.Ajax.get({url:GH.Ajax.buildRestUrl("/xboard/plan/backlog/opensprint.json"),data:C,success:function(D){if(!GH.BacklogController.visible){return }GH.log("loaded data for single open sprint "+A,GH.Logger.Contexts.ajax);GH.BacklogController.setOpenSprintData(D,B)},jiraRestFormat:true},"opensprint")};GH.BacklogController.setOpenSprintData=function(A,B){GH.BacklogModel.updateSprint(A,true);if(B){GH.BacklogView.updateOpenSprint(A)}};GH.BacklogController.updateEpicData=function(){if(!GH.BacklogController.visible){return(new AJS.$.Deferred()).resolve()}var A={rapidViewId:GH.BacklogController.rapidViewData.id};return GH.Ajax.get({url:GH.Ajax.buildRestUrl("/xboard/plan/backlog/epics.json"),data:A,success:function(B){if(!GH.BacklogController.visible){return }GH.log("loaded data for epics",GH.Logger.Contexts.ajax);GH.BacklogController.setEpicData(B)},jiraRestFormat:true},"epics")};GH.BacklogController.setEpicData=function(A){GH.BacklogModel.updateEpicData(A);GH.EpicView.updateEpics()};GH.BacklogController.reorderIssues=function(B,A,C){GH.BacklogModel.reorderIssues(B,A,C);GH.BacklogView.draw()};GH.BacklogController.sendToBottom=function(A){GH.BacklogModel.sendToBottom(A);GH.BacklogView.draw()};GH.BacklogController.sendToTop=function(A){GH.BacklogModel.sendToTop(A);GH.BacklogView.draw()};GH.BacklogController.temporarilyMoveSprintMarker=function(C,B){var A={markerId:C,markerMovedAfter:B};GH.BacklogView.updateAllMarkerStatistics(A);GH.BacklogView.updateBacklogHeader();GH.BacklogView.updateOvertakenMarkers(A)};GH.BacklogController.updateSprintMarkersPosition=function(E,C){GH.BacklogModel.updateSprintMarkersPosition(E,C);var D={rankables:_.map(E,function(G){return{id:G,type:"sprintmarker"}}),customFieldId:GH.BacklogModel.getRankCustomFieldId()};var F;var A;if(C){if(_.isNumber(C)){D.rankAfterRankable={id:C,type:"sprintmarker"}}else{D.rankAfterKey=C}F="after";A=true}else{var B=GH.SprintBacklogModel.getIssueList();D.rankBeforeKey=B.getIssueKeyAtIndex(0);F="before";A=!!D.rankBeforeKey}if(A){GH.Ajax.put({url:GH.Ajax.buildRestUrl("/api/rank/"+F),data:JSON.stringify(D),contentType:"application/json",jiraRestFormat:true})}else{GH.log("Cannot rank marker as there is nothing to rank against")}GH.BacklogView.redrawBacklogIssueList()};GH.BacklogController.openStartSprintDialog=function(B){if(AJS.$(this).hasClass("disabled")){return }var C=GH.BacklogView.getRankableId(AJS.$(this));var E=GH.RapidBoard.State.getRapidViewId();var D=GH.BacklogStatistics.getNumIssuesInSprint(C);if(D<1){return }var A=GH.BacklogStatistics.getNumVisibleIssuesInSprint(C);var F=GH.SprintBacklogModel.getLastIssueKeyInSprint(C);GH.Dialogs.StartSprintDialog.showDialog(E,C,A)};GH.BacklogController.handleSprintStarted=function(){GH.BacklogSelectionController.clearSelection();GH.RapidBoard.ViewController.setMode("work");GH.RapidBoard.State.pushState()};GH.BacklogController.handleIssueForEpicCreated=function(A,B){if(!GH.BacklogController.visible){return }if(_.isUndefined(GH.BacklogController.handleIssueForEpicCreated.deferred)){GH.BacklogController.handleIssueForEpicCreated.deferred=new AJS.$.Deferred();setTimeout(function(){GH.BacklogController.loadData().then(function(){GH.BacklogController.handleIssueForEpicCreated.deferred.resolve();GH.BacklogController.handleIssueForEpicCreated.deferred=undefined},function(){GH.BacklogController.handleIssueForEpicCreated.deferred.reject()})},0)}return GH.BacklogController.handleIssueForEpicCreated.deferred};GH.BacklogController.registerIssueCreatedCallback=function(B,A){GH.BacklogController.issueCreatedCallbacks[B]=A};GH.BacklogController.unregisterIssueCreatedCallback=function(A){delete GH.BacklogController.issueCreatedCallbacks[A]};GH.BacklogController.handleIssueCreated=function(B,C){if(!GH.BacklogController.visible){return }var A=_.clone(GH.BacklogController.issueCreatedCallbacks);setTimeout(function(){GH.BacklogController.handleIssueCreatedImpl(C,A)},0)};GH.BacklogController.reloadAndShowCreatedEpics=function(A){GH.BacklogController.updateEpicData().done(function(){GH.BacklogController._showCreatedEpicsMessage(A)})};GH.BacklogController.handleIssueCreatedImpl=function(C,A){if(C.isSubtask){return GH.BacklogController.subtasksCreated(C)}function B(D){var E=_.map(D,function(G){return{issueKey:G.key,issueId:G.id,issueType:G.fields.issuetype.id}});var F=GH.EpicConfig.getEpicIssueTypeId();return _.reduce(E,function(H,G){if(G.issueType==F){H.epics.push(G)}else{H.issues.push(G)}return H},{issues:[],epics:[]})}return GH.BacklogController.getIssueDetails(C.issues,"issuetype").done(function(D){var E=B(D.issues);GH.BacklogController.issuesAndEpicsCreated(E.issues,E.epics,A)})};GH.BacklogController.getIssueDetails=function(C,A){var B=_.pluck(C,"issueKey");return GH.BacklogController.getIssueDetailsByKeys(B,A)};GH.BacklogController.getIssueDetailsByKeys=function(C,A){var D=C.join(",");var B="issueKey in ("+D+")";return GH.Ajax.get({url:GH.Ajax.buildBareRestUrl("/rest/api/2/search"),data:{jql:B,fields:A},jiraRestFormat:true},"getissues")};GH.BacklogController.issuesAndEpicsCreated=function(B,F,E){if(_.isEmpty(B)&&_.isEmpty(F)){return }if(_.isEmpty(B)){return GH.BacklogController.reloadAndShowCreatedEpics(F)}var C=_.map(E,function(G){if(_.isFunction(G)){return G(B,F)}return false});var D=_.filter(C,function(G){return G&&((G instanceof AJS.$.Deferred)||_.isFunction(G.promise))});var A=_.map(D,function(H){var G=new $.Deferred();if(H.always){H.always(G.resolve)}else{H.then(G.resolve,G.resolve)}return G});return AJS.$.when.apply(AJS.$,A).then(function(){GH.BacklogController.reloadAndSelectCreatedIssues(B)})};GH.BacklogController.subtasksCreated=function(A){GH.RapidBoard.QuickCreate.showSubtaskCreatedMessage(A);GH.PlanController.reloadDetailView(GH.DetailsView.TAB_SUBTASKS);return GH.BacklogController.loadData()};GH.BacklogController.reloadAndSelectCreatedIssues=function(A){return GH.BacklogController.loadData().done(function(){var B=_.last(A);var C=GH.BacklogModel.isIssueVisible(B.issueKey);if(C){GH.BacklogSelectionController.selectIssue(B.issueKey)}else{GH.RapidBoard.QuickCreate.showCreatedIssuesMessage({issues:A})}})};GH.BacklogController._showCreatedEpicsMessage=function(D){var C=_.last(D);var B=GH.BacklogModel.getIssueListForEpics();var A=B.isIssueVisible(C.issueKey);GH.RapidBoard.QuickCreate.showCreatedEpicsMessage({issues:D},A);if(A){GH.EpicView.scrollToBottom()}};GH.BacklogController.handleSprintUpdated=function(B,A){GH.BacklogController.updateOpenSprint(A.id,false)};GH.BacklogController.handleIssueUpdated=function(C,F){if(!GH.BacklogController.visible){return }GH.log(C.type+" from source "+F.source+" handled","BacklogController");var I=parseInt(F.issueId,10);var E=GH.BacklogModel.findListWithIssues(I),H=false,B=false,A=false,K=false,G=false,J=false,D;if(F.source==="quickEdit"){H=true;if(GH.BacklogModel.isSprintIssueList(E)){B=true;A=GH.BacklogModel.getSprintIdForSprintIssueList(E)}else{if(GH.BacklogModel.isEpicIssueList(E)){G=true}else{K=true}}if(E){D=E.getIssueDataForId(I);if(D&&D.epic){G=true}}if(!E&&GH.BacklogModel.trackingStatistic.isEnabled){J=true}}else{K=true;if(F.fieldId===GH.BacklogController.rapidViewConfig.estimationStatistic.fieldId){if(E){D=E.getIssueDataForId(I);if(D&&D.epic){G=true}}}}if(B){GH.BacklogController.updateOpenSprint(A)}else{if(K){GH.BacklogController.reloadSingleIssue(F.issueId)}}if(H&&!J){GH.PlanController.reloadDetailView()}if(G&&!J){GH.BacklogController.updateEpicData()}if(J){GH.BacklogController.loadData()}};GH.BacklogController.handleIssuesRemovedFromSprint=function(A,B){if(!GH.BacklogController.visible){return }GH.BacklogController.loadData()};GH.BacklogController.removeIssues=function(B){var D=GH.BacklogModel.findListWithIssues(B);var C=GH.BacklogSelectionController.getSelectedIssueKey();var A=_.contains(B,C);D.removeIssues(B);GH.BacklogSelectionController.selectionManager.removeSelectedIssueKeys(B);if(GH.BacklogModel.isBacklogIssueList(D)){GH.BacklogView.updateAllMarkers()}};GH.BacklogController.isFiltersActive=function(){return !_.isEmpty(GH.PlanControls.quickfilters.getActiveQuickFilters())};GH.BacklogController.executeSearch=function(B){GH.Logger.timeStart("GH.BacklogController.executeSearch regex");if(_.isNull(B)){GH.BacklogController.lastExecutedSearchFilter=null}else{var A=" ";GH.BacklogController.lastExecutedSearchFilter=function(D){return B.test(D.key+A+D.summary+A+D.typeName)}}var C=GH.BacklogModel.setInstantFilter(GH.BacklogController.lastExecutedSearchFilter);GH.Logger.timeStop("GH.BacklogController.executeSearch regex");GH.Logger.timeStart("GH.BacklogController.executeSearch ui update");if(C){GH.BacklogView.updateHiddenIssues()}GH.Logger.timeStop("GH.BacklogController.executeSearch ui update");return false};GH.BacklogController.clearFilters=function(){var A=GH.PlanControls.quickfilters.clearFilters();GH.PlanControls.searchFilter.clearSearchBox();GH.EpicController.setFilteredEpicKey(null);if(A){GH.BacklogModel.clearFilters();GH.BacklogController.loadData().done(function(){GH.RapidBoard.State.pushState()})}else{var B=GH.BacklogModel.clearFilters();if(B){GH.EpicView.deselectAllEpics();GH.BacklogView.updateHiddenIssues();GH.RapidBoard.State.pushState()}}};GH.BacklogController.updateEpicFiltering=function(A,B){var C=GH.BacklogModel.setEpicFilter(A);if(C&&!B){GH.BacklogView.updateHiddenIssues()}};GH.BacklogController.calculateIssueRenderData=function(){var B=GH.BacklogSelectionController.getSelectedIssueKeys();var C={};_.each(B,function(E){C[E]=true});var A=GH.BacklogSelectionController.getSelectedIssueKey();var D=GH.BacklogModel.getHiddenBySearchIssues();return{selectedIssueKeys:C,mainSelectedIssue:A,hiddenIssues:D}};

The issue is eventually created, but the users think not because of this error, plus they don't see immediately the created Issue number.

When we choose to create issue from the dashboard, it works, so I just presume it might have something to do with the GreenHopper or so.

Any ideas? Many thanks!

1 answer

1 accepted

This widget could not be displayed.
Joe Wai Tye Atlassian Team Feb 26, 2013

Hi Loredana,

I suspect that you are facing this bug - https://jira.atlassian.com/browse/GHS-7317. May I know if you have disabled the feedback module? That usually triggers this bug.

Not to worry, though, as the bug has been fixed in GreenHopper 6.1.3.2, as stated in the bug report :)

Cheers,

Joe

Thx, we will try the GreenHopper Update. We didn't disable any module.

Suggest an answer

Log in or Sign up to answer
Atlassian Summit 2018

Meet the community IRL

Atlassian Summit is an excellent opportunity for in-person support, training, and networking.

Learn more
Community showcase
Posted Wednesday in Teamwork

What teamwork quotes inspire you?

Hey everyone! My name is Natalie and I'm an editor of the Atlassian Blog and I've got a question for you: What's your favorite quote about teamwork?  We've compiled a list here, along with...

160 views 16 7
Join discussion

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you