From 99b4b939bdd2140aecf19ddb09a59b44e9cd117d Mon Sep 17 00:00:00 2001 From: AAGaming Date: Fri, 17 Jun 2022 18:43:53 -0400 Subject: Implement React-based plugin store (#81) Co-authored-by: TrainDoctor <11465594+TrainDoctor@users.noreply.github.com> Co-authored-by: WerWolv --- frontend/src/components/store/Store.tsx | 55 +++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 frontend/src/components/store/Store.tsx (limited to 'frontend/src/components/store/Store.tsx') diff --git a/frontend/src/components/store/Store.tsx b/frontend/src/components/store/Store.tsx new file mode 100644 index 00000000..ebb2bb8e --- /dev/null +++ b/frontend/src/components/store/Store.tsx @@ -0,0 +1,55 @@ +import { SteamSpinner } from 'decky-frontend-lib'; +import { FC, useEffect, useState } from 'react'; + +import PluginCard from './PluginCard'; + +export interface StorePlugin { + artifact: string; + versions: { + [version: string]: string; + }; + author: string; + description: string; + tags: string[]; +} + +const StorePage: FC<{}> = () => { + const [data, setData] = useState(null); + + useEffect(() => { + (async () => { + const res = await fetch('https://beta.deckbrew.xyz/get_plugins', { method: 'GET' }).then((r) => r.json()); + console.log(res); + setData(res); + })(); + }, []); + + return ( +
+
+ {data === null ? ( +
+ +
+ ) : ( + data.map((plugin: StorePlugin) => ) + )} +
+
+ ); +}; + +export default StorePage; -- cgit v1.2.3