picobook/src/client/GamePage.tsx

101 lines
2.3 KiB
TypeScript
Raw Normal View History

2024-03-31 19:52:06 -07:00
import { useNavigate, useParams } from "react-router-dom"
2024-03-31 19:40:06 -07:00
import { Pico8Console } from "./pico8-client/Pico8Console";
import { useEffect, useState } from "react";
import { DbRelease } from "../server/dbal/dbal";
import { css } from "@emotion/css";
type Info = {
release: DbRelease | null;
versions: string[];
}
export const GamePage = () => {
const {author, slug, version} = useParams();
2024-03-31 19:52:06 -07:00
const navigate = useNavigate();
2024-03-31 19:40:06 -07:00
const [info, setInfo] = useState<Info | null>(null);
2024-03-31 21:25:54 -07:00
2024-03-31 19:40:06 -07:00
useEffect(() => {
const fetchInfo = async () => {
let url = `/api/release?author=${author}&slug=${slug}`;
if (version) {
2024-03-31 20:04:28 -07:00
url += `&version=${version.slice(1)}`;
2024-03-31 19:40:06 -07:00
}
const information = await fetch(url);
const json = await information.json();
setInfo(json);
}
fetchInfo();
}, [setInfo, author, slug, version]);
if (!info) {
return (
<div className={`
min-height: 100vh;
`}>
LOADING...
</div>
)
}
if (!info.release) {
return (
<div className={`
min-height: 100vh;
`}>
NOT FOUND
</div>
)
}
return (
<div className={css`
min-height: 100vh;
2024-04-01 00:22:52 -07:00
background-color: hsl(230, 10%, 10%);
color: white;
2024-03-31 19:40:06 -07:00
`}>
2024-03-31 19:48:23 -07:00
<div className={css`
margin: auto;
2024-03-31 19:52:06 -07:00
width: max-content;
2024-04-01 00:22:52 -07:00
max-inline-size: 66ch;
padding: 1.5em;
display: flex;
flex-direction: column;
gap: 1em;
2024-03-31 19:48:23 -07:00
`}>
2024-04-01 00:22:52 -07:00
<div>
<h1>{info.release.manifest.title ?? slug!.split("-").map(word => word[0].toUpperCase()+word.slice(1)).join(" ")}</h1>
<h2>by {info.release.author}</h2>
</div>
2024-03-31 19:48:23 -07:00
<div className={css`
2024-03-31 19:52:06 -07:00
width: 512px;
max-width: 100%;
2024-04-01 00:22:52 -07:00
margin: auto;
2024-03-31 19:48:23 -07:00
`}>
2024-04-01 00:22:52 -07:00
<div className={css`
border: 2px solid transparent;
&:focus-within {
border: 2px solid limegreen;
2024-03-31 19:48:23 -07:00
}
2024-04-01 00:22:52 -07:00
`}>
<Pico8Console carts={info.release.carts} />
</div>
<div className={css`
display: flex;
justify-content: end;
`}>
Version: <select defaultValue={info.release.version} onChange={(ev) => navigate(`/u/${author}/${slug}/v${ev.target.value}`)}>
{
[...info.versions].reverse().map(v => (
<option key={v} value={v}>{v}</option>
))
}
</select>
</div>
2024-03-31 21:25:54 -07:00
</div>
2024-04-01 00:22:52 -07:00
{/* <div>
<p>This is a paragraph about this game. It is a cool game. And a cool website to play it on. It automagically connects from GitHub.</p>
</div> */}
2024-03-31 19:48:23 -07:00
</div>
2024-03-31 19:40:06 -07:00
</div>
)
}