closes #1
This commit is contained in:
parent
d245e1bd85
commit
21ec2e8268
20
app.coffee
20
app.coffee
|
@ -27,8 +27,14 @@ Issues =
|
||||||
getClosedIssues: (callback) -> Issues.get "/repos/#{Issues.config.github_user}/#{Issues.config.github_project}/issues?state=closed", 'issues', callback
|
getClosedIssues: (callback) -> Issues.get "/repos/#{Issues.config.github_user}/#{Issues.config.github_project}/issues?state=closed", 'issues', callback
|
||||||
getMilestones: (callback) -> Issues.get "/repos/#{Issues.config.github_user}/#{Issues.config.github_project}/milestones", 'milestones', callback
|
getMilestones: (callback) -> Issues.get "/repos/#{Issues.config.github_user}/#{Issues.config.github_project}/milestones", 'milestones', callback
|
||||||
|
|
||||||
# Convert GitHub ISO to JS ISO date and then time
|
# Convert GitHub ISO 8601 to JS timestamp at the beginning of UTC day!'
|
||||||
dateToTime: (date) -> new Date(date[0...date.length - 1] + '.000' + date.charAt date.length-1).getTime()
|
dateToTime: (date) ->
|
||||||
|
# Add miliseconds and create `Date`.
|
||||||
|
date = new Date(date[0...date.length - 1] + '.000' + date.charAt date.length-1)
|
||||||
|
# Move to the beginning of the day (at 9am BST, 8am GMT, so we do not worry about time shifts).
|
||||||
|
date = new Date date.getFullYear(), date.getMonth(), date.getDate(), 9
|
||||||
|
# Return timestamp.
|
||||||
|
date.getTime();
|
||||||
|
|
||||||
# Format issues for display in a listing.
|
# Format issues for display in a listing.
|
||||||
format: (issue) ->
|
format: (issue) ->
|
||||||
|
@ -96,7 +102,7 @@ app.get '/burndown', (req, res) ->
|
||||||
|
|
||||||
# Create n dict with all dates in the milestone span.
|
# Create n dict with all dates in the milestone span.
|
||||||
days = {} ; totalDays = 0
|
days = {} ; totalDays = 0
|
||||||
day = Issues.dateToTime current.milestone.created_at # TODO: shift this to the start of the day and deal with time shifts.
|
day = Issues.dateToTime current.milestone.created_at
|
||||||
while day < current.due
|
while day < current.due
|
||||||
# Save the day.
|
# Save the day.
|
||||||
days[day] = { 'issues': [], 'actual': 0, 'ideal': 0 }
|
days[day] = { 'issues': [], 'actual': 0, 'ideal': 0 }
|
||||||
|
@ -121,14 +127,8 @@ app.get '/burndown', (req, res) ->
|
||||||
current.size += issue.size
|
current.size += issue.size
|
||||||
# Is it closed?
|
# Is it closed?
|
||||||
if issue.closed_at?
|
if issue.closed_at?
|
||||||
closed = Issues.dateToTime issue.closed_at
|
|
||||||
# Find when was it closed (will be made faster)
|
|
||||||
day = do () ->
|
|
||||||
for day, x of days
|
|
||||||
if closed < day then return day
|
|
||||||
|
|
||||||
# Save it.
|
# Save it.
|
||||||
if day? then days[day]['issues'].push issue
|
days[Issues.dateToTime issue.closed_at]['issues'].push issue
|
||||||
|
|
||||||
# Calculate the predicted daily velocity.
|
# Calculate the predicted daily velocity.
|
||||||
dailyIdeal = current['size'] / totalDays ; ideal = current['size']
|
dailyIdeal = current['size'] / totalDays ; ideal = current['size']
|
||||||
|
|
|
@ -102,7 +102,7 @@
|
||||||
// Onhover.
|
// Onhover.
|
||||||
var hoverDetail = new Rickshaw.Graph.HoverDetail({
|
var hoverDetail = new Rickshaw.Graph.HoverDetail({
|
||||||
graph: graph,
|
graph: graph,
|
||||||
xFormatter: function(d) { return new Date(d * 1000).toUTCString() },
|
xFormatter: function(d) { return new Date(d * 1000).toUTCString().substring(0, 11) },
|
||||||
formatter: function(series, stamp, points) {
|
formatter: function(series, stamp, points) {
|
||||||
if (series.name == 'Ideal') {
|
if (series.name == 'Ideal') {
|
||||||
return '<p>Ideally ' + Math.round(points) + ' points left</p>'
|
return '<p>Ideally ' + Math.round(points) + ' points left</p>'
|
||||||
|
|
Loading…
Reference in New Issue