I find having these in a consistent order makes the services much faster to read. This is the order I’ve generally been using: 1. Category 2. Route 3. Examples 4. Rendering 5. Other helpers (`fetch()`, `transform()`) 6. `handle()`
47 lines
1.0 KiB
JavaScript
47 lines
1.0 KiB
JavaScript
'use strict'
|
|
|
|
const { metric } = require('../text-formatters')
|
|
const { floorCount: floorCountColor } = require('../color-formatters')
|
|
const { BasePuppetForgeUsersService } = require('./puppetforge-base')
|
|
|
|
module.exports = class PuppetForgeModuleCountService extends BasePuppetForgeUsersService {
|
|
static get category() {
|
|
return 'other'
|
|
}
|
|
|
|
static get route() {
|
|
return {
|
|
base: 'puppetforge/mc',
|
|
pattern: ':user',
|
|
}
|
|
}
|
|
|
|
static get examples() {
|
|
return [
|
|
{
|
|
title: 'Puppet Forge modules by user',
|
|
namedParams: {
|
|
user: 'camptocamp',
|
|
},
|
|
staticPreview: this.render({ modules: 60 }),
|
|
},
|
|
]
|
|
}
|
|
|
|
static get defaultBadgeData() {
|
|
return { label: 'modules' }
|
|
}
|
|
|
|
static render({ modules }) {
|
|
return {
|
|
message: metric(modules),
|
|
color: floorCountColor(modules, 5, 10, 50),
|
|
}
|
|
}
|
|
|
|
async handle({ user }) {
|
|
const data = await this.fetch({ user })
|
|
return this.constructor.render({ modules: data.module_count })
|
|
}
|
|
}
|