nise/nise-replay-viewer/src/interface/App.tsx

36 lines
1004 B
TypeScript
Raw Normal View History

2024-03-03 15:22:03 +00:00
import {AboutDialog} from "./composites/about-dialog";
import {AnalysisSheet} from "./composites/analysis.-sheet";
import {Navbar} from "./composites/Menu";
import {SongSlider} from "./composites/song-slider";
import {Helper} from "./composites/helper";
import {useEffect, useState} from "react";
import {OsuRenderer} from "@/osu/OsuRenderer";
export function App() {
const [replayId, setReplayId] = useState<string>("");
useEffect(() => {
let pathReplayId = location.pathname.slice(1, location.pathname.length);
const loadReplay = async () => {
2024-03-03 15:22:40 +00:00
await OsuRenderer.loadReplayFromUrl(`https://nise.moe/api/score/${pathReplayId}/replay`);
2024-03-03 15:22:03 +00:00
};
if(replayId !== pathReplayId) {
setReplayId(pathReplayId);
loadReplay();
}
}, [location.pathname]);
return (
<>
<Navbar/>
<AboutDialog/>
<AnalysisSheet/>
<SongSlider/>
<Helper/>
</>
);
}