Skip to content

Saving Data Records with Forms

Enpage makes it really easy to save Data Records using forms using a few html attributes. It is the developer/designer responsibility to write the form and define the Data Record schema, while Enpage will take care of the form validation and submission.

Example

html
<!-- Fill your Data record identifier in "ep-record" attribute -->
<form ep-record="contactFormSubmissions">
  <p>
    <label for="name">Name</label>
    <!-- No need for a "required" attribute,
         it will be automatically added when needed -->
    <input type="text" name="name">
  </p>
  <p>
    <!--  input "name" attribute should reflect the data record schema -->
    <label for="email">Email</label>
    <input type="email" name="email">
  </p>
  <p>
    <label for="message">Message</label>
    <textarea name="message"></textarea>
  </p>
  <p>
    <!-- make sure to use type=submit-->
    <button type="submit">Submit</button>
  </p>

  <!-- A global form error message -->
  <template ep-form-error>
    <p>There was an error submitting the form. Please try again.</p>
  </template>

  <!-- A global confirmation message when data is saved -->
  <template ep-form-success>
    <p>Thank you for your submission!</p>
  </template>

</form>
javascript
import { defineDataRecords } from "@upstart.gg/sdk/shared/datarecords";

// Define an external data record that will be used
// in the template to let users submit a contact form

export const datarecords = defineDataRecords({
  contactFormSubmissions: {
    // Label of the data source that will be displayed in the Enpage Dashboard
    name: "Contact form submissions",
    // use the built-in "google-sheets" provider
    provider: "google-sheets",
    schema: z.object({
      name: z.string(),
      email: z.string().email(),
      message: z.string().min(20),
    })
  }
});

Enpage SDK is released under AGPL-3.0 license