Skip to content

Latest commit

 

History

History
89 lines (69 loc) · 2.6 KB

README.md

File metadata and controls

89 lines (69 loc) · 2.6 KB

Contact Form Service

Provides a contact form backend with support for sending message to Slack and more to be added.

Badge OSC

Install

npm install

Transports

Slack

TRANSPORT=slack SLACK_BOT_TOKEN=<secret> SLACK_CHANNEL_ID=<channelId> npm start

Docker

docker build -t contact-form:dev .
docker run --rm -d \
  -e TRANSPORT=slack \
  -e SLACK_BOT_TOKEN=<secret> \
  -e SLACK_CHANNEL_ID=<secret> \
  -p 8000:8000 contact-form:dev

Example form

<form action="http://localhost:8000/contact" method="POST">
  <label for="fname">First Name</label>
  <input type="text" id="fname" name="firstname" placeholder="Your name.." />

  <label for="lname">Last Name</label>
  <input
    type="text"
    id="lname"
    name="lastname"
    placeholder="Your last name.."
  />

  <label for="email">Email</label>
  <input type="email" id="email" name="email" placeholder="Your email.." />

  <label for="message">Message</label>
  <input type="text" id="message" name="message" />

  <input type="submit" value="Submit" />
</form>

NextUI / React

'use client';
import { Input, Textarea } from '@nextui-org/react';

export default function Page() {
  const handleSubmit = (formData: any) => {
    fetch(new URL('http://localhost:8000/contact'), {
      method: 'POST',
      headers: {
        'Content-Type': 'application/x-www-form-urlencoded'
      },
      body: new URLSearchParams(formData).toString()
    });
  };

  return (
    <form action={handleSubmit}>
      <Input name="firstname" placeholder="First name" />
      <Input name="lastname" placeholder="Last name" />
      <Input name="email" placeholder="Your email" />
      <Textarea
        name="message"
        minRows={8}
        placeholder="Tell us a bit about what you want our help with"
      />
      <Input type="submit" value="Send" />
    </form>
  )
}