Files
shields/services/npm/npm-type-definitions.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

74 lines
1.8 KiB
JavaScript

import NpmBase from './npm-base.js'
// For this badge to correctly detect type definitions, either the relevant
// dependencies must be declared, or the `types` key must be set in
// package.json.
export default class NpmTypeDefinitions extends NpmBase {
static category = 'platform-support'
static route = this.buildRoute('npm/types', { withTag: false })
static examples = [
{
title: 'npm type definitions',
pattern: ':packageName',
namedParams: { packageName: 'chalk' },
staticPreview: this.render({
supportedLanguages: ['TypeScript', 'Flow'],
}),
keywords: ['node', 'typescript', 'flow'],
},
]
static defaultBadgeData = {
label: 'types',
}
static render({ supportedLanguages }) {
if (supportedLanguages.length === 0) {
return { message: 'none', color: 'lightgray' }
} else {
return {
message: supportedLanguages.sort().join(' | '),
color: 'blue',
}
}
}
static transform({ devDependencies, types, typings, files }) {
const supportedLanguages = []
if (
types !== undefined ||
typings !== undefined ||
devDependencies.typescript !== undefined ||
files.includes('index.d.ts')
) {
supportedLanguages.push('TypeScript')
}
if (
devDependencies['flow-bin'] !== undefined ||
files.includes('index.js.flow')
) {
supportedLanguages.push('Flow')
}
return { supportedLanguages }
}
async handle(namedParams, queryParams) {
const { scope, packageName, registryUrl } = this.constructor.unpackParams(
namedParams,
queryParams,
)
const json = await this.fetchPackageData({
scope,
packageName,
registryUrl,
})
const props = this.constructor.transform(json)
return this.constructor.render(props)
}
}