mirror of
https://github.com/formbricks/formbricks.git
synced 2026-01-06 13:49:54 -06:00
Co-authored-by: Dhruwang <dhruwangjariwala18@gmail.com> Co-authored-by: Matthias Nannt <mail@matthiasnannt.com> Co-authored-by: ShubhamPalriwala <spalriwalau@gmail.com>
278 lines
11 KiB
TypeScript
278 lines
11 KiB
TypeScript
import Image from "next/image";
|
|
import { useRouter } from "next/router";
|
|
import { useEffect, useState } from "react";
|
|
|
|
import formbricks from "@formbricks/js";
|
|
|
|
import fbsetup from "../../public/fb-setup.png";
|
|
|
|
declare const window: any;
|
|
|
|
export default function AppPage({}) {
|
|
const [darkMode, setDarkMode] = useState(false);
|
|
const router = useRouter();
|
|
|
|
useEffect(() => {
|
|
if (darkMode) {
|
|
document.body.classList.add("dark");
|
|
} else {
|
|
document.body.classList.remove("dark");
|
|
}
|
|
}, [darkMode]);
|
|
|
|
useEffect(() => {
|
|
if (process.env.NEXT_PUBLIC_FORMBRICKS_ENVIRONMENT_ID && process.env.NEXT_PUBLIC_FORMBRICKS_API_HOST) {
|
|
const isUserId = window.location.href.includes("userId=true");
|
|
const userId = isUserId ? "THIS-IS-A-VERY-LONG-USER-ID-FOR-TESTING" : undefined;
|
|
const attributes = isUserId ? { "Init Attribute 1": "eight", "Init Attribute 2": "two" } : undefined;
|
|
formbricks.init({
|
|
environmentId: process.env.NEXT_PUBLIC_FORMBRICKS_ENVIRONMENT_ID,
|
|
apiHost: process.env.NEXT_PUBLIC_FORMBRICKS_API_HOST,
|
|
userId,
|
|
debug: true,
|
|
attributes,
|
|
});
|
|
window.formbricks = formbricks;
|
|
}
|
|
|
|
// Connect next.js router to Formbricks
|
|
if (process.env.NEXT_PUBLIC_FORMBRICKS_ENVIRONMENT_ID && process.env.NEXT_PUBLIC_FORMBRICKS_API_HOST) {
|
|
const handleRouteChange = formbricks?.registerRouteChange;
|
|
router.events.on("routeChangeComplete", handleRouteChange);
|
|
|
|
return () => {
|
|
router.events.off("routeChangeComplete", handleRouteChange);
|
|
};
|
|
}
|
|
});
|
|
|
|
return (
|
|
<div className="h-screen bg-white px-12 py-6 dark:bg-slate-800">
|
|
<div className="flex flex-col justify-between md:flex-row">
|
|
<div>
|
|
<h1 className="text-2xl font-bold text-slate-900 dark:text-white">
|
|
Formbricks In-product Survey Demo App
|
|
</h1>
|
|
<p className="text-slate-700 dark:text-slate-300">
|
|
This app helps you test your in-app surveys. You can create and test user actions, create and
|
|
update user attributes, etc.
|
|
</p>
|
|
</div>
|
|
<button
|
|
className="mt-2 rounded-lg bg-slate-200 px-6 py-1 dark:bg-slate-700 dark:text-slate-100"
|
|
onClick={() => setDarkMode(!darkMode)}>
|
|
{darkMode ? "Toggle Light Mode" : "Toggle Dark Mode"}
|
|
</button>
|
|
</div>
|
|
|
|
<div className="my-4 grid grid-cols-1 gap-6 md:grid-cols-2">
|
|
<div>
|
|
<div className="rounded-lg border border-slate-300 bg-slate-100 p-6 dark:border-slate-600 dark:bg-slate-900">
|
|
<h3 className="text-lg font-semibold text-slate-900 dark:text-white">1. Setup .env</h3>
|
|
<p className="text-slate-700 dark:text-slate-300">
|
|
Copy the environment ID of your Formbricks app to the env variable in demo/.env
|
|
</p>
|
|
<Image src={fbsetup} alt="fb setup" className="mt-4 rounded" priority />
|
|
|
|
<div className="mt-4 flex-col items-start text-sm text-slate-700 sm:flex sm:items-center sm:text-base dark:text-slate-300">
|
|
<p className="mb-1 sm:mb-0 sm:mr-2">You're connected with env:</p>
|
|
<div className="flex items-center">
|
|
<strong className="w-32 truncate sm:w-auto">
|
|
{process.env.NEXT_PUBLIC_FORMBRICKS_ENVIRONMENT_ID}
|
|
</strong>
|
|
<span className="relative ml-2 flex h-3 w-3">
|
|
<span className="absolute inline-flex h-full w-full animate-ping rounded-full bg-green-400 opacity-75"></span>
|
|
<span className="relative inline-flex h-3 w-3 rounded-full bg-green-500"></span>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div className="mt-4 rounded-lg border border-slate-300 bg-slate-100 p-6 dark:border-slate-600 dark:bg-slate-900">
|
|
<h3 className="text-lg font-semibold text-slate-900 dark:text-white">2. Widget Logs</h3>
|
|
<p className="text-slate-700 dark:text-slate-300">
|
|
Look at the logs to understand how the widget works.{" "}
|
|
<strong className="dark:text-white">Open your browser console</strong> to see the logs.
|
|
</p>
|
|
{/* <div className="max-h-[40vh] overflow-y-auto py-4">
|
|
<LogsContainer />
|
|
</div> */}
|
|
</div>
|
|
</div>
|
|
|
|
<div className="md:grid md:grid-cols-3">
|
|
<div className="col-span-3 rounded-lg border border-slate-300 bg-slate-100 p-6 dark:border-slate-600 dark:bg-slate-800">
|
|
<h3 className="text-lg font-semibold dark:text-white">
|
|
Reset person / pull data from Formbricks app
|
|
</h3>
|
|
<p className="text-slate-700 dark:text-slate-300">
|
|
On formbricks.reset() a few things happen: <strong>New person is created</strong> and{" "}
|
|
<strong>surveys & no-code actions are pulled from Formbricks:</strong>.
|
|
</p>
|
|
<button
|
|
className="my-4 rounded-lg bg-slate-500 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600"
|
|
onClick={() => {
|
|
formbricks.reset();
|
|
}}>
|
|
Reset
|
|
</button>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
If you made a change in Formbricks app and it does not seem to work, hit 'Reset' and
|
|
try again.
|
|
</p>
|
|
</div>
|
|
|
|
<div className="p-6">
|
|
<div>
|
|
<button
|
|
className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600"
|
|
onClick={() => {
|
|
formbricks.track("Code Action");
|
|
}}>
|
|
Code Action
|
|
</button>
|
|
</div>
|
|
<div>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
This button sends a{" "}
|
|
<a href="https://formbricks.com/docs/actions/code" className="underline" target="_blank">
|
|
Code Action
|
|
</a>{" "}
|
|
to the Formbricks API called 'Code Action'. You will find it in the Actions Tab.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<div className="p-6">
|
|
<div>
|
|
<button className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600">
|
|
No-Code Action
|
|
</button>
|
|
</div>
|
|
<div>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
This button sends a{" "}
|
|
<a
|
|
href="https://formbricks.com/docs/actions/no-code"
|
|
className="underline dark:text-blue-500"
|
|
target="_blank">
|
|
No Code Action
|
|
</a>{" "}
|
|
as long as you created it beforehand in the Formbricks App.{" "}
|
|
<a
|
|
href="https://formbricks.com/docs/actions/no-code"
|
|
target="_blank"
|
|
className="underline dark:text-blue-500">
|
|
Here are instructions on how to do it.
|
|
</a>
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<div className="p-6">
|
|
<div>
|
|
<button
|
|
onClick={() => {
|
|
formbricks.setAttribute("Plan", "Free");
|
|
}}
|
|
className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600">
|
|
Set Plan to 'Free'
|
|
</button>
|
|
</div>
|
|
<div>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
This button sets the{" "}
|
|
<a
|
|
href="https://formbricks.com/docs/attributes/custom-attributes"
|
|
target="_blank"
|
|
className="underline dark:text-blue-500">
|
|
attribute
|
|
</a>{" "}
|
|
'Plan' to 'Free'. If the attribute does not exist, it creates it.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<div className="p-6">
|
|
<div>
|
|
<button
|
|
onClick={() => {
|
|
formbricks.setAttribute("Plan", "Paid");
|
|
}}
|
|
className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600">
|
|
Set Plan to 'Paid'
|
|
</button>
|
|
</div>
|
|
<div>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
This button sets the{" "}
|
|
<a
|
|
href="https://formbricks.com/docs/attributes/custom-attributes"
|
|
target="_blank"
|
|
className="underline dark:text-blue-500">
|
|
attribute
|
|
</a>{" "}
|
|
'Plan' to 'Paid'. If the attribute does not exist, it creates it.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<div className="p-6">
|
|
<div>
|
|
<button
|
|
onClick={() => {
|
|
formbricks.setEmail("test@web.com");
|
|
}}
|
|
className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600">
|
|
Set Email
|
|
</button>
|
|
</div>
|
|
<div>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
This button sets the{" "}
|
|
<a
|
|
href="https://formbricks.com/docs/attributes/identify-users"
|
|
target="_blank"
|
|
className="underline dark:text-blue-500">
|
|
user email
|
|
</a>{" "}
|
|
'test@web.com'
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<div className="p-6">
|
|
{router.query.userId === "true" ? (
|
|
<div>
|
|
<button
|
|
onClick={() => {
|
|
window.location.href = "/app";
|
|
}}
|
|
className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600">
|
|
Deactivate User Identification
|
|
</button>
|
|
</div>
|
|
) : (
|
|
<div>
|
|
<button
|
|
onClick={() => {
|
|
window.location.href = "/app?userId=true";
|
|
}}
|
|
className="mb-4 rounded-lg bg-slate-800 px-6 py-3 text-white hover:bg-slate-700 dark:bg-slate-700 dark:hover:bg-slate-600">
|
|
Activate User Identification
|
|
</button>
|
|
</div>
|
|
)}
|
|
<div>
|
|
<p className="text-xs text-slate-700 dark:text-slate-300">
|
|
This button activates/deactivates{" "}
|
|
<a
|
|
href="https://formbricks.com/docs/attributes/identify-users"
|
|
target="_blank"
|
|
className="underline dark:text-blue-500">
|
|
user identification
|
|
</a>{" "}
|
|
with the userId 'THIS-IS-A-VERY-LONG-USER-ID-FOR-TESTING'
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|