mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-12-12 00:31:21 -05:00
Merge branch 'master' into production
This commit is contained in:
commit
316e0d7144
1 changed files with 42 additions and 43 deletions
|
@ -23,50 +23,49 @@ module.exports = class SchoolLicensesView extends RootView
|
|||
super()
|
||||
|
||||
updateSchools: (prepaidActivityMap, schoolPrepaidsMap) ->
|
||||
timeStart = @startDateRange.getTime()
|
||||
time2017 = new Date('2017').getTime()
|
||||
time2018 = new Date('2018').getTime()
|
||||
timeEnd = @endDateRange.getTime()
|
||||
rangeMilliseconds = timeEnd - timeStart
|
||||
@rangeKeys = [
|
||||
{name :'Today', color: 'blue', startScale: 0, width: Math.round((time2017 - timeStart) / rangeMilliseconds * 100)}
|
||||
{name: '2017', color: 'red', startScale: Math.round((time2017 - timeStart) / rangeMilliseconds * 100), width: Math.round((time2018 - time2017) / rangeMilliseconds * 100)}
|
||||
{name: '2018', color: 'yellow', startScale: Math.round((time2018 - timeStart) / rangeMilliseconds * 100), width: Math.round((timeEnd - time2018) / rangeMilliseconds * 100)}
|
||||
]
|
||||
|
||||
@schools = []
|
||||
for school, prepaids of schoolPrepaidsMap
|
||||
activity = 0
|
||||
schoolMax = 0
|
||||
schoolUsed = 0
|
||||
collapsedPrepaids = []
|
||||
for prepaid in prepaids
|
||||
activity += prepaidActivityMap[prepaid._id] ? 0
|
||||
startDate = prepaid.startDate
|
||||
endDate = prepaid.endDate
|
||||
max = parseInt(prepaid.maxRedeemers)
|
||||
used = parseInt(prepaid.redeemers?.length ? 0)
|
||||
schoolMax += max
|
||||
schoolUsed += used
|
||||
foundIdenticalDates = false
|
||||
for collapsedPrepaid in collapsedPrepaids
|
||||
if collapsedPrepaid.startDate.substring(0, 10) is startDate.substring(0, 10) and collapsedPrepaid.endDate.substring(0, 10) is endDate.substring(0, 10)
|
||||
collapsedPrepaid.max += parseInt(prepaid.maxRedeemers)
|
||||
collapsedPrepaid.used += parseInt(prepaid.redeemers?.length ? 0)
|
||||
foundIdenticalDates = true
|
||||
break
|
||||
unless foundIdenticalDates
|
||||
collapsedPrepaids.push({startDate, endDate, max, used})
|
||||
timeStart = @startDateRange.getTime()
|
||||
time2017 = new Date('2017').getTime()
|
||||
time2018 = new Date('2018').getTime()
|
||||
timeEnd = @endDateRange.getTime()
|
||||
rangeMilliseconds = timeEnd - timeStart
|
||||
@rangeKeys = [
|
||||
{name :'Today', color: 'blue', startScale: 0, width: Math.round((time2017 - timeStart) / rangeMilliseconds * 100)}
|
||||
{name: '2017', color: 'red', startScale: Math.round((time2017 - timeStart) / rangeMilliseconds * 100), width: Math.round((time2018 - time2017) / rangeMilliseconds * 100)}
|
||||
{name: '2018', color: 'yellow', startScale: Math.round((time2018 - timeStart) / rangeMilliseconds * 100), width: Math.round((timeEnd - time2018) / rangeMilliseconds * 100)}
|
||||
]
|
||||
|
||||
@schools = []
|
||||
for school, prepaids of schoolPrepaidsMap
|
||||
activity = 0
|
||||
schoolMax = 0
|
||||
schoolUsed = 0
|
||||
collapsedPrepaids = []
|
||||
for prepaid in prepaids
|
||||
activity += prepaidActivityMap[prepaid._id] ? 0
|
||||
startDate = prepaid.startDate
|
||||
endDate = prepaid.endDate
|
||||
max = parseInt(prepaid.maxRedeemers)
|
||||
used = parseInt(prepaid.redeemers?.length ? 0)
|
||||
schoolMax += max
|
||||
schoolUsed += used
|
||||
foundIdenticalDates = false
|
||||
for collapsedPrepaid in collapsedPrepaids
|
||||
collapsedPrepaid.startScale = Math.round((new Date(collapsedPrepaid.startDate).getTime() - @startDateRange.getTime()) / rangeMilliseconds * 100)
|
||||
collapsedPrepaid.startScale = 0 if collapsedPrepaid.startScale < 0
|
||||
collapsedPrepaid.rangeScale = Math.round((new Date(collapsedPrepaid.endDate).getTime() - new Date(collapsedPrepaid.startDate).getTime()) / rangeMilliseconds * 100)
|
||||
collapsedPrepaid.rangeScale = 100 - collapsedPrepaid.startScale if collapsedPrepaid.rangeScale + collapsedPrepaid.startScale > 100
|
||||
@schools.push {name: school, activity, max: schoolMax, used: schoolUsed, prepaids: collapsedPrepaids, startDate: collapsedPrepaids[0].startDate, endDate: collapsedPrepaids[0].endDate}
|
||||
if collapsedPrepaid.startDate.substring(0, 10) is startDate.substring(0, 10) and collapsedPrepaid.endDate.substring(0, 10) is endDate.substring(0, 10)
|
||||
collapsedPrepaid.max += parseInt(prepaid.maxRedeemers)
|
||||
collapsedPrepaid.used += parseInt(prepaid.redeemers?.length ? 0)
|
||||
foundIdenticalDates = true
|
||||
break
|
||||
unless foundIdenticalDates
|
||||
collapsedPrepaids.push({startDate, endDate, max, used})
|
||||
|
||||
@schools.sort (a, b) ->
|
||||
b.activity - a.activity or new Date(a.endDate).getTime() - new Date(b.endDate).getTime() or b.max - a.max or b.used - a.used or b.prepaids.length - a.prepaids.length or b.name.localeCompare(a.name)
|
||||
for collapsedPrepaid in collapsedPrepaids
|
||||
collapsedPrepaid.startScale = Math.round((new Date(collapsedPrepaid.startDate).getTime() - @startDateRange.getTime()) / rangeMilliseconds * 100)
|
||||
collapsedPrepaid.startScale = 0 if collapsedPrepaid.startScale < 0
|
||||
collapsedPrepaid.rangeScale = Math.round((new Date(collapsedPrepaid.endDate).getTime() - new Date(collapsedPrepaid.startDate).getTime()) / rangeMilliseconds * 100)
|
||||
collapsedPrepaid.rangeScale = 100 - collapsedPrepaid.startScale if collapsedPrepaid.rangeScale + collapsedPrepaid.startScale > 100
|
||||
@schools.push {name: school, activity, max: schoolMax, used: schoolUsed, prepaids: collapsedPrepaids, startDate: collapsedPrepaids[0].startDate, endDate: collapsedPrepaids[0].endDate}
|
||||
|
||||
# console.log @schools
|
||||
@render()
|
||||
@schools.sort (a, b) ->
|
||||
b.activity - a.activity or new Date(a.endDate).getTime() - new Date(b.endDate).getTime() or b.max - a.max or b.used - a.used or b.prepaids.length - a.prepaids.length or b.name.localeCompare(a.name)
|
||||
|
||||
@render()
|
||||
|
|
Loading…
Reference in a new issue