mirror of
https://github.com/formbricks/formbricks.git
synced 2026-04-22 19:39:01 -05:00
bebe29815d
Co-authored-by: Piyush Gupta <56182734+gupta-piyush19@users.noreply.github.com> Co-authored-by: Piyush Gupta <piyushguptaa2z123@gmail.com> Co-authored-by: Dhruwang <dhruwangjariwala18@gmail.com> Co-authored-by: pandeymangg <anshuman.pandey9999@gmail.com>
116 lines
4.0 KiB
TypeScript
116 lines
4.0 KiB
TypeScript
"use client";
|
|
|
|
import { useSurveyQRCode } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/lib/survey-qr-code";
|
|
import { getFormattedErrorMessage } from "@/lib/utils/helper";
|
|
import { Button } from "@/modules/ui/components/button";
|
|
import { useTranslate } from "@tolgee/react";
|
|
import { Copy, QrCode, RefreshCcw, SquareArrowOutUpRight } from "lucide-react";
|
|
import { useEffect, useState } from "react";
|
|
import { toast } from "react-hot-toast";
|
|
import { TSurvey } from "@formbricks/types/surveys/types";
|
|
import { TUserLocale } from "@formbricks/types/user";
|
|
import { getSurveyUrl } from "../../utils";
|
|
import { LanguageDropdown } from "./components/LanguageDropdown";
|
|
import { SurveyLinkDisplay } from "./components/SurveyLinkDisplay";
|
|
|
|
interface ShareSurveyLinkProps {
|
|
survey: TSurvey;
|
|
publicDomain: string;
|
|
surveyUrl: string;
|
|
setSurveyUrl: (url: string) => void;
|
|
locale: TUserLocale;
|
|
}
|
|
|
|
export const ShareSurveyLink = ({
|
|
survey,
|
|
surveyUrl,
|
|
publicDomain,
|
|
setSurveyUrl,
|
|
locale,
|
|
}: ShareSurveyLinkProps) => {
|
|
const { t } = useTranslate();
|
|
const [language, setLanguage] = useState("default");
|
|
|
|
useEffect(() => {
|
|
const fetchSurveyUrl = async () => {
|
|
try {
|
|
const url = await getSurveyUrl(survey, publicDomain, language);
|
|
setSurveyUrl(url);
|
|
} catch (error) {
|
|
const errorMessage = getFormattedErrorMessage(error);
|
|
toast.error(errorMessage);
|
|
}
|
|
};
|
|
fetchSurveyUrl();
|
|
}, [survey, language, publicDomain, setSurveyUrl]);
|
|
|
|
const generateNewSingleUseLink = async () => {
|
|
try {
|
|
const newUrl = await getSurveyUrl(survey, publicDomain, language);
|
|
setSurveyUrl(newUrl);
|
|
toast.success(t("environments.surveys.new_single_use_link_generated"));
|
|
} catch (error) {
|
|
const errorMessage = getFormattedErrorMessage(error);
|
|
toast.error(errorMessage);
|
|
}
|
|
};
|
|
|
|
const { downloadQRCode } = useSurveyQRCode(surveyUrl);
|
|
|
|
return (
|
|
<div
|
|
className={`flex max-w-full flex-col items-center justify-center space-x-2 ${survey.singleUse?.enabled ? "flex-col" : "lg:flex-row"}`}>
|
|
<SurveyLinkDisplay surveyUrl={surveyUrl} key={surveyUrl} />
|
|
<div className="mt-2 flex items-center justify-center space-x-2">
|
|
<LanguageDropdown survey={survey} setLanguage={setLanguage} locale={locale} />
|
|
<Button
|
|
title={t("environments.surveys.preview_survey_in_a_new_tab")}
|
|
aria-label={t("environments.surveys.preview_survey_in_a_new_tab")}
|
|
disabled={!surveyUrl}
|
|
onClick={() => {
|
|
let previewUrl = surveyUrl;
|
|
if (previewUrl.includes("?")) {
|
|
previewUrl += "&preview=true";
|
|
} else {
|
|
previewUrl += "?preview=true";
|
|
}
|
|
window.open(previewUrl, "_blank");
|
|
}}>
|
|
{t("common.preview")}
|
|
<SquareArrowOutUpRight />
|
|
</Button>
|
|
<Button
|
|
disabled={!surveyUrl}
|
|
variant="secondary"
|
|
title={t("environments.surveys.copy_survey_link_to_clipboard")}
|
|
aria-label={t("environments.surveys.copy_survey_link_to_clipboard")}
|
|
onClick={() => {
|
|
navigator.clipboard.writeText(surveyUrl);
|
|
toast.success(t("common.copied_to_clipboard"));
|
|
}}>
|
|
{t("common.copy")}
|
|
<Copy />
|
|
</Button>
|
|
<Button
|
|
variant="secondary"
|
|
title={t("environments.surveys.summary.download_qr_code")}
|
|
aria-label={t("environments.surveys.summary.download_qr_code")}
|
|
size={"icon"}
|
|
disabled={!surveyUrl}
|
|
onClick={downloadQRCode}>
|
|
<QrCode style={{ width: "24px", height: "24px" }} />
|
|
</Button>
|
|
{survey.singleUse?.enabled && (
|
|
<Button
|
|
disabled={!surveyUrl}
|
|
title="Regenerate single use survey link"
|
|
aria-label="Regenerate single use survey link"
|
|
onClick={generateNewSingleUseLink}>
|
|
<RefreshCcw className="h-5 w-5" />
|
|
</Button>
|
|
)}
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|