Files
formbricks-formbricks/apps/web/components/shared/EnvironmentNotice.tsx
T
Dhruwang Jariwala 0a1de196aa chore: moves setup checklist to react server components (#695)
* Chore: moves setup checklist to RSC

* fix other merge conflictsg

* made code refactors

* added TAction as return type for getActions

* fixed build issues

* fix environmentNotice component

* refactor EnvironmentNotice component

* fix js tests

---------

Co-authored-by: Matthias Nannt <mail@matthiasnannt.com>
2023-09-06 15:18:49 +09:00

40 lines
1.5 KiB
TypeScript

import { getEnvironments } from "@formbricks/lib/services/environment";
import { TEnvironment } from "@formbricks/types/v1/environment";
import { LightBulbIcon } from "@heroicons/react/24/outline";
import { headers } from "next/headers";
interface EnvironmentNoticeProps {
environment: TEnvironment;
}
export default async function EnvironmentNotice({ environment }: EnvironmentNoticeProps) {
const headersList = headers();
const currentUrl = headersList.get("x-invoke-path") || "";
const environments = await getEnvironments(environment.productId);
const otherEnvironmentId = environments.find((e) => e.id !== environment.id)?.id || "";
const replaceEnvironmentId = (url: string, newId: string): string => {
const regex = /environments\/([a-zA-Z0-9]+)/;
if (regex.test(url)) {
return url.replace(regex, `environments/${newId}`);
}
return url;
};
return (
<div>
<div className="flex items-center space-y-3 rounded-lg border border-blue-100 bg-blue-50 p-4 text-sm text-blue-900 shadow-sm md:space-y-0 md:text-base">
<LightBulbIcon className="mr-3 h-4 w-4 text-blue-400" />
<p>
{`You're currently in the ${environment.type} environment.`}
<a
href={replaceEnvironmentId(currentUrl, otherEnvironmentId)}
className="ml-1 cursor-pointer text-sm underline">
Switch to {environment.type === "production" ? "Development" : "Production"} now.
</a>
</p>
</div>
</div>
);
}