//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) } }