Commit ec305a4e authored by timel's avatar timel

refactor: forbidden

parent ee7feabe
import { useConfig } from "@/config"; import { useConfig } from "@/config";
import { initStore } from "@/stores";
const { lflistUrl } = useConfig(); const { lflistUrl } = useConfig();
type Forbiddens = Map<number, number>; class Forbidden {
private data: Map<number, number> = new Map<number, number>();
public time: string = "?";
export let forbiddenTime = "?"; public async init(): Promise<void> {
export async function initForbiddens(): Promise<void> {
const text = await (await fetch(lflistUrl)).text(); const text = await (await fetch(lflistUrl)).text();
const { time, forbiddens } = extractForbiddensFromText(text); const { time, forbiddens } = this.extractForbiddensFromText(text);
forbiddenTime = time; this.time = time;
setForbiddens(forbiddens); this.setForbiddens(forbiddens);
} initStore.forbidden = true;
}
const forbiddensMap: Forbiddens = new Map<number, number>(); public set(cardId: number, limitCount: number): void {
this.data.set(cardId, limitCount);
}
function setForbiddens(forbiddens: Forbiddens): void { public get(id: number): number | undefined {
forbiddensMap.clear(); return this.data.get(id);
for (const [cardId, limitCount] of forbiddens) {
forbiddensMap.set(cardId, limitCount);
} }
}
export function getForbiddenInfo(id: number): number | undefined { private setForbiddens(forbiddens: Map<number, number>): void {
return forbiddensMap.get(id); this.data.clear();
} for (const [cardId, limitCount] of forbiddens) {
this.data.set(cardId, limitCount);
}
}
function extractForbiddensFromText(text: string): { private extractForbiddensFromText(text: string): {
time: string; time: string;
forbiddens: Forbiddens; forbiddens: Map<number, number>;
} { } {
// 解析文本行中的卡片信息
function parseCardInfo( function parseCardInfo(
input: string, input: string,
): { cardId: number; limitCount: number } | null { ): { cardId: number; limitCount: number } | null {
...@@ -41,30 +46,37 @@ function extractForbiddensFromText(text: string): { ...@@ -41,30 +46,37 @@ function extractForbiddensFromText(text: string): {
} }
return null; return null;
} }
const lines = text.split("\n"); const lines = text.split("\n");
const forbiddens = new Map<number, number>(); const forbiddens = new Map<number, number>();
lines.shift(); // remove first line
let time = "?"; let time = "?";
// 移除第一行标题
lines.shift();
for (const line of lines) { for (const line of lines) {
if (line.startsWith("#")) { if (line.startsWith("#")) {
// do nothing // 忽略注释行
} else if (line.startsWith("!")) { } else if (line.startsWith("!")) {
// 如果时间已经设置,退出循环
if (time !== "?") { if (time !== "?") {
// 已经读取完第一个禁限表的信息了,退出循环
break; break;
} else { } else {
// 提取时间信息
time = line.substring(1).trim(); time = line.substring(1).trim();
} }
} else { } else {
const cardInfo = parseCardInfo(line); const cardInfo = parseCardInfo(line);
if (cardInfo) { if (cardInfo) {
// 将卡片信息添加到禁限表
forbiddens.set(cardInfo.cardId, cardInfo.limitCount); forbiddens.set(cardInfo.cardId, cardInfo.limitCount);
} }
} }
} }
// 返回时间和禁限表
return { time, forbiddens }; return { time, forbiddens };
}
} }
export const forbidden = new Forbidden();
...@@ -5,10 +5,11 @@ import { type NeosStore } from "./shared"; ...@@ -5,10 +5,11 @@ import { type NeosStore } from "./shared";
export const initStore = proxy({ export const initStore = proxy({
sqlite: { sqlite: {
progress: 0, // 0 -> 1 progress: 0, // 0 -> 1
}, }, // ygodb
decks: false, decks: false,
i18n: false, i18n: false,
wasm: false, wasm: false,
forbidden: false, // 禁卡表
// ... // ...
reset() {}, reset() {},
} satisfies NeosStore); } satisfies NeosStore);
...@@ -8,9 +8,9 @@ import { ...@@ -8,9 +8,9 @@ import {
extraCardTypes, extraCardTypes,
isLinkMonster, isLinkMonster,
isMonster, isMonster,
isPendulumMonster,
Race2StringCodeMap, Race2StringCodeMap,
Type2StringCodeMap, Type2StringCodeMap,
isPendulumMonster,
} from "@/common"; } from "@/common";
import { CardEffectText, IconFont, ScrollableArea, YgoCard } from "@/ui/Shared"; import { CardEffectText, IconFont, ScrollableArea, YgoCard } from "@/ui/Shared";
......
...@@ -26,7 +26,7 @@ import { LoaderFunction } from "react-router-dom"; ...@@ -26,7 +26,7 @@ import { LoaderFunction } from "react-router-dom";
import { proxy, useSnapshot } from "valtio"; import { proxy, useSnapshot } from "valtio";
import { subscribeKey } from "valtio/utils"; import { subscribeKey } from "valtio/utils";
import { type CardMeta, initForbiddens, searchCards } from "@/api"; import { type CardMeta, searchCards } from "@/api";
import { isToken } from "@/common"; import { isToken } from "@/common";
import { FtsConditions } from "@/middleware/sqlite/fts"; import { FtsConditions } from "@/middleware/sqlite/fts";
import { deckStore, type IDeck, initStore } from "@/stores"; import { deckStore, type IDeck, initStore } from "@/stores";
...@@ -59,8 +59,13 @@ export const loader: LoaderFunction = async () => { ...@@ -59,8 +59,13 @@ export const loader: LoaderFunction = async () => {
}); });
} }
// 更新禁限卡表 // 同时,等待禁卡表的加载
await initForbiddens(); if (!initStore.forbidden) {
await new Promise<void>((rs) => {
subscribeKey(initStore, "forbidden", (done) => done && rs());
});
}
return null; return null;
}; };
......
...@@ -9,6 +9,7 @@ import { ...@@ -9,6 +9,7 @@ import {
} from "react-router-dom"; } from "react-router-dom";
import { useSnapshot } from "valtio"; import { useSnapshot } from "valtio";
import { forbidden } from "@/api";
import { useConfig } from "@/config"; import { useConfig } from "@/config";
import { accountStore } from "@/stores"; import { accountStore } from "@/stores";
...@@ -28,6 +29,7 @@ export const loader: LoaderFunction = async () => { ...@@ -28,6 +29,7 @@ export const loader: LoaderFunction = async () => {
initDeck(); initDeck();
initSqlite(); initSqlite();
initWASM(); initWASM();
forbidden.init();
return null; return null;
}; };
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment