summary refs log tree commit diff
path: root/app/contact/page.tsx
diff options
context:
space:
mode:
authorAshelyn Rose <git@tempest.dev>2023-05-08 17:28:42 -0600
committerAshelyn Rose <git@tempest.dev>2023-05-08 17:28:42 -0600
commit6cddfdf8fe9bccc291ee8625d42cb42fd4ce2134 (patch)
tree2424244ae79ae3c018bd9049e9f112741c38560e /app/contact/page.tsx
parent7e3dc4ace4c6b21bc68264dc76c8c442aec8031a (diff)
implemented contact form
Diffstat (limited to 'app/contact/page.tsx')
-rw-r--r--app/contact/page.tsx91
1 files changed, 91 insertions, 0 deletions
diff --git a/app/contact/page.tsx b/app/contact/page.tsx
new file mode 100644
index 0000000..1ed2eb8
--- /dev/null
+++ b/app/contact/page.tsx
@@ -0,0 +1,91 @@
+'use client'
+import { useState, useRef, FormEvent } from 'react'
+import InfoBar from "~/components/InfoBar/"
+
+import styles from '~/styles/form.module.css'
+
+const submitUrl = 'https://kae.tempest.dev/api/contact/me'
+
+export default function Contact() {
+  const [submitting, setSubmitting] = useState(false)
+  const [status, setStatus] = useState('')
+
+  const nameRef = useRef()
+  const emailRef = useRef()
+  const messageRef = useRef()
+
+  const submit = async (ev: FormEvent<HTMLFormElement>) => {
+    ev.preventDefault()
+
+    setStatus('')
+
+    const name: string = nameRef.current?.value ?? ''
+    const email: string = emailRef.current?.value ?? ''
+    const message: string = messageRef.current?.value ?? ''
+
+    if (!name) setStatus(s => s + ' Name required.')
+    if (!email) setStatus(s => s + ' Email required.')
+    if (!message) setStatus(s => s + ' Message required.')
+
+    if (!name || !email || !message)
+      return
+
+    setSubmitting(true)
+
+    try {
+
+      await fetch(submitUrl, {
+        method: 'post',
+        headers: {
+          'content-type': 'application/json'
+        },
+        body: JSON.stringify({
+          name, email, message
+        })
+      })
+
+      setStatus('Message sent successfully')
+    } catch {
+      setStatus('Error submitting message, please try again')
+    } finally {
+      setSubmitting(false)
+    }
+  }
+
+  return (
+    <>
+      <h1 className="pageTitle">
+        Contact
+      </h1>
+      <main className="mainColumn">
+        <InfoBar>
+          Be nice.  Please don't make us regret putting this here
+        </InfoBar>
+        <form className={styles.form} onSubmit={submit}>
+          <label htmlFor="name">Name:</label>
+          <input disabled={submitting} name="name" ref={nameRef} />
+
+          <label htmlFor="email">Email:</label>
+          <input disabled={submitting} name="email" ref={emailRef} />
+
+          <label htmlFor="message">Message:</label>
+          <textarea disabled={submitting} name="message" ref={messageRef} />
+
+          <button disabled={submitting} type="submit">Submit</button>
+          {status && <span className={styles.status}>{status}</span>}
+          {/*<FormController
+          url="https://kae.tempest.dev/api/contact/tempest"
+          afterSubmit={() => setStatus('Message sent successfully!')}
+          onError={() => setStatus('Error submitting message, please try again.')}
+        >
+          <Input name="name" validate={v => !!v} />
+          <Input name="email" validate={v => !!v && v.includes('@')} />
+          <TextArea name="message" validate={v => !!v && v.length < 1000} />
+          <Button onClick={() => setStatus(null)} type="submit">submit</Button>
+          {status && <p>{status}</p>}
+        </FormController>*/}
+        </form>
+      </main>
+    </>
+  )
+}