* Build(deps-dev): bump @typescript-eslint/eslint-plugin Bumps [@typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/eslint-plugin) from 2.34.0 to 4.19.0. - [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases) - [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/CHANGELOG.md) - [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v4.19.0/packages/eslint-plugin) Signed-off-by: dependabot-preview[bot] <support@dependabot.com> * chore: update eslint camelcase rule * chore: eslint camelcase updates for wordpress * chore: fix eslint camelcase for misc other services * chore: fix eslint camelcase issue in github and gitlab * chore: run prettier * chore: account for JSX globals * deps: bump typescript-eslint-parser to v4 * chore: frontend lint changes * chore: update eslint config to only run @typescript-eslint/explicit-module-boundary-types on ts files Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com> Co-authored-by: Caleb Cartwright <caleb.cartwright@outlook.com>
80 lines
1.9 KiB
JavaScript
80 lines
1.9 KiB
JavaScript
'use strict'
|
|
|
|
const moment = require('moment')
|
|
const { InvalidResponse } = require('..')
|
|
const { formatDate } = require('../text-formatters')
|
|
const { age: ageColor } = require('../color-formatters')
|
|
const BaseWordpress = require('./wordpress-base')
|
|
|
|
const extensionData = {
|
|
plugin: {
|
|
capt: 'Plugin',
|
|
exampleSlug: 'bbpress',
|
|
lastUpdateFormat: 'YYYY-MM-DD hh:mma GMT',
|
|
},
|
|
theme: {
|
|
capt: 'Theme',
|
|
exampleSlug: 'twentyseventeen',
|
|
lastUpdateFormat: 'YYYY-MM-DD',
|
|
},
|
|
}
|
|
|
|
function LastUpdateForType(extensionType) {
|
|
const { capt, exampleSlug, lastUpdateFormat } = extensionData[extensionType]
|
|
|
|
return class WordpressLastUpdate extends BaseWordpress {
|
|
static name = `Wordpress${capt}LastUpdated`
|
|
|
|
static category = 'activity'
|
|
|
|
static route = {
|
|
base: `wordpress/${extensionType}/last-updated`,
|
|
pattern: ':slug',
|
|
}
|
|
|
|
static examples = [
|
|
{
|
|
title: `WordPress ${capt} Last Updated`,
|
|
namedParams: { slug: exampleSlug },
|
|
staticPreview: this.render({ lastUpdated: '2020-08-11' }),
|
|
},
|
|
]
|
|
|
|
static defaultBadgeData = { label: 'last updated' }
|
|
|
|
static render({ lastUpdated }) {
|
|
return {
|
|
label: 'last updated',
|
|
message: formatDate(lastUpdated),
|
|
color: ageColor(lastUpdated),
|
|
}
|
|
}
|
|
|
|
transform(lastUpdate) {
|
|
const date = moment(lastUpdate, lastUpdateFormat)
|
|
|
|
if (date.isValid()) {
|
|
return date.format('YYYY-MM-DD')
|
|
} else {
|
|
throw new InvalidResponse({ prettyMessage: 'invalid date' })
|
|
}
|
|
}
|
|
|
|
async handle({ slug }) {
|
|
const { last_updated: lastUpdated } = await this.fetch({
|
|
extensionType,
|
|
slug,
|
|
})
|
|
|
|
const newDate = await this.transform(lastUpdated)
|
|
|
|
return this.constructor.render({
|
|
lastUpdated: newDate,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
|
|
const lastupdate = ['plugin', 'theme'].map(LastUpdateForType)
|
|
module.exports = [...lastupdate]
|