FormLoom + Windsurf
MCP-nativeWindsurf (Codeium) supports MCP via its config. Add FormLoom and let Cascade wire the form.
1. Add the MCP server
Add this to ~/.codeium/windsurf/mcp_config.json:
~/.codeium/windsurf/mcp_config.json
{
"mcpServers": {
"formloom": {
"command": "npx",
"args": ["-y", "@formloom/mcp"]
}
}
}2. Ask for a form
Type a prompt like:
“Add a newsletter signup form to my SvelteKit site with FormLoom.”
What you get back
Windsurf calls get_snippet + provision_endpoint and writes framework-correct code with a live access key — it works on first run:
app/contact/page.tsx
// app/contact/page.tsx — Next.js 15 App Router, Server Action
export default function ContactPage() {
async function submit(formData: FormData) {
"use server";
const res = await fetch("https://formloom.vercel.app/api/submit/fl_provisioned_key", {
method: "POST",
headers: { "Content-Type": "application/json", Accept: "application/json" },
body: JSON.stringify(Object.fromEntries(formData)),
});
// FormLoom scores spam, stores the row, and emails you — no backend to wire.
return res.json();
}
return (
<form action={submit}>
<label>
Name
<input type="text" name="name" required />
</label>
<label>
Email
<input type="email" name="email" required />
</label>
<label>
Message
<textarea name="message" required placeholder="How can we help?"></textarea>
</label>
<!-- honeypot: bots fill this, humans don't see it -->
<input type="checkbox" name="botcheck" style="display:none" tabindex="-1" autocomplete="off" />
<button type="submit">Send</button>
</form>
);
}Steps
- 1Open Windsurf's MCP settings and add the FormLoom server (or edit `mcp_config.json`).
- 2Refresh the MCP servers list.
- 3Ask Cascade to add a form — it provisions a key and inserts the snippet.
FAQ
Yes — add the FormLoom server in Windsurf's MCP config and Cascade can call its tools.