diff options
| author | 2021-12-24 16:24:04 +0000 | |
|---|---|---|
| committer | 2021-12-24 16:24:04 +0000 | |
| commit | 9a767b6492ac09f464893005ab43d3dff9c40af5 (patch) | |
| tree | b399fc68db0d37c97755019a02dedcc047a259f5 /src | |
| parent | Support Line Breaks In Submitted Text (diff) | |
Block submission when missing OAuth2 scopes
Diffstat (limited to '')
| -rw-r--r-- | src/pages/FormPage.tsx | 39 | 
1 files changed, 24 insertions, 15 deletions
| diff --git a/src/pages/FormPage.tsx b/src/pages/FormPage.tsx index d7dfd4b..082be23 100644 --- a/src/pages/FormPage.tsx +++ b/src/pages/FormPage.tsx @@ -150,6 +150,8 @@ function FormPage(): JSX.Element {      const [sending, setSending] = useState<boolean>();      const [sent, setSent] = useState<boolean>(); +    const bottomDivRef = createRef<HTMLDivElement>(); +      useEffect(() => {          getForm(id).then(form => {              setForm(form); @@ -204,6 +206,20 @@ function FormPage(): JSX.Element {          return <RenderedQuestion ref={questionRef} focus_ref={createRef<any>()} scroll_ref={createRef<HTMLDivElement>()} question={question} public_state={new Map()} key={index + Date.now()}/>;      }); +    const open: boolean = form.features.includes(FormFeatures.Open); +    const require_auth: boolean = form.features.includes(FormFeatures.RequiresLogin); + +    const scopes: OAuthScopes[] = []; +    if (require_auth) { +        scopes.push(OAuthScopes.Identify); +        if (form.features.includes(FormFeatures.CollectEmail)) { scopes.push(OAuthScopes.Email); } +    } + +    let closed_header = null; +    if (!open) { +        closed_header = <div css={closedHeaderStyles}>This form is now closed. You will not be able to submit your response.</div>; +    } +      async function handleSubmit(event: SyntheticEvent) {          event.preventDefault();          // Client-side required validation @@ -240,6 +256,13 @@ function FormPage(): JSX.Element {              return;          } +        // Scroll to bottom when OAuth2 required +        if (scopes.length && !checkScopes(scopes)) { +            bottomDivRef.current.scrollIntoView({ behavior: "smooth", block: "end"}); + +            return; +        } +          setSending(true);          const answers: { [key: string]: unknown } = {}; @@ -279,20 +302,6 @@ function FormPage(): JSX.Element {          setSent(true);      } -    const open: boolean = form.features.includes(FormFeatures.Open); -    const require_auth: boolean = form.features.includes(FormFeatures.RequiresLogin); - -    const scopes = []; -    if (require_auth) { -        scopes.push(OAuthScopes.Identify); -        if (form.features.includes(FormFeatures.CollectEmail)) { scopes.push(OAuthScopes.Email); } -    } - -    let closed_header = null; -    if (!open) { -        closed_header = <div css={closedHeaderStyles}>This form is now closed. You will not be able to submit your response.</div>; -    } -      return (          <div>              <HeaderBar title={form.name} description={form.description}/> @@ -305,7 +314,7 @@ function FormPage(): JSX.Element {                  <Navigation form_state={open} scopes={scopes}/>              </div> -            <div css={css`margin-bottom: 10rem`}/> +            <div css={css`margin-bottom: 10rem`} ref={bottomDivRef}/>              <ScrollToTop/>          </div>      ); | 
