Files
shields/services/github/github-milestone-detail.service.js
chris48s ae018cdddc conform to standard js quote rules (#8395)
* restore standardjs quote behaviour

* conform to standard js quote rules
2022-09-12 17:22:12 +01:00

97 lines
2.6 KiB
JavaScript

import Joi from 'joi'
import { metric } from '../text-formatters.js'
import { nonNegativeInteger } from '../validators.js'
import { GithubAuthV3Service } from './github-auth-service.js'
import { documentation, errorMessagesFor } from './github-helpers.js'
const schema = Joi.object({
open_issues: nonNegativeInteger,
closed_issues: nonNegativeInteger,
title: Joi.string().required(),
}).required()
export default class GithubMilestoneDetail extends GithubAuthV3Service {
static category = 'issue-tracking'
static route = {
base: 'github/milestones',
pattern:
':variant(issues-closed|issues-open|issues-total|progress|progress-percent)/:user/:repo/:number([0-9]+)',
}
static examples = [
{
title: 'GitHub milestone',
namedParams: {
variant: 'issues-open',
user: 'badges',
repo: 'shields',
number: '1',
},
staticPreview: {
label: 'milestone issues',
message: '17/22',
color: 'blue',
},
documentation,
},
]
static defaultBadgeData = { label: 'milestones', color: 'informational' }
static render({ user, repo, variant, number, milestone }) {
let milestoneMetric
let color
let label = ''
switch (variant) {
case 'issues-open':
milestoneMetric = milestone.open_issues
color = 'red'
label = 'open issues'
break
case 'issues-closed':
milestoneMetric = milestone.closed_issues
color = 'green'
label = 'closed issues'
break
case 'issues-total':
milestoneMetric = milestone.open_issues + milestone.closed_issues
color = 'blue'
label = 'issues'
break
case 'progress':
milestoneMetric = `${milestone.closed_issues}/${
milestone.open_issues + milestone.closed_issues
}`
color = 'blue'
break
case 'progress-percent':
milestoneMetric = `${Math.floor(
(milestone.closed_issues /
(milestone.open_issues + milestone.closed_issues)) *
100
)}%`
color = 'blue'
}
return {
label: `${milestone.title}${label ? ' ' : ''}${label}`,
message: metric(milestoneMetric),
color,
}
}
async fetch({ user, repo, number }) {
return this._requestJson({
url: `/repos/${user}/${repo}/milestones/${number}`,
schema,
errorMessages: errorMessagesFor('repo or milestone not found'),
})
}
async handle({ user, repo, variant, number }) {
const milestone = await this.fetch({ user, repo, number })
return this.constructor.render({ user, repo, variant, number, milestone })
}
}