Files
shields/services/bit/bit-components.service.js
chris48s 504015c0ba migrate hapi/joi to joi (#5624)
* update joi + joi-extension-semver

* @hapi/joi --> joi

Co-authored-by: repo-ranger[bot] <39074581+repo-ranger[bot]@users.noreply.github.com>
2020-09-30 17:51:02 +00:00

53 lines
1.3 KiB
JavaScript

'use strict'
const Joi = require('joi')
const { metric } = require('../text-formatters')
const { nonNegativeInteger } = require('../validators')
const { downloadCount } = require('../color-formatters')
const { BaseJsonService } = require('..')
const collectionSchema = Joi.object({
payload: Joi.object({
totalComponents: nonNegativeInteger,
}).required(),
}).required()
module.exports = class BitComponents extends BaseJsonService {
static category = 'other'
static route = {
base: 'bit/collection/total-components',
pattern: ':owner/:collection',
}
static examples = [
{
title: 'bit',
namedParams: { owner: 'ramda', collection: 'ramda' },
staticPreview: this.render({ count: 330 }),
keywords: ['components'],
},
]
static defaultBadgeData = { label: 'components' }
static render({ count }) {
return { message: metric(count), color: downloadCount(count) }
}
async fetch({ owner, collection }) {
const url = `https://api.bit.dev/scope/${owner}/${collection}/`
return this._requestJson({
url,
schema: collectionSchema,
errorMessages: {
404: 'collection not found',
},
})
}
async handle({ owner, collection }) {
const json = await this.fetch({ owner, collection })
return this.constructor.render({ count: json.payload.totalComponents })
}
}