chore: code formatting
This commit is contained in:
@@ -91,7 +91,7 @@ export default {
|
||||
"Tenta Brella": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/5/53/S3_Weapon_Main_Tenta_Brella_Flat.png/120px-S3_Weapon_Main_Tenta_Brella_Flat.png",
|
||||
"Tri-Slosher": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/0/0e/S3_Weapon_Main_Tri-Slosher_Flat.png/120px-S3_Weapon_Main_Tri-Slosher_Flat.png",
|
||||
"Tri-Stringer": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/a/a9/S3_Weapon_Main_Tri-Stringer_Flat.png/120px-S3_Weapon_Main_Tri-Stringer_Flat.png",
|
||||
"Undercover Brella": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/8/8c/S3_Weapon_Main_Undercover_Brella_Flat.png/120px-S3_Weapon_Main_Undercover_Brella_Flat.png"
|
||||
"Undercover Brella": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/8/8c/S3_Weapon_Main_Undercover_Brella_Flat.png/120px-S3_Weapon_Main_Undercover_Brella_Flat.png",
|
||||
},
|
||||
//Subweapons icons
|
||||
subweapons: {
|
||||
@@ -108,7 +108,7 @@ export default {
|
||||
"Squid Beakon": "https://cdn.wikimg.net/en/splatoonwiki/images/f/f1/S3_Weapon_Sub_Squid_Beakon_Flat.png",
|
||||
"Suction Bomb": "https://cdn.wikimg.net/en/splatoonwiki/images/f/f2/S3_Weapon_Sub_Suction_Bomb_Flat.png",
|
||||
Torpedo: "https://cdn.wikimg.net/en/splatoonwiki/images/0/06/S3_Weapon_Sub_Torpedo_Flat.png",
|
||||
"Toxic Mist":"https://cdn.wikimg.net/en/splatoonwiki/images/6/6f/S3_Weapon_Sub_Toxic_Mist_Flat.png"
|
||||
"Toxic Mist": "https://cdn.wikimg.net/en/splatoonwiki/images/6/6f/S3_Weapon_Sub_Toxic_Mist_Flat.png",
|
||||
},
|
||||
//Specials icons
|
||||
specials: {
|
||||
@@ -128,7 +128,7 @@ export default {
|
||||
Trizooka: "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/9/93/S3_Weapon_Special_Trizooka.png/120px-S3_Weapon_Special_Trizooka.png",
|
||||
"Ultra Stamp": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/7/70/S3_Weapon_Special_Ultra_Stamp.png/120px-S3_Weapon_Special_Ultra_Stamp.png",
|
||||
"Wave Breaker": "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/6/67/S3_Weapon_Special_Wave_Breaker.png/120px-S3_Weapon_Special_Wave_Breaker.png",
|
||||
Zipcaster: "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/9/96/S3_Weapon_Special_Zipcaster.png/120px-S3_Weapon_Special_Zipcaster.png"
|
||||
Zipcaster: "https://cdn.wikimg.net/en/splatoonwiki/images/thumb/9/96/S3_Weapon_Special_Zipcaster.png/120px-S3_Weapon_Special_Zipcaster.png",
|
||||
},
|
||||
//Salmon boss icons
|
||||
salmon: {
|
||||
@@ -146,7 +146,7 @@ export default {
|
||||
"Slammin' Lid": "https://cdn.wikimg.net/en/splatoonwiki/images/f/fa/S3_Slammin%27_Lid_icon.png",
|
||||
"Steel Eel": "https://cdn.wikimg.net/en/splatoonwiki/images/6/62/S3_Steel_Eel_icon.png",
|
||||
Steelhead: "https://cdn.wikimg.net/en/splatoonwiki/images/9/9a/S3_Steelhead_icon.png",
|
||||
Stinger:"https://cdn.wikimg.net/en/splatoonwiki/images/b/b5/S3_Stinger_icon.png"
|
||||
Stinger: "https://cdn.wikimg.net/en/splatoonwiki/images/b/b5/S3_Stinger_icon.png",
|
||||
},
|
||||
//Exposed icons (use base64 when no link is available)
|
||||
icons: {
|
||||
@@ -156,9 +156,13 @@ export default {
|
||||
eggs: "https://cdn.wikimg.net/en/splatoonwiki/images/7/75/SplatNet_3_icon_Power_Egg.png",
|
||||
salmon_run: "https://cdn.wikimg.net/en/splatoonwiki/images/2/21/S3_SRNW_logo.png",
|
||||
splatoon: "https://cdn.wikimg.net/en/splatoonwiki/images/a/a3/S3_logo_JP_alt.png",
|
||||
rescues: "",
|
||||
rescued: "",
|
||||
kills: "",
|
||||
deaths: "",
|
||||
}
|
||||
rescues:
|
||||
"",
|
||||
rescued:
|
||||
"",
|
||||
kills:
|
||||
"",
|
||||
deaths:
|
||||
"",
|
||||
},
|
||||
}
|
||||
@@ -25,14 +25,15 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
//Fetch data
|
||||
const allowed = {
|
||||
files: ["profile.json", "profile.json.swap", "export", "cache"],
|
||||
net:["api.imink.app", "accounts.nintendo.com", "api.accounts.nintendo.com", "api-lp1.znc.srv.nintendo.net", "api.lp1.av5ja.srv.nintendo.net"]
|
||||
net: ["api.imink.app", "accounts.nintendo.com", "api.accounts.nintendo.com", "api-lp1.znc.srv.nintendo.net", "api.lp1.av5ja.srv.nintendo.net"],
|
||||
}
|
||||
await imports.run(`deno run --no-prompt --cached-only --no-remote --allow-read="${allowed.files}" --allow-write="${allowed.files}" --allow-net="${allowed.net}" index.ts --exporter file --no-progress`, {cwd: `${imports.__module(import.meta.url)}/s3si`}, {prefixed: false})
|
||||
|
||||
//Read fetched data
|
||||
const fetched = (await Promise.all(
|
||||
(await imports.fs.readdir(`${imports.__module(import.meta.url)}/s3si/export`))
|
||||
.map(async file => JSON.parse(await imports.fs.readFile(`${imports.__module(import.meta.url)}/s3si/export/${file}`)))))
|
||||
.map(async file => JSON.parse(await imports.fs.readFile(`${imports.__module(import.meta.url)}/s3si/export/${file}`))),
|
||||
))
|
||||
.sort((a, b) => new Date(b.data.detail.playedTime) - new Date(a.data.detail.playedTime))
|
||||
console.debug(`metrics/compute/${login}/plugins > splatoon > fetched ${fetched.length} matches`)
|
||||
|
||||
@@ -40,7 +41,8 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
let vs = null
|
||||
if (!((modes.length === 1) && (modes[0] === "salmon-run"))) {
|
||||
vs = {
|
||||
matches:await Promise.all(fetched.filter(({type, data}) => (type === "VS")&&(modes.includes(data.detail.vsRule.name.toLocaleLowerCase().replace(/ /g, "-")))).slice(0, _versus_limit).map(async ({data}) => ({
|
||||
matches: await Promise.all(
|
||||
fetched.filter(({type, data}) => (type === "VS") && (modes.includes(data.detail.vsRule.name.toLocaleLowerCase().replace(/ /g, "-")))).slice(0, _versus_limit).map(async ({data}) => ({
|
||||
mode: {
|
||||
name: data.detail.vsRule.name,
|
||||
icon: await imports.imgb64(assets.modes[data.detail.vsRule.name]),
|
||||
@@ -72,8 +74,8 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
death: result?.death ?? 0,
|
||||
assist: result?.assist ?? 0,
|
||||
special: result?.special ?? 0,
|
||||
}
|
||||
})))
|
||||
},
|
||||
}))),
|
||||
}))),
|
||||
awards: data.detail.awards,
|
||||
date: data.detail.playedTime,
|
||||
@@ -86,8 +88,9 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
stage: {
|
||||
name: data.detail.vsStage.name,
|
||||
icon: await imports.imgb64(assets.stages[data.detail.vsStage.name]),
|
||||
}
|
||||
})))
|
||||
},
|
||||
})),
|
||||
),
|
||||
}
|
||||
vs.player = vs.matches.at(-1)?.player ?? null
|
||||
}
|
||||
@@ -96,11 +99,12 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
let salmon = null
|
||||
if (modes.includes("salmon-run")) {
|
||||
salmon = {
|
||||
matches:await Promise.all(fetched.filter(({type}) => type === "COOP").slice(0, _salmon_limit).map(async ({data}) => ({
|
||||
matches: await Promise.all(
|
||||
fetched.filter(({type}) => type === "COOP").slice(0, _salmon_limit).map(async ({data}) => ({
|
||||
weapons: await Promise.all(data.detail.myResult.weapons.map(async ({name}) => ({name, icon: await imports.imgb64(assets.weapons[name])}))),
|
||||
special: {
|
||||
name: data.detail.myResult.specialWeapon.name,
|
||||
icon:await imports.imgb64(assets.specials[data.detail.myResult.specialWeapon.name])
|
||||
icon: await imports.imgb64(assets.specials[data.detail.myResult.specialWeapon.name]),
|
||||
},
|
||||
eggs: {
|
||||
golden: data.detail.myResult.goldenDeliverCount,
|
||||
@@ -112,19 +116,22 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
waves: data.detail.waveResults.map(({deliverNorm: quota, teamDeliverCount: delivered}) => ({quota, delivered})),
|
||||
failed: data.detail.resultWave,
|
||||
hazard: Math.round(data.detail.dangerRate * 100),
|
||||
boss:data.detail.bossResult ? {
|
||||
boss: data.detail.bossResult
|
||||
? {
|
||||
defeated: data.detail.bossResult.hasDefeatBoss,
|
||||
name: data.detail.bossResult.boss.name,
|
||||
icon:await imports.imgb64(assets.salmon[data.detail.bossResult.boss.name])
|
||||
} : null,
|
||||
icon: await imports.imgb64(assets.salmon[data.detail.bossResult.boss.name]),
|
||||
}
|
||||
: null,
|
||||
stage: {
|
||||
name: data.detail.coopStage.name,
|
||||
icon:await imports.imgb64(assets.stages[data.detail.coopStage.name])
|
||||
icon: await imports.imgb64(assets.stages[data.detail.coopStage.name]),
|
||||
},
|
||||
date: data.detail.playedTime,
|
||||
grade: data.detail.afterGrade.name,
|
||||
player: data.detail.myResult.player.name,
|
||||
}))),
|
||||
})),
|
||||
),
|
||||
}
|
||||
salmon.player = {
|
||||
name: salmon.matches.at(-1)?.player ?? null,
|
||||
@@ -136,7 +143,7 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
return {
|
||||
vs,
|
||||
salmon,
|
||||
icons:Object.fromEntries(await Promise.all(Object.entries(assets.icons).map(async ([k, v]) => [k, await imports.imgb64(v)])))
|
||||
icons: Object.fromEntries(await Promise.all(Object.entries(assets.icons).map(async ([k, v]) => [k, await imports.imgb64(v)]))),
|
||||
}
|
||||
}
|
||||
//Handle errors
|
||||
@@ -144,4 +151,3 @@ export default async function({login, q, imports, data, account}, {enabled = fal
|
||||
throw imports.format.error(error)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user