Skip to content

Instantly share code, notes, and snippets.

@dascgo
Created October 26, 2012 18:21
Show Gist options
  • Save dascgo/3960490 to your computer and use it in GitHub Desktop.
Save dascgo/3960490 to your computer and use it in GitHub Desktop.
tool to add functionality to JIRA's greenhopper interface. This script is inserted into the page via a bookmarklet
var gh = {
setup: function(){
$(".gh_tag").live("click", gh.tags.cycle);
$(".ghx-corner").live("click", gh.time.update);
gh.subtasks.summarize();
},
urls: {
get_details: function(key){
return "https://izeaeng.jira.com/rest/greenhopper/1.0/xboard/issue/details.json?rapidViewId=2&loadSubtasks=true&_=1351257629783&issueIdOrKey=" + key;
}
},
tags: {
list: ["gray", "red", "orange", "yellow", "blue", "green"],
cycle: function(){
var elm = $(this);
var key = elm.attr("data-key");
var color = gh.tags.next_color(elm.attr("data-color"));
localStorage.setItem('tag_' + key, color);
elm.attr("src", gh.images.tags[color]).attr("data-color", color);
},
next_color: function(current_color){
var index = gh.tags.list.indexOf(current_color);
var next_index = index + 1
if(!gh.tags.list[next_index]){
next_index = 0;
}
var color = gh.tags.list[next_index];
return color;
},
draw: function(key){
var color = localStorage.getItem('tag_' + key) || "gray";
return "<img src='" + gh.images.tags[color] + "' data-color='" + color + "' data-key='" + key + "' width='16' height='16' class='gh_tag' style='" + gh.styles.tag + "'>";
}
},
time: {
update: function(){
var elm = $(this);
var id = elm.parent().attr("data-issue-id");
console.log("need to update time on issue: " + id);
console.log("https://izeaeng.jira.com/secure/CreateWorklog!default.jspa?id=" + id + "&decorator=dialog&inline=true&_=1351270010505")
// $.get("https://izeaeng.jira.com/secure/CreateWorklog!default.jspa?id=" + id + "&decorator=dialog&inline=true&_=1351270010505");
// $("span.ghx-icon-log").click()
}
},
subtasks: {
summary: function(tasks){
var stats = { open: 0, dev: 0, qa: 0, closed: 0 }
for(var i = 0, l = tasks.length; i < l; i++){
var task = tasks[i];
switch (task.status.name){
case "Open":
stats.open++;
break;
case "In Development":
stats.dev++;
break;
case "Dev Done":
stats.dev++;
break;
case "Closed":
stats.closed++;
break;
default:
stats.qa++;
break;
}
}
return stats;
},
summarize: function(){
$(".ghx-parent-key").each(function(index){
var key = $(this).text();
$.get(gh.urls.get_details(key), function(res){
// console.log("issue: " + key);
// console.log(res)
subtask_info = gh.subtasks.summary(res.subtasks);
subtask_text = "<span style='" + gh.styles.status.base + "'><span style='" + gh.styles.status.open + "'>" + subtask_info.open + "</span> | <span style='" + gh.styles.status.dev + "'>" + subtask_info.dev + "</span> | <span style='" + gh.styles.status.qa + "'>" + subtask_info.qa + "</span> | <span style='" + gh.styles.status.closed + "'>" + subtask_info.closed + "</span></span>";
// console.log(subtask_text)
// console.log("----------------------------------------------------------------")
$("div[data-issue-key='" + key + "'] .ghx-info").html(subtask_text);
$("div.ghx-swimlane-header[data-issue-key='" + key + "'] span.ghx-heading").prepend("<span class='gh_header_box'>" + gh.tags.draw(key) + "</span>");
});
});
}
},
images: {
tags: {
gray: "",
red: "",
green: "",
yellow: "",
blue: "",
orange: ""
}
},
styles: {
tag: "margin-bottom: -2px; margin-right: 7px; cursor: pointer;",
status: {
open: "color:red;",
dev: "color:orange;",
qa: "color:gold;",
closed: "color:green;",
base: "color: #e5e5e5; font-size: 14px; font-weight: bold;"
}
}
};
gh.setup();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment