Files
metrics/source/plugins/community/16personalities/index.mjs

63 lines
2.7 KiB
JavaScript

//Setup
export default async function({login, q, imports, data, account}, {enabled = false, extras = false} = {}) {
//Plugin execution
try {
//Check if plugin is enabled and requirements are met
if ((!q["16personalities"]) || (!imports.metadata.plugins["16personalities"].enabled(enabled, {extras})))
return null
//Load inputs
let {url, sections, scores} = imports.metadata.plugins["16personalities"].inputs({data, account, q})
if (!url)
throw {error: {message: "URL is not set"}}
//Start puppeteer and navigate to page
console.debug(`metrics/compute/${login}/plugins > 16personalities > starting browser`)
const browser = await imports.puppeteer.launch()
console.debug(`metrics/compute/${login}/plugins > 16personalities > started ${await browser.version()}`)
const page = await browser.newPage()
console.debug(`metrics/compute/${login}/plugins > 16personalities > loading ${url}`)
await page.goto(url, {waitUntil: imports.puppeteer.events})
//Fetch raw data
const raw = await page.evaluate(() => ({
color:getComputedStyle(document.querySelector(".card__bg")).backgroundColor, //eslint-disable-line no-undef
type:document.querySelector(".type__code").innerText,
personality:[...document.querySelectorAll(".personality-cards .sp-personality-card")].map(card => ({
category:card.querySelector(".card__title").innerText,
value:card.querySelector(".card__subtitle").innerText,
image:card.querySelector(".card__image").src,
text:card.querySelector(".card__text").innerText
})),
traits:[...document.querySelectorAll("#traits .card__body")].map(card => ({
category:card.querySelector(".card__title").innerText,
value:card.querySelector(".card__subtitle").innerText,
score:card.querySelector(".center__num").innerText,
text:card.querySelector("p").innerText
}))
}))
//Format data
const {color} = raw
const type = raw.type.replace("(", "").replace(")", "").trim()
const personality = await Promise.all(raw.personality.map(async ({category, value, image, text}) => ({
category,
value:value.replace(`(${type})`, "").trim(),
image:await imports.imgb64(image),
text:text.replace(`${category}\n${value}\n`, "").trim()
})))
const traits = raw.traits.map(({category, value, score, text}) => ({
category,
value:`${value[0]}${value.substring(1).toLocaleLowerCase()}`,
score:scores ? Number(score.replace("%", ""))/100 : NaN,
text:text.split(".").slice(1).join("."),
}))
//Results
return {sections, color, type, personality, traits}
}
//Handle errors
catch (error) {
throw imports.format.error(error)
}
}