Files
shields/services/github/github-issues.service.js
2018-11-15 15:57:56 -05:00

160 lines
4.8 KiB
JavaScript

'use strict'
const LegacyService = require('../legacy-service')
const {
makeBadgeData: getBadgeData,
makeLogo: getLogo,
} = require('../../lib/badge-data')
const { metric } = require('../../lib/text-formatters')
const {
documentation,
checkErrorResponse: githubCheckErrorResponse,
} = require('./github-helpers')
module.exports = class GithubIssues extends LegacyService {
static get category() {
return 'issue-tracking'
}
static get route() {
return {
base: 'github',
}
}
static get examples() {
return [
{
title: 'GitHub issues',
previewUrl: 'issues/badges/shields',
keywords: ['GitHub', 'issue'],
documentation,
},
{
title: 'GitHub issues',
previewUrl: 'issues-raw/badges/shields',
keywords: ['GitHub', 'issue'],
documentation,
},
{
title: 'GitHub pull requests',
previewUrl: 'issues-pr/cdnjs/cdnjs',
keywords: ['GitHub', 'pullrequest', 'pr'],
documentation,
},
{
title: 'GitHub pull requests',
previewUrl: 'issues-pr-raw/cdnjs/cdnjs',
keywords: ['GitHub', 'pullrequest', 'pr'],
documentation,
},
{
title: 'GitHub closed issues',
previewUrl: 'issues-closed/badges/shields',
keywords: ['GitHub', 'issue'],
documentation,
},
{
title: 'GitHub closed issues',
previewUrl: 'issues-closed-raw/badges/shields',
keywords: ['GitHub', 'issue'],
documentation,
},
{
title: 'GitHub closed pull requests',
previewUrl: 'issues-pr-closed/cdnjs/cdnjs',
keywords: ['GitHub', 'pullrequest', 'pr'],
documentation,
},
{
title: 'GitHub closed pull requests',
previewUrl: 'issues-pr-closed-raw/cdnjs/cdnjs',
keywords: ['GitHub', 'pullrequest', 'pr'],
documentation,
},
{
title: 'GitHub issues by-label',
previewUrl: 'issues/badges/shields/service-badge',
keywords: ['GitHub', 'issue', 'label'],
documentation,
},
{
title: 'GitHub issues by-label',
previewUrl: 'issues-raw/badges/shields/service-badge',
keywords: ['GitHub', 'issue', 'label'],
documentation,
},
{
title: 'GitHub pull requests by-label',
previewUrl: 'issues-pr/badges/shields/service-badge',
keywords: ['GitHub', 'pullrequests', 'label'],
documentation,
},
{
title: 'GitHub pull requests by-label',
previewUrl: 'issues-pr-raw/badges/shields/service-badge',
keywords: ['GitHub', 'pullrequests', 'label'],
documentation,
},
]
}
static registerLegacyRouteHandler({ camp, cache, githubApiProvider }) {
camp.route(
/^\/github\/issues(-pr)?(-closed)?(-raw)?\/(?!detail)([^/]+)\/([^/]+)\/?(.+)?\.(svg|png|gif|jpg|json)$/,
cache((data, match, sendBadge, request) => {
const isPR = !!match[1]
const isClosed = !!match[2]
const isRaw = !!match[3]
const user = match[4] // eg, badges
const repo = match[5] // eg, shields
const ghLabel = match[6] // eg, website
const format = match[7]
const query = {}
const hasLabel = ghLabel !== undefined
query.q = `repo:${user}/${repo}${isPR ? ' is:pr' : ' is:issue'}${
isClosed ? ' is:closed' : ' is:open'
}${hasLabel ? ` label:"${ghLabel}"` : ''}`
const classText = isClosed ? 'closed' : 'open'
const leftClassText = isRaw ? `${classText} ` : ''
const rightClassText = !isRaw ? ` ${classText}` : ''
const isGhLabelMultiWord = hasLabel && ghLabel.includes(' ')
const labelText = hasLabel
? `${isGhLabelMultiWord ? `"${ghLabel}"` : ghLabel} `
: ''
const targetText = isPR ? 'pull requests' : 'issues'
const badgeData = getBadgeData(
leftClassText + labelText + targetText,
data
)
if (badgeData.template === 'social') {
badgeData.logo = getLogo('github', data)
}
githubApiProvider.request(
request,
'/search/issues',
query,
(err, res, buffer) => {
if (githubCheckErrorResponse(badgeData, err, res)) {
sendBadge(format, badgeData)
return
}
try {
const data = JSON.parse(buffer)
const issues = data.total_count
badgeData.text[1] = metric(issues) + rightClassText
badgeData.colorscheme = issues > 0 ? 'yellow' : 'brightgreen'
sendBadge(format, badgeData)
} catch (e) {
badgeData.text[1] = 'invalid'
sendBadge(format, badgeData)
}
}
)
})
)
}
}