Files
shields/services/puppetforge/puppetforge-user-module-count.service.js
Paul Melnikow 1cdcaabd38 Unify order of properties and methods in services (#3353)
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()`
2019-04-23 21:36:04 -04:00

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 })
}
}