import pagosB from "./pagos.bestiary";
import anemosB from "./anemos.bestiary";
import pyrosB from "./pyros.bestiary";
import hydatosB from "./hydatos.bestiary";
import day from "dayjs";
import isBetween from "dayjs/plugin/isBetween";
day.extend(isBetween);
const bestiaries = {
pagos: pagosB,
anemos: anemosB,
pyros: pyrosB,
hydatos: hydatosB,
};
export const logograms = {
CONCEPTUAL: 0,
FUNDAMENTAL: 1,
OFFENSIVE: 2,
PROTECTIVE: 3,
CURATIVE: 4,
TACTICAL: 5,
INMICAL: 6,
MITIGATIVE: 7,
OBSCURE: 8,
};
export function getLogogramName(logogram) {
switch (logogram) {
case 0:
return "Conceptual";
case 1:
return "Fundamental";
case 2:
return "Offensive";
case 3:
return "Protective";
case 4:
return "Curative";
case 5:
return "Tactical";
case 6:
return "Inmical";
case 7:
return "Mitigative";
case 8:
return "Obscure";
}
}
export function getMatches(forecast, level) {
let res = [];
bestiaries[forecast[0].zone].forEach((b) => {
if (
(b.level >= level && b.level - 2 <= level) ||
(b.levelRange && b.levelRange[0] - 2 <= level && b.levelRange[1] >= level)
) {
res.push({
name: b.name.trim(),
level: b.level,
levelRange: b.levelRange,
elem: b.elem,
special: b.type > 0,
mutating: b.type === 1,
augmenting: b.type === 2,
logogram: typeof b.logogram === "number" && getLogogramName(b.logogram),
spawning:
!b.spawnConditions ||
b.spawnConditions.includes(forecast[0].currWeather),
nextSpawn:
!b.spawnConditions || findNextSpawn(forecast, b.spawnConditions),
uptime: findForecastMatch(forecast, b.conditions),
});
}
});
return res;
}
function getEzTime() {
return day(new Date().getTime() * (1440 / 70));
}
function findForecastMatch(forecast, conditions) {
const time = getEzTime();
const dn = time.isBetween(time.hour(8), time.hour(18)) ? "day" : "night";
return {
isUp: forecastMatches(forecast, conditions[dn], 0),
weathers: conditions[dn],
futureUptime: [1, 2, 3, 4].map((i) => {
return futureForecastMatches(forecast, conditions, i);
}),
};
}
function findNextSpawn(forecast, spawnConditions) {
return forecast.find((f) => {
return spawnConditions.includes(f.currWeather);
});
}
function forecastMatches(forecast, condition, index) {
const currWeather = forecast[index].currWeather;
return condition.some((c) => c === currWeather);
}
function futureForecastMatches(forecast, conditions, index) {
const fc = forecast[index];
const fcTime = day((fc.date.getTime() * 1440) / 70);
const dn = day(fcTime).isBetween(fcTime.hour(8), fcTime.hour(18))
? "day"
: "night";
return conditions[dn].some((c) => c === fc.currWeather);
}