04.5.10 Framer
The Latenode platform allows interaction with websites created using the Framer service. For interaction, only the Trigger on Webhook node is needed.
Let's create a scenario that records the email address entered in a website form into a Google Sheet. First, use the Framer service to create the registration form with a field for entering the email address and a confirmation button.
Creating a Framer Form
- In the Framer workspace, choose the method to add a Code element. In the Create Code File window, enter any name and select the New component option.
data:image/s3,"s3://crabby-images/32c25/32c255b522949513b112e79176f63e3087982688" alt=""
- Click the Create button.
data:image/s3,"s3://crabby-images/82783/82783ef36778647a203f198067a74973f72c71aa" alt=""
- On the opened page, add the code below and save the changes by pressing Ctrl + S. The form with an email input field and a Signup button will appear on the right side of the interface.
import React, { useState } from "react"
import Example from "https://framer.com/m/framer/Example.js@^1.0.0"
export default function AuthorizationForm(props) {
// Update this with your Trigger on Webhook URL
const formUrl =
"You_URL"
// MAYBE: If you are adding more fields to your form in addition to email update here
const [email, setEmail] = useState("")
const [formStatus, setFormStatus] = useState("unsubmitted")
const onSubmit = async (event) => {
event.preventDefault()
try {
const response = await fetch(formUrl, {
method: "POST",
body: JSON.stringify({ email }), // Construct your form data: comma seperated list
headers: {
"Content-type": "application/json",
},
})
if (!response.ok) {
throw new Error("Network response was not ok")
}
setFormStatus("submitted") // Update state to indicate successful submission
} catch (error) {
console.error("Error during form submission: ", error)
setFormStatus("error") // Update state to indicate an error
}
}
// Function to update email state
// MAYBE: If you are adding more fields to your form in addition to email update here
const handleEmailChange = (event) => {
setEmail(event.target.value)
}
if (formStatus === "submitted") {
return (
<div style={responseText}>
Thank you! You have successfully registered.
</div>
)
}
if (formStatus === "error") {
return <div>Something went wrong. Please refresh and try again!</div>
}
return (
<>
{/* Label for the form */}
<div style={labelStyle}>Please provide your email address.</div>
{/* Form */}
<form onSubmit={onSubmit} style={containerStyle}>
<input
type="email"
value={email}
onChange={handleEmailChange}
placeholder="Your email"
required
style={inputStyle}
/>
<input type="submit" value="Signup" style={submitButtonStyle} />
</form>
</>
)
}
/// Updated Form Styles to match the provided image
// Assuming a dark theme similar to the one in the image
const containerStyle = {
display: "flex", // Changed from flexDirection to display for correct CSS
justifyContent: "space-between", // Align items side-by-side
alignItems: "center",
//background: "#18181B", // Dark background
padding: "0.5rem", // Reduced padding
borderRadius: "4px", // Smaller border radius for a subtler curve
// boxShadow: "0 4px 8px rgba(0, 0, 0, 0.1)", // A subtle shadow
maxWidth: "500px", // Max width for the form
margin: "auto", // Center the form in the page
}
const inputStyle = {
flex: "1", // Take up the remaining space
fontSize: "16px", // Smaller font size
padding: "0.75rem", // Comfortable padding
margin: "0", // No margin for the input
backgroundColor: "#18181B", // Background to match the container
border: "1px solid #333", // Subtle border
borderRadius: "12px", // Matching the container's border radius
color: "#FFF", // Text color
marginRight: "0.5rem", // Space between input and button
}
const submitButtonStyle = {
fontSize: "16px", // Matching font size with the input
padding: "0.75rem 1.5rem", // Padding similar to the input
backgroundColor: "#2C91ED", // Bright accent color for the button
color: "#FFF", // Text color
border: "none", // No border
borderRadius: "12px", // Matching the container's border radius
cursor: "pointer", // Cursor for button
fontWeight: "bold", // Bold font weight for the button text
}
const responseText = {
textAlign: "center", // Center the response text
color: "#5FCEAE", // Color for the response message
fontSize: "16px", // Consistent font size
marginTop: "1rem", // Space above the response text
}
const labelStyle = {
textAlign: "center", // Center align text
color: "#FFF", // Text color
fontSize: "16px", // Font size
marginBottom: "1rem", // Space below the label
}
data:image/s3,"s3://crabby-images/3c2b1/3c2b109ba5704df2fd272f4294c8f50011e86849" alt=""
Setting Up the Latenode Scenario and Sending Email
- In the scenario created on the platform, add a Trigger on Webhook node. After adding, copy the URL address. You can run the node once to view the output data.
data:image/s3,"s3://crabby-images/8c967/8c967decc04f582a368d4da9aba8704ec4b836cf" alt=""
data:image/s3,"s3://crabby-images/c33a0/c33a04cd857e0cd5d5f5919b1c4262c85776552f" alt=""
- Replace
You_URL
in the Framer form code with the URL address of the Trigger on Webhook node.
Remember, the Production-branch of the scenario is initiated by a request sent to the Production-version URL of the Trigger on Webhook node. The Development-branch of the scenario is initiated by a request sent to the Development-version URL of the Trigger on Webhook node.
- After adding the URL address, fill in the field with a test email address and click the Signup button.
data:image/s3,"s3://crabby-images/c5c03/c5c036dabb413ffff13190ce7792b3e3a51301d7" alt=""
- Once you click the Signup button, the Trigger on Webhook node will execute, and the output data will include the provided email address.
data:image/s3,"s3://crabby-images/6e18a/6e18a91d96455cc192db7f26055663ced1445b9d" alt=""
- To record the received email address in a Google Sheet, add an Add Single Row node and configure it:
- Create or select an existing authorization.
- Choose the desired Google Sheet and sheet tab.
- Select the parameter from the previous node for the Values field in the auxiliary window.
data:image/s3,"s3://crabby-images/805bb/805bbff28c47b0eb1028f890f4dd4f41b29157ec" alt=""
The result of the scenario execution is that the email address entered in the Framer form is recorded in a cell of the Google Sheet.
data:image/s3,"s3://crabby-images/544f4/544f408f8855f472e353da579b4359df6035dcef" alt=""
data:image/s3,"s3://crabby-images/a4dd4/a4dd44637ce4d1676f313de1b7c9ed458f37486b" alt=""