Files
shields/services/github/github-top-language.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

53 lines
1.2 KiB
JavaScript

import { BaseGithubLanguage } from './github-languages-base.js'
import { documentation } from './github-helpers.js'
export default class GithubTopLanguage extends BaseGithubLanguage {
static category = 'analysis'
static route = {
base: 'github/languages/top',
pattern: ':user/:repo',
}
static examples = [
{
title: 'GitHub top language',
namedParams: {
user: 'badges',
repo: 'shields',
},
staticPreview: this.render({
language: 'javascript',
languageSize: 99.5,
totalSize: 100,
}),
documentation,
},
]
static defaultBadgeData = {
label: 'language',
}
static render({ language, languageSize, totalSize }) {
const message =
totalSize === 0
? 'none'
: `${((languageSize / totalSize) * 100).toFixed(1)}%`
return { label: language.toLowerCase(), message, color: 'blue' }
}
async handle({ user, repo }) {
const data = await this.fetch({ user, repo })
const language = Object.keys(data).reduce(
(a, b) => (data[a] > data[b] ? a : b),
'language',
)
return this.constructor.render({
language,
languageSize: data[language],
totalSize: this.getTotalSize(data),
})
}
}