Apply linter
This commit is contained in:
@@ -1,24 +1,25 @@
|
|||||||
//Setup
|
//Setup
|
||||||
export default async function ({ login, q, imports, data, account },{ enabled = false, token } = {}) {
|
export default async function ({ login, q, imports, data, account }, { enabled = false, token } = {}) {
|
||||||
//Plugin execution
|
//Plugin execution
|
||||||
try {
|
try {
|
||||||
//Check if plugin is enabled and requirements are met
|
//Check if plugin is enabled and requirements are met
|
||||||
if (!enabled || !q.wakatime) return null;
|
if (!enabled || !q.wakatime)
|
||||||
|
return null
|
||||||
|
|
||||||
//Load inputs
|
//Load inputs
|
||||||
let { sections, days, limit, url, user } = imports.metadata.plugins.wakatime.inputs({ data, account, q });
|
let { sections, days, limit, url, user } = imports.metadata.plugins.wakatime.inputs({ data, account, q })
|
||||||
if (!limit) limit = void limit;
|
if (!limit) limit = void limit
|
||||||
const range =
|
const range =
|
||||||
{
|
{
|
||||||
7: "last_7_days",
|
"7": "last_7_days",
|
||||||
30: "last_30_days",
|
"30": "last_30_days",
|
||||||
180: "last_6_months",
|
"180": "last_6_months",
|
||||||
365: "last_year",
|
"365": "last_year",
|
||||||
}[days] ?? "last_7_days";
|
}[days] ?? "last_7_days"
|
||||||
|
|
||||||
//Querying api and format result (https://wakatime.com/developers#stats)
|
//Querying api and format result (https://wakatime.com/developers#stats)
|
||||||
console.debug(`metrics/compute/${login}/plugins > wakatime > querying api`);
|
console.debug(`metrics/compute/${login}/plugins > wakatime > querying api`)
|
||||||
const {data: { data: stats }} = await imports.axios.get(`${url}/api/v1/users/${user}/stats/${range}?api_key=${token}`);
|
const {data: { data: stats }} = await imports.axios.get(`${url}/api/v1/users/${user}/stats/${range}?api_key=${token}`)
|
||||||
const result = {
|
const result = {
|
||||||
sections,
|
sections,
|
||||||
days,
|
days,
|
||||||
@@ -30,18 +31,19 @@ export default async function ({ login, q, imports, data, account },{ enabled =
|
|||||||
languages:stats.languages.map(({name, percent, total_seconds:total}) => ({name, percent:percent/100, total})).sort((a, b) => b.percent - a.percent).slice(0, limit),
|
languages:stats.languages.map(({name, percent, total_seconds:total}) => ({name, percent:percent/100, total})).sort((a, b) => b.percent - a.percent).slice(0, limit),
|
||||||
os:stats.operating_systems.map(({name, percent, total_seconds:total}) => ({name, percent:percent/100, total})).sort((a, b) => b.percent - a.percent).slice(0, limit),
|
os:stats.operating_systems.map(({name, percent, total_seconds:total}) => ({name, percent:percent/100, total})).sort((a, b) => b.percent - a.percent).slice(0, limit),
|
||||||
editors:stats.editors.map(({name, percent, total_seconds:total}) => ({name, percent:percent/100, total})).sort((a, b) => b.percent - a.percent).slice(0, limit),
|
editors:stats.editors.map(({name, percent, total_seconds:total}) => ({name, percent:percent/100, total})).sort((a, b) => b.percent - a.percent).slice(0, limit),
|
||||||
};
|
}
|
||||||
|
|
||||||
//Result
|
//Result
|
||||||
return result;
|
return result
|
||||||
} catch (error) {
|
}
|
||||||
//Handle errors
|
//Handle errors
|
||||||
let message = "An error occured";
|
catch (error) {
|
||||||
|
let message = "An error occured"
|
||||||
if (error.isAxiosError) {
|
if (error.isAxiosError) {
|
||||||
const status = error.response?.status;
|
const status = error.response?.status
|
||||||
message = `API returned ${status}`;
|
message = `API returned ${status}`
|
||||||
error = error.response?.data ?? null;
|
error = error.response?.data ?? null
|
||||||
}
|
}
|
||||||
throw {error:{message, instance:error }};
|
throw {error:{message, instance:error }}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user