diff options
| author | 2020-10-05 13:05:35 +0100 | |
|---|---|---|
| committer | 2020-10-05 13:05:35 +0100 | |
| commit | cadc534fccbeaeed8dd4b00480b16555ac0ab207 (patch) | |
| tree | cde772207e058941941e2ff65df34f23f397f450 | |
| parent | Update headerbar to be more responsive and take custom text (diff) | |
Major rewrite of forms page to render specific form
| -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>  } | 
