Files
shields/services/github/github-milestone-detail.service.js
dependabot[bot] b9d96755ec chore(deps-dev): bump prettier from 2.8.8 to 3.0.0 (#9357)
* chore(deps-dev): bump prettier from 2.8.8 to 3.0.0

Bumps [prettier](https://github.com/prettier/prettier) from 2.8.8 to 3.0.0.
- [Release notes](https://github.com/prettier/prettier/releases)
- [Changelog](https://github.com/prettier/prettier/blob/main/CHANGELOG.md)
- [Commits](https://github.com/prettier/prettier/compare/2.8.8...3.0.0)

---
updated-dependencies:
- dependency-name: prettier
  dependency-type: direct:development
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>

* reformat all the things (prettier 3)

* update tests to await calls to prettier.format()

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: chris48s <git@chris-shaw.dev>
2023-07-10 09:27:51 +00: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, httpErrorsFor } 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,
httpErrors: httpErrorsFor('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 })
}
}