diff options
| author | 2020-10-05 13:13:51 +0100 | |
|---|---|---|
| committer | 2020-10-05 13:13:51 +0100 | |
| commit | 91ef1e8d905e1ac68f6a3968f379d0675dfe6dcf (patch) | |
| tree | 617e685d475acd15a7a6423d3a9b7826ee674f00 /src/pages | |
| parent | Merge pull request #14 from python-discord/api/add-dummy-forms (diff) | |
| parent | Update header test to include custom titles (diff) | |
Merge pull request #15 from python-discord/forms/add-form-page
Add specific form page
Diffstat (limited to 'src/pages')
| -rw-r--r-- | src/pages/FormPage.tsx | 43 | 
1 files changed, 40 insertions, 3 deletions
| diff --git a/src/pages/FormPage.tsx b/src/pages/FormPage.tsx index aa4cec3..45c093a 100644 --- a/src/pages/FormPage.tsx +++ b/src/pages/FormPage.tsx @@ -2,10 +2,47 @@  import { jsx } from "@emotion/core";  import { Link } from "react-router-dom"; +import { DotLoader } from "react-spinners"; + +import { useParams } from "react-router"; +import HeaderBar from "../components/HeaderBar"; +import { useEffect, useState } from "react"; +import { Form, getForm } from "../api/forms"; + +interface PathParams { +    id: string +} + +function Loading() { +    return <div> +        <HeaderBar title={"Loading..."}/> +        <div css={{display: "flex", justifyContent: "center"}}> +            <DotLoader color="white"/> +        </div> +    </div> +} +  function FormPage() { -    return <div css={{marginLeft: "20px"}}> -        <h1>Form page</h1> -        <Link to="/" css={{color: "white"}}>Go home</Link> +    const { id } = useParams<PathParams>(); + +    const [form, setForm] = useState<Form>(); + +    useEffect(() => { +        getForm(id).then(form => { +            setForm(form); +        }) +    }) + +    if (!form) { +        return <Loading/> +    } + +    return <div> +        <HeaderBar title={form.title}/> +        <div css={{marginLeft: "20px"}}> +            <h1>{form.description}</h1> +            <Link to="/" css={{color: "white"}}>Return home</Link> +        </div>      </div>  } | 
