mirror of
https://github.com/misenhower/splatoon3.ink.git
synced 2026-04-26 07:49:22 -05:00
113 lines
3.2 KiB
JavaScript
113 lines
3.2 KiB
JavaScript
import StatusGenerator from "./StatusGenerator.mjs";
|
|
import Media from "../Media.mjs";
|
|
import { useUSSplatfestsStore, useEUSplatfestsStore, useJPSplatfestsStore, useAPSplatfestsStore, STATUS_ACTIVE, STATUS_PAST } from '../../../src/stores/splatfests.mjs';
|
|
import { useTimeStore } from "../../../src/stores/time.mjs";
|
|
|
|
export default class SplatfestStatus extends StatusGenerator
|
|
{
|
|
key = 'splatfest';
|
|
name = 'Splatfest';
|
|
|
|
constructor(region) {
|
|
super();
|
|
this.region = region;
|
|
this.key += `.${region}`;
|
|
this.name += ` (${region})`;
|
|
}
|
|
|
|
async getFestival() {
|
|
await this.preparePinia();
|
|
let store;
|
|
switch(this.region) {
|
|
case "NA": store = useUSSplatfestsStore(); break;
|
|
case "EU": store = useEUSplatfestsStore(); break;
|
|
case "JP": store = useJPSplatfestsStore(); break;
|
|
case "AP": store = useAPSplatfestsStore(); break;
|
|
}
|
|
return store.upcomingFestival
|
|
|| store.activeFestival
|
|
|| store.recentFestival;
|
|
}
|
|
|
|
async getState() {
|
|
let festival = await this.getFestival();
|
|
|
|
let startTime = Date.parse(festival?.startTime);
|
|
let now = useTimeStore().now;
|
|
let hoursAway = (startTime - now) / (1000 * 60 * 60);
|
|
|
|
switch (true) {
|
|
case !festival:
|
|
return null;
|
|
case festival.status === STATUS_PAST:
|
|
return 'ended';
|
|
case festival.status === STATUS_ACTIVE:
|
|
return 'active';
|
|
case hoursAway <= 24:
|
|
return 'upcoming:1d';
|
|
case hoursAway <= 72:
|
|
return 'upcoming:3d';
|
|
default:
|
|
return 'upcoming';
|
|
}
|
|
}
|
|
|
|
async getDataTime() {
|
|
let festival = await this.getFestival();
|
|
let state = await this.getState();
|
|
|
|
if (!festival || !state) {
|
|
return null;
|
|
}
|
|
|
|
return `${festival.id}:${state}`;
|
|
}
|
|
|
|
async shouldPost(client) {
|
|
let festival = await this.getFestival();
|
|
|
|
if (festival?.regions[0] !== this.region) {
|
|
return false;
|
|
}
|
|
|
|
let currentId = await this.getDataTime();
|
|
|
|
let cachedId = await this.lastPostCache(client).getData();
|
|
|
|
return currentId && currentId !== cachedId;
|
|
}
|
|
|
|
async _getStatus() {
|
|
let festival = await this.getFestival();
|
|
let state = await this.getState();
|
|
|
|
if (!festival || !state) {
|
|
return false;
|
|
}
|
|
|
|
const global = festival.regions.length == 4;
|
|
const regionText = global ? 'global' : festival.regions.join("/");
|
|
|
|
switch (state) {
|
|
case 'upcoming':
|
|
return `You can now vote in the next ${regionText} Splatfest: ${festival.title} #splatfest #splatoon3`;
|
|
case 'upcoming:3d':
|
|
return `Reminder: The next ${regionText} Splatfest starts in 3 DAYS! ${festival.title} #splatfest #splatoon3`
|
|
case 'upcoming:1d':
|
|
return `Reminder: The next ${regionText} Splatfest starts in 24 HOURS! ${festival.title} #splatfest #splatoon3`
|
|
case 'active':
|
|
return `The ${regionText} Splatfest is NOW OPEN! ${festival.title} #splatfest #splatoon3`
|
|
case 'ended':
|
|
return `The ${regionText} Splatfest is now closed. Results are usually posted within 2 hours! #splatfest #splatoon3`
|
|
}
|
|
}
|
|
|
|
/** @param {ScreenshotHelper} screenshotHelper */
|
|
async _getMedia(screenshotHelper) {
|
|
let media = new Media;
|
|
media.file = await screenshotHelper.capture(`splatfest/${this.region}`);
|
|
|
|
return media;
|
|
}
|
|
}
|