mirror of
https://github.com/sergi0g/cup.git
synced 2025-11-16 00:53:47 -05:00
62 lines
2.3 KiB
TypeScript
62 lines
2.3 KiB
TypeScript
import { useState } from "react";
|
|
import Logo from "./components/Logo";
|
|
import Statistic from "./components/Statistic";
|
|
import Image from "./components/Image";
|
|
import { LastChecked } from "./components/LastChecked";
|
|
import Loading from "./components/Loading";
|
|
import { Data } from "./types";
|
|
import { theme } from "./theme";
|
|
import RefreshButton from "./components/RefreshButton";
|
|
import Search from "./components/Search";
|
|
|
|
function App() {
|
|
const [data, setData] = useState<Data | null>(null);
|
|
const [searchQuery, setSearchQuery] = useState("");
|
|
if (!data) return <Loading onLoad={setData} />;
|
|
return (
|
|
<div
|
|
className={`flex justify-center min-h-screen bg-${theme}-50 dark:bg-${theme}-950`}
|
|
>
|
|
<div className="lg:px-8 sm:px-6 px-4 max-w-[80rem] mx-auto h-full w-full">
|
|
<div className="flex flex-col max-w-[48rem] mx-auto h-full my-8">
|
|
<div className="flex items-center gap-1">
|
|
<h1 className="text-5xl lg:text-6xl font-bold dark:text-white">
|
|
Cup
|
|
</h1>
|
|
<Logo />
|
|
</div>
|
|
<div
|
|
className={`shadow-sm bg-white dark:bg-${theme}-900 rounded-md my-8`}
|
|
>
|
|
<dl className="lg:grid-cols-4 md:grid-cols-2 gap-1 grid-cols-1 grid overflow-hidden *:relative">
|
|
{Object.entries(data.metrics).map(([name, value]) => (
|
|
<Statistic name={name} value={value} key={name} />
|
|
))}
|
|
</dl>
|
|
</div>
|
|
<div
|
|
className={`shadow-sm bg-white dark:bg-${theme}-900 rounded-md my-8`}
|
|
>
|
|
<div
|
|
className={`flex justify-between items-center px-6 py-4 text-${theme}-500`}
|
|
>
|
|
<LastChecked datetime={data.last_updated} />
|
|
<RefreshButton />
|
|
</div>
|
|
<Search onChange={setSearchQuery}/>
|
|
<ul
|
|
className={`*:py-4 *:px-6 *:flex *:items-center *:gap-3 dark:divide-${theme}-800 divide-y dark:text-white`}
|
|
>
|
|
{Object.entries(data.images).filter(([name]) => name.includes(searchQuery)).map(([name, status]) => (
|
|
<Image name={name} status={status} key={name} />
|
|
))}
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export default App;
|