diff options
| author | Pinapelz <yukais@pinapelz.com> | 2025-04-14 03:13:02 -0700 |
|---|---|---|
| committer | Pinapelz <yukais@pinapelz.com> | 2025-04-14 03:13:02 -0700 |
| commit | 073fc8fe92e60fd4662580e8216600379a0edfae (patch) | |
| tree | 4a78d028fd78af8d30584df24bbfc164e1de9896 /site/src/pages | |
| parent | 7b93b8587d93d8f86ac8d8e25c589bba02c20476 (diff) | |
chore: refactor id to game title conversion to shared module
Diffstat (limited to 'site/src/pages')
| -rw-r--r-- | site/src/pages/Homepage.tsx | 35 |
1 files changed, 4 insertions, 31 deletions
diff --git a/site/src/pages/Homepage.tsx b/site/src/pages/Homepage.tsx index 6f53096..0e17a43 100644 --- a/site/src/pages/Homepage.tsx +++ b/site/src/pages/Homepage.tsx @@ -1,6 +1,7 @@ import { useEffect, useState } from "react"; import { NewsData, NewsFeed } from "../components/NewsFeed"; import { useParams } from "react-router-dom"; +import { getGameTitle } from "../utils.ts"; import TitleBar from "../components/TitleBar"; interface ArcadeNewsAPIData { @@ -16,23 +17,7 @@ export default function Home() { useEffect(() => { const fetchNews = async () => { setLoading(true); - let jsonFile = "news.json"; - if (gameId) { - switch(gameId) { - case "sdvx": - jsonFile = "sdvx_news.json"; - break; - case "iidx": - jsonFile = "iidx_news.json"; - break; - case "chunithm_jp": - jsonFile = "chunithm_jp_news.json"; - break; - default: - jsonFile = "news.json"; - } - } - + const jsonFile = gameId ? `${gameId}_news.json` : "news.json"; try { const response = await fetch("https://arcade-news.pinapelz.com/"+`${jsonFile}`); if (!response.ok) { @@ -60,18 +45,6 @@ export default function Home() { ); } - // Game-specific title mapping - const getGameTitle = () => { - if (!gameId) return null; - - switch(gameId) { - case "sdvx": return "SOUND VOLTEX"; - case "iidx": return "beatmania IIDX"; - case "chunithm_jp": return "CHUNITHM (JAPAN)"; - default: return gameId.toUpperCase(); - } - }; - return ( <> <TitleBar /> @@ -79,7 +52,7 @@ export default function Home() { <div className="max-w-[600px] mx-auto px-4"> {gameId && ( <h1 className="text-2xl font-bold text-center text-white mb-6"> - {getGameTitle()} News + {getGameTitle(gameId)} News </h1> )} <NewsFeed newsItems={newsFeedData.news_posts} /> @@ -87,4 +60,4 @@ export default function Home() { </div> </> ); -}
\ No newline at end of file +} |
