diff options
| author | Tradam <[email protected]> | 2024-05-16 12:18:04 -0400 |
|---|---|---|
| committer | Tradam <[email protected]> | 2024-05-16 12:18:04 -0400 |
| commit | 519568969b9ff3a47e595073a40fef099586e3c9 (patch) | |
| tree | b3d1636d4a793228635daeaf88355be9b623dc6b /app/javascript/components | |
| parent | 181fdfa158cb4e35303417980541a8c6904b5dc5 (diff) | |
| download | gameHolster-519568969b9ff3a47e595073a40fef099586e3c9.tar.gz gameHolster-519568969b9ff3a47e595073a40fef099586e3c9.zip | |
rendering an uploaded HTML file
Diffstat (limited to 'app/javascript/components')
| -rw-r--r-- | app/javascript/components/Games.jsx | 71 | ||||
| -rw-r--r-- | app/javascript/components/Home.jsx | 19 | ||||
| -rw-r--r-- | app/javascript/components/Layout.jsx | 12 |
3 files changed, 77 insertions, 25 deletions
diff --git a/app/javascript/components/Games.jsx b/app/javascript/components/Games.jsx new file mode 100644 index 0000000..adf9f2d --- /dev/null +++ b/app/javascript/components/Games.jsx @@ -0,0 +1,71 @@ +import React, { useState, useEffect } from "react"; +//import { Link } from "react-router-dom"; +import GameCard from "./GameCard"; + +//export default () => ( +export default function Games () { + const [games, setGames] = useState([]); + useEffect(() => { + const url = "/api/v1/games/index"; + fetch(url).then((response) => { + if (response.ok) { + return response.json(); + } + throw new Error("Network response was not ok."); + }).then((response) => setGames(response)).catch(() => navigate("/")); + }, []); + const allGames = games.map((games, index) => ( + <div>{ blog }</div> + )); + var handleSubmit = (e) => { + e.preventDefault() //stops submit from happening + + const formData = new FormData() + formData.append('game[title]', e.target.title.value) + formData.append('game[game_file]', e.target.game_file.files[0], e.target.game_file.value) + + for (var pair of formData.entries()) { + console.log(pair[0] + ', ' + pair[1]) + }; + + fetch('http://127.0.0.1:3000/api/v1/games', { + method: 'post', + body: formData, + }); + } + return( + <> + <div> + <div className="flex flex-col gap-16 max-w-6xl shrink"> + <div className="title font-bold text-6xl font-title">Games</div> + <div className=""> + <div className="jumbotron jumbotron-fluid bg-transparent"> + <div className="container secondary-color"> + <form onSubmit={handleSubmit} action="/upload" method="post" className="flex flex-col gap-4"> + <div> + <label>Title</label> + <input type="text" name="title" /> + </div> + <div> + <label>File</label> + <input type="file" name="game_file" /> + </div> + <button type="submit" className="w-32 bg-stone-900 text-stone-50 rounded">submit</button> + </form> + </div> + </div> + </div> + { allGames } + <div className="flex flex-row flex-wrap gap-20 justify-around"> + <GameCard /> + <GameCard /> + <GameCard /> + <GameCard /> + <GameCard /> + <GameCard /> + </div> + </div> + </div> + </> + ); +}; diff --git a/app/javascript/components/Home.jsx b/app/javascript/components/Home.jsx index b67571c..5f79834 100644 --- a/app/javascript/components/Home.jsx +++ b/app/javascript/components/Home.jsx @@ -33,27 +33,8 @@ export default function Home () { Ea optio vitae culpa voluptatem consectetur. Ab quisquam sed ipsum. Perspiciatis minus odit quas qui consequuntur dicta reiciendis a. Nihil minima sed aliquam. </p> <hr className="my-4" /> - <form onSubmit={handleSubmit} action="/upload" method="post" className="flex flex-col gap-4"> - <div> - <label>Title</label> - <input type="text" name="title" /> </div> - <div> - <label>File</label> - <input type="file" name="game_file" /> </div> - <button type="submit" className="w-32 bg-stone-900 text-stone-50 rounded">submit</button> - </form> - </div> - </div> - </div> - <div className="flex flex-row flex-wrap gap-20 justify-around"> - <GameCard /> - <GameCard /> - <GameCard /> - <GameCard /> - <GameCard /> - <GameCard /> </div> </div> </div> diff --git a/app/javascript/components/Layout.jsx b/app/javascript/components/Layout.jsx index 01ec055..30d1086 100644 --- a/app/javascript/components/Layout.jsx +++ b/app/javascript/components/Layout.jsx @@ -14,9 +14,9 @@ export default function Layout ({userData}) { userData.name ? <div className="flex items-end gap-2 pb-2"> <div className="text-xs"> Logged in as: </div> <div>{userData.name}</div> </div> : <a href="https://github.com/login/oauth/authorize?client_id=74468ad0847e527262d9" className="pb-2"> Login with Github </a> } <div className="text-3xl py-10 text-center font-title">Adam Malczewski</div> <div className="flex flex-col items-center gap-1 w-full"> - <Button link={ <Link to="/" className="text-stone-50 bg-transparent" role="button">About Me</Link> }/> - <Button link={ <Link to="/blogs" className="text-stone-50 bg-transparent" role="button">Blog</Link> }/> - <Button link={ <Link to="/games" className="text-stone-50 bg-transparent" role="button">Games</Link> }/> + <Button link={ <Link to="/" className="absolute flex top-0 left-0 w-36 h-16 text-stone-50 bg-transparent justify-center items-center" role="button"><div className="h-min">About Me</div></Link> }/> + <Button link={ <Link to="/blogs" className="absolute flex top-0 left-0 w-36 h-16 text-stone-50 bg-transparent justify-center items-center" role="button"><div className="h-min">Blog</div></Link> }/> + <Button link={ <Link to="/games" className="absolute flex top-0 left-0 w-36 h-16 text-stone-50 bg-transparent justify-center items-center" role="button"><div className="h-min">Games</div></Link> }/> <Button link={ <div className="text-stone-50 bg-transparent w-36 h-16 flex justify-center items-center"> <a id="contact" href="mailto:[email protected]" className="w-36 h-16 relative text-center whitespace-nowrap flex justify-center items-center"> <div className="contact w-36 h-16 flex items-center justify-center"> @@ -28,9 +28,9 @@ export default function Layout ({userData}) </a> </div> }/> <div className="socials flex flex-row place-content-center gap-1"> - <Button link={<a id="contact" href="https://github.com/realtradam" className=" w-10 h-10 text-center whitespace-nowrap flex justify-center items-center"><i className="fa-brands fa-github"></i></a>} width={10} height={16} spinner={3}/> - <Button link={<a id="contact" href="https://www.linkedin.com/in/adammalczewski/" className=" w-10 h-10 text-center whitespace-nowrap flex justify-center items-center"><i className="fa-brands fa-linkedin"></i></a>} width={10} height={16} spinner={3}/> - <Button link={<a id="contact" href="https://tradam.itch.io" className=" w-10 h-10 text-center whitespace-nowrap flex justify-center items-center"><i className="fa-brands fa-itch-io"></i></a>} width={10} height={16} spinner={3}/> + <Button link={<a id="contact" href="https://github.com/realtradam" className="absolute flex top-0 left-0 w-10 h-16 text-stone-50 bg-transparent justify-center items-center"><i className="fa-brands fa-github"></i></a>} width={10} height={16} spinner={3}/> + <Button link={<a id="contact" href="https://www.linkedin.com/in/adammalczewski/" className="absolute flex top-0 left-0 w-10 h-16 text-stone-50 bg-transparent justify-center items-center"><i className="fa-brands fa-linkedin"></i></a>} width={10} height={16} spinner={3}/> + <Button link={<a id="contact" href="https://tradam.itch.io" className="absolute flex top-0 left-0 w-10 h-16 text-stone-50 bg-transparent justify-center items-center"><i className="fa-brands fa-itch-io"></i></a>} width={10} height={16} spinner={3}/> </div> </div> </div> |
