mirror of
https://github.com/formbricks/formbricks.git
synced 2026-05-05 19:30:48 -05:00
Compare commits
45 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 7d297a3acd | |||
| abbf634c48 | |||
| 8a01425f39 | |||
| 2ab0441404 | |||
| 299ae81b21 | |||
| f73f13f16c | |||
| e9bcbf6e4c | |||
| 32eda35a71 | |||
| 84999cddfd | |||
| f0a0cf531a | |||
| f3e02fa466 | |||
| f0a93ae092 | |||
| 1c922dfe2c | |||
| 33010fb6f5 | |||
| d5fdacadd7 | |||
| d939263472 | |||
| e4aa66b067 | |||
| ffcc101ed9 | |||
| 2740cd16b9 | |||
| 7eb94f0bd5 | |||
| 6dd2e707fe | |||
| 58d5de7d45 | |||
| 7c3fa8b5ea | |||
| 2601169877 | |||
| aecf85815a | |||
| c6ebaea989 | |||
| 68c1422733 | |||
| 6942502baf | |||
| a4bd217761 | |||
| fee770358c | |||
| 44f8f80cac | |||
| 858a7f7aa9 | |||
| ac40b90e81 | |||
| aa21b4e442 | |||
| fa72296de5 | |||
| 3776b31794 | |||
| 5c7ea33fb0 | |||
| 70b8b13e66 | |||
| 33f60ce2be | |||
| c0386cea5a | |||
| 262edd4602 | |||
| 7a752b073d | |||
| ad785453ca | |||
| e1d3ba3e69 | |||
| e1b30d2ade |
@@ -1,2 +0,0 @@
|
|||||||
echo "{\"branchName\": \"$(git rev-parse --abbrev-ref HEAD)\"}" > ./branch.json
|
|
||||||
prettier --write ./branch.json
|
|
||||||
+12
-17
@@ -10,25 +10,20 @@
|
|||||||
"build-storybook": "storybook build",
|
"build-storybook": "storybook build",
|
||||||
"clean": "rimraf .turbo node_modules dist storybook-static"
|
"clean": "rimraf .turbo node_modules dist storybook-static"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
|
||||||
"@formbricks/survey-ui": "workspace:*"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@chromatic-com/storybook": "^5.0.0",
|
"@chromatic-com/storybook": "^5.0.1",
|
||||||
"@storybook/addon-a11y": "10.1.11",
|
"@storybook/addon-a11y": "10.2.14",
|
||||||
"@storybook/addon-links": "10.1.11",
|
"@storybook/addon-links": "10.2.14",
|
||||||
"@storybook/addon-onboarding": "10.1.11",
|
"@storybook/addon-onboarding": "10.2.14",
|
||||||
"@storybook/react-vite": "10.1.11",
|
"@storybook/react-vite": "10.2.14",
|
||||||
"@typescript-eslint/eslint-plugin": "8.53.0",
|
"@typescript-eslint/eslint-plugin": "8.56.1",
|
||||||
"@tailwindcss/vite": "4.1.18",
|
"@tailwindcss/vite": "4.2.1",
|
||||||
"@typescript-eslint/parser": "8.53.0",
|
"@typescript-eslint/parser": "8.56.1",
|
||||||
"@vitejs/plugin-react": "5.1.2",
|
"@vitejs/plugin-react": "5.1.4",
|
||||||
"esbuild": "0.25.12",
|
|
||||||
"eslint-plugin-react-refresh": "0.4.26",
|
"eslint-plugin-react-refresh": "0.4.26",
|
||||||
"eslint-plugin-storybook": "10.1.11",
|
"eslint-plugin-storybook": "10.2.14",
|
||||||
"prop-types": "15.8.1",
|
"storybook": "10.2.14",
|
||||||
"storybook": "10.1.11",
|
|
||||||
"vite": "7.3.1",
|
"vite": "7.3.1",
|
||||||
"@storybook/addon-docs": "10.1.11"
|
"@storybook/addon-docs": "10.2.14"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
const baseConfig = require("../../.prettierrc.js");
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
...baseConfig,
|
||||||
|
tailwindConfig: "./tailwind.config.js",
|
||||||
|
};
|
||||||
@@ -101,6 +101,9 @@ RUN chown -R nextjs:nextjs ./apps/web/public && chmod -R 755 ./apps/web/public
|
|||||||
# Create packages/database directory structure with proper ownership for runtime migrations
|
# Create packages/database directory structure with proper ownership for runtime migrations
|
||||||
RUN mkdir -p ./packages/database/migrations && chown -R nextjs:nextjs ./packages/database
|
RUN mkdir -p ./packages/database/migrations && chown -R nextjs:nextjs ./packages/database
|
||||||
|
|
||||||
|
COPY --from=installer /app/packages/database/package.json ./packages/database/package.json
|
||||||
|
RUN chown nextjs:nextjs ./packages/database/package.json && chmod 644 ./packages/database/package.json
|
||||||
|
|
||||||
COPY --from=installer /app/packages/database/schema.prisma ./packages/database/schema.prisma
|
COPY --from=installer /app/packages/database/schema.prisma ./packages/database/schema.prisma
|
||||||
RUN chown nextjs:nextjs ./packages/database/schema.prisma && chmod 644 ./packages/database/schema.prisma
|
RUN chown nextjs:nextjs ./packages/database/schema.prisma && chmod 644 ./packages/database/schema.prisma
|
||||||
|
|
||||||
|
|||||||
+1
-1
@@ -69,7 +69,7 @@ export const ConnectWithFormbricks = ({
|
|||||||
) : (
|
) : (
|
||||||
<div className="flex animate-pulse flex-col items-center space-y-4">
|
<div className="flex animate-pulse flex-col items-center space-y-4">
|
||||||
<span className="relative flex h-10 w-10">
|
<span className="relative flex h-10 w-10">
|
||||||
<span className="animate-ping-slow absolute inline-flex h-full w-full rounded-full bg-slate-400 opacity-75"></span>
|
<span className="absolute inline-flex h-full w-full animate-ping-slow rounded-full bg-slate-400 opacity-75"></span>
|
||||||
<span className="relative inline-flex h-10 w-10 rounded-full bg-slate-500"></span>
|
<span className="relative inline-flex h-10 w-10 rounded-full bg-slate-500"></span>
|
||||||
</span>
|
</span>
|
||||||
<p className="pt-4 text-sm font-medium text-slate-600">
|
<p className="pt-4 text-sm font-medium text-slate-600">
|
||||||
|
|||||||
@@ -46,7 +46,7 @@ const Page = async (props: ConnectPageProps) => {
|
|||||||
channel={channel}
|
channel={channel}
|
||||||
/>
|
/>
|
||||||
<Button
|
<Button
|
||||||
className="absolute top-5 right-5 !mt-0 text-slate-500 hover:text-slate-700"
|
className="absolute right-5 top-5 !mt-0 text-slate-500 hover:text-slate-700"
|
||||||
variant="ghost"
|
variant="ghost"
|
||||||
asChild>
|
asChild>
|
||||||
<Link href={`/environments/${environment.id}`}>
|
<Link href={`/environments/${environment.id}`}>
|
||||||
|
|||||||
@@ -49,7 +49,7 @@ const Page = async (props: XMTemplatePageProps) => {
|
|||||||
<XMTemplateList project={project} user={user} environmentId={environment.id} />
|
<XMTemplateList project={project} user={user} environmentId={environment.id} />
|
||||||
{projects.length >= 2 && (
|
{projects.length >= 2 && (
|
||||||
<Button
|
<Button
|
||||||
className="absolute top-5 right-5 !mt-0 text-slate-500 hover:text-slate-700"
|
className="absolute right-5 top-5 !mt-0 text-slate-500 hover:text-slate-700"
|
||||||
variant="ghost"
|
variant="ghost"
|
||||||
asChild>
|
asChild>
|
||||||
<Link href={`/environments/${environment.id}/surveys`}>
|
<Link href={`/environments/${environment.id}/surveys`}>
|
||||||
|
|||||||
+1
-1
@@ -42,7 +42,7 @@ export const LandingSidebar = ({ user, organization }: LandingSidebarProps) => {
|
|||||||
return (
|
return (
|
||||||
<aside
|
<aside
|
||||||
className={cn(
|
className={cn(
|
||||||
"w-sidebar-collapsed z-40 flex flex-col justify-between rounded-r-xl border-r border-slate-200 bg-white pt-3 shadow-md transition-all duration-100"
|
"z-40 flex w-sidebar-collapsed flex-col justify-between rounded-r-xl border-r border-slate-200 bg-white pt-3 shadow-md transition-all duration-100"
|
||||||
)}>
|
)}>
|
||||||
<Image src={FBLogo} width={160} height={30} alt={t("environments.formbricks_logo")} />
|
<Image src={FBLogo} width={160} height={30} alt={t("environments.formbricks_logo")} />
|
||||||
|
|
||||||
|
|||||||
+1
-1
@@ -50,7 +50,7 @@ const Page = async (props: ChannelPageProps) => {
|
|||||||
<OnboardingOptionsContainer options={channelOptions} />
|
<OnboardingOptionsContainer options={channelOptions} />
|
||||||
{projects.length >= 1 && (
|
{projects.length >= 1 && (
|
||||||
<Button
|
<Button
|
||||||
className="absolute top-5 right-5 !mt-0 text-slate-500 hover:text-slate-700"
|
className="absolute right-5 top-5 !mt-0 text-slate-500 hover:text-slate-700"
|
||||||
variant="ghost"
|
variant="ghost"
|
||||||
asChild>
|
asChild>
|
||||||
<Link href={"/"}>
|
<Link href={"/"}>
|
||||||
|
|||||||
+1
-1
@@ -47,7 +47,7 @@ const Page = async (props: ModePageProps) => {
|
|||||||
<OnboardingOptionsContainer options={channelOptions} />
|
<OnboardingOptionsContainer options={channelOptions} />
|
||||||
{projects.length >= 1 && (
|
{projects.length >= 1 && (
|
||||||
<Button
|
<Button
|
||||||
className="absolute top-5 right-5 !mt-0 text-slate-500 hover:text-slate-700"
|
className="absolute right-5 top-5 !mt-0 text-slate-500 hover:text-slate-700"
|
||||||
variant="ghost"
|
variant="ghost"
|
||||||
asChild>
|
asChild>
|
||||||
<Link href={"/"}>
|
<Link href={"/"}>
|
||||||
|
|||||||
+11
-13
@@ -228,7 +228,7 @@ export const ProjectSettings = ({
|
|||||||
</FormProvider>
|
</FormProvider>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="relative flex h-[30rem] w-1/2 flex-col items-center justify-center space-y-2 rounded-lg border bg-slate-200 shadow">
|
<div className="relative flex w-1/2 flex-col items-center justify-center space-y-2 rounded-lg border bg-slate-200 p-6 shadow">
|
||||||
{logoUrl && (
|
{logoUrl && (
|
||||||
<Image
|
<Image
|
||||||
src={logoUrl}
|
src={logoUrl}
|
||||||
@@ -239,18 +239,16 @@ export const ProjectSettings = ({
|
|||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
<p className="text-sm text-slate-400">{t("common.preview")}</p>
|
<p className="text-sm text-slate-400">{t("common.preview")}</p>
|
||||||
<div className="z-0 h-3/4 w-3/4">
|
<SurveyInline
|
||||||
<SurveyInline
|
appUrl={publicDomain}
|
||||||
appUrl={publicDomain}
|
isPreviewMode={true}
|
||||||
isPreviewMode={true}
|
survey={previewSurvey(projectName || t("common.my_product"), t)}
|
||||||
survey={previewSurvey(projectName || "my Product", t)}
|
styling={previewStyling}
|
||||||
styling={previewStyling}
|
isBrandingEnabled={false}
|
||||||
isBrandingEnabled={false}
|
languageCode="default"
|
||||||
languageCode="default"
|
onFileUpload={async (file) => file.name}
|
||||||
onFileUpload={async (file) => file.name}
|
autoFocus={false}
|
||||||
autoFocus={false}
|
/>
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<CreateTeamModal
|
<CreateTeamModal
|
||||||
open={createTeamModalOpen}
|
open={createTeamModalOpen}
|
||||||
|
|||||||
+1
-1
@@ -69,7 +69,7 @@ const Page = async (props: ProjectSettingsPageProps) => {
|
|||||||
/>
|
/>
|
||||||
{projects.length >= 1 && (
|
{projects.length >= 1 && (
|
||||||
<Button
|
<Button
|
||||||
className="absolute top-5 right-5 !mt-0 text-slate-500 hover:text-slate-700"
|
className="absolute right-5 top-5 !mt-0 text-slate-500 hover:text-slate-700"
|
||||||
variant="ghost"
|
variant="ghost"
|
||||||
asChild>
|
asChild>
|
||||||
<Link href={"/"}>
|
<Link href={"/"}>
|
||||||
|
|||||||
@@ -188,7 +188,7 @@ export const MainNavigation = ({
|
|||||||
size="icon"
|
size="icon"
|
||||||
onClick={toggleSidebar}
|
onClick={toggleSidebar}
|
||||||
className={cn(
|
className={cn(
|
||||||
"rounded-xl bg-slate-50 p-1 text-slate-600 transition-all hover:bg-slate-100 focus:ring-0 focus:ring-transparent focus:outline-none"
|
"rounded-xl bg-slate-50 p-1 text-slate-600 transition-all hover:bg-slate-100 focus:outline-none focus:ring-0 focus:ring-transparent"
|
||||||
)}>
|
)}>
|
||||||
{isCollapsed ? (
|
{isCollapsed ? (
|
||||||
<PanelLeftOpenIcon strokeWidth={1.5} />
|
<PanelLeftOpenIcon strokeWidth={1.5} />
|
||||||
|
|||||||
+1
-1
@@ -53,7 +53,7 @@ export const WidgetStatusIndicator = ({ environment }: WidgetStatusIndicatorProp
|
|||||||
<currentStatus.icon />
|
<currentStatus.icon />
|
||||||
</div>
|
</div>
|
||||||
<p className="text-md font-bold text-slate-800 md:text-xl">{currentStatus.title}</p>
|
<p className="text-md font-bold text-slate-800 md:text-xl">{currentStatus.title}</p>
|
||||||
<p className="w-2/3 text-sm text-balance text-slate-600">{currentStatus.subtitle}</p>
|
<p className="w-2/3 text-balance text-sm text-slate-600">{currentStatus.subtitle}</p>
|
||||||
{status === "notImplemented" && (
|
{status === "notImplemented" && (
|
||||||
<Button variant="outline" size="sm" className="bg-white" onClick={() => router.refresh()}>
|
<Button variant="outline" size="sm" className="bg-white" onClick={() => router.refresh()}>
|
||||||
<RotateCcwIcon />
|
<RotateCcwIcon />
|
||||||
|
|||||||
+1
-1
@@ -81,7 +81,7 @@ export const OrganizationBreadcrumb = ({
|
|||||||
getOrganizationsForSwitcherAction({ organizationId: currentOrganizationId }).then((result) => {
|
getOrganizationsForSwitcherAction({ organizationId: currentOrganizationId }).then((result) => {
|
||||||
if (result?.data) {
|
if (result?.data) {
|
||||||
// Sort organizations by name
|
// Sort organizations by name
|
||||||
const sorted = result.data.toSorted((a, b) => a.name.localeCompare(b.name));
|
const sorted = [...result.data].sort((a, b) => a.name.localeCompare(b.name));
|
||||||
setOrganizations(sorted);
|
setOrganizations(sorted);
|
||||||
} else {
|
} else {
|
||||||
// Handle server errors or validation errors
|
// Handle server errors or validation errors
|
||||||
|
|||||||
@@ -82,7 +82,7 @@ export const ProjectBreadcrumb = ({
|
|||||||
getProjectsForSwitcherAction({ organizationId: currentOrganizationId }).then((result) => {
|
getProjectsForSwitcherAction({ organizationId: currentOrganizationId }).then((result) => {
|
||||||
if (result?.data) {
|
if (result?.data) {
|
||||||
// Sort projects by name
|
// Sort projects by name
|
||||||
const sorted = result.data.toSorted((a, b) => a.name.localeCompare(b.name));
|
const sorted = [...result.data].sort((a, b) => a.name.localeCompare(b.name));
|
||||||
setProjects(sorted);
|
setProjects(sorted);
|
||||||
} else {
|
} else {
|
||||||
// Handle server errors or validation errors
|
// Handle server errors or validation errors
|
||||||
|
|||||||
+1
-1
@@ -98,7 +98,7 @@ export const PasswordConfirmationModal = ({
|
|||||||
aria-label="password"
|
aria-label="password"
|
||||||
aria-required="true"
|
aria-required="true"
|
||||||
required
|
required
|
||||||
className="focus:border-brand-dark focus:ring-brand-dark block w-full rounded-md border-slate-300 shadow-sm sm:text-sm"
|
className="block w-full rounded-md border-slate-300 shadow-sm focus:border-brand-dark focus:ring-brand-dark sm:text-sm"
|
||||||
value={field.value}
|
value={field.value}
|
||||||
onChange={(password) => field.onChange(password)}
|
onChange={(password) => field.onChange(password)}
|
||||||
/>
|
/>
|
||||||
|
|||||||
+5
-1
@@ -9,6 +9,7 @@ import { Alert, AlertDescription } from "@/modules/ui/components/alert";
|
|||||||
import { IdBadge } from "@/modules/ui/components/id-badge";
|
import { IdBadge } from "@/modules/ui/components/id-badge";
|
||||||
import { PageContentWrapper } from "@/modules/ui/components/page-content-wrapper";
|
import { PageContentWrapper } from "@/modules/ui/components/page-content-wrapper";
|
||||||
import { PageHeader } from "@/modules/ui/components/page-header";
|
import { PageHeader } from "@/modules/ui/components/page-header";
|
||||||
|
import packageJson from "@/package.json";
|
||||||
import { SettingsCard } from "../../components/SettingsCard";
|
import { SettingsCard } from "../../components/SettingsCard";
|
||||||
import { DeleteOrganization } from "./components/DeleteOrganization";
|
import { DeleteOrganization } from "./components/DeleteOrganization";
|
||||||
import { EditOrganizationNameForm } from "./components/EditOrganizationNameForm";
|
import { EditOrganizationNameForm } from "./components/EditOrganizationNameForm";
|
||||||
@@ -81,7 +82,10 @@ const Page = async (props: { params: Promise<{ environmentId: string }> }) => {
|
|||||||
</SettingsCard>
|
</SettingsCard>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
<IdBadge id={organization.id} label={t("common.organization_id")} variant="column" />
|
<div className="space-y-2">
|
||||||
|
<IdBadge id={organization.id} label={t("common.organization_id")} variant="column" />
|
||||||
|
<IdBadge id={packageJson.version} label={t("common.formbricks_version")} variant="column" />
|
||||||
|
</div>
|
||||||
</PageContentWrapper>
|
</PageContentWrapper>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
+29
@@ -4,6 +4,7 @@ import { revalidatePath } from "next/cache";
|
|||||||
import { z } from "zod";
|
import { z } from "zod";
|
||||||
import { ZId } from "@formbricks/types/common";
|
import { ZId } from "@formbricks/types/common";
|
||||||
import { ZResponseFilterCriteria } from "@formbricks/types/responses";
|
import { ZResponseFilterCriteria } from "@formbricks/types/responses";
|
||||||
|
import { getDisplaysBySurveyIdWithContact } from "@/lib/display/service";
|
||||||
import { getResponseCountBySurveyId, getResponses } from "@/lib/response/service";
|
import { getResponseCountBySurveyId, getResponses } from "@/lib/response/service";
|
||||||
import { authenticatedActionClient } from "@/lib/utils/action-client";
|
import { authenticatedActionClient } from "@/lib/utils/action-client";
|
||||||
import { checkAuthorizationUpdated } from "@/lib/utils/action-client/action-client-middleware";
|
import { checkAuthorizationUpdated } from "@/lib/utils/action-client/action-client-middleware";
|
||||||
@@ -106,3 +107,31 @@ export const getResponseCountAction = authenticatedActionClient
|
|||||||
|
|
||||||
return getResponseCountBySurveyId(parsedInput.surveyId, parsedInput.filterCriteria);
|
return getResponseCountBySurveyId(parsedInput.surveyId, parsedInput.filterCriteria);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const ZGetDisplaysWithContactAction = z.object({
|
||||||
|
surveyId: ZId,
|
||||||
|
limit: z.number().int().min(1).max(100),
|
||||||
|
offset: z.number().int().nonnegative(),
|
||||||
|
});
|
||||||
|
|
||||||
|
export const getDisplaysWithContactAction = authenticatedActionClient
|
||||||
|
.schema(ZGetDisplaysWithContactAction)
|
||||||
|
.action(async ({ ctx, parsedInput }) => {
|
||||||
|
await checkAuthorizationUpdated({
|
||||||
|
userId: ctx.user.id,
|
||||||
|
organizationId: await getOrganizationIdFromSurveyId(parsedInput.surveyId),
|
||||||
|
access: [
|
||||||
|
{
|
||||||
|
type: "organization",
|
||||||
|
roles: ["owner", "manager"],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: "projectTeam",
|
||||||
|
minPermission: "read",
|
||||||
|
projectId: await getProjectIdFromSurveyId(parsedInput.surveyId),
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
return getDisplaysBySurveyIdWithContact(parsedInput.surveyId, parsedInput.limit, parsedInput.offset);
|
||||||
|
});
|
||||||
|
|||||||
+3
-1
@@ -4,6 +4,7 @@ import { ResponseFilterProvider } from "@/app/(app)/environments/[environmentId]
|
|||||||
import { getResponseCountBySurveyId } from "@/lib/response/service";
|
import { getResponseCountBySurveyId } from "@/lib/response/service";
|
||||||
import { getSurvey } from "@/lib/survey/service";
|
import { getSurvey } from "@/lib/survey/service";
|
||||||
import { authOptions } from "@/modules/auth/lib/authOptions";
|
import { authOptions } from "@/modules/auth/lib/authOptions";
|
||||||
|
import { getTranslate } from "@/lingodotdev/server";
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
params: Promise<{ surveyId: string; environmentId: string }>;
|
params: Promise<{ surveyId: string; environmentId: string }>;
|
||||||
@@ -14,10 +15,11 @@ export const generateMetadata = async (props: Props): Promise<Metadata> => {
|
|||||||
const session = await getServerSession(authOptions);
|
const session = await getServerSession(authOptions);
|
||||||
const survey = await getSurvey(params.surveyId);
|
const survey = await getSurvey(params.surveyId);
|
||||||
const responseCount = await getResponseCountBySurveyId(params.surveyId);
|
const responseCount = await getResponseCountBySurveyId(params.surveyId);
|
||||||
|
const t = await getTranslate();
|
||||||
|
|
||||||
if (session) {
|
if (session) {
|
||||||
return {
|
return {
|
||||||
title: `${responseCount} Responses | ${survey?.name} Results`,
|
title: `${t("common.count_responses", { count: responseCount })} | ${t("environments.surveys.summary.survey_results", { surveyName: survey?.name })}`,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
|
|||||||
+2
-4
@@ -30,8 +30,7 @@ export const CalSummary = ({ elementSummary, survey }: CalSummaryProps) => {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<p className="flex w-32 items-end justify-end text-slate-600">
|
<p className="flex w-32 items-end justify-end text-slate-600">
|
||||||
{elementSummary.booked.count}{" "}
|
{t("common.count_responses", { count: elementSummary.booked.count })}
|
||||||
{elementSummary.booked.count === 1 ? t("common.response") : t("common.responses")}
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<ProgressBar barColor="bg-brand-dark" progress={elementSummary.booked.percentage / 100} />
|
<ProgressBar barColor="bg-brand-dark" progress={elementSummary.booked.percentage / 100} />
|
||||||
@@ -47,8 +46,7 @@ export const CalSummary = ({ elementSummary, survey }: CalSummaryProps) => {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<p className="flex w-32 items-end justify-end text-slate-600">
|
<p className="flex w-32 items-end justify-end text-slate-600">
|
||||||
{elementSummary.skipped.count}{" "}
|
{t("common.count_responses", { count: elementSummary.skipped.count })}
|
||||||
{elementSummary.skipped.count === 1 ? t("common.response") : t("common.responses")}
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<ProgressBar barColor="bg-brand-dark" progress={elementSummary.skipped.percentage / 100} />
|
<ProgressBar barColor="bg-brand-dark" progress={elementSummary.skipped.percentage / 100} />
|
||||||
|
|||||||
+1
-1
@@ -64,7 +64,7 @@ export const ConsentSummary = ({ elementSummary, survey, setFilter }: ConsentSum
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<p className="flex w-32 items-end justify-end text-slate-600">
|
<p className="flex w-32 items-end justify-end text-slate-600">
|
||||||
{summaryItem.count} {summaryItem.count === 1 ? t("common.response") : t("common.responses")}
|
{t("common.count_responses", { count: summaryItem.count })}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div className="group-hover:opacity-80">
|
<div className="group-hover:opacity-80">
|
||||||
|
|||||||
+1
-1
@@ -48,7 +48,7 @@ export const ElementSummaryHeader = ({
|
|||||||
{showResponses && (
|
{showResponses && (
|
||||||
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
||||||
<InboxIcon className="mr-2 h-4 w-4" />
|
<InboxIcon className="mr-2 h-4 w-4" />
|
||||||
{`${elementSummary.responseCount} ${t("common.responses")}`}
|
{t("common.count_responses", { count: elementSummary.responseCount })}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
{additionalInfo}
|
{additionalInfo}
|
||||||
|
|||||||
+1
-2
@@ -41,8 +41,7 @@ export const HiddenFieldsSummary = ({ environment, elementSummary, locale }: Hid
|
|||||||
</div>
|
</div>
|
||||||
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
||||||
<InboxIcon className="mr-2 h-4 w-4" />
|
<InboxIcon className="mr-2 h-4 w-4" />
|
||||||
{elementSummary.responseCount}{" "}
|
{t("common.count_responses", { count: elementSummary.responseCount })}
|
||||||
{elementSummary.responseCount === 1 ? t("common.response") : t("common.responses")}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
+2
-2
@@ -31,7 +31,7 @@ export const MatrixElementSummary = ({ elementSummary, survey, setFilter }: Matr
|
|||||||
if (label) {
|
if (label) {
|
||||||
return label;
|
return label;
|
||||||
} else if (percentage !== undefined && totalResponsesForRow !== undefined) {
|
} else if (percentage !== undefined && totalResponsesForRow !== undefined) {
|
||||||
return `${Math.round((percentage / 100) * totalResponsesForRow)} ${t("common.responses")}`;
|
return t("common.count_responses", { count: Math.round((percentage / 100) * totalResponsesForRow) });
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
};
|
};
|
||||||
@@ -77,7 +77,7 @@ export const MatrixElementSummary = ({ elementSummary, survey, setFilter }: Matr
|
|||||||
)}>
|
)}>
|
||||||
<button
|
<button
|
||||||
style={{ backgroundColor: `rgba(0,196,184,${getOpacityLevel(percentage)})` }}
|
style={{ backgroundColor: `rgba(0,196,184,${getOpacityLevel(percentage)})` }}
|
||||||
className="hover:outline-brand-dark m-1 flex h-full w-40 cursor-pointer items-center justify-center rounded p-4 text-sm text-slate-950 hover:outline"
|
className="m-1 flex h-full w-40 cursor-pointer items-center justify-center rounded p-4 text-sm text-slate-950 hover:outline hover:outline-brand-dark"
|
||||||
onClick={() =>
|
onClick={() =>
|
||||||
setFilter(
|
setFilter(
|
||||||
elementSummary.element.id,
|
elementSummary.element.id,
|
||||||
|
|||||||
+2
-2
@@ -75,7 +75,7 @@ export const MultipleChoiceSummary = ({
|
|||||||
elementSummary.type === "multipleChoiceMulti" ? (
|
elementSummary.type === "multipleChoiceMulti" ? (
|
||||||
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
||||||
<InboxIcon className="mr-2 h-4 w-4" />
|
<InboxIcon className="mr-2 h-4 w-4" />
|
||||||
{`${elementSummary.selectionCount} ${t("common.selections")}`}
|
{t("common.count_selections", { count: elementSummary.selectionCount })}
|
||||||
</div>
|
</div>
|
||||||
) : undefined
|
) : undefined
|
||||||
}
|
}
|
||||||
@@ -110,7 +110,7 @@ export const MultipleChoiceSummary = ({
|
|||||||
</div>
|
</div>
|
||||||
<div className="flex w-full space-x-2">
|
<div className="flex w-full space-x-2">
|
||||||
<p className="flex w-full pt-1 text-slate-600 sm:items-end sm:justify-end sm:pt-0">
|
<p className="flex w-full pt-1 text-slate-600 sm:items-end sm:justify-end sm:pt-0">
|
||||||
{result.count} {result.count === 1 ? t("common.selection") : t("common.selections")}
|
{t("common.count_selections", { count: result.count })}
|
||||||
</p>
|
</p>
|
||||||
<p className="rounded-lg bg-slate-100 px-2 text-slate-700">
|
<p className="rounded-lg bg-slate-100 px-2 text-slate-700">
|
||||||
{convertFloatToNDecimal(result.percentage, 2)}%
|
{convertFloatToNDecimal(result.percentage, 2)}%
|
||||||
|
|||||||
+2
-3
@@ -123,8 +123,7 @@ export const NPSSummary = ({ elementSummary, survey, setFilter }: NPSSummaryProp
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<p className="flex w-32 items-end justify-end text-slate-600">
|
<p className="flex w-32 items-end justify-end text-slate-600">
|
||||||
{elementSummary[group]?.count}{" "}
|
{t("common.count_responses", { count: elementSummary[group]?.count })}
|
||||||
{elementSummary[group]?.count === 1 ? t("common.response") : t("common.responses")}
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<ProgressBar
|
<ProgressBar
|
||||||
@@ -158,7 +157,7 @@ export const NPSSummary = ({ elementSummary, survey, setFilter }: NPSSummaryProp
|
|||||||
}>
|
}>
|
||||||
<div className="flex h-32 w-full flex-col items-center justify-end">
|
<div className="flex h-32 w-full flex-col items-center justify-end">
|
||||||
<div
|
<div
|
||||||
className="bg-brand-dark w-full rounded-t-lg border border-slate-200 transition-all group-hover:brightness-110"
|
className="w-full rounded-t-lg border border-slate-200 bg-brand-dark transition-all group-hover:brightness-110"
|
||||||
style={{
|
style={{
|
||||||
height: `${Math.max(choice.percentage, 2)}%`,
|
height: `${Math.max(choice.percentage, 2)}%`,
|
||||||
opacity,
|
opacity,
|
||||||
|
|||||||
+2
-2
@@ -37,7 +37,7 @@ export const PictureChoiceSummary = ({ elementSummary, survey, setFilter }: Pict
|
|||||||
elementSummary.element.allowMulti ? (
|
elementSummary.element.allowMulti ? (
|
||||||
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
<div className="flex items-center rounded-lg bg-slate-100 p-2">
|
||||||
<InboxIcon className="mr-2 h-4 w-4" />
|
<InboxIcon className="mr-2 h-4 w-4" />
|
||||||
{`${elementSummary.selectionCount} ${t("common.selections")}`}
|
{t("common.count_selections", { count: elementSummary.selectionCount })}
|
||||||
</div>
|
</div>
|
||||||
) : undefined
|
) : undefined
|
||||||
}
|
}
|
||||||
@@ -74,7 +74,7 @@ export const PictureChoiceSummary = ({ elementSummary, survey, setFilter }: Pict
|
|||||||
</div>
|
</div>
|
||||||
<div className="flex w-full space-x-2">
|
<div className="flex w-full space-x-2">
|
||||||
<p className="flex w-full pt-1 text-slate-600 sm:items-end sm:justify-end sm:pt-0">
|
<p className="flex w-full pt-1 text-slate-600 sm:items-end sm:justify-end sm:pt-0">
|
||||||
{result.count} {result.count === 1 ? t("common.selection") : t("common.selections")}
|
{t("common.count_selections", { count: result.count })}
|
||||||
</p>
|
</p>
|
||||||
<p className="self-end rounded-lg bg-slate-100 px-2 text-slate-700">
|
<p className="self-end rounded-lg bg-slate-100 px-2 text-slate-700">
|
||||||
{convertFloatToNDecimal(result.percentage, 2)}%
|
{convertFloatToNDecimal(result.percentage, 2)}%
|
||||||
|
|||||||
+3
-4
@@ -116,7 +116,7 @@ export const RatingSummary = ({ elementSummary, survey, setFilter }: RatingSumma
|
|||||||
)
|
)
|
||||||
}>
|
}>
|
||||||
<div
|
<div
|
||||||
className={`bg-brand-dark h-full ${isFirst ? "rounded-tl-lg" : ""} ${isLast ? "rounded-tr-lg" : ""}`}
|
className={`h-full bg-brand-dark ${isFirst ? "rounded-tl-lg" : ""} ${isLast ? "rounded-tr-lg" : ""}`}
|
||||||
style={{ opacity }}
|
style={{ opacity }}
|
||||||
/>
|
/>
|
||||||
</ClickableBarSegment>
|
</ClickableBarSegment>
|
||||||
@@ -198,7 +198,7 @@ export const RatingSummary = ({ elementSummary, survey, setFilter }: RatingSumma
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<p className="flex w-32 items-end justify-end text-slate-600">
|
<p className="flex w-32 items-end justify-end text-slate-600">
|
||||||
{result.count} {result.count === 1 ? t("common.response") : t("common.responses")}
|
{t("common.count_responses", { count: result.count })}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<ProgressBar barColor="bg-brand-dark" progress={result.percentage / 100} />
|
<ProgressBar barColor="bg-brand-dark" progress={result.percentage / 100} />
|
||||||
@@ -215,8 +215,7 @@ export const RatingSummary = ({ elementSummary, survey, setFilter }: RatingSumma
|
|||||||
<div className="text flex justify-between px-2">
|
<div className="text flex justify-between px-2">
|
||||||
<p className="font-semibold text-slate-700">{t("common.dismissed")}</p>
|
<p className="font-semibold text-slate-700">{t("common.dismissed")}</p>
|
||||||
<p className="flex w-32 items-end justify-end text-slate-600">
|
<p className="flex w-32 items-end justify-end text-slate-600">
|
||||||
{elementSummary.dismissed.count}{" "}
|
{t("common.count_responses", { count: elementSummary.dismissed.count })}
|
||||||
{elementSummary.dismissed.count === 1 ? t("common.response") : t("common.responses")}
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
+125
@@ -0,0 +1,125 @@
|
|||||||
|
"use client";
|
||||||
|
|
||||||
|
import { AlertCircleIcon, InfoIcon } from "lucide-react";
|
||||||
|
import Link from "next/link";
|
||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { TDisplayWithContact } from "@formbricks/types/displays";
|
||||||
|
import { TUserLocale } from "@formbricks/types/user";
|
||||||
|
import { timeSince } from "@/lib/time";
|
||||||
|
import { Button } from "@/modules/ui/components/button";
|
||||||
|
|
||||||
|
interface SummaryImpressionsProps {
|
||||||
|
displays: TDisplayWithContact[];
|
||||||
|
isLoading: boolean;
|
||||||
|
hasMore: boolean;
|
||||||
|
displaysError: string | null;
|
||||||
|
environmentId: string;
|
||||||
|
locale: TUserLocale;
|
||||||
|
onLoadMore: () => void;
|
||||||
|
onRetry: () => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
const getDisplayContactIdentifier = (display: TDisplayWithContact): string => {
|
||||||
|
if (!display.contact) return "";
|
||||||
|
return display.contact.attributes?.email || display.contact.attributes?.userId || display.contact.id;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const SummaryImpressions = ({
|
||||||
|
displays,
|
||||||
|
isLoading,
|
||||||
|
hasMore,
|
||||||
|
displaysError,
|
||||||
|
environmentId,
|
||||||
|
locale,
|
||||||
|
onLoadMore,
|
||||||
|
onRetry,
|
||||||
|
}: SummaryImpressionsProps) => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const renderContent = () => {
|
||||||
|
if (displaysError) {
|
||||||
|
return (
|
||||||
|
<div className="p-8">
|
||||||
|
<div className="flex flex-col items-center gap-4 text-center">
|
||||||
|
<div className="flex items-center gap-2 text-red-600">
|
||||||
|
<AlertCircleIcon className="h-5 w-5" />
|
||||||
|
<span className="text-sm font-medium">{t("common.error_loading_data")}</span>
|
||||||
|
</div>
|
||||||
|
<p className="text-sm text-slate-500">{displaysError}</p>
|
||||||
|
<Button onClick={onRetry} variant="secondary" size="sm">
|
||||||
|
{t("common.try_again")}
|
||||||
|
</Button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (displays.length === 0) {
|
||||||
|
return (
|
||||||
|
<div className="p-8 text-center text-sm text-slate-500">
|
||||||
|
{t("environments.surveys.summary.no_identified_impressions")}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div className="grid min-h-10 grid-cols-4 items-center border-b border-slate-200 bg-slate-100 text-sm font-semibold text-slate-600">
|
||||||
|
<div className="col-span-2 px-4 md:px-6">{t("common.user")}</div>
|
||||||
|
<div className="col-span-2 px-4 md:px-6">{t("environments.contacts.survey_viewed_at")}</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div className="max-h-[62vh] overflow-y-auto">
|
||||||
|
{displays.map((display) => (
|
||||||
|
<div
|
||||||
|
key={display.id}
|
||||||
|
className="grid grid-cols-4 items-center border-b border-slate-100 py-2 text-xs text-slate-800 last:border-transparent md:text-sm">
|
||||||
|
<div className="col-span-2 pl-4 md:pl-6">
|
||||||
|
{display.contact ? (
|
||||||
|
<Link
|
||||||
|
className="ph-no-capture break-all text-slate-600 hover:underline"
|
||||||
|
href={`/environments/${environmentId}/contacts/${display.contact.id}`}>
|
||||||
|
{getDisplayContactIdentifier(display)}
|
||||||
|
</Link>
|
||||||
|
) : (
|
||||||
|
<span className="break-all text-slate-600">{t("common.anonymous")}</span>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
<div className="col-span-2 px-4 text-slate-500 md:px-6">
|
||||||
|
{timeSince(display.createdAt.toString(), locale)}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{hasMore && (
|
||||||
|
<div className="flex justify-center border-t border-slate-100 py-4">
|
||||||
|
<Button onClick={onLoadMore} variant="secondary" size="sm">
|
||||||
|
{t("common.load_more")}
|
||||||
|
</Button>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (isLoading) {
|
||||||
|
return (
|
||||||
|
<div className="rounded-xl border border-slate-200 bg-white p-8 shadow-sm">
|
||||||
|
<div className="flex items-center justify-center">
|
||||||
|
<div className="h-6 w-32 animate-pulse rounded-full bg-slate-200"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="rounded-xl border border-slate-200 bg-white shadow-sm">
|
||||||
|
<div className="flex items-center gap-2 rounded-t-xl border-b border-slate-200 bg-slate-50 px-4 py-3 text-sm text-slate-600">
|
||||||
|
<InfoIcon className="h-4 w-4 shrink-0" />
|
||||||
|
<span>{t("environments.surveys.summary.impressions_identified_only")}</span>
|
||||||
|
</div>
|
||||||
|
{renderContent()}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
+8
-4
@@ -10,8 +10,8 @@ interface SummaryMetadataProps {
|
|||||||
surveySummary: TSurveySummary["meta"];
|
surveySummary: TSurveySummary["meta"];
|
||||||
quotasCount: number;
|
quotasCount: number;
|
||||||
isLoading: boolean;
|
isLoading: boolean;
|
||||||
tab: "dropOffs" | "quotas" | undefined;
|
tab: "dropOffs" | "quotas" | "impressions" | undefined;
|
||||||
setTab: React.Dispatch<React.SetStateAction<"dropOffs" | "quotas" | undefined>>;
|
setTab: React.Dispatch<React.SetStateAction<"dropOffs" | "quotas" | "impressions" | undefined>>;
|
||||||
isQuotasAllowed: boolean;
|
isQuotasAllowed: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -53,7 +53,7 @@ export const SummaryMetadata = ({
|
|||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const dropoffCountValue = dropOffCount === 0 ? <span>-</span> : dropOffCount;
|
const dropoffCountValue = dropOffCount === 0 ? <span>-</span> : dropOffCount;
|
||||||
|
|
||||||
const handleTabChange = (val: "dropOffs" | "quotas") => {
|
const handleTabChange = (val: "dropOffs" | "quotas" | "impressions") => {
|
||||||
const change = tab === val ? undefined : val;
|
const change = tab === val ? undefined : val;
|
||||||
setTab(change);
|
setTab(change);
|
||||||
};
|
};
|
||||||
@@ -65,12 +65,16 @@ export const SummaryMetadata = ({
|
|||||||
`grid gap-4 sm:grid-cols-2 md:grid-cols-3 md:gap-x-2 lg:grid-cols-3 2xl:grid-cols-5`,
|
`grid gap-4 sm:grid-cols-2 md:grid-cols-3 md:gap-x-2 lg:grid-cols-3 2xl:grid-cols-5`,
|
||||||
isQuotasAllowed && quotasCount > 0 && "2xl:grid-cols-6"
|
isQuotasAllowed && quotasCount > 0 && "2xl:grid-cols-6"
|
||||||
)}>
|
)}>
|
||||||
<StatCard
|
<InteractiveCard
|
||||||
|
key="impressions"
|
||||||
|
tab="impressions"
|
||||||
label={t("environments.surveys.summary.impressions")}
|
label={t("environments.surveys.summary.impressions")}
|
||||||
percentage={null}
|
percentage={null}
|
||||||
value={displayCount === 0 ? <span>-</span> : displayCount}
|
value={displayCount === 0 ? <span>-</span> : displayCount}
|
||||||
tooltipText={t("environments.surveys.summary.impressions_tooltip")}
|
tooltipText={t("environments.surveys.summary.impressions_tooltip")}
|
||||||
isLoading={isLoading}
|
isLoading={isLoading}
|
||||||
|
onClick={() => handleTabChange("impressions")}
|
||||||
|
isActive={tab === "impressions"}
|
||||||
/>
|
/>
|
||||||
<StatCard
|
<StatCard
|
||||||
label={t("environments.surveys.summary.starts")}
|
label={t("environments.surveys.summary.starts")}
|
||||||
|
|||||||
+84
-3
@@ -1,21 +1,31 @@
|
|||||||
"use client";
|
"use client";
|
||||||
|
|
||||||
import { useSearchParams } from "next/navigation";
|
import { useSearchParams } from "next/navigation";
|
||||||
import { useEffect, useMemo, useState } from "react";
|
import { useCallback, useEffect, useMemo, useRef, useState } from "react";
|
||||||
|
import toast from "react-hot-toast";
|
||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { TDisplayWithContact } from "@formbricks/types/displays";
|
||||||
import { TEnvironment } from "@formbricks/types/environment";
|
import { TEnvironment } from "@formbricks/types/environment";
|
||||||
import { TSurvey, TSurveySummary } from "@formbricks/types/surveys/types";
|
import { TSurvey, TSurveySummary } from "@formbricks/types/surveys/types";
|
||||||
import { TUserLocale } from "@formbricks/types/user";
|
import { TUserLocale } from "@formbricks/types/user";
|
||||||
import { getSurveySummaryAction } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/actions";
|
import {
|
||||||
|
getDisplaysWithContactAction,
|
||||||
|
getSurveySummaryAction,
|
||||||
|
} from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/actions";
|
||||||
import { useResponseFilter } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/components/response-filter-context";
|
import { useResponseFilter } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/components/response-filter-context";
|
||||||
import ScrollToTop from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/ScrollToTop";
|
import ScrollToTop from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/ScrollToTop";
|
||||||
import { SummaryDropOffs } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/SummaryDropOffs";
|
import { SummaryDropOffs } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/SummaryDropOffs";
|
||||||
|
import { SummaryImpressions } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/SummaryImpressions";
|
||||||
import { CustomFilter } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/components/CustomFilter";
|
import { CustomFilter } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/components/CustomFilter";
|
||||||
import { getFormattedFilters } from "@/app/lib/surveys/surveys";
|
import { getFormattedFilters } from "@/app/lib/surveys/surveys";
|
||||||
|
import { getFormattedErrorMessage } from "@/lib/utils/helper";
|
||||||
import { replaceHeadlineRecall } from "@/lib/utils/recall";
|
import { replaceHeadlineRecall } from "@/lib/utils/recall";
|
||||||
import { QuotasSummary } from "@/modules/ee/quotas/components/quotas-summary";
|
import { QuotasSummary } from "@/modules/ee/quotas/components/quotas-summary";
|
||||||
import { SummaryList } from "./SummaryList";
|
import { SummaryList } from "./SummaryList";
|
||||||
import { SummaryMetadata } from "./SummaryMetadata";
|
import { SummaryMetadata } from "./SummaryMetadata";
|
||||||
|
|
||||||
|
const DISPLAYS_PER_PAGE = 15;
|
||||||
|
|
||||||
const defaultSurveySummary: TSurveySummary = {
|
const defaultSurveySummary: TSurveySummary = {
|
||||||
meta: {
|
meta: {
|
||||||
completedPercentage: 0,
|
completedPercentage: 0,
|
||||||
@@ -51,17 +61,76 @@ export const SummaryPage = ({
|
|||||||
initialSurveySummary,
|
initialSurveySummary,
|
||||||
isQuotasAllowed,
|
isQuotasAllowed,
|
||||||
}: SummaryPageProps) => {
|
}: SummaryPageProps) => {
|
||||||
|
const { t } = useTranslation();
|
||||||
const searchParams = useSearchParams();
|
const searchParams = useSearchParams();
|
||||||
|
|
||||||
const [surveySummary, setSurveySummary] = useState<TSurveySummary>(
|
const [surveySummary, setSurveySummary] = useState<TSurveySummary>(
|
||||||
initialSurveySummary || defaultSurveySummary
|
initialSurveySummary || defaultSurveySummary
|
||||||
);
|
);
|
||||||
|
|
||||||
const [tab, setTab] = useState<"dropOffs" | "quotas" | undefined>(undefined);
|
const [tab, setTab] = useState<"dropOffs" | "quotas" | "impressions" | undefined>(undefined);
|
||||||
const [isLoading, setIsLoading] = useState(!initialSurveySummary);
|
const [isLoading, setIsLoading] = useState(!initialSurveySummary);
|
||||||
|
|
||||||
const { selectedFilter, dateRange, resetState } = useResponseFilter();
|
const { selectedFilter, dateRange, resetState } = useResponseFilter();
|
||||||
|
|
||||||
|
const [displays, setDisplays] = useState<TDisplayWithContact[]>([]);
|
||||||
|
const [isDisplaysLoading, setIsDisplaysLoading] = useState(false);
|
||||||
|
const [hasMoreDisplays, setHasMoreDisplays] = useState(true);
|
||||||
|
const [displaysError, setDisplaysError] = useState<string | null>(null);
|
||||||
|
const displaysFetchedRef = useRef(false);
|
||||||
|
|
||||||
|
const fetchDisplays = useCallback(
|
||||||
|
async (offset: number) => {
|
||||||
|
const response = await getDisplaysWithContactAction({
|
||||||
|
surveyId,
|
||||||
|
limit: DISPLAYS_PER_PAGE,
|
||||||
|
offset,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!response?.data) {
|
||||||
|
const errorMessage = getFormattedErrorMessage(response);
|
||||||
|
throw new Error(errorMessage);
|
||||||
|
}
|
||||||
|
|
||||||
|
return response?.data ?? [];
|
||||||
|
},
|
||||||
|
[surveyId]
|
||||||
|
);
|
||||||
|
|
||||||
|
const loadInitialDisplays = useCallback(async () => {
|
||||||
|
setIsDisplaysLoading(true);
|
||||||
|
setDisplaysError(null);
|
||||||
|
try {
|
||||||
|
const data = await fetchDisplays(0);
|
||||||
|
setDisplays(data);
|
||||||
|
setHasMoreDisplays(data.length === DISPLAYS_PER_PAGE);
|
||||||
|
} catch (error) {
|
||||||
|
toast.error(error);
|
||||||
|
setDisplays([]);
|
||||||
|
setHasMoreDisplays(false);
|
||||||
|
} finally {
|
||||||
|
setIsDisplaysLoading(false);
|
||||||
|
}
|
||||||
|
}, [fetchDisplays, t]);
|
||||||
|
|
||||||
|
const handleLoadMoreDisplays = useCallback(async () => {
|
||||||
|
try {
|
||||||
|
const data = await fetchDisplays(displays.length);
|
||||||
|
setDisplays((prev) => [...prev, ...data]);
|
||||||
|
setHasMoreDisplays(data.length === DISPLAYS_PER_PAGE);
|
||||||
|
} catch (error) {
|
||||||
|
const errorMessage = error instanceof Error ? error.message : t("common.something_went_wrong");
|
||||||
|
toast.error(errorMessage);
|
||||||
|
}
|
||||||
|
}, [fetchDisplays, displays.length, t]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (tab === "impressions" && !displaysFetchedRef.current) {
|
||||||
|
displaysFetchedRef.current = true;
|
||||||
|
loadInitialDisplays();
|
||||||
|
}
|
||||||
|
}, [tab, loadInitialDisplays]);
|
||||||
|
|
||||||
// Only fetch data when filters change or when there's no initial data
|
// Only fetch data when filters change or when there's no initial data
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
// If we have initial data and no filters are applied, don't fetch
|
// If we have initial data and no filters are applied, don't fetch
|
||||||
@@ -121,6 +190,18 @@ export const SummaryPage = ({
|
|||||||
setTab={setTab}
|
setTab={setTab}
|
||||||
isQuotasAllowed={isQuotasAllowed}
|
isQuotasAllowed={isQuotasAllowed}
|
||||||
/>
|
/>
|
||||||
|
{tab === "impressions" && (
|
||||||
|
<SummaryImpressions
|
||||||
|
displays={displays}
|
||||||
|
isLoading={isDisplaysLoading}
|
||||||
|
hasMore={hasMoreDisplays}
|
||||||
|
displaysError={displaysError}
|
||||||
|
environmentId={environment.id}
|
||||||
|
locale={locale}
|
||||||
|
onLoadMore={handleLoadMoreDisplays}
|
||||||
|
onRetry={loadInitialDisplays}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
{tab === "dropOffs" && <SummaryDropOffs dropOff={surveySummary.dropOff} survey={surveyMemoized} />}
|
{tab === "dropOffs" && <SummaryDropOffs dropOff={surveySummary.dropOff} survey={surveyMemoized} />}
|
||||||
{isQuotasAllowed && tab === "quotas" && <QuotasSummary quotas={surveySummary.quotas} />}
|
{isQuotasAllowed && tab === "quotas" && <QuotasSummary quotas={surveySummary.quotas} />}
|
||||||
<div className="flex gap-1.5">
|
<div className="flex gap-1.5">
|
||||||
|
|||||||
+2
-2
@@ -4,9 +4,9 @@ import { ChevronDownIcon, ChevronUpIcon } from "lucide-react";
|
|||||||
import { BaseCard } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/base-card";
|
import { BaseCard } from "@/app/(app)/environments/[environmentId]/surveys/[surveyId]/(analysis)/summary/components/base-card";
|
||||||
|
|
||||||
interface InteractiveCardProps {
|
interface InteractiveCardProps {
|
||||||
tab: "dropOffs" | "quotas";
|
tab: "dropOffs" | "quotas" | "impressions";
|
||||||
label: string;
|
label: string;
|
||||||
percentage: number;
|
percentage: number | null;
|
||||||
value: React.ReactNode;
|
value: React.ReactNode;
|
||||||
tooltipText: string;
|
tooltipText: string;
|
||||||
isLoading: boolean;
|
isLoading: boolean;
|
||||||
|
|||||||
+1
-1
@@ -352,7 +352,7 @@ export const AnonymousLinksTab = ({
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: t("environments.surveys.share.anonymous_links.custom_start_point"),
|
title: t("environments.surveys.share.anonymous_links.custom_start_point"),
|
||||||
href: "https://formbricks.com/docs/xm-and-surveys/surveys/link-surveys/start-at-question",
|
href: "https://formbricks.com/docs/xm-and-surveys/surveys/link-surveys/start-at-block",
|
||||||
},
|
},
|
||||||
]}
|
]}
|
||||||
/>
|
/>
|
||||||
|
|||||||
+2
-2
@@ -105,7 +105,7 @@ export const CustomHtmlTab = ({ projectCustomScripts, isReadOnly }: CustomHtmlTa
|
|||||||
<div className={scriptsMode === "replace" ? "opacity-50" : ""}>
|
<div className={scriptsMode === "replace" ? "opacity-50" : ""}>
|
||||||
<FormLabel>{t("environments.surveys.share.custom_html.workspace_scripts_label")}</FormLabel>
|
<FormLabel>{t("environments.surveys.share.custom_html.workspace_scripts_label")}</FormLabel>
|
||||||
<div className="mt-2 max-h-32 overflow-auto rounded-md border border-slate-200 bg-slate-50 p-3">
|
<div className="mt-2 max-h-32 overflow-auto rounded-md border border-slate-200 bg-slate-50 p-3">
|
||||||
<pre className="font-mono text-xs whitespace-pre-wrap text-slate-600">
|
<pre className="whitespace-pre-wrap font-mono text-xs text-slate-600">
|
||||||
{projectCustomScripts}
|
{projectCustomScripts}
|
||||||
</pre>
|
</pre>
|
||||||
</div>
|
</div>
|
||||||
@@ -135,7 +135,7 @@ export const CustomHtmlTab = ({ projectCustomScripts, isReadOnly }: CustomHtmlTa
|
|||||||
rows={8}
|
rows={8}
|
||||||
placeholder={t("environments.surveys.share.custom_html.placeholder")}
|
placeholder={t("environments.surveys.share.custom_html.placeholder")}
|
||||||
className={cn(
|
className={cn(
|
||||||
"focus:border-brand-dark flex w-full rounded-md border border-slate-300 bg-white px-3 py-2 font-mono text-xs text-slate-800 placeholder:text-slate-400 focus:ring-2 focus:ring-slate-400 focus:ring-offset-2 focus:outline-none disabled:cursor-not-allowed disabled:opacity-50"
|
"flex w-full rounded-md border border-slate-300 bg-white px-3 py-2 font-mono text-xs text-slate-800 placeholder:text-slate-400 focus:border-brand-dark focus:outline-none focus:ring-2 focus:ring-slate-400 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50"
|
||||||
)}
|
)}
|
||||||
{...field}
|
{...field}
|
||||||
disabled={isReadOnly}
|
disabled={isReadOnly}
|
||||||
|
|||||||
+1
-1
@@ -66,7 +66,7 @@ export const SuccessView: React.FC<SuccessViewProps> = ({
|
|||||||
className="relative flex flex-col items-center gap-3 rounded-lg border border-slate-100 bg-white p-4 text-center text-sm text-slate-900 hover:border-slate-200 md:p-8">
|
className="relative flex flex-col items-center gap-3 rounded-lg border border-slate-100 bg-white p-4 text-center text-sm text-slate-900 hover:border-slate-200 md:p-8">
|
||||||
<UserIcon className="h-8 w-8 stroke-1 text-slate-900" />
|
<UserIcon className="h-8 w-8 stroke-1 text-slate-900" />
|
||||||
{t("environments.surveys.summary.use_personal_links")}
|
{t("environments.surveys.summary.use_personal_links")}
|
||||||
<Badge size="normal" type="success" className="absolute top-3 right-3" text={t("common.new")} />
|
<Badge size="normal" type="success" className="absolute right-3 top-3" text={t("common.new")} />
|
||||||
</button>
|
</button>
|
||||||
<Link
|
<Link
|
||||||
href={`/environments/${environmentId}/settings/notifications`}
|
href={`/environments/${environmentId}/settings/notifications`}
|
||||||
|
|||||||
+1
-1
@@ -192,7 +192,7 @@ export const ElementsComboBox = ({ options, selected, onChangeValue }: ElementCo
|
|||||||
value={inputValue}
|
value={inputValue}
|
||||||
onValueChange={setInputValue}
|
onValueChange={setInputValue}
|
||||||
placeholder={open ? `${t("common.search")}...` : t("common.select_filter")}
|
placeholder={open ? `${t("common.search")}...` : t("common.select_filter")}
|
||||||
className="max-w-full grow border-none p-0 pl-2 text-sm shadow-none ring-offset-transparent outline-none focus:border-none focus:shadow-none focus:ring-offset-0 focus:outline-none"
|
className="max-w-full grow border-none p-0 pl-2 text-sm shadow-none outline-none ring-offset-transparent focus:border-none focus:shadow-none focus:outline-none focus:ring-offset-0"
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
<Button
|
<Button
|
||||||
|
|||||||
+2
-2
@@ -241,7 +241,7 @@ export const ResponseFilter = ({ survey }: ResponseFilterProps) => {
|
|||||||
<Popover open={isOpen} onOpenChange={handleOpenChange}>
|
<Popover open={isOpen} onOpenChange={handleOpenChange}>
|
||||||
<PopoverTrigger asChild>
|
<PopoverTrigger asChild>
|
||||||
<PopoverTriggerButton isOpen={isOpen}>
|
<PopoverTriggerButton isOpen={isOpen}>
|
||||||
Filter <b>{activeFilterCount > 0 && `(${activeFilterCount})`}</b>
|
{t("common.filter")} <b>{activeFilterCount > 0 && `(${activeFilterCount})`}</b>
|
||||||
</PopoverTriggerButton>
|
</PopoverTriggerButton>
|
||||||
</PopoverTrigger>
|
</PopoverTrigger>
|
||||||
<PopoverContent
|
<PopoverContent
|
||||||
@@ -329,7 +329,7 @@ export const ResponseFilter = ({ survey }: ResponseFilterProps) => {
|
|||||||
</div>
|
</div>
|
||||||
{i !== filterValue.filter.length - 1 && (
|
{i !== filterValue.filter.length - 1 && (
|
||||||
<div className="my-4 flex items-center">
|
<div className="my-4 flex items-center">
|
||||||
<p className="mr-4 font-semibold text-slate-800">and</p>
|
<p className="mr-4 font-semibold text-slate-800">{t("common.and")}</p>
|
||||||
<hr className="w-full text-slate-600" />
|
<hr className="w-full text-slate-600" />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|||||||
+2
-2
@@ -10,7 +10,7 @@ const Loading = () => {
|
|||||||
<div className="mt-6 p-6">
|
<div className="mt-6 p-6">
|
||||||
<GoBackButton />
|
<GoBackButton />
|
||||||
<div className="mb-6 text-right">
|
<div className="mb-6 text-right">
|
||||||
<Button className="pointer-events-none animate-pulse cursor-not-allowed bg-slate-200 select-none">
|
<Button className="pointer-events-none animate-pulse cursor-not-allowed select-none bg-slate-200">
|
||||||
{t("environments.integrations.google_sheets.link_new_sheet")}
|
{t("environments.integrations.google_sheets.link_new_sheet")}
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
@@ -51,7 +51,7 @@ const Loading = () => {
|
|||||||
<div className="mt-0 h-4 w-24 animate-pulse rounded-full bg-slate-200"></div>
|
<div className="mt-0 h-4 w-24 animate-pulse rounded-full bg-slate-200"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="col-span-2 my-auto flex items-center justify-center text-center text-sm whitespace-nowrap text-slate-500">
|
<div className="col-span-2 my-auto flex items-center justify-center whitespace-nowrap text-center text-sm text-slate-500">
|
||||||
<div className="h-4 w-16 animate-pulse rounded-full bg-slate-200"></div>
|
<div className="h-4 w-16 animate-pulse rounded-full bg-slate-200"></div>
|
||||||
</div>
|
</div>
|
||||||
<div className="text-center"></div>
|
<div className="text-center"></div>
|
||||||
|
|||||||
+2
-2
@@ -10,7 +10,7 @@ const Loading = () => {
|
|||||||
<div className="mt-6 p-6">
|
<div className="mt-6 p-6">
|
||||||
<GoBackButton />
|
<GoBackButton />
|
||||||
<div className="mb-6 text-right">
|
<div className="mb-6 text-right">
|
||||||
<Button className="pointer-events-none animate-pulse cursor-not-allowed bg-slate-200 select-none">
|
<Button className="pointer-events-none animate-pulse cursor-not-allowed select-none bg-slate-200">
|
||||||
{t("environments.integrations.notion.link_database")}
|
{t("environments.integrations.notion.link_database")}
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
@@ -48,7 +48,7 @@ const Loading = () => {
|
|||||||
<div className="mt-0 h-4 w-24 animate-pulse rounded-full bg-slate-200"></div>
|
<div className="mt-0 h-4 w-24 animate-pulse rounded-full bg-slate-200"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="col-span-2 my-auto flex items-center justify-center text-center text-sm whitespace-nowrap text-slate-500">
|
<div className="col-span-2 my-auto flex items-center justify-center whitespace-nowrap text-center text-sm text-slate-500">
|
||||||
<div className="h-4 w-16 animate-pulse rounded-full bg-slate-200"></div>
|
<div className="h-4 w-16 animate-pulse rounded-full bg-slate-200"></div>
|
||||||
</div>
|
</div>
|
||||||
<div className="text-center"></div>
|
<div className="text-center"></div>
|
||||||
|
|||||||
@@ -6,140 +6,138 @@ export const GET = async (req: NextRequest) => {
|
|||||||
let brandColor = req.nextUrl.searchParams.get("brandColor");
|
let brandColor = req.nextUrl.searchParams.get("brandColor");
|
||||||
|
|
||||||
return new ImageResponse(
|
return new ImageResponse(
|
||||||
(
|
<div
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "column",
|
||||||
|
width: "100%",
|
||||||
|
height: "100%",
|
||||||
|
alignItems: "center",
|
||||||
|
backgroundColor: brandColor ? brandColor + "BF" : "#0000BFBF", // /75 opacity is approximately BF in hex
|
||||||
|
borderRadius: "0.75rem",
|
||||||
|
}}>
|
||||||
<div
|
<div
|
||||||
style={{
|
style={{
|
||||||
display: "flex",
|
display: "flex",
|
||||||
flexDirection: "column",
|
flexDirection: "column",
|
||||||
width: "100%",
|
width: "80%",
|
||||||
height: "100%",
|
height: "60%",
|
||||||
alignItems: "center",
|
backgroundColor: "white",
|
||||||
backgroundColor: brandColor ? brandColor + "BF" : "#0000BFBF", // /75 opacity is approximately BF in hex
|
|
||||||
borderRadius: "0.75rem",
|
borderRadius: "0.75rem",
|
||||||
|
marginTop: "3.25rem",
|
||||||
|
position: "absolute",
|
||||||
|
left: "3rem",
|
||||||
|
top: "0.75rem",
|
||||||
|
opacity: 0.2,
|
||||||
|
transform: "rotate(356deg)",
|
||||||
|
}}></div>
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "column",
|
||||||
|
width: "84%",
|
||||||
|
height: "60%",
|
||||||
|
backgroundColor: "white",
|
||||||
|
borderRadius: "0.75rem",
|
||||||
|
marginTop: "3rem",
|
||||||
|
position: "absolute",
|
||||||
|
top: "1.25rem",
|
||||||
|
left: "3.25rem",
|
||||||
|
borderWidth: "2px",
|
||||||
|
opacity: 0.6,
|
||||||
|
transform: "rotate(357deg)",
|
||||||
|
}}></div>
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "column",
|
||||||
|
width: "85%",
|
||||||
|
height: "67%",
|
||||||
|
alignItems: "center",
|
||||||
|
backgroundColor: "white",
|
||||||
|
borderRadius: "0.75rem",
|
||||||
|
marginTop: "2rem",
|
||||||
|
position: "absolute",
|
||||||
|
top: "2.3rem",
|
||||||
|
left: "3.5rem",
|
||||||
|
transform: "rotate(360deg)",
|
||||||
}}>
|
}}>
|
||||||
<div
|
<div style={{ display: "flex", flexDirection: "column", width: "100%" }}>
|
||||||
style={{
|
<div
|
||||||
display: "flex",
|
style={{
|
||||||
flexDirection: "column",
|
display: "flex",
|
||||||
width: "80%",
|
flexDirection: "column",
|
||||||
height: "60%",
|
width: "100%",
|
||||||
backgroundColor: "white",
|
justifyContent: "space-between",
|
||||||
borderRadius: "0.75rem",
|
}}>
|
||||||
marginTop: "3.25rem",
|
|
||||||
position: "absolute",
|
|
||||||
left: "3rem",
|
|
||||||
top: "0.75rem",
|
|
||||||
opacity: 0.2,
|
|
||||||
transform: "rotate(356deg)",
|
|
||||||
}}></div>
|
|
||||||
<div
|
|
||||||
style={{
|
|
||||||
display: "flex",
|
|
||||||
flexDirection: "column",
|
|
||||||
width: "84%",
|
|
||||||
height: "60%",
|
|
||||||
backgroundColor: "white",
|
|
||||||
borderRadius: "0.75rem",
|
|
||||||
marginTop: "3rem",
|
|
||||||
position: "absolute",
|
|
||||||
top: "1.25rem",
|
|
||||||
left: "3.25rem",
|
|
||||||
borderWidth: "2px",
|
|
||||||
opacity: 0.6,
|
|
||||||
transform: "rotate(357deg)",
|
|
||||||
}}></div>
|
|
||||||
<div
|
|
||||||
style={{
|
|
||||||
display: "flex",
|
|
||||||
flexDirection: "column",
|
|
||||||
width: "85%",
|
|
||||||
height: "67%",
|
|
||||||
alignItems: "center",
|
|
||||||
backgroundColor: "white",
|
|
||||||
borderRadius: "0.75rem",
|
|
||||||
marginTop: "2rem",
|
|
||||||
position: "absolute",
|
|
||||||
top: "2.3rem",
|
|
||||||
left: "3.5rem",
|
|
||||||
transform: "rotate(360deg)",
|
|
||||||
}}>
|
|
||||||
<div style={{ display: "flex", flexDirection: "column", width: "100%" }}>
|
|
||||||
<div
|
<div
|
||||||
style={{
|
style={{
|
||||||
display: "flex",
|
display: "flex",
|
||||||
flexDirection: "column",
|
flexDirection: "column",
|
||||||
width: "100%",
|
paddingLeft: "2rem",
|
||||||
justifyContent: "space-between",
|
paddingRight: "2rem",
|
||||||
|
}}>
|
||||||
|
<h2
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "column",
|
||||||
|
fontSize: "2rem",
|
||||||
|
fontWeight: "700",
|
||||||
|
letterSpacing: "-0.025em",
|
||||||
|
color: "#0f172a",
|
||||||
|
textAlign: "left",
|
||||||
|
marginTop: "3.75rem",
|
||||||
|
}}>
|
||||||
|
{name}
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div style={{ display: "flex", justifyContent: "flex-end", marginRight: "2.5rem" }}>
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
borderRadius: "1rem",
|
||||||
|
position: "absolute",
|
||||||
|
right: "-0.5rem",
|
||||||
|
marginTop: "0.5rem",
|
||||||
|
}}>
|
||||||
|
<div
|
||||||
|
content=""
|
||||||
|
style={{
|
||||||
|
borderRadius: "0.75rem",
|
||||||
|
border: "1px solid transparent",
|
||||||
|
backgroundColor: brandColor ?? "#000",
|
||||||
|
height: "4.5rem",
|
||||||
|
width: "9.5rem",
|
||||||
|
opacity: 0.5,
|
||||||
|
}}></div>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
borderRadius: "1rem",
|
||||||
|
boxShadow: "0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1)",
|
||||||
}}>
|
}}>
|
||||||
<div
|
<div
|
||||||
style={{
|
style={{
|
||||||
display: "flex",
|
display: "flex",
|
||||||
flexDirection: "column",
|
alignItems: "center",
|
||||||
paddingLeft: "2rem",
|
justifyContent: "center",
|
||||||
paddingRight: "2rem",
|
borderRadius: "0.75rem",
|
||||||
|
border: "1px solid transparent",
|
||||||
|
backgroundColor: brandColor ?? "#000",
|
||||||
|
fontSize: "1.5rem",
|
||||||
|
color: "white",
|
||||||
|
height: "4.5rem",
|
||||||
|
width: "9.5rem",
|
||||||
}}>
|
}}>
|
||||||
<h2
|
Begin!
|
||||||
style={{
|
|
||||||
display: "flex",
|
|
||||||
flexDirection: "column",
|
|
||||||
fontSize: "2rem",
|
|
||||||
fontWeight: "700",
|
|
||||||
letterSpacing: "-0.025em",
|
|
||||||
color: "#0f172a",
|
|
||||||
textAlign: "left",
|
|
||||||
marginTop: "3.75rem",
|
|
||||||
}}>
|
|
||||||
{name}
|
|
||||||
</h2>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div style={{ display: "flex", justifyContent: "flex-end", marginRight: "2.5rem" }}>
|
|
||||||
<div
|
|
||||||
style={{
|
|
||||||
display: "flex",
|
|
||||||
borderRadius: "1rem",
|
|
||||||
position: "absolute",
|
|
||||||
right: "-0.5rem",
|
|
||||||
marginTop: "0.5rem",
|
|
||||||
}}>
|
|
||||||
<div
|
|
||||||
content=""
|
|
||||||
style={{
|
|
||||||
borderRadius: "0.75rem",
|
|
||||||
border: "1px solid transparent",
|
|
||||||
backgroundColor: brandColor ?? "#000",
|
|
||||||
height: "4.5rem",
|
|
||||||
width: "9.5rem",
|
|
||||||
opacity: 0.5,
|
|
||||||
}}></div>
|
|
||||||
</div>
|
|
||||||
<div
|
|
||||||
style={{
|
|
||||||
display: "flex",
|
|
||||||
borderRadius: "1rem",
|
|
||||||
boxShadow: "0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1)",
|
|
||||||
}}>
|
|
||||||
<div
|
|
||||||
style={{
|
|
||||||
display: "flex",
|
|
||||||
alignItems: "center",
|
|
||||||
justifyContent: "center",
|
|
||||||
borderRadius: "0.75rem",
|
|
||||||
border: "1px solid transparent",
|
|
||||||
backgroundColor: brandColor ?? "#000",
|
|
||||||
fontSize: "1.5rem",
|
|
||||||
color: "white",
|
|
||||||
height: "4.5rem",
|
|
||||||
width: "9.5rem",
|
|
||||||
}}>
|
|
||||||
Begin!
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
),
|
</div>,
|
||||||
{
|
{
|
||||||
width: 800,
|
width: 800,
|
||||||
height: 400,
|
height: 400,
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import {
|
|||||||
} from "@formbricks/types/integration/slack";
|
} from "@formbricks/types/integration/slack";
|
||||||
import { responses } from "@/app/lib/api/response";
|
import { responses } from "@/app/lib/api/response";
|
||||||
import { TSessionAuthentication, withV1ApiWrapper } from "@/app/lib/api/with-api-logging";
|
import { TSessionAuthentication, withV1ApiWrapper } from "@/app/lib/api/with-api-logging";
|
||||||
import { SLACK_CLIENT_ID, SLACK_CLIENT_SECRET, WEBAPP_URL } from "@/lib/constants";
|
import { SLACK_CLIENT_ID, SLACK_CLIENT_SECRET, SLACK_REDIRECT_URI, WEBAPP_URL } from "@/lib/constants";
|
||||||
import { hasUserEnvironmentAccess } from "@/lib/environment/auth";
|
import { hasUserEnvironmentAccess } from "@/lib/environment/auth";
|
||||||
import { createOrUpdateIntegration, getIntegrationByType } from "@/lib/integration/service";
|
import { createOrUpdateIntegration, getIntegrationByType } from "@/lib/integration/service";
|
||||||
|
|
||||||
@@ -56,6 +56,7 @@ export const GET = withV1ApiWrapper({
|
|||||||
code,
|
code,
|
||||||
client_id: SLACK_CLIENT_ID,
|
client_id: SLACK_CLIENT_ID,
|
||||||
client_secret: SLACK_CLIENT_SECRET,
|
client_secret: SLACK_CLIENT_SECRET,
|
||||||
|
redirect_uri: SLACK_REDIRECT_URI,
|
||||||
};
|
};
|
||||||
const formBody: string[] = [];
|
const formBody: string[] = [];
|
||||||
for (const property in formData) {
|
for (const property in formData) {
|
||||||
|
|||||||
@@ -131,13 +131,11 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("logs and audits on error response with API key authentication", async () => {
|
test("logs and audits on error response with API key authentication", async () => {
|
||||||
const { queueAuditEvent: mockedQueueAuditEvent } = (await import(
|
const { queueAuditEvent: mockedQueueAuditEvent } =
|
||||||
"@/modules/ee/audit-logs/lib/handler"
|
(await import("@/modules/ee/audit-logs/lib/handler")) as unknown as { queueAuditEvent: Mock };
|
||||||
)) as unknown as { queueAuditEvent: Mock };
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
||||||
@@ -185,13 +183,11 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("does not log Sentry if not 500", async () => {
|
test("does not log Sentry if not 500", async () => {
|
||||||
const { queueAuditEvent: mockedQueueAuditEvent } = (await import(
|
const { queueAuditEvent: mockedQueueAuditEvent } =
|
||||||
"@/modules/ee/audit-logs/lib/handler"
|
(await import("@/modules/ee/audit-logs/lib/handler")) as unknown as { queueAuditEvent: Mock };
|
||||||
)) as unknown as { queueAuditEvent: Mock };
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
||||||
@@ -233,13 +229,11 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("logs and audits on thrown error", async () => {
|
test("logs and audits on thrown error", async () => {
|
||||||
const { queueAuditEvent: mockedQueueAuditEvent } = (await import(
|
const { queueAuditEvent: mockedQueueAuditEvent } =
|
||||||
"@/modules/ee/audit-logs/lib/handler"
|
(await import("@/modules/ee/audit-logs/lib/handler")) as unknown as { queueAuditEvent: Mock };
|
||||||
)) as unknown as { queueAuditEvent: Mock };
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
||||||
@@ -291,13 +285,11 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("does not log on success response but still audits", async () => {
|
test("does not log on success response but still audits", async () => {
|
||||||
const { queueAuditEvent: mockedQueueAuditEvent } = (await import(
|
const { queueAuditEvent: mockedQueueAuditEvent } =
|
||||||
"@/modules/ee/audit-logs/lib/handler"
|
(await import("@/modules/ee/audit-logs/lib/handler")) as unknown as { queueAuditEvent: Mock };
|
||||||
)) as unknown as { queueAuditEvent: Mock };
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
||||||
@@ -347,13 +339,11 @@ describe("withV1ApiWrapper", () => {
|
|||||||
REDIS_URL: "redis://localhost:6379",
|
REDIS_URL: "redis://localhost:6379",
|
||||||
}));
|
}));
|
||||||
|
|
||||||
const { queueAuditEvent: mockedQueueAuditEvent } = (await import(
|
const { queueAuditEvent: mockedQueueAuditEvent } =
|
||||||
"@/modules/ee/audit-logs/lib/handler"
|
(await import("@/modules/ee/audit-logs/lib/handler")) as unknown as { queueAuditEvent: Mock };
|
||||||
)) as unknown as { queueAuditEvent: Mock };
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
const { withV1ApiWrapper } = await import("./with-api-logging");
|
const { withV1ApiWrapper } = await import("./with-api-logging");
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
@@ -376,9 +366,8 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("handles client-side API routes without authentication", async () => {
|
test("handles client-side API routes without authentication", async () => {
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { applyIPRateLimit } = await import("@/modules/core/rate-limit/helpers");
|
const { applyIPRateLimit } = await import("@/modules/core/rate-limit/helpers");
|
||||||
|
|
||||||
@@ -410,9 +399,8 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("returns authentication error for non-client routes without auth", async () => {
|
test("returns authentication error for non-client routes without auth", async () => {
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
|
|
||||||
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
||||||
@@ -435,9 +423,8 @@ describe("withV1ApiWrapper", () => {
|
|||||||
|
|
||||||
test("handles rate limiting errors", async () => {
|
test("handles rate limiting errors", async () => {
|
||||||
const { applyRateLimit } = await import("@/modules/core/rate-limit/helpers");
|
const { applyRateLimit } = await import("@/modules/core/rate-limit/helpers");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
@@ -462,13 +449,11 @@ describe("withV1ApiWrapper", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("skips audit log creation when no action/targetType provided", async () => {
|
test("skips audit log creation when no action/targetType provided", async () => {
|
||||||
const { queueAuditEvent: mockedQueueAuditEvent } = (await import(
|
const { queueAuditEvent: mockedQueueAuditEvent } =
|
||||||
"@/modules/ee/audit-logs/lib/handler"
|
(await import("@/modules/ee/audit-logs/lib/handler")) as unknown as { queueAuditEvent: Mock };
|
||||||
)) as unknown as { queueAuditEvent: Mock };
|
|
||||||
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
const { authenticateRequest } = await import("@/app/api/v1/auth");
|
||||||
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } = await import(
|
const { isClientSideApiRoute, isManagementApiRoute, isIntegrationRoute } =
|
||||||
"@/app/middleware/endpoint-validator"
|
await import("@/app/middleware/endpoint-validator");
|
||||||
);
|
|
||||||
|
|
||||||
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
vi.mocked(authenticateRequest).mockResolvedValue(mockApiAuthentication);
|
||||||
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
vi.mocked(isClientSideApiRoute).mockReturnValue({ isClientSideApi: false, isRateLimited: true });
|
||||||
|
|||||||
@@ -4854,6 +4854,17 @@ export const previewSurvey = (projectName: string, t: TFunction): TSurvey => {
|
|||||||
}),
|
}),
|
||||||
isDraft: true,
|
isDraft: true,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
...buildOpenTextElement({
|
||||||
|
id: "preview-open-text-01",
|
||||||
|
headline: t("templates.preview_survey_question_open_text_headline"),
|
||||||
|
subheader: t("templates.preview_survey_question_open_text_subheader"),
|
||||||
|
placeholder: t("templates.preview_survey_question_open_text_placeholder"),
|
||||||
|
inputType: "text",
|
||||||
|
required: false,
|
||||||
|
}),
|
||||||
|
isDraft: true,
|
||||||
|
},
|
||||||
],
|
],
|
||||||
buttonLabel: createI18nString(t("templates.next"), []),
|
buttonLabel: createI18nString(t("templates.next"), []),
|
||||||
backButtonLabel: createI18nString(t("templates.preview_survey_question_2_back_button_label"), []),
|
backButtonLabel: createI18nString(t("templates.preview_survey_question_2_back_button_label"), []),
|
||||||
|
|||||||
@@ -313,7 +313,7 @@ describe("endpoint-validator", () => {
|
|||||||
expect(isPublicDomainRoute("/c")).toBe(false);
|
expect(isPublicDomainRoute("/c")).toBe(false);
|
||||||
expect(isPublicDomainRoute("/contact/token")).toBe(false);
|
expect(isPublicDomainRoute("/contact/token")).toBe(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should return true for pretty URL survey routes", () => {
|
test("should return true for pretty URL survey routes", () => {
|
||||||
expect(isPublicDomainRoute("/p/pretty123")).toBe(true);
|
expect(isPublicDomainRoute("/p/pretty123")).toBe(true);
|
||||||
expect(isPublicDomainRoute("/p/pretty-name-with-dashes")).toBe(true);
|
expect(isPublicDomainRoute("/p/pretty-name-with-dashes")).toBe(true);
|
||||||
|
|||||||
+28
-6
@@ -150,7 +150,9 @@ checksums:
|
|||||||
common/copy_link: 57a37acfe6d7ed71d00fbbc8079fbb35
|
common/copy_link: 57a37acfe6d7ed71d00fbbc8079fbb35
|
||||||
common/count_attributes: 042fba9baffef5afe2c24f13d4f50697
|
common/count_attributes: 042fba9baffef5afe2c24f13d4f50697
|
||||||
common/count_contacts: b1c413a4b06961b71b6aeee95d6775d7
|
common/count_contacts: b1c413a4b06961b71b6aeee95d6775d7
|
||||||
|
common/count_members: 8cabb9805075f20e3977b919b3b2fdc5
|
||||||
common/count_responses: 690118a456c01c5b4d437ae82b50b131
|
common/count_responses: 690118a456c01c5b4d437ae82b50b131
|
||||||
|
common/count_selections: c0f581d21468af2f46dad171921f71ba
|
||||||
common/create_new_organization: 51dae7b33143686ee218abf5bea764a5
|
common/create_new_organization: 51dae7b33143686ee218abf5bea764a5
|
||||||
common/create_segment: 9d8291cd4d778b53b73bbc84fd91c181
|
common/create_segment: 9d8291cd4d778b53b73bbc84fd91c181
|
||||||
common/create_survey: 1cfbba08d34876566d84b2960054a987
|
common/create_survey: 1cfbba08d34876566d84b2960054a987
|
||||||
@@ -164,6 +166,7 @@ checksums:
|
|||||||
common/days: c95fe8aedde21a0b5653dbd0b3c58b48
|
common/days: c95fe8aedde21a0b5653dbd0b3c58b48
|
||||||
common/default: d9c6dc5c412fe94143dfd1d332ec81d4
|
common/default: d9c6dc5c412fe94143dfd1d332ec81d4
|
||||||
common/delete: 8bcf303dd10a645b5baacb02b47d72c9
|
common/delete: 8bcf303dd10a645b5baacb02b47d72c9
|
||||||
|
common/delete_what: 718ddfcc1dec7f3e8b67856fba838267
|
||||||
common/description: e17686a22ffad04cc7bb70524ed4478b
|
common/description: e17686a22ffad04cc7bb70524ed4478b
|
||||||
common/dev_env: e650911d5e19ba256358e0cda154c005
|
common/dev_env: e650911d5e19ba256358e0cda154c005
|
||||||
common/development: 85211dbb918bda7a6e87649dcfc1b17a
|
common/development: 85211dbb918bda7a6e87649dcfc1b17a
|
||||||
@@ -191,13 +194,16 @@ checksums:
|
|||||||
common/error: 3c95bcb32c2104b99a46f5b3dd015248
|
common/error: 3c95bcb32c2104b99a46f5b3dd015248
|
||||||
common/error_component_description: fa9eee04f864c3fe6e6681f716caa015
|
common/error_component_description: fa9eee04f864c3fe6e6681f716caa015
|
||||||
common/error_component_title: ae68fa341a143aaa13a5ea30dd57a63e
|
common/error_component_title: ae68fa341a143aaa13a5ea30dd57a63e
|
||||||
|
common/error_loading_data: aaeffbfe4a2c2145442a57de524494be
|
||||||
common/error_rate_limit_description: 37791a33a947204662ee9c6544e90f51
|
common/error_rate_limit_description: 37791a33a947204662ee9c6544e90f51
|
||||||
common/error_rate_limit_title: 23ac9419e267e610e1bfd38e1dc35dc0
|
common/error_rate_limit_title: 23ac9419e267e610e1bfd38e1dc35dc0
|
||||||
common/expand_rows: b6e06327cb8718dfd6651720843e4dad
|
common/expand_rows: b6e06327cb8718dfd6651720843e4dad
|
||||||
common/failed_to_copy_to_clipboard: de836a7d628d36c832809252f188f784
|
common/failed_to_copy_to_clipboard: de836a7d628d36c832809252f188f784
|
||||||
common/failed_to_load_organizations: 512808a2b674c7c28bca73f8f91fd87e
|
common/failed_to_load_organizations: 512808a2b674c7c28bca73f8f91fd87e
|
||||||
common/failed_to_load_workspaces: 6ee3448097394517dc605074cd4e6ea4
|
common/failed_to_load_workspaces: 6ee3448097394517dc605074cd4e6ea4
|
||||||
|
common/filter: 626325a05e4c8800f7ede7012b0cadaf
|
||||||
common/finish: ffa7a10f71182b48fefed7135bee24fa
|
common/finish: ffa7a10f71182b48fefed7135bee24fa
|
||||||
|
common/first_name: cf040a5d6a9fd696be400380cc99f54b
|
||||||
common/follow_these: 3a730b242bb17a3f95e01bf0dae86885
|
common/follow_these: 3a730b242bb17a3f95e01bf0dae86885
|
||||||
common/formbricks_version: d9967c797f3e49ca0cae78bc0ebd19cb
|
common/formbricks_version: d9967c797f3e49ca0cae78bc0ebd19cb
|
||||||
common/full_name: f45991923345e8322c9ff8cd6b7e2b16
|
common/full_name: f45991923345e8322c9ff8cd6b7e2b16
|
||||||
@@ -210,6 +216,7 @@ checksums:
|
|||||||
common/hidden_field: 3ed5c58d0ed359e558cdf7bd33606d2d
|
common/hidden_field: 3ed5c58d0ed359e558cdf7bd33606d2d
|
||||||
common/hidden_fields: 3de6cfd308293a826cb8679fd1d49972
|
common/hidden_fields: 3de6cfd308293a826cb8679fd1d49972
|
||||||
common/hide_column: 23ce94db148f2d8e4a0923defead6cf1
|
common/hide_column: 23ce94db148f2d8e4a0923defead6cf1
|
||||||
|
common/id: c8886d38aeea2ed5f785aba4fc96784b
|
||||||
common/image: 048ba7a239de0fbd883ade8558415830
|
common/image: 048ba7a239de0fbd883ade8558415830
|
||||||
common/images: 9305827c28694866f49db42b4c51831f
|
common/images: 9305827c28694866f49db42b4c51831f
|
||||||
common/import: 348b8ab981de5b7f1fca6d7302263bbd
|
common/import: 348b8ab981de5b7f1fca6d7302263bbd
|
||||||
@@ -227,6 +234,7 @@ checksums:
|
|||||||
common/key: 3d1065ab98a1c2f1210507fd5c7bf515
|
common/key: 3d1065ab98a1c2f1210507fd5c7bf515
|
||||||
common/label: a5c71bf158481233f8215dbd38cc196b
|
common/label: a5c71bf158481233f8215dbd38cc196b
|
||||||
common/language: 277fd1a41cc237a437cd1d5e4a80463b
|
common/language: 277fd1a41cc237a437cd1d5e4a80463b
|
||||||
|
common/last_name: 2c9a7de7738ca007ba9023c385149c26
|
||||||
common/learn_more: e598091d132f890c37a6d4ed94f6d794
|
common/learn_more: e598091d132f890c37a6d4ed94f6d794
|
||||||
common/license_expired: 7af13535e320e4197989472c01387d2c
|
common/license_expired: 7af13535e320e4197989472c01387d2c
|
||||||
common/light_overlay: 0499907ea7b8405f4267b117998b5a78
|
common/light_overlay: 0499907ea7b8405f4267b117998b5a78
|
||||||
@@ -253,6 +261,7 @@ checksums:
|
|||||||
common/move_down: 4f4de55743043355ad4a839aff2c48ff
|
common/move_down: 4f4de55743043355ad4a839aff2c48ff
|
||||||
common/move_up: 69f25b205c677abdb26cbb69d97cd10b
|
common/move_up: 69f25b205c677abdb26cbb69d97cd10b
|
||||||
common/multiple_languages: 7d8ddd4b40d32fcd7bd6f7bac6485b1f
|
common/multiple_languages: 7d8ddd4b40d32fcd7bd6f7bac6485b1f
|
||||||
|
common/my_product: ad022177062f9ef6e9acf33b13e889aa
|
||||||
common/name: 9368b5a047572b6051f334af5aa76819
|
common/name: 9368b5a047572b6051f334af5aa76819
|
||||||
common/new: 126d036fae5fb6b629728ecb97e6195b
|
common/new: 126d036fae5fb6b629728ecb97e6195b
|
||||||
common/new_version_available: 399ddfc4232712e18ddab2587356b3dc
|
common/new_version_available: 399ddfc4232712e18ddab2587356b3dc
|
||||||
@@ -401,6 +410,7 @@ checksums:
|
|||||||
common/top_right: 241f95c923846911aaf13af6109333e5
|
common/top_right: 241f95c923846911aaf13af6109333e5
|
||||||
common/try_again: 33dd8820e743e35a66e6977f69e9d3b5
|
common/try_again: 33dd8820e743e35a66e6977f69e9d3b5
|
||||||
common/type: f04471a7ddac844b9ad145eb9911ef75
|
common/type: f04471a7ddac844b9ad145eb9911ef75
|
||||||
|
common/unknown_survey: dd8f6985e17ccf19fac1776e18b2c498
|
||||||
common/unlock_more_workspaces_with_a_higher_plan: fe1590075b855bb4306c9388b65143b0
|
common/unlock_more_workspaces_with_a_higher_plan: fe1590075b855bb4306c9388b65143b0
|
||||||
common/update: 079fc039262fd31b10532929685c2d1b
|
common/update: 079fc039262fd31b10532929685c2d1b
|
||||||
common/updated: 8aa8ff2dc2977ca4b269e80a513100b4
|
common/updated: 8aa8ff2dc2977ca4b269e80a513100b4
|
||||||
@@ -619,6 +629,7 @@ checksums:
|
|||||||
environments/contacts/delete_attribute_confirmation: 01d99b89eb3d27ff468d0db1b4aeb394
|
environments/contacts/delete_attribute_confirmation: 01d99b89eb3d27ff468d0db1b4aeb394
|
||||||
environments/contacts/delete_contact_confirmation: 2d45579e0bb4bc40fb1ee75b43c0e7a4
|
environments/contacts/delete_contact_confirmation: 2d45579e0bb4bc40fb1ee75b43c0e7a4
|
||||||
environments/contacts/delete_contact_confirmation_with_quotas: d3d17f13ae46ce04c126c82bf01299ac
|
environments/contacts/delete_contact_confirmation_with_quotas: d3d17f13ae46ce04c126c82bf01299ac
|
||||||
|
environments/contacts/displays: fcc4527002bd045021882be463b8ac72
|
||||||
environments/contacts/edit_attribute: 92a83c96a5d850e7d39002e8fd5898f4
|
environments/contacts/edit_attribute: 92a83c96a5d850e7d39002e8fd5898f4
|
||||||
environments/contacts/edit_attribute_description: 073a3084bb2f3b34ed1320ed1cd6db3c
|
environments/contacts/edit_attribute_description: 073a3084bb2f3b34ed1320ed1cd6db3c
|
||||||
environments/contacts/edit_attribute_values: 44e4e7a661cc1b59200bb07c710072a7
|
environments/contacts/edit_attribute_values: 44e4e7a661cc1b59200bb07c710072a7
|
||||||
@@ -630,6 +641,7 @@ checksums:
|
|||||||
environments/contacts/invalid_csv_column_names: dcb8534e7d4c00b9ea7bdaf389f72328
|
environments/contacts/invalid_csv_column_names: dcb8534e7d4c00b9ea7bdaf389f72328
|
||||||
environments/contacts/invalid_date_format: 5bad9730ac5a5bacd0792098f712b1c4
|
environments/contacts/invalid_date_format: 5bad9730ac5a5bacd0792098f712b1c4
|
||||||
environments/contacts/invalid_number_format: bd0422507385f671c3046730a6febc64
|
environments/contacts/invalid_number_format: bd0422507385f671c3046730a6febc64
|
||||||
|
environments/contacts/no_activity_yet: f88897ac05afd6bf8af0d4834ad24ffc
|
||||||
environments/contacts/no_published_link_surveys_available: 9c1abc5b21aba827443cdf87dd6c8bfe
|
environments/contacts/no_published_link_surveys_available: 9c1abc5b21aba827443cdf87dd6c8bfe
|
||||||
environments/contacts/no_published_surveys: bd945b0e2e2328c17615c94143bdd62b
|
environments/contacts/no_published_surveys: bd945b0e2e2328c17615c94143bdd62b
|
||||||
environments/contacts/no_responses_found: f10190cffdda4ca1bed479acbb89b13f
|
environments/contacts/no_responses_found: f10190cffdda4ca1bed479acbb89b13f
|
||||||
@@ -644,6 +656,8 @@ checksums:
|
|||||||
environments/contacts/select_a_survey: 1f49086dfb874307aae1136e88c3d514
|
environments/contacts/select_a_survey: 1f49086dfb874307aae1136e88c3d514
|
||||||
environments/contacts/select_attribute: d93fb60eb4fbb42bf13a22f6216fbd79
|
environments/contacts/select_attribute: d93fb60eb4fbb42bf13a22f6216fbd79
|
||||||
environments/contacts/select_attribute_key: 673a6683fab41b387d921841cded7e38
|
environments/contacts/select_attribute_key: 673a6683fab41b387d921841cded7e38
|
||||||
|
environments/contacts/survey_viewed: 646d413218626787b0373ffd71cb7451
|
||||||
|
environments/contacts/survey_viewed_at: 2ab535237af5c3c3f33acc792a7e70a4
|
||||||
environments/contacts/system_attributes: eadb6a8888c7b32c0e68881f945ae9b6
|
environments/contacts/system_attributes: eadb6a8888c7b32c0e68881f945ae9b6
|
||||||
environments/contacts/unlock_contacts_description: c5572047f02b4c39e5109f9de715499d
|
environments/contacts/unlock_contacts_description: c5572047f02b4c39e5109f9de715499d
|
||||||
environments/contacts/unlock_contacts_title: a8b3d7db03eb404d9267fd5cdd6d5ddb
|
environments/contacts/unlock_contacts_title: a8b3d7db03eb404d9267fd5cdd6d5ddb
|
||||||
@@ -1010,7 +1024,7 @@ checksums:
|
|||||||
environments/settings/general/email_customization_preview_email_heading: 8b798cb8438b3dd356c02dab33b4c897
|
environments/settings/general/email_customization_preview_email_heading: 8b798cb8438b3dd356c02dab33b4c897
|
||||||
environments/settings/general/email_customization_preview_email_text: fa6ae92403cc8f3c35c03e6c94cbde51
|
environments/settings/general/email_customization_preview_email_text: fa6ae92403cc8f3c35c03e6c94cbde51
|
||||||
environments/settings/general/error_deleting_organization_please_try_again: 7f0fe257d4a0b40bff025408a7766706
|
environments/settings/general/error_deleting_organization_please_try_again: 7f0fe257d4a0b40bff025408a7766706
|
||||||
environments/settings/general/from_your_organization: 4b7970431edb3d0f13c394dbd755a055
|
environments/settings/general/from_your_organization: 9ebd6dcd79f7bfad3fea46ed2e3133d2
|
||||||
environments/settings/general/invitation_sent_once_more: e6e5ea066810f9dcb65788aa4f05d6e2
|
environments/settings/general/invitation_sent_once_more: e6e5ea066810f9dcb65788aa4f05d6e2
|
||||||
environments/settings/general/invite_deleted_successfully: 1c7dca6d0f6870d945288e38cfd2f943
|
environments/settings/general/invite_deleted_successfully: 1c7dca6d0f6870d945288e38cfd2f943
|
||||||
environments/settings/general/invite_expires_on: 6fd2356ad91a5f189070c43855904bb4
|
environments/settings/general/invite_expires_on: 6fd2356ad91a5f189070c43855904bb4
|
||||||
@@ -1165,6 +1179,7 @@ checksums:
|
|||||||
environments/surveys/edit/add_fallback_placeholder: 0e77ea487ddd7bc7fc2f1574b018dc08
|
environments/surveys/edit/add_fallback_placeholder: 0e77ea487ddd7bc7fc2f1574b018dc08
|
||||||
environments/surveys/edit/add_hidden_field_id: a8f55b51b790cf5f4d898af7770ad1ed
|
environments/surveys/edit/add_hidden_field_id: a8f55b51b790cf5f4d898af7770ad1ed
|
||||||
environments/surveys/edit/add_highlight_border: 66f52b21fbb9aa6561c98a090abaaf8f
|
environments/surveys/edit/add_highlight_border: 66f52b21fbb9aa6561c98a090abaaf8f
|
||||||
|
environments/surveys/edit/add_highlight_border_description: fe548fe03ea10ef5cd9e553d6812b3c2
|
||||||
environments/surveys/edit/add_logic: f234c9f1393a9ed4792dfbd15838c951
|
environments/surveys/edit/add_logic: f234c9f1393a9ed4792dfbd15838c951
|
||||||
environments/surveys/edit/add_none_of_the_above: dbe1ada4512d6c3f80c54c8fac107ec6
|
environments/surveys/edit/add_none_of_the_above: dbe1ada4512d6c3f80c54c8fac107ec6
|
||||||
environments/surveys/edit/add_option: 143c54f0b201067fe5159284d6daeca2
|
environments/surveys/edit/add_option: 143c54f0b201067fe5159284d6daeca2
|
||||||
@@ -1363,7 +1378,6 @@ checksums:
|
|||||||
environments/surveys/edit/follow_ups_modal_updated_successfull_toast: 61204fada3231f4f1fe3866e87e1130a
|
environments/surveys/edit/follow_ups_modal_updated_successfull_toast: 61204fada3231f4f1fe3866e87e1130a
|
||||||
environments/surveys/edit/follow_ups_new: 224c779d252b3e75086e4ed456ba2548
|
environments/surveys/edit/follow_ups_new: 224c779d252b3e75086e4ed456ba2548
|
||||||
environments/surveys/edit/follow_ups_upgrade_button_text: 4cd167527fc6cdb5b0bfc9b486b142a8
|
environments/surveys/edit/follow_ups_upgrade_button_text: 4cd167527fc6cdb5b0bfc9b486b142a8
|
||||||
environments/surveys/edit/form_styling: 1278a2db4257b5500474161133acc857
|
|
||||||
environments/surveys/edit/formbricks_sdk_is_not_connected: 35165b0cac182a98408007a378cc677e
|
environments/surveys/edit/formbricks_sdk_is_not_connected: 35165b0cac182a98408007a378cc677e
|
||||||
environments/surveys/edit/four_points: b289628a6b8a6cd0f7d17a14ca6cd7bf
|
environments/surveys/edit/four_points: b289628a6b8a6cd0f7d17a14ca6cd7bf
|
||||||
environments/surveys/edit/heading: 79e9dfa461f38a239d34b9833ca103f1
|
environments/surveys/edit/heading: 79e9dfa461f38a239d34b9833ca103f1
|
||||||
@@ -1534,7 +1548,7 @@ checksums:
|
|||||||
environments/surveys/edit/response_limits_redirections_and_more: e4f1cf94e56ad0e1b08701158d688802
|
environments/surveys/edit/response_limits_redirections_and_more: e4f1cf94e56ad0e1b08701158d688802
|
||||||
environments/surveys/edit/response_options: 2988136d5248d7726583108992dcbaee
|
environments/surveys/edit/response_options: 2988136d5248d7726583108992dcbaee
|
||||||
environments/surveys/edit/roundness: 5a161c8f5f258defb57ed1d551737cc4
|
environments/surveys/edit/roundness: 5a161c8f5f258defb57ed1d551737cc4
|
||||||
environments/surveys/edit/roundness_description: bde131aa5674836416dcdf2ff517d899
|
environments/surveys/edit/roundness_description: 03940a6871ae43efa4810cba7cadb74b
|
||||||
environments/surveys/edit/row_used_in_logic_error: f89453ff1b6db77ad84af840fedd9813
|
environments/surveys/edit/row_used_in_logic_error: f89453ff1b6db77ad84af840fedd9813
|
||||||
environments/surveys/edit/rows: 8f41f34e6ca28221cf1ebd948af4c151
|
environments/surveys/edit/rows: 8f41f34e6ca28221cf1ebd948af4c151
|
||||||
environments/surveys/edit/save_and_close: 6ede705b3f82f30269ff3054a5049e34
|
environments/surveys/edit/save_and_close: 6ede705b3f82f30269ff3054a5049e34
|
||||||
@@ -1580,6 +1594,7 @@ checksums:
|
|||||||
environments/surveys/edit/survey_completed_subheading: db537c356c3ab6564d24de0d11a0fee2
|
environments/surveys/edit/survey_completed_subheading: db537c356c3ab6564d24de0d11a0fee2
|
||||||
environments/surveys/edit/survey_display_settings: 8ed19e6a8e1376f7a1ba037d82c4ae11
|
environments/surveys/edit/survey_display_settings: 8ed19e6a8e1376f7a1ba037d82c4ae11
|
||||||
environments/surveys/edit/survey_placement: 083c10f257337f9648bf9d435b18ec2c
|
environments/surveys/edit/survey_placement: 083c10f257337f9648bf9d435b18ec2c
|
||||||
|
environments/surveys/edit/survey_styling: 7f96d6563e934e65687b74374a33b1dc
|
||||||
environments/surveys/edit/survey_trigger: f0c7014a684ca566698b87074fad5579
|
environments/surveys/edit/survey_trigger: f0c7014a684ca566698b87074fad5579
|
||||||
environments/surveys/edit/switch_multi_language_on_to_get_started: cca0ef91ee49095da30cd1e3f26c406f
|
environments/surveys/edit/switch_multi_language_on_to_get_started: cca0ef91ee49095da30cd1e3f26c406f
|
||||||
environments/surveys/edit/target_block_not_found: 0a0c401017ab32364fec2fcbf815d832
|
environments/surveys/edit/target_block_not_found: 0a0c401017ab32364fec2fcbf815d832
|
||||||
@@ -1668,7 +1683,6 @@ checksums:
|
|||||||
environments/surveys/edit/welcome_message: 986a434e3895c8ee0b267df95cc40051
|
environments/surveys/edit/welcome_message: 986a434e3895c8ee0b267df95cc40051
|
||||||
environments/surveys/edit/without_a_filter_all_of_your_users_can_be_surveyed: 451990569c61f25d01044cc45b1ce122
|
environments/surveys/edit/without_a_filter_all_of_your_users_can_be_surveyed: 451990569c61f25d01044cc45b1ce122
|
||||||
environments/surveys/edit/you_have_not_created_a_segment_yet: c6658bd1cee9c5c957c675db044708dd
|
environments/surveys/edit/you_have_not_created_a_segment_yet: c6658bd1cee9c5c957c675db044708dd
|
||||||
environments/surveys/edit/you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations: 04241177ba989ef4c1d8c01e1a7b8541
|
|
||||||
environments/surveys/edit/your_description_here_recall_information_with: 60f73a3cc9bdb9afea2166a7db8fd618
|
environments/surveys/edit/your_description_here_recall_information_with: 60f73a3cc9bdb9afea2166a7db8fd618
|
||||||
environments/surveys/edit/your_question_here_recall_information_with: 6395bd54f5167830c9d662ba403da167
|
environments/surveys/edit/your_question_here_recall_information_with: 6395bd54f5167830c9d662ba403da167
|
||||||
environments/surveys/edit/your_web_app: 07234bed03a33330dc50ae9fcf0174f3
|
environments/surveys/edit/your_web_app: 07234bed03a33330dc50ae9fcf0174f3
|
||||||
@@ -1850,6 +1864,7 @@ checksums:
|
|||||||
environments/surveys/summary/filtered_responses_excel: 06e57bae9e41979fd7fc4b8bfe3466f9
|
environments/surveys/summary/filtered_responses_excel: 06e57bae9e41979fd7fc4b8bfe3466f9
|
||||||
environments/surveys/summary/generating_qr_code: 5026d4a76f995db458195e5215d9bbd9
|
environments/surveys/summary/generating_qr_code: 5026d4a76f995db458195e5215d9bbd9
|
||||||
environments/surveys/summary/impressions: 7fe38d42d68a64d3fd8436a063751584
|
environments/surveys/summary/impressions: 7fe38d42d68a64d3fd8436a063751584
|
||||||
|
environments/surveys/summary/impressions_identified_only: 10f8c491463c73b8e6534314ee00d165
|
||||||
environments/surveys/summary/impressions_tooltip: 4d0823cbf360304770c7c5913e33fdc8
|
environments/surveys/summary/impressions_tooltip: 4d0823cbf360304770c7c5913e33fdc8
|
||||||
environments/surveys/summary/in_app/connection_description: 9710bbf8048a8a5c3b2b56db9d946b73
|
environments/surveys/summary/in_app/connection_description: 9710bbf8048a8a5c3b2b56db9d946b73
|
||||||
environments/surveys/summary/in_app/connection_title: 29e8a40ad6a7fdb5af5ee9451a70a9aa
|
environments/surveys/summary/in_app/connection_title: 29e8a40ad6a7fdb5af5ee9451a70a9aa
|
||||||
@@ -1890,6 +1905,7 @@ checksums:
|
|||||||
environments/surveys/summary/last_quarter: 2e565a81de9b3d7b1ee709ebb6f6eda1
|
environments/surveys/summary/last_quarter: 2e565a81de9b3d7b1ee709ebb6f6eda1
|
||||||
environments/surveys/summary/last_year: fe7c268a48bf85bc40da000e6e437637
|
environments/surveys/summary/last_year: fe7c268a48bf85bc40da000e6e437637
|
||||||
environments/surveys/summary/limit: 347051f1a068e01e8c4e4f6744d8e727
|
environments/surveys/summary/limit: 347051f1a068e01e8c4e4f6744d8e727
|
||||||
|
environments/surveys/summary/no_identified_impressions: c3bc42e6feb9010ced905ded51c5afc4
|
||||||
environments/surveys/summary/no_responses_found: f10190cffdda4ca1bed479acbb89b13f
|
environments/surveys/summary/no_responses_found: f10190cffdda4ca1bed479acbb89b13f
|
||||||
environments/surveys/summary/other_values_found: 48a74ee68c05f7fb162072b50c683b6a
|
environments/surveys/summary/other_values_found: 48a74ee68c05f7fb162072b50c683b6a
|
||||||
environments/surveys/summary/overall: 6c6d6533013d4739766af84b2871bca6
|
environments/surveys/summary/overall: 6c6d6533013d4739766af84b2871bca6
|
||||||
@@ -1912,6 +1928,7 @@ checksums:
|
|||||||
environments/surveys/summary/starts: 3153990a4ade414f501a7e63ab771362
|
environments/surveys/summary/starts: 3153990a4ade414f501a7e63ab771362
|
||||||
environments/surveys/summary/starts_tooltip: 0a7dd01320490dbbea923053fa1ccad6
|
environments/surveys/summary/starts_tooltip: 0a7dd01320490dbbea923053fa1ccad6
|
||||||
environments/surveys/summary/survey_reset_successfully: f53db36a28980ef4766215cf13f01e51
|
environments/surveys/summary/survey_reset_successfully: f53db36a28980ef4766215cf13f01e51
|
||||||
|
environments/surveys/summary/survey_results: b7d86f636beaee2b4d5746bdda058d07
|
||||||
environments/surveys/summary/this_month: 50845a38865204a97773c44dcd2ebb90
|
environments/surveys/summary/this_month: 50845a38865204a97773c44dcd2ebb90
|
||||||
environments/surveys/summary/this_quarter: 9c77d94783dff2269c069389122cd7bd
|
environments/surveys/summary/this_quarter: 9c77d94783dff2269c069389122cd7bd
|
||||||
environments/surveys/summary/this_year: 1e69651c2ac722f8ce138f43cf2e02f9
|
environments/surveys/summary/this_year: 1e69651c2ac722f8ce138f43cf2e02f9
|
||||||
@@ -2031,7 +2048,7 @@ checksums:
|
|||||||
environments/workspace/look/advanced_styling_field_description_size: a0d51c3ab7dc56320ecedc2b27917842
|
environments/workspace/look/advanced_styling_field_description_size: a0d51c3ab7dc56320ecedc2b27917842
|
||||||
environments/workspace/look/advanced_styling_field_description_size_description: ff880ea1beddd1b1ec7416d0b8a69cf3
|
environments/workspace/look/advanced_styling_field_description_size_description: ff880ea1beddd1b1ec7416d0b8a69cf3
|
||||||
environments/workspace/look/advanced_styling_field_description_weight: 514680cc7202ad29835c1cbcde3def1c
|
environments/workspace/look/advanced_styling_field_description_weight: 514680cc7202ad29835c1cbcde3def1c
|
||||||
environments/workspace/look/advanced_styling_field_description_weight_description: 441ac8db1a32557813eb68fbfd759061
|
environments/workspace/look/advanced_styling_field_description_weight_description: aa95bc81b5336a548e256bce49350683
|
||||||
environments/workspace/look/advanced_styling_field_font_size: ca44d14429b2175a1b194793b4ab8f6b
|
environments/workspace/look/advanced_styling_field_font_size: ca44d14429b2175a1b194793b4ab8f6b
|
||||||
environments/workspace/look/advanced_styling_field_font_weight: bfef83778146cf40550df9650d8a07da
|
environments/workspace/look/advanced_styling_field_font_weight: bfef83778146cf40550df9650d8a07da
|
||||||
environments/workspace/look/advanced_styling_field_headline_color: 4ccf3935ad90c88ad4add24f498673ce
|
environments/workspace/look/advanced_styling_field_headline_color: 4ccf3935ad90c88ad4add24f498673ce
|
||||||
@@ -2045,7 +2062,7 @@ checksums:
|
|||||||
environments/workspace/look/advanced_styling_field_indicator_bg_description: 7eb3b54a8b331354ec95c0dc1545c620
|
environments/workspace/look/advanced_styling_field_indicator_bg_description: 7eb3b54a8b331354ec95c0dc1545c620
|
||||||
environments/workspace/look/advanced_styling_field_input_border_radius_description: 0007f1bb572b35d9a3720daeb7a55617
|
environments/workspace/look/advanced_styling_field_input_border_radius_description: 0007f1bb572b35d9a3720daeb7a55617
|
||||||
environments/workspace/look/advanced_styling_field_input_font_size_description: 5311f95dcbd083623e35c98ea5374c3b
|
environments/workspace/look/advanced_styling_field_input_font_size_description: 5311f95dcbd083623e35c98ea5374c3b
|
||||||
environments/workspace/look/advanced_styling_field_input_height_description: e19ec0dc432478def0fd1199ad765e38
|
environments/workspace/look/advanced_styling_field_input_height_description: bb7439d42ec3848a8fa9edb8b001b69a
|
||||||
environments/workspace/look/advanced_styling_field_input_padding_x_description: 10e14296468321c13fda77fd1ba58dfd
|
environments/workspace/look/advanced_styling_field_input_padding_x_description: 10e14296468321c13fda77fd1ba58dfd
|
||||||
environments/workspace/look/advanced_styling_field_input_padding_y_description: 98b4aeff2940516d05ea61bdc1211d0d
|
environments/workspace/look/advanced_styling_field_input_padding_y_description: 98b4aeff2940516d05ea61bdc1211d0d
|
||||||
environments/workspace/look/advanced_styling_field_input_placeholder_opacity_description: f55a6700884d24014404e58876121ddf
|
environments/workspace/look/advanced_styling_field_input_placeholder_opacity_description: f55a6700884d24014404e58876121ddf
|
||||||
@@ -2054,6 +2071,8 @@ checksums:
|
|||||||
environments/workspace/look/advanced_styling_field_input_text_description: 460450df24ea0cc902710118a5000feb
|
environments/workspace/look/advanced_styling_field_input_text_description: 460450df24ea0cc902710118a5000feb
|
||||||
environments/workspace/look/advanced_styling_field_option_bg: 0ceaed10d99ed4ad83cb0934ab970174
|
environments/workspace/look/advanced_styling_field_option_bg: 0ceaed10d99ed4ad83cb0934ab970174
|
||||||
environments/workspace/look/advanced_styling_field_option_bg_description: 6cd6ccecbbb9f2f19439d7c682eb67c1
|
environments/workspace/look/advanced_styling_field_option_bg_description: 6cd6ccecbbb9f2f19439d7c682eb67c1
|
||||||
|
environments/workspace/look/advanced_styling_field_option_border: aa478eb148515b6a2637fb144ff72028
|
||||||
|
environments/workspace/look/advanced_styling_field_option_border_description: 8f75b740e8dcb7f6cfeff2e5d5ca7c92
|
||||||
environments/workspace/look/advanced_styling_field_option_border_radius_description: 23f81c25b2681a7c9e2c4f2e7d2e0656
|
environments/workspace/look/advanced_styling_field_option_border_radius_description: 23f81c25b2681a7c9e2c4f2e7d2e0656
|
||||||
environments/workspace/look/advanced_styling_field_option_font_size_description: 5430fd9b08819972f0a613bf3fa659da
|
environments/workspace/look/advanced_styling_field_option_font_size_description: 5430fd9b08819972f0a613bf3fa659da
|
||||||
environments/workspace/look/advanced_styling_field_option_label: 2767a5db32742073a01aac16488e93dc
|
environments/workspace/look/advanced_styling_field_option_label: 2767a5db32742073a01aac16488e93dc
|
||||||
@@ -2835,6 +2854,9 @@ checksums:
|
|||||||
templates/preview_survey_question_2_choice_2_label: 1af148222f327f28cf0db6513de5989e
|
templates/preview_survey_question_2_choice_2_label: 1af148222f327f28cf0db6513de5989e
|
||||||
templates/preview_survey_question_2_headline: 5cfb173d156555227fbc2c97ad921e72
|
templates/preview_survey_question_2_headline: 5cfb173d156555227fbc2c97ad921e72
|
||||||
templates/preview_survey_question_2_subheader: 2e652d8acd68d072e5a0ae686c4011c0
|
templates/preview_survey_question_2_subheader: 2e652d8acd68d072e5a0ae686c4011c0
|
||||||
|
templates/preview_survey_question_open_text_headline: a9509a47e0456ae98ec3ddac3d6fad2c
|
||||||
|
templates/preview_survey_question_open_text_placeholder: 37ee9c84f3777b9220d4faec1e1c78ee
|
||||||
|
templates/preview_survey_question_open_text_subheader: 3c7bf09f3f17b02bc2fbbbdb347a5830
|
||||||
templates/preview_survey_welcome_card_headline: 8778dc41547a2778d0f9482da989fc00
|
templates/preview_survey_welcome_card_headline: 8778dc41547a2778d0f9482da989fc00
|
||||||
templates/prioritize_features_description: 1eae41fad0e3947f803d8539081e59ec
|
templates/prioritize_features_description: 1eae41fad0e3947f803d8539081e59ec
|
||||||
templates/prioritize_features_name: 4ca59ff1f9c319aaa68c3106d820fd6a
|
templates/prioritize_features_name: 4ca59ff1f9c319aaa68c3106d820fd6a
|
||||||
|
|||||||
@@ -63,7 +63,8 @@ export const INVITE_DISABLED = env.INVITE_DISABLED === "1";
|
|||||||
|
|
||||||
export const SLACK_CLIENT_SECRET = env.SLACK_CLIENT_SECRET;
|
export const SLACK_CLIENT_SECRET = env.SLACK_CLIENT_SECRET;
|
||||||
export const SLACK_CLIENT_ID = env.SLACK_CLIENT_ID;
|
export const SLACK_CLIENT_ID = env.SLACK_CLIENT_ID;
|
||||||
export const SLACK_AUTH_URL = `https://slack.com/oauth/v2/authorize?client_id=${env.SLACK_CLIENT_ID}&scope=channels:read,chat:write,chat:write.public,chat:write.customize,groups:read`;
|
export const SLACK_REDIRECT_URI = `${WEBAPP_URL}/api/v1/integrations/slack/callback`;
|
||||||
|
export const SLACK_AUTH_URL = `https://slack.com/oauth/v2/authorize?client_id=${env.SLACK_CLIENT_ID}&scope=channels:read,chat:write,chat:write.public,chat:write.customize,groups:read&redirect_uri=${SLACK_REDIRECT_URI}`;
|
||||||
|
|
||||||
export const GOOGLE_SHEETS_CLIENT_ID = env.GOOGLE_SHEETS_CLIENT_ID;
|
export const GOOGLE_SHEETS_CLIENT_ID = env.GOOGLE_SHEETS_CLIENT_ID;
|
||||||
export const GOOGLE_SHEETS_CLIENT_SECRET = env.GOOGLE_SHEETS_CLIENT_SECRET;
|
export const GOOGLE_SHEETS_CLIENT_SECRET = env.GOOGLE_SHEETS_CLIENT_SECRET;
|
||||||
|
|||||||
@@ -1,9 +1,10 @@
|
|||||||
import "server-only";
|
import "server-only";
|
||||||
import { Prisma } from "@prisma/client";
|
import { Prisma } from "@prisma/client";
|
||||||
import { cache as reactCache } from "react";
|
import { cache as reactCache } from "react";
|
||||||
|
import { z } from "zod";
|
||||||
import { prisma } from "@formbricks/database";
|
import { prisma } from "@formbricks/database";
|
||||||
import { ZId } from "@formbricks/types/common";
|
import { ZId } from "@formbricks/types/common";
|
||||||
import { TDisplay, TDisplayFilters } from "@formbricks/types/displays";
|
import { TDisplay, TDisplayFilters, TDisplayWithContact } from "@formbricks/types/displays";
|
||||||
import { DatabaseError } from "@formbricks/types/errors";
|
import { DatabaseError } from "@formbricks/types/errors";
|
||||||
import { validateInputs } from "../utils/validate";
|
import { validateInputs } from "../utils/validate";
|
||||||
|
|
||||||
@@ -23,13 +24,12 @@ export const getDisplayCountBySurveyId = reactCache(
|
|||||||
const displayCount = await prisma.display.count({
|
const displayCount = await prisma.display.count({
|
||||||
where: {
|
where: {
|
||||||
surveyId: surveyId,
|
surveyId: surveyId,
|
||||||
...(filters &&
|
...(filters?.createdAt && {
|
||||||
filters.createdAt && {
|
createdAt: {
|
||||||
createdAt: {
|
gte: filters.createdAt.min,
|
||||||
gte: filters.createdAt.min,
|
lte: filters.createdAt.max,
|
||||||
lte: filters.createdAt.max,
|
},
|
||||||
},
|
}),
|
||||||
}),
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
return displayCount;
|
return displayCount;
|
||||||
@@ -42,6 +42,97 @@ export const getDisplayCountBySurveyId = reactCache(
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
export const getDisplaysByContactId = reactCache(
|
||||||
|
async (contactId: string): Promise<Pick<TDisplay, "id" | "createdAt" | "surveyId">[]> => {
|
||||||
|
validateInputs([contactId, ZId]);
|
||||||
|
|
||||||
|
try {
|
||||||
|
const displays = await prisma.display.findMany({
|
||||||
|
where: { contactId },
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
createdAt: true,
|
||||||
|
surveyId: true,
|
||||||
|
},
|
||||||
|
orderBy: { createdAt: "desc" },
|
||||||
|
});
|
||||||
|
|
||||||
|
return displays;
|
||||||
|
} catch (error) {
|
||||||
|
if (error instanceof Prisma.PrismaClientKnownRequestError) {
|
||||||
|
throw new DatabaseError(error.message);
|
||||||
|
}
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
export const getDisplaysBySurveyIdWithContact = reactCache(
|
||||||
|
async (surveyId: string, limit?: number, offset?: number): Promise<TDisplayWithContact[]> => {
|
||||||
|
validateInputs(
|
||||||
|
[surveyId, ZId],
|
||||||
|
[limit, z.number().int().min(1).optional()],
|
||||||
|
[offset, z.number().int().nonnegative().optional()]
|
||||||
|
);
|
||||||
|
|
||||||
|
try {
|
||||||
|
const displays = await prisma.display.findMany({
|
||||||
|
where: {
|
||||||
|
surveyId,
|
||||||
|
contactId: { not: null },
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
createdAt: true,
|
||||||
|
surveyId: true,
|
||||||
|
contact: {
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
attributes: {
|
||||||
|
where: {
|
||||||
|
attributeKey: {
|
||||||
|
key: { in: ["email", "userId"] },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
attributeKey: { select: { key: true } },
|
||||||
|
value: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
orderBy: { createdAt: "desc" },
|
||||||
|
take: limit,
|
||||||
|
skip: offset,
|
||||||
|
});
|
||||||
|
|
||||||
|
return displays.map((display) => ({
|
||||||
|
id: display.id,
|
||||||
|
createdAt: display.createdAt,
|
||||||
|
surveyId: display.surveyId,
|
||||||
|
contact: display.contact
|
||||||
|
? {
|
||||||
|
id: display.contact.id,
|
||||||
|
attributes: display.contact.attributes.reduce(
|
||||||
|
(acc, attr) => {
|
||||||
|
acc[attr.attributeKey.key] = attr.value;
|
||||||
|
return acc;
|
||||||
|
},
|
||||||
|
{} as Record<string, string>
|
||||||
|
),
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
}));
|
||||||
|
} catch (error) {
|
||||||
|
if (error instanceof Prisma.PrismaClientKnownRequestError) {
|
||||||
|
throw new DatabaseError(error.message);
|
||||||
|
}
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
export const deleteDisplay = async (displayId: string, tx?: Prisma.TransactionClient): Promise<TDisplay> => {
|
export const deleteDisplay = async (displayId: string, tx?: Prisma.TransactionClient): Promise<TDisplay> => {
|
||||||
validateInputs([displayId, ZId]);
|
validateInputs([displayId, ZId]);
|
||||||
try {
|
try {
|
||||||
|
|||||||
@@ -0,0 +1,219 @@
|
|||||||
|
import { mockDisplayId, mockSurveyId } from "./__mocks__/data.mock";
|
||||||
|
import { prisma } from "@/lib/__mocks__/database";
|
||||||
|
import { Prisma } from "@prisma/client";
|
||||||
|
import { describe, expect, test, vi } from "vitest";
|
||||||
|
import { PrismaErrorType } from "@formbricks/database/types/error";
|
||||||
|
import { DatabaseError, ValidationError } from "@formbricks/types/errors";
|
||||||
|
import { getDisplaysByContactId, getDisplaysBySurveyIdWithContact } from "../service";
|
||||||
|
|
||||||
|
const mockContactId = "clqnj99r9000008lebgf8734j";
|
||||||
|
|
||||||
|
const mockDisplaysForContact = [
|
||||||
|
{
|
||||||
|
id: mockDisplayId,
|
||||||
|
createdAt: new Date("2024-01-15T10:00:00Z"),
|
||||||
|
surveyId: mockSurveyId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "clqkr5smu000208jy50v6g5k5",
|
||||||
|
createdAt: new Date("2024-01-14T10:00:00Z"),
|
||||||
|
surveyId: "clqkr8dlv000308jybb08evgs",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const mockDisplaysWithContact = [
|
||||||
|
{
|
||||||
|
id: mockDisplayId,
|
||||||
|
createdAt: new Date("2024-01-15T10:00:00Z"),
|
||||||
|
surveyId: mockSurveyId,
|
||||||
|
contact: {
|
||||||
|
id: mockContactId,
|
||||||
|
attributes: [
|
||||||
|
{ attributeKey: { key: "email" }, value: "test@example.com" },
|
||||||
|
{ attributeKey: { key: "userId" }, value: "user-123" },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "clqkr5smu000208jy50v6g5k5",
|
||||||
|
createdAt: new Date("2024-01-14T10:00:00Z"),
|
||||||
|
surveyId: "clqkr8dlv000308jybb08evgs",
|
||||||
|
contact: {
|
||||||
|
id: "clqnj99r9000008lebgf8734k",
|
||||||
|
attributes: [{ attributeKey: { key: "userId" }, value: "user-456" }],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
describe("getDisplaysByContactId", () => {
|
||||||
|
describe("Happy Path", () => {
|
||||||
|
test("returns displays for a contact ordered by createdAt desc", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockResolvedValue(mockDisplaysForContact as any);
|
||||||
|
|
||||||
|
const result = await getDisplaysByContactId(mockContactId);
|
||||||
|
|
||||||
|
expect(result).toEqual(mockDisplaysForContact);
|
||||||
|
expect(prisma.display.findMany).toHaveBeenCalledWith({
|
||||||
|
where: { contactId: mockContactId },
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
createdAt: true,
|
||||||
|
surveyId: true,
|
||||||
|
},
|
||||||
|
orderBy: { createdAt: "desc" },
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test("returns empty array when contact has no displays", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockResolvedValue([]);
|
||||||
|
|
||||||
|
const result = await getDisplaysByContactId(mockContactId);
|
||||||
|
|
||||||
|
expect(result).toEqual([]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Sad Path", () => {
|
||||||
|
test("throws a ValidationError if the contactId is invalid", async () => {
|
||||||
|
await expect(getDisplaysByContactId("not-a-cuid")).rejects.toThrow(ValidationError);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("throws DatabaseError on PrismaClientKnownRequestError", async () => {
|
||||||
|
const errToThrow = new Prisma.PrismaClientKnownRequestError("Mock error", {
|
||||||
|
code: PrismaErrorType.UniqueConstraintViolation,
|
||||||
|
clientVersion: "0.0.1",
|
||||||
|
});
|
||||||
|
|
||||||
|
vi.mocked(prisma.display.findMany).mockRejectedValue(errToThrow);
|
||||||
|
|
||||||
|
await expect(getDisplaysByContactId(mockContactId)).rejects.toThrow(DatabaseError);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("throws generic Error for other exceptions", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockRejectedValue(new Error("Mock error"));
|
||||||
|
|
||||||
|
await expect(getDisplaysByContactId(mockContactId)).rejects.toThrow(Error);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("getDisplaysBySurveyIdWithContact", () => {
|
||||||
|
describe("Happy Path", () => {
|
||||||
|
test("returns displays with contact attributes transformed", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockResolvedValue(mockDisplaysWithContact as any);
|
||||||
|
|
||||||
|
const result = await getDisplaysBySurveyIdWithContact(mockSurveyId, 15, 0);
|
||||||
|
|
||||||
|
expect(result).toEqual([
|
||||||
|
{
|
||||||
|
id: mockDisplayId,
|
||||||
|
createdAt: new Date("2024-01-15T10:00:00Z"),
|
||||||
|
surveyId: mockSurveyId,
|
||||||
|
contact: {
|
||||||
|
id: mockContactId,
|
||||||
|
attributes: { email: "test@example.com", userId: "user-123" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "clqkr5smu000208jy50v6g5k5",
|
||||||
|
createdAt: new Date("2024-01-14T10:00:00Z"),
|
||||||
|
surveyId: "clqkr8dlv000308jybb08evgs",
|
||||||
|
contact: {
|
||||||
|
id: "clqnj99r9000008lebgf8734k",
|
||||||
|
attributes: { userId: "user-456" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("calls prisma with correct where clause and pagination", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockResolvedValue([]);
|
||||||
|
|
||||||
|
await getDisplaysBySurveyIdWithContact(mockSurveyId, 15, 0);
|
||||||
|
|
||||||
|
expect(prisma.display.findMany).toHaveBeenCalledWith({
|
||||||
|
where: {
|
||||||
|
surveyId: mockSurveyId,
|
||||||
|
contactId: { not: null },
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
createdAt: true,
|
||||||
|
surveyId: true,
|
||||||
|
contact: {
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
attributes: {
|
||||||
|
where: {
|
||||||
|
attributeKey: {
|
||||||
|
key: { in: ["email", "userId"] },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
attributeKey: { select: { key: true } },
|
||||||
|
value: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
orderBy: { createdAt: "desc" },
|
||||||
|
take: 15,
|
||||||
|
skip: 0,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test("returns empty array when no displays found", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockResolvedValue([]);
|
||||||
|
|
||||||
|
const result = await getDisplaysBySurveyIdWithContact(mockSurveyId);
|
||||||
|
|
||||||
|
expect(result).toEqual([]);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("handles display with null contact", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockResolvedValue([
|
||||||
|
{
|
||||||
|
id: mockDisplayId,
|
||||||
|
createdAt: new Date("2024-01-15T10:00:00Z"),
|
||||||
|
surveyId: mockSurveyId,
|
||||||
|
contact: null,
|
||||||
|
},
|
||||||
|
] as any);
|
||||||
|
|
||||||
|
const result = await getDisplaysBySurveyIdWithContact(mockSurveyId);
|
||||||
|
|
||||||
|
expect(result).toEqual([
|
||||||
|
{
|
||||||
|
id: mockDisplayId,
|
||||||
|
createdAt: new Date("2024-01-15T10:00:00Z"),
|
||||||
|
surveyId: mockSurveyId,
|
||||||
|
contact: null,
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Sad Path", () => {
|
||||||
|
test("throws a ValidationError if the surveyId is invalid", async () => {
|
||||||
|
await expect(getDisplaysBySurveyIdWithContact("not-a-cuid")).rejects.toThrow(ValidationError);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("throws DatabaseError on PrismaClientKnownRequestError", async () => {
|
||||||
|
const errToThrow = new Prisma.PrismaClientKnownRequestError("Mock error", {
|
||||||
|
code: PrismaErrorType.UniqueConstraintViolation,
|
||||||
|
clientVersion: "0.0.1",
|
||||||
|
});
|
||||||
|
|
||||||
|
vi.mocked(prisma.display.findMany).mockRejectedValue(errToThrow);
|
||||||
|
|
||||||
|
await expect(getDisplaysBySurveyIdWithContact(mockSurveyId)).rejects.toThrow(DatabaseError);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("throws generic Error for other exceptions", async () => {
|
||||||
|
vi.mocked(prisma.display.findMany).mockRejectedValue(new Error("Mock error"));
|
||||||
|
|
||||||
|
await expect(getDisplaysBySurveyIdWithContact(mockSurveyId)).rejects.toThrow(Error);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -1,44 +1,66 @@
|
|||||||
import { beforeEach, describe, expect, test, vi } from "vitest";
|
import { beforeEach, describe, expect, test, vi } from "vitest";
|
||||||
|
|
||||||
// Mock constants module
|
|
||||||
const envMock = {
|
const envMock = {
|
||||||
env: {
|
WEBAPP_URL: undefined as string | undefined,
|
||||||
WEBAPP_URL: "http://localhost:3000",
|
VERCEL_URL: undefined as string | undefined,
|
||||||
PUBLIC_URL: undefined as string | undefined,
|
PUBLIC_URL: undefined as string | undefined,
|
||||||
},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
vi.mock("@/lib/env", () => envMock);
|
vi.mock("./env", () => ({
|
||||||
|
env: envMock,
|
||||||
|
}));
|
||||||
|
|
||||||
|
const loadGetPublicDomain = async () => {
|
||||||
|
vi.resetModules();
|
||||||
|
const { getPublicDomain } = await import("./getPublicUrl");
|
||||||
|
return getPublicDomain;
|
||||||
|
};
|
||||||
|
|
||||||
describe("getPublicDomain", () => {
|
describe("getPublicDomain", () => {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
vi.resetModules();
|
envMock.WEBAPP_URL = undefined;
|
||||||
|
envMock.VERCEL_URL = undefined;
|
||||||
|
envMock.PUBLIC_URL = undefined;
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should return WEBAPP_URL when PUBLIC_URL is not set", async () => {
|
test("returns trimmed WEBAPP_URL when configured", async () => {
|
||||||
const { getPublicDomain } = await import("./getPublicUrl");
|
envMock.WEBAPP_URL = " https://app.formbricks.com ";
|
||||||
const domain = getPublicDomain();
|
|
||||||
expect(domain).toBe("http://localhost:3000");
|
const getPublicDomain = await loadGetPublicDomain();
|
||||||
|
|
||||||
|
expect(getPublicDomain()).toBe("https://app.formbricks.com");
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should return PUBLIC_URL when it is set", async () => {
|
test("falls back to VERCEL_URL when WEBAPP_URL is empty", async () => {
|
||||||
envMock.env.PUBLIC_URL = "https://surveys.example.com";
|
envMock.WEBAPP_URL = " ";
|
||||||
const { getPublicDomain } = await import("./getPublicUrl");
|
envMock.VERCEL_URL = "preview.formbricks.com";
|
||||||
const domain = getPublicDomain();
|
|
||||||
expect(domain).toBe("https://surveys.example.com");
|
const getPublicDomain = await loadGetPublicDomain();
|
||||||
|
|
||||||
|
expect(getPublicDomain()).toBe("https://preview.formbricks.com");
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should handle empty string PUBLIC_URL by returning WEBAPP_URL", async () => {
|
test("falls back to localhost when WEBAPP_URL and VERCEL_URL are not set", async () => {
|
||||||
envMock.env.PUBLIC_URL = "";
|
const getPublicDomain = await loadGetPublicDomain();
|
||||||
const { getPublicDomain } = await import("./getPublicUrl");
|
|
||||||
const domain = getPublicDomain();
|
expect(getPublicDomain()).toBe("http://localhost:3000");
|
||||||
expect(domain).toBe("http://localhost:3000");
|
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should handle undefined PUBLIC_URL by returning WEBAPP_URL", async () => {
|
test("returns PUBLIC_URL when set", async () => {
|
||||||
envMock.env.PUBLIC_URL = undefined;
|
envMock.WEBAPP_URL = "https://app.formbricks.com";
|
||||||
const { getPublicDomain } = await import("./getPublicUrl");
|
envMock.PUBLIC_URL = "https://surveys.formbricks.com";
|
||||||
const domain = getPublicDomain();
|
|
||||||
expect(domain).toBe("http://localhost:3000");
|
const getPublicDomain = await loadGetPublicDomain();
|
||||||
|
|
||||||
|
expect(getPublicDomain()).toBe("https://surveys.formbricks.com");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("falls back to WEBAPP_URL when PUBLIC_URL is empty", async () => {
|
||||||
|
envMock.WEBAPP_URL = "https://app.formbricks.com";
|
||||||
|
envMock.PUBLIC_URL = " ";
|
||||||
|
|
||||||
|
const getPublicDomain = await loadGetPublicDomain();
|
||||||
|
|
||||||
|
expect(getPublicDomain()).toBe("https://app.formbricks.com");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,8 +1,18 @@
|
|||||||
import "server-only";
|
import "server-only";
|
||||||
import { env } from "./env";
|
import { env } from "./env";
|
||||||
|
|
||||||
const WEBAPP_URL =
|
const configuredWebappUrl = env.WEBAPP_URL?.trim() ?? "";
|
||||||
env.WEBAPP_URL ?? (env.VERCEL_URL ? `https://${env.VERCEL_URL}` : "") ?? "http://localhost:3000";
|
const WEBAPP_URL = (() => {
|
||||||
|
if (configuredWebappUrl !== "") {
|
||||||
|
return configuredWebappUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (env.VERCEL_URL) {
|
||||||
|
return `https://${env.VERCEL_URL}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return "http://localhost:3000";
|
||||||
|
})();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the public domain URL
|
* Returns the public domain URL
|
||||||
|
|||||||
@@ -397,7 +397,6 @@ export const getResponseDownloadFile = async (
|
|||||||
"Survey ID",
|
"Survey ID",
|
||||||
"Formbricks ID (internal)",
|
"Formbricks ID (internal)",
|
||||||
"User ID",
|
"User ID",
|
||||||
"Notes",
|
|
||||||
"Tags",
|
"Tags",
|
||||||
...metaDataFields,
|
...metaDataFields,
|
||||||
...elements.flat(),
|
...elements.flat(),
|
||||||
|
|||||||
@@ -60,6 +60,7 @@ export const getSuggestedColors = (brandColor: string = DEFAULT_BRAND_COLOR) =>
|
|||||||
// Options (Radio / Checkbox)
|
// Options (Radio / Checkbox)
|
||||||
"optionBgColor.light": inputBg,
|
"optionBgColor.light": inputBg,
|
||||||
"optionLabelColor.light": questionColor,
|
"optionLabelColor.light": questionColor,
|
||||||
|
"optionBorderColor.light": inputBorder,
|
||||||
|
|
||||||
// Card
|
// Card
|
||||||
"cardBackgroundColor.light": cardBg,
|
"cardBackgroundColor.light": cardBg,
|
||||||
@@ -138,6 +139,7 @@ export const STYLE_DEFAULTS: TProjectStyling = {
|
|||||||
// Options
|
// Options
|
||||||
optionBgColor: { light: _colors["optionBgColor.light"] },
|
optionBgColor: { light: _colors["optionBgColor.light"] },
|
||||||
optionLabelColor: { light: _colors["optionLabelColor.light"] },
|
optionLabelColor: { light: _colors["optionLabelColor.light"] },
|
||||||
|
optionBorderColor: { light: _colors["optionBorderColor.light"] },
|
||||||
optionBorderRadius: 8,
|
optionBorderRadius: 8,
|
||||||
optionPaddingX: 16,
|
optionPaddingX: 16,
|
||||||
optionPaddingY: 16,
|
optionPaddingY: 16,
|
||||||
@@ -169,6 +171,7 @@ export const deriveNewFieldsFromLegacy = (saved: Record<string, unknown>): Recor
|
|||||||
const q = light("questionColor");
|
const q = light("questionColor");
|
||||||
const b = light("brandColor");
|
const b = light("brandColor");
|
||||||
const i = light("inputColor");
|
const i = light("inputColor");
|
||||||
|
const inputBorder = light("inputBorderColor");
|
||||||
|
|
||||||
return {
|
return {
|
||||||
...(q && !saved.elementHeadlineColor && { elementHeadlineColor: { light: q } }),
|
...(q && !saved.elementHeadlineColor && { elementHeadlineColor: { light: q } }),
|
||||||
@@ -179,9 +182,9 @@ export const deriveNewFieldsFromLegacy = (saved: Record<string, unknown>): Recor
|
|||||||
...(b && !saved.buttonBgColor && { buttonBgColor: { light: b } }),
|
...(b && !saved.buttonBgColor && { buttonBgColor: { light: b } }),
|
||||||
...(b && !saved.buttonTextColor && { buttonTextColor: { light: isLight(b) ? "#0f172a" : "#ffffff" } }),
|
...(b && !saved.buttonTextColor && { buttonTextColor: { light: isLight(b) ? "#0f172a" : "#ffffff" } }),
|
||||||
...(i && !saved.optionBgColor && { optionBgColor: { light: i } }),
|
...(i && !saved.optionBgColor && { optionBgColor: { light: i } }),
|
||||||
|
...(inputBorder && !saved.optionBorderColor && { optionBorderColor: { light: inputBorder } }),
|
||||||
...(b && !saved.progressIndicatorBgColor && { progressIndicatorBgColor: { light: b } }),
|
...(b && !saved.progressIndicatorBgColor && { progressIndicatorBgColor: { light: b } }),
|
||||||
...(b &&
|
...(b && !saved.progressTrackBgColor && { progressTrackBgColor: { light: mixColor(b, "#ffffff", 0.8) } }),
|
||||||
!saved.progressTrackBgColor && { progressTrackBgColor: { light: mixColor(b, "#ffffff", 0.8) } }),
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -211,6 +214,7 @@ export const buildStylingFromBrandColor = (brandColor: string = DEFAULT_BRAND_CO
|
|||||||
inputTextColor: { light: colors["inputTextColor.light"] },
|
inputTextColor: { light: colors["inputTextColor.light"] },
|
||||||
optionBgColor: { light: colors["optionBgColor.light"] },
|
optionBgColor: { light: colors["optionBgColor.light"] },
|
||||||
optionLabelColor: { light: colors["optionLabelColor.light"] },
|
optionLabelColor: { light: colors["optionLabelColor.light"] },
|
||||||
|
optionBorderColor: { light: colors["optionBorderColor.light"] },
|
||||||
cardBackgroundColor: { light: colors["cardBackgroundColor.light"] },
|
cardBackgroundColor: { light: colors["cardBackgroundColor.light"] },
|
||||||
cardBorderColor: { light: colors["cardBorderColor.light"] },
|
cardBorderColor: { light: colors["cardBorderColor.light"] },
|
||||||
highlightBorderColor: { light: colors["highlightBorderColor.light"] },
|
highlightBorderColor: { light: colors["highlightBorderColor.light"] },
|
||||||
|
|||||||
@@ -508,6 +508,7 @@ export const updateSurveyInternal = async (
|
|||||||
newFollowUps.length > 0
|
newFollowUps.length > 0
|
||||||
? {
|
? {
|
||||||
data: newFollowUps.map((followUp) => ({
|
data: newFollowUps.map((followUp) => ({
|
||||||
|
id: followUp.id,
|
||||||
name: followUp.name,
|
name: followUp.name,
|
||||||
trigger: followUp.trigger,
|
trigger: followUp.trigger,
|
||||||
action: followUp.action,
|
action: followUp.action,
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Kopieren",
|
"copy": "Kopieren",
|
||||||
"copy_code": "Code kopieren",
|
"copy_code": "Code kopieren",
|
||||||
"copy_link": "Link kopieren",
|
"copy_link": "Link kopieren",
|
||||||
"count_attributes": "{value, plural, one {{value} Attribut} other {{value} Attribute}}",
|
"count_attributes": "{count, plural, one {{count} Attribut} other {{count} Attribute}}",
|
||||||
"count_contacts": "{value, plural, one {{value} Kontakt} other {{value} Kontakte}}",
|
"count_contacts": "{count, plural, one {{count} Kontakt} other {{count} Kontakte}}",
|
||||||
"count_responses": "{value, plural, one {{value} Antwort} other {{value} Antworten}}",
|
"count_members": "{count, plural, one {{count} Mitglied} other {{count} Mitglieder}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} Antwort} other {{count} Antworten}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} Auswahl} other {{count} Auswahlen}}",
|
||||||
"create_new_organization": "Neue Organisation erstellen",
|
"create_new_organization": "Neue Organisation erstellen",
|
||||||
"create_segment": "Segment erstellen",
|
"create_segment": "Segment erstellen",
|
||||||
"create_survey": "Umfrage erstellen",
|
"create_survey": "Umfrage erstellen",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "Tage",
|
"days": "Tage",
|
||||||
"default": "Standard",
|
"default": "Standard",
|
||||||
"delete": "Löschen",
|
"delete": "Löschen",
|
||||||
|
"delete_what": "{deleteWhat} löschen",
|
||||||
"description": "Beschreibung",
|
"description": "Beschreibung",
|
||||||
"dev_env": "Entwicklungsumgebung",
|
"dev_env": "Entwicklungsumgebung",
|
||||||
"development": "Entwicklung",
|
"development": "Entwicklung",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Fehler",
|
"error": "Fehler",
|
||||||
"error_component_description": "Diese Ressource existiert nicht oder Du hast nicht die notwendigen Rechte, um darauf zuzugreifen.",
|
"error_component_description": "Diese Ressource existiert nicht oder Du hast nicht die notwendigen Rechte, um darauf zuzugreifen.",
|
||||||
"error_component_title": "Fehler beim Laden der Ressourcen",
|
"error_component_title": "Fehler beim Laden der Ressourcen",
|
||||||
|
"error_loading_data": "Fehler beim Laden der Daten",
|
||||||
"error_rate_limit_description": "Maximale Anzahl an Anfragen erreicht. Bitte später erneut versuchen.",
|
"error_rate_limit_description": "Maximale Anzahl an Anfragen erreicht. Bitte später erneut versuchen.",
|
||||||
"error_rate_limit_title": "Rate Limit Überschritten",
|
"error_rate_limit_title": "Rate Limit Überschritten",
|
||||||
"expand_rows": "Zeilen erweitern",
|
"expand_rows": "Zeilen erweitern",
|
||||||
"failed_to_copy_to_clipboard": "Fehler beim Kopieren in die Zwischenablage",
|
"failed_to_copy_to_clipboard": "Fehler beim Kopieren in die Zwischenablage",
|
||||||
"failed_to_load_organizations": "Fehler beim Laden der Organisationen",
|
"failed_to_load_organizations": "Fehler beim Laden der Organisationen",
|
||||||
"failed_to_load_workspaces": "Projekte konnten nicht geladen werden",
|
"failed_to_load_workspaces": "Projekte konnten nicht geladen werden",
|
||||||
|
"filter": "Filter",
|
||||||
"finish": "Fertigstellen",
|
"finish": "Fertigstellen",
|
||||||
|
"first_name": "Vorname",
|
||||||
"follow_these": "Folge diesen",
|
"follow_these": "Folge diesen",
|
||||||
"formbricks_version": "Formbricks Version",
|
"formbricks_version": "Formbricks Version",
|
||||||
"full_name": "Name",
|
"full_name": "Name",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Verstecktes Feld",
|
"hidden_field": "Verstecktes Feld",
|
||||||
"hidden_fields": "Versteckte Felder",
|
"hidden_fields": "Versteckte Felder",
|
||||||
"hide_column": "Spalte ausblenden",
|
"hide_column": "Spalte ausblenden",
|
||||||
|
"id": "ID",
|
||||||
"image": "Bild",
|
"image": "Bild",
|
||||||
"images": "Bilder",
|
"images": "Bilder",
|
||||||
"import": "Importieren",
|
"import": "Importieren",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Schlüssel",
|
"key": "Schlüssel",
|
||||||
"label": "Bezeichnung",
|
"label": "Bezeichnung",
|
||||||
"language": "Sprache",
|
"language": "Sprache",
|
||||||
|
"last_name": "Nachname",
|
||||||
"learn_more": "Mehr erfahren",
|
"learn_more": "Mehr erfahren",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Helle Überlagerung",
|
"light_overlay": "Helle Überlagerung",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Darstellung",
|
"look_and_feel": "Darstellung",
|
||||||
"manage": "Verwalten",
|
"manage": "Verwalten",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Mitglied",
|
|
||||||
"members": "Mitglieder",
|
"members": "Mitglieder",
|
||||||
"members_and_teams": "Mitglieder & Teams",
|
"members_and_teams": "Mitglieder & Teams",
|
||||||
"membership_not_found": "Mitgliedschaft nicht gefunden",
|
"membership_not_found": "Mitgliedschaft nicht gefunden",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Nach unten bewegen",
|
"move_down": "Nach unten bewegen",
|
||||||
"move_up": "Nach oben bewegen",
|
"move_up": "Nach oben bewegen",
|
||||||
"multiple_languages": "Mehrsprachigkeit",
|
"multiple_languages": "Mehrsprachigkeit",
|
||||||
|
"my_product": "mein Produkt",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"new": "Neu",
|
"new": "Neu",
|
||||||
"new_version_available": "Formbricks {version} ist da. Jetzt aktualisieren!",
|
"new_version_available": "Formbricks {version} ist da. Jetzt aktualisieren!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Teams auswählen",
|
"select_teams": "Teams auswählen",
|
||||||
"selected": "Ausgewählt",
|
"selected": "Ausgewählt",
|
||||||
"selected_questions": "Ausgewählte Fragen",
|
"selected_questions": "Ausgewählte Fragen",
|
||||||
"selection": "Auswahl",
|
|
||||||
"selections": "Auswahlen",
|
|
||||||
"send_test_email": "Test-E-Mail senden",
|
"send_test_email": "Test-E-Mail senden",
|
||||||
"session_not_found": "Sitzung nicht gefunden",
|
"session_not_found": "Sitzung nicht gefunden",
|
||||||
"settings": "Einstellungen",
|
"settings": "Einstellungen",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Oben rechts",
|
"top_right": "Oben rechts",
|
||||||
"try_again": "Versuch's nochmal",
|
"try_again": "Versuch's nochmal",
|
||||||
"type": "Typ",
|
"type": "Typ",
|
||||||
|
"unknown_survey": "Unbekannte Umfrage",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Schalten Sie mehr Projekte mit einem höheren Tarif frei.",
|
"unlock_more_workspaces_with_a_higher_plan": "Schalten Sie mehr Projekte mit einem höheren Tarif frei.",
|
||||||
"update": "Aktualisierung",
|
"update": "Aktualisierung",
|
||||||
"updated": "Aktualisiert",
|
"updated": "Aktualisiert",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Dadurch wird das ausgewählte Attribut gelöscht. Alle mit diesem Attribut verknüpften Kontaktdaten gehen verloren.} other {Dadurch werden die ausgewählten Attribute gelöscht. Alle mit diesen Attributen verknüpften Kontaktdaten gehen verloren.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Dadurch wird das ausgewählte Attribut gelöscht. Alle mit diesem Attribut verknüpften Kontaktdaten gehen verloren.} other {Dadurch werden die ausgewählten Attribute gelöscht. Alle mit diesen Attributen verknüpften Kontaktdaten gehen verloren.}}",
|
||||||
"delete_contact_confirmation": "Dies wird alle Umfrageantworten und Kontaktattribute löschen, die mit diesem Kontakt verbunden sind. Jegliche zielgerichtete Kommunikation und Personalisierung basierend auf den Daten dieses Kontakts gehen verloren.",
|
"delete_contact_confirmation": "Dies wird alle Umfrageantworten und Kontaktattribute löschen, die mit diesem Kontakt verbunden sind. Jegliche zielgerichtete Kommunikation und Personalisierung basierend auf den Daten dieses Kontakts gehen verloren.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Dies wird alle Umfrageantworten und Kontaktattribute löschen, die mit diesem Kontakt verbunden sind. Jegliche zielgerichtete Kommunikation und Personalisierung basierend auf den Daten dieses Kontakts gehen verloren. Wenn dieser Kontakt Antworten hat, die zu den Umfragequoten zählen, werden die Quotenstände reduziert, aber die Quotenlimits bleiben unverändert.} other {Dies wird alle Umfrageantworten und Kontaktattribute löschen, die mit diesen Kontakten verbunden sind. Jegliche zielgerichtete Kommunikation und Personalisierung basierend auf den Daten dieses Kontakts gehen verloren. Wenn diesen Kontakten Antworten haben, die zu den Umfragequoten zählen, werden die Quotenstände reduziert, aber die Quotenlimits bleiben unverändert.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Dies wird alle Umfrageantworten und Kontaktattribute löschen, die mit diesem Kontakt verbunden sind. Jegliche zielgerichtete Kommunikation und Personalisierung basierend auf den Daten dieses Kontakts gehen verloren. Wenn dieser Kontakt Antworten hat, die zu den Umfragequoten zählen, werden die Quotenstände reduziert, aber die Quotenlimits bleiben unverändert.} other {Dies wird alle Umfrageantworten und Kontaktattribute löschen, die mit diesen Kontakten verbunden sind. Jegliche zielgerichtete Kommunikation und Personalisierung basierend auf den Daten dieses Kontakts gehen verloren. Wenn diesen Kontakten Antworten haben, die zu den Umfragequoten zählen, werden die Quotenstände reduziert, aber die Quotenlimits bleiben unverändert.}}",
|
||||||
|
"displays": "Anzeigen",
|
||||||
"edit_attribute": "Attribut bearbeiten",
|
"edit_attribute": "Attribut bearbeiten",
|
||||||
"edit_attribute_description": "Aktualisieren Sie die Bezeichnung und Beschreibung für dieses Attribut.",
|
"edit_attribute_description": "Aktualisieren Sie die Bezeichnung und Beschreibung für dieses Attribut.",
|
||||||
"edit_attribute_values": "Attribute bearbeiten",
|
"edit_attribute_values": "Attribute bearbeiten",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Ungültige CSV-Spaltennamen: {columns}. Spaltennamen, die zu neuen Attributen werden, dürfen nur Kleinbuchstaben, Zahlen und Unterstriche enthalten und müssen mit einem Buchstaben beginnen.",
|
"invalid_csv_column_names": "Ungültige CSV-Spaltennamen: {columns}. Spaltennamen, die zu neuen Attributen werden, dürfen nur Kleinbuchstaben, Zahlen und Unterstriche enthalten und müssen mit einem Buchstaben beginnen.",
|
||||||
"invalid_date_format": "Ungültiges Datumsformat. Bitte verwende ein gültiges Datum.",
|
"invalid_date_format": "Ungültiges Datumsformat. Bitte verwende ein gültiges Datum.",
|
||||||
"invalid_number_format": "Ungültiges Zahlenformat. Bitte gib eine gültige Zahl ein.",
|
"invalid_number_format": "Ungültiges Zahlenformat. Bitte gib eine gültige Zahl ein.",
|
||||||
|
"no_activity_yet": "Noch keine Aktivität",
|
||||||
"no_published_link_surveys_available": "Keine veröffentlichten Link-Umfragen verfügbar. Bitte veröffentliche zuerst eine Link-Umfrage.",
|
"no_published_link_surveys_available": "Keine veröffentlichten Link-Umfragen verfügbar. Bitte veröffentliche zuerst eine Link-Umfrage.",
|
||||||
"no_published_surveys": "Keine veröffentlichten Umfragen",
|
"no_published_surveys": "Keine veröffentlichten Umfragen",
|
||||||
"no_responses_found": "Keine Antworten gefunden",
|
"no_responses_found": "Keine Antworten gefunden",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Wähle eine Umfrage aus",
|
"select_a_survey": "Wähle eine Umfrage aus",
|
||||||
"select_attribute": "Attribut auswählen",
|
"select_attribute": "Attribut auswählen",
|
||||||
"select_attribute_key": "Attributschlüssel auswählen",
|
"select_attribute_key": "Attributschlüssel auswählen",
|
||||||
|
"survey_viewed": "Umfrage angesehen",
|
||||||
|
"survey_viewed_at": "Angesehen am",
|
||||||
"system_attributes": "Systemattribute",
|
"system_attributes": "Systemattribute",
|
||||||
"unlock_contacts_description": "Verwalte Kontakte und sende gezielte Umfragen",
|
"unlock_contacts_description": "Verwalte Kontakte und sende gezielte Umfragen",
|
||||||
"unlock_contacts_title": "Kontakte mit einem höheren Plan freischalten",
|
"unlock_contacts_title": "Kontakte mit einem höheren Plan freischalten",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Hey {userName}",
|
"email_customization_preview_email_heading": "Hey {userName}",
|
||||||
"email_customization_preview_email_text": "Dies ist eine E-Mail-Vorschau, um dir zu zeigen, welches Logo in den E-Mails gerendert wird.",
|
"email_customization_preview_email_text": "Dies ist eine E-Mail-Vorschau, um dir zu zeigen, welches Logo in den E-Mails gerendert wird.",
|
||||||
"error_deleting_organization_please_try_again": "Fehler beim Löschen der Organisation. Bitte versuche es erneut.",
|
"error_deleting_organization_please_try_again": "Fehler beim Löschen der Organisation. Bitte versuche es erneut.",
|
||||||
"from_your_organization": "von deiner Organisation",
|
"from_your_organization": "{memberName} aus Ihrer Organisation",
|
||||||
"invitation_sent_once_more": "Einladung nochmal gesendet.",
|
"invitation_sent_once_more": "Einladung nochmal gesendet.",
|
||||||
"invite_deleted_successfully": "Einladung erfolgreich gelöscht",
|
"invite_deleted_successfully": "Einladung erfolgreich gelöscht",
|
||||||
"invite_expires_on": "Einladung läuft ab am {date}",
|
"invite_expires_on": "Einladung läuft ab am {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Platzhalter hinzufügen, falls kein Wert zur Verfügung steht.",
|
"add_fallback_placeholder": "Platzhalter hinzufügen, falls kein Wert zur Verfügung steht.",
|
||||||
"add_hidden_field_id": "Verstecktes Feld ID hinzufügen",
|
"add_hidden_field_id": "Verstecktes Feld ID hinzufügen",
|
||||||
"add_highlight_border": "Rahmen hinzufügen",
|
"add_highlight_border": "Rahmen hinzufügen",
|
||||||
|
"add_highlight_border_description": "Gilt nur für In-Product-Umfragen.",
|
||||||
"add_logic": "Logik hinzufügen",
|
"add_logic": "Logik hinzufügen",
|
||||||
"add_none_of_the_above": "Füge \"Keine der oben genannten Optionen\" hinzu",
|
"add_none_of_the_above": "Füge \"Keine der oben genannten Optionen\" hinzu",
|
||||||
"add_option": "Option hinzufügen",
|
"add_option": "Option hinzufügen",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Nachverfolgung aktualisiert und wird gespeichert, sobald du die Umfrage speicherst.",
|
"follow_ups_modal_updated_successfull_toast": "Nachverfolgung aktualisiert und wird gespeichert, sobald du die Umfrage speicherst.",
|
||||||
"follow_ups_new": "Neues Follow-up",
|
"follow_ups_new": "Neues Follow-up",
|
||||||
"follow_ups_upgrade_button_text": "Upgrade, um Follow-ups zu aktivieren",
|
"follow_ups_upgrade_button_text": "Upgrade, um Follow-ups zu aktivieren",
|
||||||
"form_styling": "Umfrage Styling",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK ist nicht verbunden",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK ist nicht verbunden",
|
||||||
"four_points": "4 Punkte",
|
"four_points": "4 Punkte",
|
||||||
"heading": "Überschrift",
|
"heading": "Überschrift",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Antwort Limits, Weiterleitungen und mehr.",
|
"response_limits_redirections_and_more": "Antwort Limits, Weiterleitungen und mehr.",
|
||||||
"response_options": "Antwortoptionen",
|
"response_options": "Antwortoptionen",
|
||||||
"roundness": "Rundheit",
|
"roundness": "Rundheit",
|
||||||
"roundness_description": "Steuert, wie abgerundet die Kartenecken sind.",
|
"roundness_description": "Steuert, wie abgerundet die Ecken sind.",
|
||||||
"row_used_in_logic_error": "Diese Zeile wird in der Logik der Frage {questionIndex} verwendet. Bitte entferne sie zuerst aus der Logik.",
|
"row_used_in_logic_error": "Diese Zeile wird in der Logik der Frage {questionIndex} verwendet. Bitte entferne sie zuerst aus der Logik.",
|
||||||
"rows": "Zeilen",
|
"rows": "Zeilen",
|
||||||
"save_and_close": "Speichern & Schließen",
|
"save_and_close": "Speichern & Schließen",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Diese kostenlose und quelloffene Umfrage wurde geschlossen",
|
"survey_completed_subheading": "Diese kostenlose und quelloffene Umfrage wurde geschlossen",
|
||||||
"survey_display_settings": "Einstellungen zur Anzeige der Umfrage",
|
"survey_display_settings": "Einstellungen zur Anzeige der Umfrage",
|
||||||
"survey_placement": "Platzierung der Umfrage",
|
"survey_placement": "Platzierung der Umfrage",
|
||||||
|
"survey_styling": "Umfrage Styling",
|
||||||
"survey_trigger": "Auslöser der Umfrage",
|
"survey_trigger": "Auslöser der Umfrage",
|
||||||
"switch_multi_language_on_to_get_started": "Aktiviere Mehrsprachigkeit, um loszulegen 👉",
|
"switch_multi_language_on_to_get_started": "Aktiviere Mehrsprachigkeit, um loszulegen 👉",
|
||||||
"target_block_not_found": "Zielblock nicht gefunden",
|
"target_block_not_found": "Zielblock nicht gefunden",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Willkommensnachricht",
|
"welcome_message": "Willkommensnachricht",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Ohne Filter können alle deine Nutzer befragt werden.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Ohne Filter können alle deine Nutzer befragt werden.",
|
||||||
"you_have_not_created_a_segment_yet": "Du hast noch keinen Segment erstellt.",
|
"you_have_not_created_a_segment_yet": "Du hast noch keinen Segment erstellt.",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Sie müssen zwei oder mehr Sprachen in Ihrem Workspace eingerichtet haben, um mit Übersetzungen zu arbeiten.",
|
|
||||||
"your_description_here_recall_information_with": "Deine Beschreibung hier. Informationen abrufen mit @",
|
"your_description_here_recall_information_with": "Deine Beschreibung hier. Informationen abrufen mit @",
|
||||||
"your_question_here_recall_information_with": "Deine Frage hier. Informationen abrufen mit @",
|
"your_question_here_recall_information_with": "Deine Frage hier. Informationen abrufen mit @",
|
||||||
"your_web_app": "Deine Web-App",
|
"your_web_app": "Deine Web-App",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Gefilterte Antworten (Excel)",
|
"filtered_responses_excel": "Gefilterte Antworten (Excel)",
|
||||||
"generating_qr_code": "QR-Code wird generiert",
|
"generating_qr_code": "QR-Code wird generiert",
|
||||||
"impressions": "Eindrücke",
|
"impressions": "Eindrücke",
|
||||||
|
"impressions_identified_only": "Zeigt nur Impressionen von identifizierten Kontakten",
|
||||||
"impressions_tooltip": "Anzahl der Aufrufe der Umfrage.",
|
"impressions_tooltip": "Anzahl der Aufrufe der Umfrage.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "Die Umfrage wird den Nutzern Ihrer Website angezeigt, die den unten aufgeführten Kriterien entsprechen",
|
"connection_description": "Die Umfrage wird den Nutzern Ihrer Website angezeigt, die den unten aufgeführten Kriterien entsprechen",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Letztes Quartal",
|
"last_quarter": "Letztes Quartal",
|
||||||
"last_year": "Letztes Jahr",
|
"last_year": "Letztes Jahr",
|
||||||
"limit": "Limit",
|
"limit": "Limit",
|
||||||
|
"no_identified_impressions": "Keine Impressionen von identifizierten Kontakten",
|
||||||
"no_responses_found": "Keine Antworten gefunden",
|
"no_responses_found": "Keine Antworten gefunden",
|
||||||
"other_values_found": "Andere Werte gefunden",
|
"other_values_found": "Andere Werte gefunden",
|
||||||
"overall": "Insgesamt",
|
"overall": "Insgesamt",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Startet",
|
"starts": "Startet",
|
||||||
"starts_tooltip": "So oft wurde die Umfrage gestartet.",
|
"starts_tooltip": "So oft wurde die Umfrage gestartet.",
|
||||||
"survey_reset_successfully": "Umfrage erfolgreich zurückgesetzt! {responseCount} Antworten und {displayCount} Anzeigen wurden gelöscht.",
|
"survey_reset_successfully": "Umfrage erfolgreich zurückgesetzt! {responseCount} Antworten und {displayCount} Anzeigen wurden gelöscht.",
|
||||||
|
"survey_results": "{surveyName}-Ergebnisse",
|
||||||
"this_month": "Dieser Monat",
|
"this_month": "Dieser Monat",
|
||||||
"this_quarter": "Dieses Quartal",
|
"this_quarter": "Dieses Quartal",
|
||||||
"this_year": "Dieses Jahr",
|
"this_year": "Dieses Jahr",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Färbt den gefüllten Teil des Balkens.",
|
"advanced_styling_field_indicator_bg_description": "Färbt den gefüllten Teil des Balkens.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Rundet die Eingabeecken ab.",
|
"advanced_styling_field_input_border_radius_description": "Rundet die Eingabeecken ab.",
|
||||||
"advanced_styling_field_input_font_size_description": "Skaliert den eingegebenen Text in Eingabefeldern.",
|
"advanced_styling_field_input_font_size_description": "Skaliert den eingegebenen Text in Eingabefeldern.",
|
||||||
"advanced_styling_field_input_height_description": "Legt die Mindesthöhe des Eingabefelds fest.",
|
"advanced_styling_field_input_height_description": "Steuert die Mindesthöhe der Eingabe.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Fügt links und rechts Abstand hinzu.",
|
"advanced_styling_field_input_padding_x_description": "Fügt links und rechts Abstand hinzu.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Fügt oben und unten Abstand hinzu.",
|
"advanced_styling_field_input_padding_y_description": "Fügt oben und unten Abstand hinzu.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Blendet den Platzhaltertext aus.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Blendet den Platzhaltertext aus.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Färbt den eingegebenen Text in Eingabefeldern.",
|
"advanced_styling_field_input_text_description": "Färbt den eingegebenen Text in Eingabefeldern.",
|
||||||
"advanced_styling_field_option_bg": "Hintergrund",
|
"advanced_styling_field_option_bg": "Hintergrund",
|
||||||
"advanced_styling_field_option_bg_description": "Füllt die Optionselemente.",
|
"advanced_styling_field_option_bg_description": "Füllt die Optionselemente.",
|
||||||
|
"advanced_styling_field_option_border": "Rahmenfarbe",
|
||||||
|
"advanced_styling_field_option_border_description": "Umrandet Radio- und Checkbox-Optionen.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Rundet die Ecken der Optionen ab.",
|
"advanced_styling_field_option_border_radius_description": "Rundet die Ecken der Optionen ab.",
|
||||||
"advanced_styling_field_option_font_size_description": "Skaliert den Text der Optionsbeschriftung.",
|
"advanced_styling_field_option_font_size_description": "Skaliert den Text der Optionsbeschriftung.",
|
||||||
"advanced_styling_field_option_label": "Label-Farbe",
|
"advanced_styling_field_option_label": "Label-Farbe",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Nein, danke!",
|
"preview_survey_question_2_choice_2_label": "Nein, danke!",
|
||||||
"preview_survey_question_2_headline": "Möchtest Du auf dem Laufenden bleiben?",
|
"preview_survey_question_2_headline": "Möchtest Du auf dem Laufenden bleiben?",
|
||||||
"preview_survey_question_2_subheader": "Dies ist eine Beispielbeschreibung.",
|
"preview_survey_question_2_subheader": "Dies ist eine Beispielbeschreibung.",
|
||||||
|
"preview_survey_question_open_text_headline": "Möchtest Du noch etwas teilen?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Tippe deine Antwort hier...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Dein Feedback hilft uns, besser zu werden.",
|
||||||
"preview_survey_welcome_card_headline": "Willkommen!",
|
"preview_survey_welcome_card_headline": "Willkommen!",
|
||||||
"prioritize_features_description": "Identifiziere die Funktionen, die deine Nutzer am meisten und am wenigsten brauchen.",
|
"prioritize_features_description": "Identifiziere die Funktionen, die deine Nutzer am meisten und am wenigsten brauchen.",
|
||||||
"prioritize_features_name": "Funktionen priorisieren",
|
"prioritize_features_name": "Funktionen priorisieren",
|
||||||
|
|||||||
+31
-12
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Copy",
|
"copy": "Copy",
|
||||||
"copy_code": "Copy code",
|
"copy_code": "Copy code",
|
||||||
"copy_link": "Copy Link",
|
"copy_link": "Copy Link",
|
||||||
"count_attributes": "{value, plural, one {{value} attribute} other {{value} attributes}}",
|
"count_attributes": "{count, plural, one {{count} attribute} other {{count} attributes}}",
|
||||||
"count_contacts": "{value, plural, one {{value} contact} other {{value} contacts}}",
|
"count_contacts": "{count, plural, one {{count} contact} other {{count} contacts}}",
|
||||||
"count_responses": "{value, plural, one {{value} response} other {{value} responses}}",
|
"count_members": "{count, plural, one {{count} member} other {{count} members}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} response} other {{count} responses}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} selection} other {{count} selections}}",
|
||||||
"create_new_organization": "Create new organization",
|
"create_new_organization": "Create new organization",
|
||||||
"create_segment": "Create segment",
|
"create_segment": "Create segment",
|
||||||
"create_survey": "Create survey",
|
"create_survey": "Create survey",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "days",
|
"days": "days",
|
||||||
"default": "Default",
|
"default": "Default",
|
||||||
"delete": "Delete",
|
"delete": "Delete",
|
||||||
|
"delete_what": "Delete {deleteWhat}",
|
||||||
"description": "Description",
|
"description": "Description",
|
||||||
"dev_env": "Dev Environment",
|
"dev_env": "Dev Environment",
|
||||||
"development": "Development",
|
"development": "Development",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Error",
|
"error": "Error",
|
||||||
"error_component_description": "This resource does not exist or you do not have the necessary rights to access it.",
|
"error_component_description": "This resource does not exist or you do not have the necessary rights to access it.",
|
||||||
"error_component_title": "Error loading resources",
|
"error_component_title": "Error loading resources",
|
||||||
|
"error_loading_data": "Error loading data",
|
||||||
"error_rate_limit_description": "Maximum number of requests reached. Please try again later.",
|
"error_rate_limit_description": "Maximum number of requests reached. Please try again later.",
|
||||||
"error_rate_limit_title": "Rate Limit Exceeded",
|
"error_rate_limit_title": "Rate Limit Exceeded",
|
||||||
"expand_rows": "Expand rows",
|
"expand_rows": "Expand rows",
|
||||||
"failed_to_copy_to_clipboard": "Failed to copy to clipboard",
|
"failed_to_copy_to_clipboard": "Failed to copy to clipboard",
|
||||||
"failed_to_load_organizations": "Failed to load organizations",
|
"failed_to_load_organizations": "Failed to load organizations",
|
||||||
"failed_to_load_workspaces": "Failed to load workspaces",
|
"failed_to_load_workspaces": "Failed to load workspaces",
|
||||||
|
"filter": "Filter",
|
||||||
"finish": "Finish",
|
"finish": "Finish",
|
||||||
|
"first_name": "First Name",
|
||||||
"follow_these": "Follow these",
|
"follow_these": "Follow these",
|
||||||
"formbricks_version": "Formbricks Version",
|
"formbricks_version": "Formbricks Version",
|
||||||
"full_name": "Full name",
|
"full_name": "Full name",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Hidden field",
|
"hidden_field": "Hidden field",
|
||||||
"hidden_fields": "Hidden fields",
|
"hidden_fields": "Hidden fields",
|
||||||
"hide_column": "Hide column",
|
"hide_column": "Hide column",
|
||||||
|
"id": "ID",
|
||||||
"image": "Image",
|
"image": "Image",
|
||||||
"images": "Images",
|
"images": "Images",
|
||||||
"import": "Import",
|
"import": "Import",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Key",
|
"key": "Key",
|
||||||
"label": "Label",
|
"label": "Label",
|
||||||
"language": "Language",
|
"language": "Language",
|
||||||
|
"last_name": "Last Name",
|
||||||
"learn_more": "Learn more",
|
"learn_more": "Learn more",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Light overlay",
|
"light_overlay": "Light overlay",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Look & Feel",
|
"look_and_feel": "Look & Feel",
|
||||||
"manage": "Manage",
|
"manage": "Manage",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Member",
|
|
||||||
"members": "Members",
|
"members": "Members",
|
||||||
"members_and_teams": "Members & Teams",
|
"members_and_teams": "Members & Teams",
|
||||||
"membership_not_found": "Membership not found",
|
"membership_not_found": "Membership not found",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Move down",
|
"move_down": "Move down",
|
||||||
"move_up": "Move up",
|
"move_up": "Move up",
|
||||||
"multiple_languages": "Multiple languages",
|
"multiple_languages": "Multiple languages",
|
||||||
|
"my_product": "my Product",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"new": "New",
|
"new": "New",
|
||||||
"new_version_available": "Formbricks {version} is here. Upgrade now!",
|
"new_version_available": "Formbricks {version} is here. Upgrade now!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Select teams",
|
"select_teams": "Select teams",
|
||||||
"selected": "Selected",
|
"selected": "Selected",
|
||||||
"selected_questions": "Selected questions",
|
"selected_questions": "Selected questions",
|
||||||
"selection": "Selection",
|
|
||||||
"selections": "Selections",
|
|
||||||
"send_test_email": "Send test email",
|
"send_test_email": "Send test email",
|
||||||
"session_not_found": "Session not found",
|
"session_not_found": "Session not found",
|
||||||
"settings": "Settings",
|
"settings": "Settings",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Top Right",
|
"top_right": "Top Right",
|
||||||
"try_again": "Try again",
|
"try_again": "Try again",
|
||||||
"type": "Type",
|
"type": "Type",
|
||||||
|
"unknown_survey": "Unknown survey",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Unlock more workspaces with a higher plan.",
|
"unlock_more_workspaces_with_a_higher_plan": "Unlock more workspaces with a higher plan.",
|
||||||
"update": "Update",
|
"update": "Update",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {This will delete the selected attribute. Any contact data associated with this attribute will be lost.} other {This will delete the selected attributes. Any contact data associated with these attributes will be lost.}}",
|
"delete_attribute_confirmation": "{value, plural, one {This will delete the selected attribute. Any contact data associated with this attribute will be lost.} other {This will delete the selected attributes. Any contact data associated with these attributes will be lost.}}",
|
||||||
"delete_contact_confirmation": "This will delete all survey responses and contact attributes associated with this contact. Any targeting and personalization based on this contact’s data will be lost.",
|
"delete_contact_confirmation": "This will delete all survey responses and contact attributes associated with this contact. Any targeting and personalization based on this contact’s data will be lost.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {This will delete all survey responses and contact attributes associated with this contact. Any targeting and personalization based on this contact’s data will be lost. If this contact has responses that count towards survey quotas, the quota counts will be reduced but the quota limits will remain unchanged.} other {This will delete all survey responses and contact attributes associated with these contacts. Any targeting and personalization based on these contacts’ data will be lost. If these contacts have responses that count towards survey quotas, the quota counts will be reduced but the quota limits will remain unchanged.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {This will delete all survey responses and contact attributes associated with this contact. Any targeting and personalization based on this contact’s data will be lost. If this contact has responses that count towards survey quotas, the quota counts will be reduced but the quota limits will remain unchanged.} other {This will delete all survey responses and contact attributes associated with these contacts. Any targeting and personalization based on these contacts’ data will be lost. If these contacts have responses that count towards survey quotas, the quota counts will be reduced but the quota limits will remain unchanged.}}",
|
||||||
|
"displays": "Displays",
|
||||||
"edit_attribute": "Edit attribute",
|
"edit_attribute": "Edit attribute",
|
||||||
"edit_attribute_description": "Update the label and description for this attribute.",
|
"edit_attribute_description": "Update the label and description for this attribute.",
|
||||||
"edit_attribute_values": "Edit attributes",
|
"edit_attribute_values": "Edit attributes",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Invalid CSV column name(s): {columns}. Column names that will become new attributes must only contain lowercase letters, numbers, and underscores, and must start with a letter.",
|
"invalid_csv_column_names": "Invalid CSV column name(s): {columns}. Column names that will become new attributes must only contain lowercase letters, numbers, and underscores, and must start with a letter.",
|
||||||
"invalid_date_format": "Invalid date format. Please use a valid date.",
|
"invalid_date_format": "Invalid date format. Please use a valid date.",
|
||||||
"invalid_number_format": "Invalid number format. Please enter a valid number.",
|
"invalid_number_format": "Invalid number format. Please enter a valid number.",
|
||||||
|
"no_activity_yet": "No activity yet",
|
||||||
"no_published_link_surveys_available": "No published link surveys available. Please publish a link survey first.",
|
"no_published_link_surveys_available": "No published link surveys available. Please publish a link survey first.",
|
||||||
"no_published_surveys": "No published surveys",
|
"no_published_surveys": "No published surveys",
|
||||||
"no_responses_found": "No responses found",
|
"no_responses_found": "No responses found",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Select a survey",
|
"select_a_survey": "Select a survey",
|
||||||
"select_attribute": "Select Attribute",
|
"select_attribute": "Select Attribute",
|
||||||
"select_attribute_key": "Select attribute key",
|
"select_attribute_key": "Select attribute key",
|
||||||
|
"survey_viewed": "Survey viewed",
|
||||||
|
"survey_viewed_at": "Viewed At",
|
||||||
"system_attributes": "System Attributes",
|
"system_attributes": "System Attributes",
|
||||||
"unlock_contacts_description": "Manage contacts and send out targeted surveys",
|
"unlock_contacts_description": "Manage contacts and send out targeted surveys",
|
||||||
"unlock_contacts_title": "Unlock contacts with a higher plan",
|
"unlock_contacts_title": "Unlock contacts with a higher plan",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Hey {userName}",
|
"email_customization_preview_email_heading": "Hey {userName}",
|
||||||
"email_customization_preview_email_text": "This is an email preview to show you which logo will be rendered in the emails.",
|
"email_customization_preview_email_text": "This is an email preview to show you which logo will be rendered in the emails.",
|
||||||
"error_deleting_organization_please_try_again": "Error deleting organization. Please try again.",
|
"error_deleting_organization_please_try_again": "Error deleting organization. Please try again.",
|
||||||
"from_your_organization": "from your organization",
|
"from_your_organization": "{memberName} from your organization",
|
||||||
"invitation_sent_once_more": "Invitation sent once more.",
|
"invitation_sent_once_more": "Invitation sent once more.",
|
||||||
"invite_deleted_successfully": "Invite deleted successfully",
|
"invite_deleted_successfully": "Invite deleted successfully",
|
||||||
"invite_expires_on": "Invite expires on {date}",
|
"invite_expires_on": "Invite expires on {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Add a placeholder to show if there is no value to recall.",
|
"add_fallback_placeholder": "Add a placeholder to show if there is no value to recall.",
|
||||||
"add_hidden_field_id": "Add hidden field ID",
|
"add_hidden_field_id": "Add hidden field ID",
|
||||||
"add_highlight_border": "Add highlight border",
|
"add_highlight_border": "Add highlight border",
|
||||||
|
"add_highlight_border_description": "Only applies to in-product surveys.",
|
||||||
"add_logic": "Add logic",
|
"add_logic": "Add logic",
|
||||||
"add_none_of_the_above": "Add “None of the Above”",
|
"add_none_of_the_above": "Add “None of the Above”",
|
||||||
"add_option": "Add option",
|
"add_option": "Add option",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Follow-up updated and will be saved once you save the survey.",
|
"follow_ups_modal_updated_successfull_toast": "Follow-up updated and will be saved once you save the survey.",
|
||||||
"follow_ups_new": "New follow-up",
|
"follow_ups_new": "New follow-up",
|
||||||
"follow_ups_upgrade_button_text": "Upgrade to enable follow-ups",
|
"follow_ups_upgrade_button_text": "Upgrade to enable follow-ups",
|
||||||
"form_styling": "Form styling",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK is not connected",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK is not connected",
|
||||||
"four_points": "4 points",
|
"four_points": "4 points",
|
||||||
"heading": "Heading",
|
"heading": "Heading",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Response limits, redirections and more.",
|
"response_limits_redirections_and_more": "Response limits, redirections and more.",
|
||||||
"response_options": "Response Options",
|
"response_options": "Response Options",
|
||||||
"roundness": "Roundness",
|
"roundness": "Roundness",
|
||||||
"roundness_description": "Controls how rounded the card corners are.",
|
"roundness_description": "Controls how rounded corners are.",
|
||||||
"row_used_in_logic_error": "This row is used in logic of question {questionIndex}. Please remove it from logic first.",
|
"row_used_in_logic_error": "This row is used in logic of question {questionIndex}. Please remove it from logic first.",
|
||||||
"rows": "Rows",
|
"rows": "Rows",
|
||||||
"save_and_close": "Save & Close",
|
"save_and_close": "Save & Close",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "This free & open-source survey has been closed",
|
"survey_completed_subheading": "This free & open-source survey has been closed",
|
||||||
"survey_display_settings": "Survey Display Settings",
|
"survey_display_settings": "Survey Display Settings",
|
||||||
"survey_placement": "Survey Placement",
|
"survey_placement": "Survey Placement",
|
||||||
|
"survey_styling": "Survey styling",
|
||||||
"survey_trigger": "Survey Trigger",
|
"survey_trigger": "Survey Trigger",
|
||||||
"switch_multi_language_on_to_get_started": "Switch multi-language on to get started 👉",
|
"switch_multi_language_on_to_get_started": "Switch multi-language on to get started 👉",
|
||||||
"target_block_not_found": "Target block not found",
|
"target_block_not_found": "Target block not found",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Welcome message",
|
"welcome_message": "Welcome message",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Without a filter, all of your users can be surveyed.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Without a filter, all of your users can be surveyed.",
|
||||||
"you_have_not_created_a_segment_yet": "You have not created a segment yet",
|
"you_have_not_created_a_segment_yet": "You have not created a segment yet",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "You need to have two or more languages set up in your workspace to work with translations.",
|
|
||||||
"your_description_here_recall_information_with": "Your description here. Recall information with @",
|
"your_description_here_recall_information_with": "Your description here. Recall information with @",
|
||||||
"your_question_here_recall_information_with": "Your question here. Recall information with @",
|
"your_question_here_recall_information_with": "Your question here. Recall information with @",
|
||||||
"your_web_app": "Your web app",
|
"your_web_app": "Your web app",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Filtered responses (Excel)",
|
"filtered_responses_excel": "Filtered responses (Excel)",
|
||||||
"generating_qr_code": "Generating QR code",
|
"generating_qr_code": "Generating QR code",
|
||||||
"impressions": "Impressions",
|
"impressions": "Impressions",
|
||||||
|
"impressions_identified_only": "Only showing impressions from identified contacts",
|
||||||
"impressions_tooltip": "Number of times the survey has been viewed.",
|
"impressions_tooltip": "Number of times the survey has been viewed.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "The survey will be shown to users of your website, that match the criteria listed below",
|
"connection_description": "The survey will be shown to users of your website, that match the criteria listed below",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Last quarter",
|
"last_quarter": "Last quarter",
|
||||||
"last_year": "Last year",
|
"last_year": "Last year",
|
||||||
"limit": "Limit",
|
"limit": "Limit",
|
||||||
|
"no_identified_impressions": "No impressions from identified contacts",
|
||||||
"no_responses_found": "No responses found",
|
"no_responses_found": "No responses found",
|
||||||
"other_values_found": "Other values found",
|
"other_values_found": "Other values found",
|
||||||
"overall": "Overall",
|
"overall": "Overall",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Starts",
|
"starts": "Starts",
|
||||||
"starts_tooltip": "Number of times the survey has been started.",
|
"starts_tooltip": "Number of times the survey has been started.",
|
||||||
"survey_reset_successfully": "Survey reset successfully. {responseCount} responses and {displayCount} displays were deleted.",
|
"survey_reset_successfully": "Survey reset successfully. {responseCount} responses and {displayCount} displays were deleted.",
|
||||||
|
"survey_results": "{surveyName} Results",
|
||||||
"this_month": "This month",
|
"this_month": "This month",
|
||||||
"this_quarter": "This quarter",
|
"this_quarter": "This quarter",
|
||||||
"this_year": "This year",
|
"this_year": "This year",
|
||||||
@@ -2148,7 +2162,7 @@
|
|||||||
"advanced_styling_field_description_size": "Description Font Size",
|
"advanced_styling_field_description_size": "Description Font Size",
|
||||||
"advanced_styling_field_description_size_description": "Scales the description text.",
|
"advanced_styling_field_description_size_description": "Scales the description text.",
|
||||||
"advanced_styling_field_description_weight": "Description Font Weight",
|
"advanced_styling_field_description_weight": "Description Font Weight",
|
||||||
"advanced_styling_field_description_weight_description": "Makes description text lighter or bolder.",
|
"advanced_styling_field_description_weight_description": "Makes descr. text lighter or bolder.",
|
||||||
"advanced_styling_field_font_size": "Font Size",
|
"advanced_styling_field_font_size": "Font Size",
|
||||||
"advanced_styling_field_font_weight": "Font Weight",
|
"advanced_styling_field_font_weight": "Font Weight",
|
||||||
"advanced_styling_field_headline_color": "Headline Color",
|
"advanced_styling_field_headline_color": "Headline Color",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Colors the filled portion of the bar.",
|
"advanced_styling_field_indicator_bg_description": "Colors the filled portion of the bar.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Rounds the input corners.",
|
"advanced_styling_field_input_border_radius_description": "Rounds the input corners.",
|
||||||
"advanced_styling_field_input_font_size_description": "Scales the typed text in inputs.",
|
"advanced_styling_field_input_font_size_description": "Scales the typed text in inputs.",
|
||||||
"advanced_styling_field_input_height_description": "Controls the minimum height of the input field.",
|
"advanced_styling_field_input_height_description": "Controls the min. height of the input.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Adds space on the left and right.",
|
"advanced_styling_field_input_padding_x_description": "Adds space on the left and right.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Adds space on the top and bottom.",
|
"advanced_styling_field_input_padding_y_description": "Adds space on the top and bottom.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Fades the placeholder hint text.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Fades the placeholder hint text.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Colors the typed text in inputs.",
|
"advanced_styling_field_input_text_description": "Colors the typed text in inputs.",
|
||||||
"advanced_styling_field_option_bg": "Background",
|
"advanced_styling_field_option_bg": "Background",
|
||||||
"advanced_styling_field_option_bg_description": "Fills the option items.",
|
"advanced_styling_field_option_bg_description": "Fills the option items.",
|
||||||
|
"advanced_styling_field_option_border": "Border Color",
|
||||||
|
"advanced_styling_field_option_border_description": "Outlines radio and checkbox options.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Rounds the option corners.",
|
"advanced_styling_field_option_border_radius_description": "Rounds the option corners.",
|
||||||
"advanced_styling_field_option_font_size_description": "Scales the option label text.",
|
"advanced_styling_field_option_font_size_description": "Scales the option label text.",
|
||||||
"advanced_styling_field_option_label": "Label Color",
|
"advanced_styling_field_option_label": "Label Color",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "No, thank you!",
|
"preview_survey_question_2_choice_2_label": "No, thank you!",
|
||||||
"preview_survey_question_2_headline": "Want to stay in the loop?",
|
"preview_survey_question_2_headline": "Want to stay in the loop?",
|
||||||
"preview_survey_question_2_subheader": "This is an example description.",
|
"preview_survey_question_2_subheader": "This is an example description.",
|
||||||
|
"preview_survey_question_open_text_headline": "Anything else you'd like to share?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Type your answer here…",
|
||||||
|
"preview_survey_question_open_text_subheader": "Your feedback helps us improve.",
|
||||||
"preview_survey_welcome_card_headline": "Welcome!",
|
"preview_survey_welcome_card_headline": "Welcome!",
|
||||||
"prioritize_features_description": "Identify features your users need most and least.",
|
"prioritize_features_description": "Identify features your users need most and least.",
|
||||||
"prioritize_features_name": "Prioritize Features",
|
"prioritize_features_name": "Prioritize Features",
|
||||||
|
|||||||
+31
-12
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Copiar",
|
"copy": "Copiar",
|
||||||
"copy_code": "Copiar código",
|
"copy_code": "Copiar código",
|
||||||
"copy_link": "Copiar enlace",
|
"copy_link": "Copiar enlace",
|
||||||
"count_attributes": "{value, plural, one {{value} atributo} other {{value} atributos}}",
|
"count_attributes": "{count, plural, one {{count} atributo} other {{count} atributos}}",
|
||||||
"count_contacts": "{value, plural, one {{value} contacto} other {{value} contactos}}",
|
"count_contacts": "{count, plural, one {{count} contacto} other {{count} contactos}}",
|
||||||
"count_responses": "{value, plural, one {{value} respuesta} other {{value} respuestas}}",
|
"count_members": "{count, plural, one {{count} miembro} other {{count} miembros}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} respuesta} other {{count} respuestas}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} selección} other {{count} selecciones}}",
|
||||||
"create_new_organization": "Crear organización nueva",
|
"create_new_organization": "Crear organización nueva",
|
||||||
"create_segment": "Crear segmento",
|
"create_segment": "Crear segmento",
|
||||||
"create_survey": "Crear encuesta",
|
"create_survey": "Crear encuesta",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "días",
|
"days": "días",
|
||||||
"default": "Predeterminado",
|
"default": "Predeterminado",
|
||||||
"delete": "Eliminar",
|
"delete": "Eliminar",
|
||||||
|
"delete_what": "Eliminar {deleteWhat}",
|
||||||
"description": "Descripción",
|
"description": "Descripción",
|
||||||
"dev_env": "Entorno de desarrollo",
|
"dev_env": "Entorno de desarrollo",
|
||||||
"development": "Desarrollo",
|
"development": "Desarrollo",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Error",
|
"error": "Error",
|
||||||
"error_component_description": "Este recurso no existe o no tienes los derechos necesarios para acceder a él.",
|
"error_component_description": "Este recurso no existe o no tienes los derechos necesarios para acceder a él.",
|
||||||
"error_component_title": "Error al cargar recursos",
|
"error_component_title": "Error al cargar recursos",
|
||||||
|
"error_loading_data": "Error al cargar los datos",
|
||||||
"error_rate_limit_description": "Número máximo de solicitudes alcanzado. Por favor, inténtalo de nuevo más tarde.",
|
"error_rate_limit_description": "Número máximo de solicitudes alcanzado. Por favor, inténtalo de nuevo más tarde.",
|
||||||
"error_rate_limit_title": "Límite de frecuencia excedido",
|
"error_rate_limit_title": "Límite de frecuencia excedido",
|
||||||
"expand_rows": "Expandir filas",
|
"expand_rows": "Expandir filas",
|
||||||
"failed_to_copy_to_clipboard": "Error al copiar al portapapeles",
|
"failed_to_copy_to_clipboard": "Error al copiar al portapapeles",
|
||||||
"failed_to_load_organizations": "Error al cargar organizaciones",
|
"failed_to_load_organizations": "Error al cargar organizaciones",
|
||||||
"failed_to_load_workspaces": "Error al cargar los proyectos",
|
"failed_to_load_workspaces": "Error al cargar los proyectos",
|
||||||
|
"filter": "Filtro",
|
||||||
"finish": "Finalizar",
|
"finish": "Finalizar",
|
||||||
|
"first_name": "Nombre",
|
||||||
"follow_these": "Sigue estos",
|
"follow_these": "Sigue estos",
|
||||||
"formbricks_version": "Versión de Formbricks",
|
"formbricks_version": "Versión de Formbricks",
|
||||||
"full_name": "Nombre completo",
|
"full_name": "Nombre completo",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Campo oculto",
|
"hidden_field": "Campo oculto",
|
||||||
"hidden_fields": "Campos ocultos",
|
"hidden_fields": "Campos ocultos",
|
||||||
"hide_column": "Ocultar columna",
|
"hide_column": "Ocultar columna",
|
||||||
|
"id": "ID",
|
||||||
"image": "Imagen",
|
"image": "Imagen",
|
||||||
"images": "Imágenes",
|
"images": "Imágenes",
|
||||||
"import": "Importar",
|
"import": "Importar",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Clave",
|
"key": "Clave",
|
||||||
"label": "Etiqueta",
|
"label": "Etiqueta",
|
||||||
"language": "Idioma",
|
"language": "Idioma",
|
||||||
|
"last_name": "Apellido",
|
||||||
"learn_more": "Saber más",
|
"learn_more": "Saber más",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Superposición clara",
|
"light_overlay": "Superposición clara",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Apariencia",
|
"look_and_feel": "Apariencia",
|
||||||
"manage": "Gestionar",
|
"manage": "Gestionar",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Miembro",
|
|
||||||
"members": "Miembros",
|
"members": "Miembros",
|
||||||
"members_and_teams": "Miembros y equipos",
|
"members_and_teams": "Miembros y equipos",
|
||||||
"membership_not_found": "Membresía no encontrada",
|
"membership_not_found": "Membresía no encontrada",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Mover hacia abajo",
|
"move_down": "Mover hacia abajo",
|
||||||
"move_up": "Mover hacia arriba",
|
"move_up": "Mover hacia arriba",
|
||||||
"multiple_languages": "Múltiples idiomas",
|
"multiple_languages": "Múltiples idiomas",
|
||||||
|
"my_product": "mi producto",
|
||||||
"name": "Nombre",
|
"name": "Nombre",
|
||||||
"new": "Nuevo",
|
"new": "Nuevo",
|
||||||
"new_version_available": "Formbricks {version} está aquí. ¡Actualiza ahora!",
|
"new_version_available": "Formbricks {version} está aquí. ¡Actualiza ahora!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Seleccionar equipos",
|
"select_teams": "Seleccionar equipos",
|
||||||
"selected": "Seleccionado",
|
"selected": "Seleccionado",
|
||||||
"selected_questions": "Preguntas seleccionadas",
|
"selected_questions": "Preguntas seleccionadas",
|
||||||
"selection": "Selección",
|
|
||||||
"selections": "Selecciones",
|
|
||||||
"send_test_email": "Enviar correo electrónico de prueba",
|
"send_test_email": "Enviar correo electrónico de prueba",
|
||||||
"session_not_found": "Sesión no encontrada",
|
"session_not_found": "Sesión no encontrada",
|
||||||
"settings": "Ajustes",
|
"settings": "Ajustes",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Superior derecha",
|
"top_right": "Superior derecha",
|
||||||
"try_again": "Intentar de nuevo",
|
"try_again": "Intentar de nuevo",
|
||||||
"type": "Tipo",
|
"type": "Tipo",
|
||||||
|
"unknown_survey": "Encuesta desconocida",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Desbloquea más proyectos con un plan superior.",
|
"unlock_more_workspaces_with_a_higher_plan": "Desbloquea más proyectos con un plan superior.",
|
||||||
"update": "Actualizar",
|
"update": "Actualizar",
|
||||||
"updated": "Actualizado",
|
"updated": "Actualizado",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Esto eliminará el atributo seleccionado. Se perderán todos los datos de contacto asociados con este atributo.} other {Esto eliminará los atributos seleccionados. Se perderán todos los datos de contacto asociados con estos atributos.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Esto eliminará el atributo seleccionado. Se perderán todos los datos de contacto asociados con este atributo.} other {Esto eliminará los atributos seleccionados. Se perderán todos los datos de contacto asociados con estos atributos.}}",
|
||||||
"delete_contact_confirmation": "Esto eliminará todas las respuestas de encuestas y atributos de contacto asociados con este contacto. Cualquier segmentación y personalización basada en los datos de este contacto se perderá.",
|
"delete_contact_confirmation": "Esto eliminará todas las respuestas de encuestas y atributos de contacto asociados con este contacto. Cualquier segmentación y personalización basada en los datos de este contacto se perderá.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Esto eliminará todas las respuestas de encuestas y atributos de contacto asociados con este contacto. Cualquier segmentación y personalización basada en los datos de este contacto se perderá. Si este contacto tiene respuestas que cuentan para las cuotas de encuesta, los recuentos de cuota se reducirán pero los límites de cuota permanecerán sin cambios.} other {Esto eliminará todas las respuestas de encuestas y atributos de contacto asociados con estos contactos. Cualquier segmentación y personalización basada en los datos de estos contactos se perderá. Si estos contactos tienen respuestas que cuentan para las cuotas de encuesta, los recuentos de cuota se reducirán pero los límites de cuota permanecerán sin cambios.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Esto eliminará todas las respuestas de encuestas y atributos de contacto asociados con este contacto. Cualquier segmentación y personalización basada en los datos de este contacto se perderá. Si este contacto tiene respuestas que cuentan para las cuotas de encuesta, los recuentos de cuota se reducirán pero los límites de cuota permanecerán sin cambios.} other {Esto eliminará todas las respuestas de encuestas y atributos de contacto asociados con estos contactos. Cualquier segmentación y personalización basada en los datos de estos contactos se perderá. Si estos contactos tienen respuestas que cuentan para las cuotas de encuesta, los recuentos de cuota se reducirán pero los límites de cuota permanecerán sin cambios.}}",
|
||||||
|
"displays": "Visualizaciones",
|
||||||
"edit_attribute": "Editar atributo",
|
"edit_attribute": "Editar atributo",
|
||||||
"edit_attribute_description": "Actualiza la etiqueta y la descripción de este atributo.",
|
"edit_attribute_description": "Actualiza la etiqueta y la descripción de este atributo.",
|
||||||
"edit_attribute_values": "Editar atributos",
|
"edit_attribute_values": "Editar atributos",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Nombre(s) de columna CSV no válido(s): {columns}. Los nombres de columna que se convertirán en nuevos atributos solo deben contener letras minúsculas, números y guiones bajos, y deben comenzar con una letra.",
|
"invalid_csv_column_names": "Nombre(s) de columna CSV no válido(s): {columns}. Los nombres de columna que se convertirán en nuevos atributos solo deben contener letras minúsculas, números y guiones bajos, y deben comenzar con una letra.",
|
||||||
"invalid_date_format": "Formato de fecha no válido. Por favor, usa una fecha válida.",
|
"invalid_date_format": "Formato de fecha no válido. Por favor, usa una fecha válida.",
|
||||||
"invalid_number_format": "Formato de número no válido. Por favor, introduce un número válido.",
|
"invalid_number_format": "Formato de número no válido. Por favor, introduce un número válido.",
|
||||||
|
"no_activity_yet": "Aún no hay actividad",
|
||||||
"no_published_link_surveys_available": "No hay encuestas de enlace publicadas disponibles. Por favor, publica primero una encuesta de enlace.",
|
"no_published_link_surveys_available": "No hay encuestas de enlace publicadas disponibles. Por favor, publica primero una encuesta de enlace.",
|
||||||
"no_published_surveys": "No hay encuestas publicadas",
|
"no_published_surveys": "No hay encuestas publicadas",
|
||||||
"no_responses_found": "No se encontraron respuestas",
|
"no_responses_found": "No se encontraron respuestas",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Selecciona una encuesta",
|
"select_a_survey": "Selecciona una encuesta",
|
||||||
"select_attribute": "Seleccionar atributo",
|
"select_attribute": "Seleccionar atributo",
|
||||||
"select_attribute_key": "Seleccionar clave de atributo",
|
"select_attribute_key": "Seleccionar clave de atributo",
|
||||||
|
"survey_viewed": "Encuesta vista",
|
||||||
|
"survey_viewed_at": "Vista el",
|
||||||
"system_attributes": "Atributos del sistema",
|
"system_attributes": "Atributos del sistema",
|
||||||
"unlock_contacts_description": "Gestiona contactos y envía encuestas dirigidas",
|
"unlock_contacts_description": "Gestiona contactos y envía encuestas dirigidas",
|
||||||
"unlock_contacts_title": "Desbloquea contactos con un plan superior",
|
"unlock_contacts_title": "Desbloquea contactos con un plan superior",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Hola {userName}",
|
"email_customization_preview_email_heading": "Hola {userName}",
|
||||||
"email_customization_preview_email_text": "Este es un correo electrónico de vista previa para mostrarte qué logotipo se mostrará en los correos electrónicos.",
|
"email_customization_preview_email_text": "Este es un correo electrónico de vista previa para mostrarte qué logotipo se mostrará en los correos electrónicos.",
|
||||||
"error_deleting_organization_please_try_again": "Error al eliminar la organización. Por favor, inténtalo de nuevo.",
|
"error_deleting_organization_please_try_again": "Error al eliminar la organización. Por favor, inténtalo de nuevo.",
|
||||||
"from_your_organization": "de tu organización",
|
"from_your_organization": "{memberName} de tu organización",
|
||||||
"invitation_sent_once_more": "Invitación enviada una vez más.",
|
"invitation_sent_once_more": "Invitación enviada una vez más.",
|
||||||
"invite_deleted_successfully": "Invitación eliminada correctamente",
|
"invite_deleted_successfully": "Invitación eliminada correctamente",
|
||||||
"invite_expires_on": "La invitación expira el {date}",
|
"invite_expires_on": "La invitación expira el {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Añadir un marcador de posición para mostrar si no hay valor que recuperar.",
|
"add_fallback_placeholder": "Añadir un marcador de posición para mostrar si no hay valor que recuperar.",
|
||||||
"add_hidden_field_id": "Añadir ID de campo oculto",
|
"add_hidden_field_id": "Añadir ID de campo oculto",
|
||||||
"add_highlight_border": "Añadir borde destacado",
|
"add_highlight_border": "Añadir borde destacado",
|
||||||
|
"add_highlight_border_description": "Solo se aplica a encuestas dentro del producto.",
|
||||||
"add_logic": "Añadir lógica",
|
"add_logic": "Añadir lógica",
|
||||||
"add_none_of_the_above": "Añadir \"Ninguna de las anteriores\"",
|
"add_none_of_the_above": "Añadir \"Ninguna de las anteriores\"",
|
||||||
"add_option": "Añadir opción",
|
"add_option": "Añadir opción",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Seguimiento actualizado y se guardará cuando guardes la encuesta.",
|
"follow_ups_modal_updated_successfull_toast": "Seguimiento actualizado y se guardará cuando guardes la encuesta.",
|
||||||
"follow_ups_new": "Nuevo seguimiento",
|
"follow_ups_new": "Nuevo seguimiento",
|
||||||
"follow_ups_upgrade_button_text": "Actualiza para habilitar seguimientos",
|
"follow_ups_upgrade_button_text": "Actualiza para habilitar seguimientos",
|
||||||
"form_styling": "Estilo del formulario",
|
|
||||||
"formbricks_sdk_is_not_connected": "El SDK de Formbricks no está conectado",
|
"formbricks_sdk_is_not_connected": "El SDK de Formbricks no está conectado",
|
||||||
"four_points": "4 puntos",
|
"four_points": "4 puntos",
|
||||||
"heading": "Encabezado",
|
"heading": "Encabezado",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Límites de respuestas, redirecciones y más.",
|
"response_limits_redirections_and_more": "Límites de respuestas, redirecciones y más.",
|
||||||
"response_options": "Opciones de respuesta",
|
"response_options": "Opciones de respuesta",
|
||||||
"roundness": "Redondez",
|
"roundness": "Redondez",
|
||||||
"roundness_description": "Controla qué tan redondeadas están las esquinas de la tarjeta.",
|
"roundness_description": "Controla qué tan redondeadas están las esquinas.",
|
||||||
"row_used_in_logic_error": "Esta fila se utiliza en la lógica de la pregunta {questionIndex}. Por favor, elimínala de la lógica primero.",
|
"row_used_in_logic_error": "Esta fila se utiliza en la lógica de la pregunta {questionIndex}. Por favor, elimínala de la lógica primero.",
|
||||||
"rows": "Filas",
|
"rows": "Filas",
|
||||||
"save_and_close": "Guardar y cerrar",
|
"save_and_close": "Guardar y cerrar",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Esta encuesta gratuita y de código abierto ha sido cerrada",
|
"survey_completed_subheading": "Esta encuesta gratuita y de código abierto ha sido cerrada",
|
||||||
"survey_display_settings": "Ajustes de visualización de la encuesta",
|
"survey_display_settings": "Ajustes de visualización de la encuesta",
|
||||||
"survey_placement": "Ubicación de la encuesta",
|
"survey_placement": "Ubicación de la encuesta",
|
||||||
|
"survey_styling": "Estilo del formulario",
|
||||||
"survey_trigger": "Activador de la encuesta",
|
"survey_trigger": "Activador de la encuesta",
|
||||||
"switch_multi_language_on_to_get_started": "Activa el modo multiidioma para comenzar 👉",
|
"switch_multi_language_on_to_get_started": "Activa el modo multiidioma para comenzar 👉",
|
||||||
"target_block_not_found": "Bloque objetivo no encontrado",
|
"target_block_not_found": "Bloque objetivo no encontrado",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Mensaje de bienvenida",
|
"welcome_message": "Mensaje de bienvenida",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Sin un filtro, todos tus usuarios pueden ser encuestados.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Sin un filtro, todos tus usuarios pueden ser encuestados.",
|
||||||
"you_have_not_created_a_segment_yet": "Aún no has creado un segmento",
|
"you_have_not_created_a_segment_yet": "Aún no has creado un segmento",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Necesitas tener dos o más idiomas configurados en tu proyecto para trabajar con traducciones.",
|
|
||||||
"your_description_here_recall_information_with": "Tu descripción aquí. Recupera información con @",
|
"your_description_here_recall_information_with": "Tu descripción aquí. Recupera información con @",
|
||||||
"your_question_here_recall_information_with": "Tu pregunta aquí. Recupera información con @",
|
"your_question_here_recall_information_with": "Tu pregunta aquí. Recupera información con @",
|
||||||
"your_web_app": "Tu aplicación web",
|
"your_web_app": "Tu aplicación web",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Respuestas filtradas (Excel)",
|
"filtered_responses_excel": "Respuestas filtradas (Excel)",
|
||||||
"generating_qr_code": "Generando código QR",
|
"generating_qr_code": "Generando código QR",
|
||||||
"impressions": "Impresiones",
|
"impressions": "Impresiones",
|
||||||
|
"impressions_identified_only": "Solo se muestran impresiones de contactos identificados",
|
||||||
"impressions_tooltip": "Número de veces que se ha visto la encuesta.",
|
"impressions_tooltip": "Número de veces que se ha visto la encuesta.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "La encuesta se mostrará a los usuarios de tu sitio web que cumplan con los criterios enumerados a continuación",
|
"connection_description": "La encuesta se mostrará a los usuarios de tu sitio web que cumplan con los criterios enumerados a continuación",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Último trimestre",
|
"last_quarter": "Último trimestre",
|
||||||
"last_year": "Último año",
|
"last_year": "Último año",
|
||||||
"limit": "Límite",
|
"limit": "Límite",
|
||||||
|
"no_identified_impressions": "No hay impresiones de contactos identificados",
|
||||||
"no_responses_found": "No se han encontrado respuestas",
|
"no_responses_found": "No se han encontrado respuestas",
|
||||||
"other_values_found": "Otros valores encontrados",
|
"other_values_found": "Otros valores encontrados",
|
||||||
"overall": "General",
|
"overall": "General",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Inicios",
|
"starts": "Inicios",
|
||||||
"starts_tooltip": "Número de veces que se ha iniciado la encuesta.",
|
"starts_tooltip": "Número de veces que se ha iniciado la encuesta.",
|
||||||
"survey_reset_successfully": "¡Encuesta restablecida correctamente! Se eliminaron {responseCount} respuestas y {displayCount} visualizaciones.",
|
"survey_reset_successfully": "¡Encuesta restablecida correctamente! Se eliminaron {responseCount} respuestas y {displayCount} visualizaciones.",
|
||||||
|
"survey_results": "Resultados de {surveyName}",
|
||||||
"this_month": "Este mes",
|
"this_month": "Este mes",
|
||||||
"this_quarter": "Este trimestre",
|
"this_quarter": "Este trimestre",
|
||||||
"this_year": "Este año",
|
"this_year": "Este año",
|
||||||
@@ -2148,7 +2162,7 @@
|
|||||||
"advanced_styling_field_description_size": "Tamaño de fuente de la descripción",
|
"advanced_styling_field_description_size": "Tamaño de fuente de la descripción",
|
||||||
"advanced_styling_field_description_size_description": "Escala el texto de la descripción.",
|
"advanced_styling_field_description_size_description": "Escala el texto de la descripción.",
|
||||||
"advanced_styling_field_description_weight": "Grosor de fuente de la descripción",
|
"advanced_styling_field_description_weight": "Grosor de fuente de la descripción",
|
||||||
"advanced_styling_field_description_weight_description": "Hace el texto de la descripción más ligero o más grueso.",
|
"advanced_styling_field_description_weight_description": "Hace el texto de descripción más ligero o más grueso.",
|
||||||
"advanced_styling_field_font_size": "Tamaño de fuente",
|
"advanced_styling_field_font_size": "Tamaño de fuente",
|
||||||
"advanced_styling_field_font_weight": "Grosor de fuente",
|
"advanced_styling_field_font_weight": "Grosor de fuente",
|
||||||
"advanced_styling_field_headline_color": "Color del titular",
|
"advanced_styling_field_headline_color": "Color del titular",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Colorea la porción rellena de la barra.",
|
"advanced_styling_field_indicator_bg_description": "Colorea la porción rellena de la barra.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Redondea las esquinas del campo.",
|
"advanced_styling_field_input_border_radius_description": "Redondea las esquinas del campo.",
|
||||||
"advanced_styling_field_input_font_size_description": "Escala el texto escrito en los campos.",
|
"advanced_styling_field_input_font_size_description": "Escala el texto escrito en los campos.",
|
||||||
"advanced_styling_field_input_height_description": "Controla la altura mínima del campo de entrada.",
|
"advanced_styling_field_input_height_description": "Controla la altura mínima de la entrada.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Añade espacio a la izquierda y a la derecha.",
|
"advanced_styling_field_input_padding_x_description": "Añade espacio a la izquierda y a la derecha.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Añade espacio en la parte superior e inferior.",
|
"advanced_styling_field_input_padding_y_description": "Añade espacio en la parte superior e inferior.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Atenúa el texto de sugerencia del marcador de posición.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Atenúa el texto de sugerencia del marcador de posición.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Colorea el texto escrito en los campos de entrada.",
|
"advanced_styling_field_input_text_description": "Colorea el texto escrito en los campos de entrada.",
|
||||||
"advanced_styling_field_option_bg": "Fondo",
|
"advanced_styling_field_option_bg": "Fondo",
|
||||||
"advanced_styling_field_option_bg_description": "Rellena los elementos de opción.",
|
"advanced_styling_field_option_bg_description": "Rellena los elementos de opción.",
|
||||||
|
"advanced_styling_field_option_border": "Color del borde",
|
||||||
|
"advanced_styling_field_option_border_description": "Delimita las opciones de radio y casillas de verificación.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Redondea las esquinas de las opciones.",
|
"advanced_styling_field_option_border_radius_description": "Redondea las esquinas de las opciones.",
|
||||||
"advanced_styling_field_option_font_size_description": "Escala el texto de la etiqueta de opción.",
|
"advanced_styling_field_option_font_size_description": "Escala el texto de la etiqueta de opción.",
|
||||||
"advanced_styling_field_option_label": "Color de la etiqueta",
|
"advanced_styling_field_option_label": "Color de la etiqueta",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "¡No, gracias!",
|
"preview_survey_question_2_choice_2_label": "¡No, gracias!",
|
||||||
"preview_survey_question_2_headline": "¿Quieres estar al tanto?",
|
"preview_survey_question_2_headline": "¿Quieres estar al tanto?",
|
||||||
"preview_survey_question_2_subheader": "Esta es una descripción de ejemplo.",
|
"preview_survey_question_2_subheader": "Esta es una descripción de ejemplo.",
|
||||||
|
"preview_survey_question_open_text_headline": "¿Hay algo más que te gustaría compartir?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Escribe tu respuesta aquí...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Tus comentarios nos ayudan a mejorar.",
|
||||||
"preview_survey_welcome_card_headline": "¡Bienvenido!",
|
"preview_survey_welcome_card_headline": "¡Bienvenido!",
|
||||||
"prioritize_features_description": "Identifica las funciones que tus usuarios necesitan más y menos.",
|
"prioritize_features_description": "Identifica las funciones que tus usuarios necesitan más y menos.",
|
||||||
"prioritize_features_name": "Priorizar funciones",
|
"prioritize_features_name": "Priorizar funciones",
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Copier",
|
"copy": "Copier",
|
||||||
"copy_code": "Copier le code",
|
"copy_code": "Copier le code",
|
||||||
"copy_link": "Copier le lien",
|
"copy_link": "Copier le lien",
|
||||||
"count_attributes": "{value, plural, one {{value} attribut} other {{value} attributs}}",
|
"count_attributes": "{count, plural, one {{count} attribut} other {{count} attributs}}",
|
||||||
"count_contacts": "{value, plural, one {# contact} other {# contacts} }",
|
"count_contacts": "{count, plural, one {# contact} other {# contacts} }",
|
||||||
"count_responses": "{value, plural, other {# réponses}}",
|
"count_members": "{count, plural, one {{count} membre} other {{count} membres}}",
|
||||||
|
"count_responses": "{count, plural, other {# réponses}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} sélection} other {{count} sélections}}",
|
||||||
"create_new_organization": "Créer une nouvelle organisation",
|
"create_new_organization": "Créer une nouvelle organisation",
|
||||||
"create_segment": "Créer un segment",
|
"create_segment": "Créer un segment",
|
||||||
"create_survey": "Créer un sondage",
|
"create_survey": "Créer un sondage",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "jours",
|
"days": "jours",
|
||||||
"default": "Par défaut",
|
"default": "Par défaut",
|
||||||
"delete": "Supprimer",
|
"delete": "Supprimer",
|
||||||
|
"delete_what": "Supprimer {deleteWhat}",
|
||||||
"description": "Description",
|
"description": "Description",
|
||||||
"dev_env": "Environnement de développement",
|
"dev_env": "Environnement de développement",
|
||||||
"development": "Développement",
|
"development": "Développement",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Erreur",
|
"error": "Erreur",
|
||||||
"error_component_description": "Cette ressource n'existe pas ou vous n'avez pas les droits nécessaires pour y accéder.",
|
"error_component_description": "Cette ressource n'existe pas ou vous n'avez pas les droits nécessaires pour y accéder.",
|
||||||
"error_component_title": "Erreur de chargement des ressources",
|
"error_component_title": "Erreur de chargement des ressources",
|
||||||
|
"error_loading_data": "Erreur lors du chargement des données",
|
||||||
"error_rate_limit_description": "Nombre maximal de demandes atteint. Veuillez réessayer plus tard.",
|
"error_rate_limit_description": "Nombre maximal de demandes atteint. Veuillez réessayer plus tard.",
|
||||||
"error_rate_limit_title": "Limite de Taux Dépassée",
|
"error_rate_limit_title": "Limite de Taux Dépassée",
|
||||||
"expand_rows": "Développer les lignes",
|
"expand_rows": "Développer les lignes",
|
||||||
"failed_to_copy_to_clipboard": "Échec de la copie dans le presse-papiers",
|
"failed_to_copy_to_clipboard": "Échec de la copie dans le presse-papiers",
|
||||||
"failed_to_load_organizations": "Échec du chargement des organisations",
|
"failed_to_load_organizations": "Échec du chargement des organisations",
|
||||||
"failed_to_load_workspaces": "Échec du chargement des projets",
|
"failed_to_load_workspaces": "Échec du chargement des projets",
|
||||||
|
"filter": "Filtre",
|
||||||
"finish": "Terminer",
|
"finish": "Terminer",
|
||||||
|
"first_name": "Prénom",
|
||||||
"follow_these": "Suivez ceci",
|
"follow_these": "Suivez ceci",
|
||||||
"formbricks_version": "Version de Formbricks",
|
"formbricks_version": "Version de Formbricks",
|
||||||
"full_name": "Nom complet",
|
"full_name": "Nom complet",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Champ caché",
|
"hidden_field": "Champ caché",
|
||||||
"hidden_fields": "Champs cachés",
|
"hidden_fields": "Champs cachés",
|
||||||
"hide_column": "Cacher la colonne",
|
"hide_column": "Cacher la colonne",
|
||||||
|
"id": "ID",
|
||||||
"image": "Image",
|
"image": "Image",
|
||||||
"images": "Images",
|
"images": "Images",
|
||||||
"import": "Importer",
|
"import": "Importer",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Clé",
|
"key": "Clé",
|
||||||
"label": "Étiquette",
|
"label": "Étiquette",
|
||||||
"language": "Langue",
|
"language": "Langue",
|
||||||
|
"last_name": "Nom de famille",
|
||||||
"learn_more": "En savoir plus",
|
"learn_more": "En savoir plus",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Claire",
|
"light_overlay": "Claire",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Apparence",
|
"look_and_feel": "Apparence",
|
||||||
"manage": "Gérer",
|
"manage": "Gérer",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Membre",
|
|
||||||
"members": "Membres",
|
"members": "Membres",
|
||||||
"members_and_teams": "Membres & Équipes",
|
"members_and_teams": "Membres & Équipes",
|
||||||
"membership_not_found": "Abonnement non trouvé",
|
"membership_not_found": "Abonnement non trouvé",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Déplacer vers le bas",
|
"move_down": "Déplacer vers le bas",
|
||||||
"move_up": "Déplacer vers le haut",
|
"move_up": "Déplacer vers le haut",
|
||||||
"multiple_languages": "Plusieurs langues",
|
"multiple_languages": "Plusieurs langues",
|
||||||
|
"my_product": "mon produit",
|
||||||
"name": "Nom",
|
"name": "Nom",
|
||||||
"new": "Nouveau",
|
"new": "Nouveau",
|
||||||
"new_version_available": "Formbricks {version} est là. Mettez à jour maintenant !",
|
"new_version_available": "Formbricks {version} est là. Mettez à jour maintenant !",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Sélectionner les équipes",
|
"select_teams": "Sélectionner les équipes",
|
||||||
"selected": "Sélectionné",
|
"selected": "Sélectionné",
|
||||||
"selected_questions": "Questions sélectionnées",
|
"selected_questions": "Questions sélectionnées",
|
||||||
"selection": "Sélection",
|
|
||||||
"selections": "Sélections",
|
|
||||||
"send_test_email": "Envoyer un e-mail de test",
|
"send_test_email": "Envoyer un e-mail de test",
|
||||||
"session_not_found": "Session non trouvée",
|
"session_not_found": "Session non trouvée",
|
||||||
"settings": "Paramètres",
|
"settings": "Paramètres",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "En haut à droite",
|
"top_right": "En haut à droite",
|
||||||
"try_again": "Réessayer",
|
"try_again": "Réessayer",
|
||||||
"type": "Type",
|
"type": "Type",
|
||||||
|
"unknown_survey": "Enquête inconnue",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Débloquez plus de projets avec un forfait supérieur.",
|
"unlock_more_workspaces_with_a_higher_plan": "Débloquez plus de projets avec un forfait supérieur.",
|
||||||
"update": "Mise à jour",
|
"update": "Mise à jour",
|
||||||
"updated": "Mise à jour",
|
"updated": "Mise à jour",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Cela supprimera l'attribut sélectionné. Toutes les données de contact associées à cet attribut seront perdues.} other {Cela supprimera les attributs sélectionnés. Toutes les données de contact associées à ces attributs seront perdues.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Cela supprimera l'attribut sélectionné. Toutes les données de contact associées à cet attribut seront perdues.} other {Cela supprimera les attributs sélectionnés. Toutes les données de contact associées à ces attributs seront perdues.}}",
|
||||||
"delete_contact_confirmation": "Cela supprimera toutes les réponses aux enquêtes et les attributs de contact associés à ce contact. Toute la personnalisation et le ciblage basés sur les données de ce contact seront perdus.",
|
"delete_contact_confirmation": "Cela supprimera toutes les réponses aux enquêtes et les attributs de contact associés à ce contact. Toute la personnalisation et le ciblage basés sur les données de ce contact seront perdus.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, other {Cela supprimera toutes les réponses aux enquêtes et les attributs de contact associés à ce contact. Toute la personnalisation et le ciblage basés sur les données de ce contact seront perdus. Si ce contact a des réponses qui comptent dans les quotas de l'enquête, les comptes de quotas seront réduits mais les limites de quota resteront inchangées.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, other {Cela supprimera toutes les réponses aux enquêtes et les attributs de contact associés à ce contact. Toute la personnalisation et le ciblage basés sur les données de ce contact seront perdus. Si ce contact a des réponses qui comptent dans les quotas de l'enquête, les comptes de quotas seront réduits mais les limites de quota resteront inchangées.}}",
|
||||||
|
"displays": "Affichages",
|
||||||
"edit_attribute": "Modifier l'attribut",
|
"edit_attribute": "Modifier l'attribut",
|
||||||
"edit_attribute_description": "Mettez à jour l'étiquette et la description de cet attribut.",
|
"edit_attribute_description": "Mettez à jour l'étiquette et la description de cet attribut.",
|
||||||
"edit_attribute_values": "Modifier les attributs",
|
"edit_attribute_values": "Modifier les attributs",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Nom(s) de colonne CSV invalide(s) : {columns}. Les noms de colonnes qui deviendront de nouveaux attributs ne doivent contenir que des lettres minuscules, des chiffres et des underscores, et doivent commencer par une lettre.",
|
"invalid_csv_column_names": "Nom(s) de colonne CSV invalide(s) : {columns}. Les noms de colonnes qui deviendront de nouveaux attributs ne doivent contenir que des lettres minuscules, des chiffres et des underscores, et doivent commencer par une lettre.",
|
||||||
"invalid_date_format": "Format de date invalide. Merci d'utiliser une date valide.",
|
"invalid_date_format": "Format de date invalide. Merci d'utiliser une date valide.",
|
||||||
"invalid_number_format": "Format de nombre invalide. Veuillez saisir un nombre valide.",
|
"invalid_number_format": "Format de nombre invalide. Veuillez saisir un nombre valide.",
|
||||||
|
"no_activity_yet": "Aucune activité pour le moment",
|
||||||
"no_published_link_surveys_available": "Aucune enquête par lien publiée n'est disponible. Veuillez d'abord publier une enquête par lien.",
|
"no_published_link_surveys_available": "Aucune enquête par lien publiée n'est disponible. Veuillez d'abord publier une enquête par lien.",
|
||||||
"no_published_surveys": "Aucune enquête publiée",
|
"no_published_surveys": "Aucune enquête publiée",
|
||||||
"no_responses_found": "Aucune réponse trouvée",
|
"no_responses_found": "Aucune réponse trouvée",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Sélectionner une enquête",
|
"select_a_survey": "Sélectionner une enquête",
|
||||||
"select_attribute": "Sélectionner un attribut",
|
"select_attribute": "Sélectionner un attribut",
|
||||||
"select_attribute_key": "Sélectionner une clé d'attribut",
|
"select_attribute_key": "Sélectionner une clé d'attribut",
|
||||||
|
"survey_viewed": "Enquête consultée",
|
||||||
|
"survey_viewed_at": "Consultée le",
|
||||||
"system_attributes": "Attributs système",
|
"system_attributes": "Attributs système",
|
||||||
"unlock_contacts_description": "Gérer les contacts et envoyer des enquêtes ciblées",
|
"unlock_contacts_description": "Gérer les contacts et envoyer des enquêtes ciblées",
|
||||||
"unlock_contacts_title": "Débloquez des contacts avec un plan supérieur.",
|
"unlock_contacts_title": "Débloquez des contacts avec un plan supérieur.",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Salut {userName}",
|
"email_customization_preview_email_heading": "Salut {userName}",
|
||||||
"email_customization_preview_email_text": "Cette est une prévisualisation d'e-mail pour vous montrer quel logo sera rendu dans les e-mails.",
|
"email_customization_preview_email_text": "Cette est une prévisualisation d'e-mail pour vous montrer quel logo sera rendu dans les e-mails.",
|
||||||
"error_deleting_organization_please_try_again": "Erreur lors de la suppression de l'organisation. Veuillez réessayer.",
|
"error_deleting_organization_please_try_again": "Erreur lors de la suppression de l'organisation. Veuillez réessayer.",
|
||||||
"from_your_organization": "de votre organisation",
|
"from_your_organization": "{memberName} de votre organisation",
|
||||||
"invitation_sent_once_more": "Invitation envoyée une fois de plus.",
|
"invitation_sent_once_more": "Invitation envoyée une fois de plus.",
|
||||||
"invite_deleted_successfully": "Invitation supprimée avec succès",
|
"invite_deleted_successfully": "Invitation supprimée avec succès",
|
||||||
"invite_expires_on": "L'invitation expire le {date}",
|
"invite_expires_on": "L'invitation expire le {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Ajouter un espace réservé à afficher s'il n'y a pas de valeur à rappeler.",
|
"add_fallback_placeholder": "Ajouter un espace réservé à afficher s'il n'y a pas de valeur à rappeler.",
|
||||||
"add_hidden_field_id": "Ajouter un champ caché ID",
|
"add_hidden_field_id": "Ajouter un champ caché ID",
|
||||||
"add_highlight_border": "Ajouter une bordure de surlignage",
|
"add_highlight_border": "Ajouter une bordure de surlignage",
|
||||||
|
"add_highlight_border_description": "S'applique uniquement aux sondages intégrés au produit.",
|
||||||
"add_logic": "Ajouter de la logique",
|
"add_logic": "Ajouter de la logique",
|
||||||
"add_none_of_the_above": "Ajouter \"Aucun des éléments ci-dessus\"",
|
"add_none_of_the_above": "Ajouter \"Aucun des éléments ci-dessus\"",
|
||||||
"add_option": "Ajouter une option",
|
"add_option": "Ajouter une option",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "\"Suivi mis à jour et sera enregistré une fois que vous sauvegarderez le sondage.\"",
|
"follow_ups_modal_updated_successfull_toast": "\"Suivi mis à jour et sera enregistré une fois que vous sauvegarderez le sondage.\"",
|
||||||
"follow_ups_new": "Nouveau suivi",
|
"follow_ups_new": "Nouveau suivi",
|
||||||
"follow_ups_upgrade_button_text": "Passez à la version supérieure pour activer les relances",
|
"follow_ups_upgrade_button_text": "Passez à la version supérieure pour activer les relances",
|
||||||
"form_styling": "Style de formulaire",
|
|
||||||
"formbricks_sdk_is_not_connected": "Le SDK Formbricks n'est pas connecté",
|
"formbricks_sdk_is_not_connected": "Le SDK Formbricks n'est pas connecté",
|
||||||
"four_points": "4 points",
|
"four_points": "4 points",
|
||||||
"heading": "En-tête",
|
"heading": "En-tête",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Limites de réponse, redirections et plus.",
|
"response_limits_redirections_and_more": "Limites de réponse, redirections et plus.",
|
||||||
"response_options": "Options de réponse",
|
"response_options": "Options de réponse",
|
||||||
"roundness": "Rondeur",
|
"roundness": "Rondeur",
|
||||||
"roundness_description": "Contrôle l'arrondi des coins de la carte.",
|
"roundness_description": "Contrôle l'arrondi des coins.",
|
||||||
"row_used_in_logic_error": "Cette ligne est utilisée dans la logique de la question {questionIndex}. Veuillez d'abord la supprimer de la logique.",
|
"row_used_in_logic_error": "Cette ligne est utilisée dans la logique de la question {questionIndex}. Veuillez d'abord la supprimer de la logique.",
|
||||||
"rows": "Lignes",
|
"rows": "Lignes",
|
||||||
"save_and_close": "Enregistrer et fermer",
|
"save_and_close": "Enregistrer et fermer",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Cette enquête gratuite et open-source a été fermée",
|
"survey_completed_subheading": "Cette enquête gratuite et open-source a été fermée",
|
||||||
"survey_display_settings": "Paramètres d'affichage de l'enquête",
|
"survey_display_settings": "Paramètres d'affichage de l'enquête",
|
||||||
"survey_placement": "Placement de l'enquête",
|
"survey_placement": "Placement de l'enquête",
|
||||||
|
"survey_styling": "Style de formulaire",
|
||||||
"survey_trigger": "Déclencheur d'enquête",
|
"survey_trigger": "Déclencheur d'enquête",
|
||||||
"switch_multi_language_on_to_get_started": "Activez le mode multilingue pour commencer 👉",
|
"switch_multi_language_on_to_get_started": "Activez le mode multilingue pour commencer 👉",
|
||||||
"target_block_not_found": "Bloc cible non trouvé",
|
"target_block_not_found": "Bloc cible non trouvé",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Message de bienvenue",
|
"welcome_message": "Message de bienvenue",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Sans filtre, tous vos utilisateurs peuvent être sondés.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Sans filtre, tous vos utilisateurs peuvent être sondés.",
|
||||||
"you_have_not_created_a_segment_yet": "Tu n'as pas encore créé de segment.",
|
"you_have_not_created_a_segment_yet": "Tu n'as pas encore créé de segment.",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Vous devez avoir deux langues ou plus configurées dans votre espace de travail pour travailler avec les traductions.",
|
|
||||||
"your_description_here_recall_information_with": "Votre description ici. Rappelez-vous des informations avec @",
|
"your_description_here_recall_information_with": "Votre description ici. Rappelez-vous des informations avec @",
|
||||||
"your_question_here_recall_information_with": "Votre question ici. Rappelez-vous des informations avec @",
|
"your_question_here_recall_information_with": "Votre question ici. Rappelez-vous des informations avec @",
|
||||||
"your_web_app": "Votre application web",
|
"your_web_app": "Votre application web",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Réponses filtrées (Excel)",
|
"filtered_responses_excel": "Réponses filtrées (Excel)",
|
||||||
"generating_qr_code": "Génération du code QR",
|
"generating_qr_code": "Génération du code QR",
|
||||||
"impressions": "Impressions",
|
"impressions": "Impressions",
|
||||||
|
"impressions_identified_only": "Affichage uniquement des impressions des contacts identifiés",
|
||||||
"impressions_tooltip": "Nombre de fois que l'enquête a été consultée.",
|
"impressions_tooltip": "Nombre de fois que l'enquête a été consultée.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "Le sondage sera affiché aux utilisateurs de votre site web, qui correspondent aux critères listés ci-dessous",
|
"connection_description": "Le sondage sera affiché aux utilisateurs de votre site web, qui correspondent aux critères listés ci-dessous",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "dernier trimestre",
|
"last_quarter": "dernier trimestre",
|
||||||
"last_year": "l'année dernière",
|
"last_year": "l'année dernière",
|
||||||
"limit": "Limite",
|
"limit": "Limite",
|
||||||
|
"no_identified_impressions": "Aucune impression des contacts identifiés",
|
||||||
"no_responses_found": "Aucune réponse trouvée",
|
"no_responses_found": "Aucune réponse trouvée",
|
||||||
"other_values_found": "D'autres valeurs trouvées",
|
"other_values_found": "D'autres valeurs trouvées",
|
||||||
"overall": "Globalement",
|
"overall": "Globalement",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Commence",
|
"starts": "Commence",
|
||||||
"starts_tooltip": "Nombre de fois que l'enquête a été commencée.",
|
"starts_tooltip": "Nombre de fois que l'enquête a été commencée.",
|
||||||
"survey_reset_successfully": "Réinitialisation du sondage réussie ! {responseCount} réponses et {displayCount} affichages ont été supprimés.",
|
"survey_reset_successfully": "Réinitialisation du sondage réussie ! {responseCount} réponses et {displayCount} affichages ont été supprimés.",
|
||||||
|
"survey_results": "Résultats de {surveyName}",
|
||||||
"this_month": "Ce mois-ci",
|
"this_month": "Ce mois-ci",
|
||||||
"this_quarter": "Ce trimestre",
|
"this_quarter": "Ce trimestre",
|
||||||
"this_year": "Cette année",
|
"this_year": "Cette année",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Colore la partie remplie de la barre.",
|
"advanced_styling_field_indicator_bg_description": "Colore la partie remplie de la barre.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Arrondit les coins du champ de saisie.",
|
"advanced_styling_field_input_border_radius_description": "Arrondit les coins du champ de saisie.",
|
||||||
"advanced_styling_field_input_font_size_description": "Ajuste la taille du texte saisi dans les champs.",
|
"advanced_styling_field_input_font_size_description": "Ajuste la taille du texte saisi dans les champs.",
|
||||||
"advanced_styling_field_input_height_description": "Contrôle la hauteur minimale du champ de saisie.",
|
"advanced_styling_field_input_height_description": "Contrôle la hauteur min. du champ de saisie.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Ajoute de l'espace à gauche et à droite.",
|
"advanced_styling_field_input_padding_x_description": "Ajoute de l'espace à gauche et à droite.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Ajoute de l'espace en haut et en bas.",
|
"advanced_styling_field_input_padding_y_description": "Ajoute de l'espace en haut et en bas.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Atténue le texte d'indication du placeholder.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Atténue le texte d'indication du placeholder.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Colore le texte saisi dans les champs.",
|
"advanced_styling_field_input_text_description": "Colore le texte saisi dans les champs.",
|
||||||
"advanced_styling_field_option_bg": "Arrière-plan",
|
"advanced_styling_field_option_bg": "Arrière-plan",
|
||||||
"advanced_styling_field_option_bg_description": "Remplit les éléments d'option.",
|
"advanced_styling_field_option_bg_description": "Remplit les éléments d'option.",
|
||||||
|
"advanced_styling_field_option_border": "Couleur de bordure",
|
||||||
|
"advanced_styling_field_option_border_description": "Contours des options de boutons radio et de cases à cocher.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Arrondit les coins des options.",
|
"advanced_styling_field_option_border_radius_description": "Arrondit les coins des options.",
|
||||||
"advanced_styling_field_option_font_size_description": "Ajuste la taille du texte des libellés d'option.",
|
"advanced_styling_field_option_font_size_description": "Ajuste la taille du texte des libellés d'option.",
|
||||||
"advanced_styling_field_option_label": "Couleur de l'étiquette",
|
"advanced_styling_field_option_label": "Couleur de l'étiquette",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Non, merci !",
|
"preview_survey_question_2_choice_2_label": "Non, merci !",
|
||||||
"preview_survey_question_2_headline": "Souhaitez-vous être informé ?",
|
"preview_survey_question_2_headline": "Souhaitez-vous être informé ?",
|
||||||
"preview_survey_question_2_subheader": "Ceci est un exemple de description.",
|
"preview_survey_question_2_subheader": "Ceci est un exemple de description.",
|
||||||
|
"preview_survey_question_open_text_headline": "Autre chose que vous aimeriez partager ?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Entrez votre réponse ici...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Vos commentaires nous aident à nous améliorer.",
|
||||||
"preview_survey_welcome_card_headline": "Bienvenue !",
|
"preview_survey_welcome_card_headline": "Bienvenue !",
|
||||||
"prioritize_features_description": "Identifiez les fonctionnalités dont vos utilisateurs ont le plus et le moins besoin.",
|
"prioritize_features_description": "Identifiez les fonctionnalités dont vos utilisateurs ont le plus et le moins besoin.",
|
||||||
"prioritize_features_name": "Prioriser les fonctionnalités",
|
"prioritize_features_name": "Prioriser les fonctionnalités",
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Másolás",
|
"copy": "Másolás",
|
||||||
"copy_code": "Kód másolása",
|
"copy_code": "Kód másolása",
|
||||||
"copy_link": "Hivatkozás másolása",
|
"copy_link": "Hivatkozás másolása",
|
||||||
"count_attributes": "{value, plural, one {{value} attribútum} other {{value} attribútum}}",
|
"count_attributes": "{count, plural, one {{count} attribútum} other {{count} attribútum}}",
|
||||||
"count_contacts": "{value, plural, one {{value} partner} other {{value} partner}}",
|
"count_contacts": "{count, plural, one {{count} partner} other {{count} partner}}",
|
||||||
"count_responses": "{value, plural, one {{value} válasz} other {{value} válasz}}",
|
"count_members": "{count, plural, one {{count} tag} other {{count} tag}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} válasz} other {{count} válasz}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} kijelölés} other {{count} kijelölés}}",
|
||||||
"create_new_organization": "Új szervezet létrehozása",
|
"create_new_organization": "Új szervezet létrehozása",
|
||||||
"create_segment": "Szakasz létrehozása",
|
"create_segment": "Szakasz létrehozása",
|
||||||
"create_survey": "Kérdőív létrehozása",
|
"create_survey": "Kérdőív létrehozása",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "napok",
|
"days": "napok",
|
||||||
"default": "Alapértelmezett",
|
"default": "Alapértelmezett",
|
||||||
"delete": "Törlés",
|
"delete": "Törlés",
|
||||||
|
"delete_what": "{deleteWhat} törlése",
|
||||||
"description": "Leírás",
|
"description": "Leírás",
|
||||||
"dev_env": "Fejlesztői környezet",
|
"dev_env": "Fejlesztői környezet",
|
||||||
"development": "Fejlesztés",
|
"development": "Fejlesztés",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Hiba",
|
"error": "Hiba",
|
||||||
"error_component_description": "Ez az erőforrás nem létezik, vagy nem rendelkezik a hozzáféréshez szükséges jogosultságokkal.",
|
"error_component_description": "Ez az erőforrás nem létezik, vagy nem rendelkezik a hozzáféréshez szükséges jogosultságokkal.",
|
||||||
"error_component_title": "Hiba az erőforrások betöltésekor",
|
"error_component_title": "Hiba az erőforrások betöltésekor",
|
||||||
|
"error_loading_data": "Hiba az adatok betöltése során",
|
||||||
"error_rate_limit_description": "A kérések legnagyobb száma elérve. Próbálja meg később újra.",
|
"error_rate_limit_description": "A kérések legnagyobb száma elérve. Próbálja meg később újra.",
|
||||||
"error_rate_limit_title": "A sebességkorlát elérve",
|
"error_rate_limit_title": "A sebességkorlát elérve",
|
||||||
"expand_rows": "Sorok kinyitása",
|
"expand_rows": "Sorok kinyitása",
|
||||||
"failed_to_copy_to_clipboard": "Nem sikerült másolni a vágólapra",
|
"failed_to_copy_to_clipboard": "Nem sikerült másolni a vágólapra",
|
||||||
"failed_to_load_organizations": "Nem sikerült betölteni a szervezeteket",
|
"failed_to_load_organizations": "Nem sikerült betölteni a szervezeteket",
|
||||||
"failed_to_load_workspaces": "Nem sikerült a munkaterületek betöltése",
|
"failed_to_load_workspaces": "Nem sikerült a munkaterületek betöltése",
|
||||||
|
"filter": "Szűrő",
|
||||||
"finish": "Befejezés",
|
"finish": "Befejezés",
|
||||||
|
"first_name": "Keresztnév",
|
||||||
"follow_these": "Ezek követése",
|
"follow_these": "Ezek követése",
|
||||||
"formbricks_version": "Formbricks verziója",
|
"formbricks_version": "Formbricks verziója",
|
||||||
"full_name": "Teljes név",
|
"full_name": "Teljes név",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Rejtett mező",
|
"hidden_field": "Rejtett mező",
|
||||||
"hidden_fields": "Rejtett mezők",
|
"hidden_fields": "Rejtett mezők",
|
||||||
"hide_column": "Oszlop elrejtése",
|
"hide_column": "Oszlop elrejtése",
|
||||||
|
"id": "ID",
|
||||||
"image": "Kép",
|
"image": "Kép",
|
||||||
"images": "Képek",
|
"images": "Képek",
|
||||||
"import": "Importálás",
|
"import": "Importálás",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Kulcs",
|
"key": "Kulcs",
|
||||||
"label": "Címke",
|
"label": "Címke",
|
||||||
"language": "Nyelv",
|
"language": "Nyelv",
|
||||||
|
"last_name": "Vezetéknév",
|
||||||
"learn_more": "Tudjon meg többet",
|
"learn_more": "Tudjon meg többet",
|
||||||
"license_expired": "A licenc lejárt",
|
"license_expired": "A licenc lejárt",
|
||||||
"light_overlay": "Világos rávetítés",
|
"light_overlay": "Világos rávetítés",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Megjelenés",
|
"look_and_feel": "Megjelenés",
|
||||||
"manage": "Kezelés",
|
"manage": "Kezelés",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Tag",
|
|
||||||
"members": "Tagok",
|
"members": "Tagok",
|
||||||
"members_and_teams": "Tagok és csapatok",
|
"members_and_teams": "Tagok és csapatok",
|
||||||
"membership_not_found": "A tagság nem található",
|
"membership_not_found": "A tagság nem található",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Mozgatás le",
|
"move_down": "Mozgatás le",
|
||||||
"move_up": "Mozgatás fel",
|
"move_up": "Mozgatás fel",
|
||||||
"multiple_languages": "Több nyelv",
|
"multiple_languages": "Több nyelv",
|
||||||
|
"my_product": "saját termék",
|
||||||
"name": "Név",
|
"name": "Név",
|
||||||
"new": "Új",
|
"new": "Új",
|
||||||
"new_version_available": "A Formbricks {version} megérkezett. Frissítsen most!",
|
"new_version_available": "A Formbricks {version} megérkezett. Frissítsen most!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Csapatok kiválasztása",
|
"select_teams": "Csapatok kiválasztása",
|
||||||
"selected": "Kiválasztva",
|
"selected": "Kiválasztva",
|
||||||
"selected_questions": "Kiválasztott kérdések",
|
"selected_questions": "Kiválasztott kérdések",
|
||||||
"selection": "Kiválasztás",
|
|
||||||
"selections": "Kiválasztások",
|
|
||||||
"send_test_email": "Teszt e-mail küldése",
|
"send_test_email": "Teszt e-mail küldése",
|
||||||
"session_not_found": "A munkamenet nem található",
|
"session_not_found": "A munkamenet nem található",
|
||||||
"settings": "Beállítások",
|
"settings": "Beállítások",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Jobbra fent",
|
"top_right": "Jobbra fent",
|
||||||
"try_again": "Próbálja újra",
|
"try_again": "Próbálja újra",
|
||||||
"type": "Típus",
|
"type": "Típus",
|
||||||
|
"unknown_survey": "Ismeretlen kérdőív",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Több munkaterület feloldása egy magasabb csomaggal.",
|
"unlock_more_workspaces_with_a_higher_plan": "Több munkaterület feloldása egy magasabb csomaggal.",
|
||||||
"update": "Frissítés",
|
"update": "Frissítés",
|
||||||
"updated": "Frissítve",
|
"updated": "Frissítve",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Ez törölni fogja a kiválasztott attribútumot. Az ehhez az attribútumhoz hozzárendelt összes partneradat el fog veszni.} other {Ez törölni fogja a kiválasztott attribútumokat. Az ezekhez az attribútumokhoz hozzárendelt összes partneradat el fog veszni.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Ez törölni fogja a kiválasztott attribútumot. Az ehhez az attribútumhoz hozzárendelt összes partneradat el fog veszni.} other {Ez törölni fogja a kiválasztott attribútumokat. Az ezekhez az attribútumokhoz hozzárendelt összes partneradat el fog veszni.}}",
|
||||||
"delete_contact_confirmation": "Ez törölni fogja az ehhez a partnerhez tartozó összes kérdőívválaszt és partnerattribútumot. A partner adatain alapuló bármilyen célzás és személyre szabás el fog veszni.",
|
"delete_contact_confirmation": "Ez törölni fogja az ehhez a partnerhez tartozó összes kérdőívválaszt és partnerattribútumot. A partner adatain alapuló bármilyen célzás és személyre szabás el fog veszni.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Ez törölni fogja az ehhez a partnerhez tartozó összes kérdőívválaszt és partnerattribútumot. A partner adatain alapuló bármilyen célzás és személyre szabás el fog veszni. Ha ez a partner olyan válaszokkal rendelkezik, amelyek a kérdőívkvótákba beletartoznak, akkor a kvóta számlálója csökkentve lesz, de a kvóta korlátai változatlanok maradnak.} other {Ez törölni fogja az ezekhez a partnerekhez tartozó összes kérdőívválaszt és partnerattribútumot. A partnerek adatain alapuló bármilyen célzás és személyre szabás el fog veszni. Ha ezek a partnerek olyan válaszokkal rendelkeznek, amelyek a kérdőívkvótákba beletartoznak, akkor a kvóta számlálója csökkentve lesz, de a kvóta korlátai változatlanok maradnak.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Ez törölni fogja az ehhez a partnerhez tartozó összes kérdőívválaszt és partnerattribútumot. A partner adatain alapuló bármilyen célzás és személyre szabás el fog veszni. Ha ez a partner olyan válaszokkal rendelkezik, amelyek a kérdőívkvótákba beletartoznak, akkor a kvóta számlálója csökkentve lesz, de a kvóta korlátai változatlanok maradnak.} other {Ez törölni fogja az ezekhez a partnerekhez tartozó összes kérdőívválaszt és partnerattribútumot. A partnerek adatain alapuló bármilyen célzás és személyre szabás el fog veszni. Ha ezek a partnerek olyan válaszokkal rendelkeznek, amelyek a kérdőívkvótákba beletartoznak, akkor a kvóta számlálója csökkentve lesz, de a kvóta korlátai változatlanok maradnak.}}",
|
||||||
|
"displays": "Megjelenítések",
|
||||||
"edit_attribute": "Attribútum szerkesztése",
|
"edit_attribute": "Attribútum szerkesztése",
|
||||||
"edit_attribute_description": "Az attribútum címkéjének és leírásának frissítése.",
|
"edit_attribute_description": "Az attribútum címkéjének és leírásának frissítése.",
|
||||||
"edit_attribute_values": "Attribútumok szerkesztése",
|
"edit_attribute_values": "Attribútumok szerkesztése",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Érvénytelen CSV oszlopnév(nevek): {columns}. Az új attribútumokká váló oszlopnevek csak kisbetűket, számokat és aláhúzásjeleket tartalmazhatnak, és betűvel kell kezdődniük.",
|
"invalid_csv_column_names": "Érvénytelen CSV oszlopnév(nevek): {columns}. Az új attribútumokká váló oszlopnevek csak kisbetűket, számokat és aláhúzásjeleket tartalmazhatnak, és betűvel kell kezdődniük.",
|
||||||
"invalid_date_format": "Érvénytelen dátumformátum. Kérlek, adj meg egy érvényes dátumot.",
|
"invalid_date_format": "Érvénytelen dátumformátum. Kérlek, adj meg egy érvényes dátumot.",
|
||||||
"invalid_number_format": "Érvénytelen számformátum. Kérlek, adj meg egy érvényes számot.",
|
"invalid_number_format": "Érvénytelen számformátum. Kérlek, adj meg egy érvényes számot.",
|
||||||
|
"no_activity_yet": "Még nincs aktivitás",
|
||||||
"no_published_link_surveys_available": "Nem érhetők el közzétett hivatkozás-kérdőívek. Először tegyen közzé egy hivatkozás-kérdőívet.",
|
"no_published_link_surveys_available": "Nem érhetők el közzétett hivatkozás-kérdőívek. Először tegyen közzé egy hivatkozás-kérdőívet.",
|
||||||
"no_published_surveys": "Nincsenek közzétett kérdőívek",
|
"no_published_surveys": "Nincsenek közzétett kérdőívek",
|
||||||
"no_responses_found": "Nem találhatók válaszok",
|
"no_responses_found": "Nem találhatók válaszok",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Kérdőív kiválasztása",
|
"select_a_survey": "Kérdőív kiválasztása",
|
||||||
"select_attribute": "Attribútum kiválasztása",
|
"select_attribute": "Attribútum kiválasztása",
|
||||||
"select_attribute_key": "Attribútum kulcs kiválasztása",
|
"select_attribute_key": "Attribútum kulcs kiválasztása",
|
||||||
|
"survey_viewed": "Kérdőív megtekintve",
|
||||||
|
"survey_viewed_at": "Megtekintve",
|
||||||
"system_attributes": "Rendszer attribútumok",
|
"system_attributes": "Rendszer attribútumok",
|
||||||
"unlock_contacts_description": "Partnerek kezelése és célzott kérdőívek kiküldése",
|
"unlock_contacts_description": "Partnerek kezelése és célzott kérdőívek kiküldése",
|
||||||
"unlock_contacts_title": "Partnerek feloldása egy magasabb csomaggal",
|
"unlock_contacts_title": "Partnerek feloldása egy magasabb csomaggal",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Helló {userName}",
|
"email_customization_preview_email_heading": "Helló {userName}",
|
||||||
"email_customization_preview_email_text": "Ez egy e-mail előnézet, amely azt mutatja meg, hogy melyik logó fog megjelenni az e-mailekben.",
|
"email_customization_preview_email_text": "Ez egy e-mail előnézet, amely azt mutatja meg, hogy melyik logó fog megjelenni az e-mailekben.",
|
||||||
"error_deleting_organization_please_try_again": "Hiba a szervezet törlésekor. Próbálja meg újra.",
|
"error_deleting_organization_please_try_again": "Hiba a szervezet törlésekor. Próbálja meg újra.",
|
||||||
"from_your_organization": "a szervezetétől",
|
"from_your_organization": "{memberName} a szervezetből",
|
||||||
"invitation_sent_once_more": "A meghívó még egyszer elküldve.",
|
"invitation_sent_once_more": "A meghívó még egyszer elküldve.",
|
||||||
"invite_deleted_successfully": "A meghívó sikeresen törölve",
|
"invite_deleted_successfully": "A meghívó sikeresen törölve",
|
||||||
"invite_expires_on": "A meghívó lejár ekkor: {date}",
|
"invite_expires_on": "A meghívó lejár ekkor: {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Helykitöltő hozzáadása annak megjelenítéshez, hogy nincs visszahívandó érték.",
|
"add_fallback_placeholder": "Helykitöltő hozzáadása annak megjelenítéshez, hogy nincs visszahívandó érték.",
|
||||||
"add_hidden_field_id": "Rejtett mezőazonosító hozzáadása",
|
"add_hidden_field_id": "Rejtett mezőazonosító hozzáadása",
|
||||||
"add_highlight_border": "Kiemelési szegély hozzáadása",
|
"add_highlight_border": "Kiemelési szegély hozzáadása",
|
||||||
|
"add_highlight_border_description": "Csak a terméken belüli felmérésekre vonatkozik.",
|
||||||
"add_logic": "Logika hozzáadása",
|
"add_logic": "Logika hozzáadása",
|
||||||
"add_none_of_the_above": "„A fentiek közül egyik sem” hozzáadása",
|
"add_none_of_the_above": "„A fentiek közül egyik sem” hozzáadása",
|
||||||
"add_option": "Lehetőség hozzáadása",
|
"add_option": "Lehetőség hozzáadása",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "A követés frissítve, és akkor lesz elmentve, ha elmenti a kérdőívet.",
|
"follow_ups_modal_updated_successfull_toast": "A követés frissítve, és akkor lesz elmentve, ha elmenti a kérdőívet.",
|
||||||
"follow_ups_new": "Új követés",
|
"follow_ups_new": "Új követés",
|
||||||
"follow_ups_upgrade_button_text": "Magasabb csomagra váltás a követések engedélyezéséhez",
|
"follow_ups_upgrade_button_text": "Magasabb csomagra váltás a követések engedélyezéséhez",
|
||||||
"form_styling": "Űrlap stílusának beállítása",
|
|
||||||
"formbricks_sdk_is_not_connected": "A Formbricks SDK nincs csatlakoztatva",
|
"formbricks_sdk_is_not_connected": "A Formbricks SDK nincs csatlakoztatva",
|
||||||
"four_points": "4 pont",
|
"four_points": "4 pont",
|
||||||
"heading": "Címsor",
|
"heading": "Címsor",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Válaszkorlátok, átirányítások és egyebek.",
|
"response_limits_redirections_and_more": "Válaszkorlátok, átirányítások és egyebek.",
|
||||||
"response_options": "Válasz beállításai",
|
"response_options": "Válasz beállításai",
|
||||||
"roundness": "Kerekesség",
|
"roundness": "Kerekesség",
|
||||||
"roundness_description": "Annak vezérlése, hogy a kártya sarkai mennyire legyenek lekerekítve.",
|
"roundness_description": "Szabályozza a sarkok lekerekítését.",
|
||||||
"row_used_in_logic_error": "Ez a sor használatban van a(z) {questionIndex}. kérdés logikájában. Először távolítsa el a logikából.",
|
"row_used_in_logic_error": "Ez a sor használatban van a(z) {questionIndex}. kérdés logikájában. Először távolítsa el a logikából.",
|
||||||
"rows": "Sorok",
|
"rows": "Sorok",
|
||||||
"save_and_close": "Mentés és bezárás",
|
"save_and_close": "Mentés és bezárás",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Ez a szabad és nyílt forráskódú kérdőív le lett zárva",
|
"survey_completed_subheading": "Ez a szabad és nyílt forráskódú kérdőív le lett zárva",
|
||||||
"survey_display_settings": "Kérdőív megjelenítésének beállításai",
|
"survey_display_settings": "Kérdőív megjelenítésének beállításai",
|
||||||
"survey_placement": "Kérdőív elhelyezése",
|
"survey_placement": "Kérdőív elhelyezése",
|
||||||
|
"survey_styling": "Űrlap stílusának beállítása",
|
||||||
"survey_trigger": "Kérdőív aktiválója",
|
"survey_trigger": "Kérdőív aktiválója",
|
||||||
"switch_multi_language_on_to_get_started": "Kapcsolja be a többnyelvűséget a kezdéshez 👉",
|
"switch_multi_language_on_to_get_started": "Kapcsolja be a többnyelvűséget a kezdéshez 👉",
|
||||||
"target_block_not_found": "A célblokk nem található",
|
"target_block_not_found": "A célblokk nem található",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Üdvözlő üzenet",
|
"welcome_message": "Üdvözlő üzenet",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Szűrő nélkül az összes felhasználója megkérdezhető.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Szűrő nélkül az összes felhasználója megkérdezhető.",
|
||||||
"you_have_not_created_a_segment_yet": "Még nem hozott létre szakaszt",
|
"you_have_not_created_a_segment_yet": "Még nem hozott létre szakaszt",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Be kell állítania kettő vagy több nyelvet a munkaterületen a fordításokkal való munkához.",
|
|
||||||
"your_description_here_recall_information_with": "Ide jön a leírás. Információk visszahívása a @ karakterrel.",
|
"your_description_here_recall_information_with": "Ide jön a leírás. Információk visszahívása a @ karakterrel.",
|
||||||
"your_question_here_recall_information_with": "Ide jön a kérdés. Információk visszahívása a @ karakterrel.",
|
"your_question_here_recall_information_with": "Ide jön a kérdés. Információk visszahívása a @ karakterrel.",
|
||||||
"your_web_app": "Saját webalkalmazás",
|
"your_web_app": "Saját webalkalmazás",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Szűrt válaszok (Excel)",
|
"filtered_responses_excel": "Szűrt válaszok (Excel)",
|
||||||
"generating_qr_code": "QR-kód előállítása",
|
"generating_qr_code": "QR-kód előállítása",
|
||||||
"impressions": "Benyomások",
|
"impressions": "Benyomások",
|
||||||
|
"impressions_identified_only": "Csak az azonosított kapcsolatok megjelenítései láthatók",
|
||||||
"impressions_tooltip": "A kérdőív megtekintési alkalmainak száma.",
|
"impressions_tooltip": "A kérdőív megtekintési alkalmainak száma.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "A kérdőív a webhelye azon felhasználóinak lesz megjelenítve, akik megfelelnek az alább felsorolt feltételeknek",
|
"connection_description": "A kérdőív a webhelye azon felhasználóinak lesz megjelenítve, akik megfelelnek az alább felsorolt feltételeknek",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Elmúlt negyedév",
|
"last_quarter": "Elmúlt negyedév",
|
||||||
"last_year": "Elmúlt év",
|
"last_year": "Elmúlt év",
|
||||||
"limit": "Korlát",
|
"limit": "Korlát",
|
||||||
|
"no_identified_impressions": "Nincsenek megjelenítések azonosított kapcsolatoktól",
|
||||||
"no_responses_found": "Nem találhatók válaszok",
|
"no_responses_found": "Nem találhatók válaszok",
|
||||||
"other_values_found": "Más értékek találhatók",
|
"other_values_found": "Más értékek találhatók",
|
||||||
"overall": "Összesen",
|
"overall": "Összesen",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Elkezdések",
|
"starts": "Elkezdések",
|
||||||
"starts_tooltip": "A kérdőív elkezdési alkalmainak száma.",
|
"starts_tooltip": "A kérdőív elkezdési alkalmainak száma.",
|
||||||
"survey_reset_successfully": "A kérdőív sikeresen visszaállítva. {responseCount} válasz és {displayCount} megjelenítés lett törölve.",
|
"survey_reset_successfully": "A kérdőív sikeresen visszaállítva. {responseCount} válasz és {displayCount} megjelenítés lett törölve.",
|
||||||
|
"survey_results": "{surveyName} eredményei",
|
||||||
"this_month": "Ez a hónap",
|
"this_month": "Ez a hónap",
|
||||||
"this_quarter": "Ez a negyedév",
|
"this_quarter": "Ez a negyedév",
|
||||||
"this_year": "Ez az év",
|
"this_year": "Ez az év",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Kiszínezi a sáv kitöltött részét.",
|
"advanced_styling_field_indicator_bg_description": "Kiszínezi a sáv kitöltött részét.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Lekerekíti a beviteli mező sarkait.",
|
"advanced_styling_field_input_border_radius_description": "Lekerekíti a beviteli mező sarkait.",
|
||||||
"advanced_styling_field_input_font_size_description": "Átméretezi a beviteli mezőkbe beírt szöveget.",
|
"advanced_styling_field_input_font_size_description": "Átméretezi a beviteli mezőkbe beírt szöveget.",
|
||||||
"advanced_styling_field_input_height_description": "A beviteli mező minimális magasságát szabályozza.",
|
"advanced_styling_field_input_height_description": "Szabályozza a beviteli mező minimális magasságát.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Térközt ad hozzá balra és jobbra.",
|
"advanced_styling_field_input_padding_x_description": "Térközt ad hozzá balra és jobbra.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Térközt ad hozzá fent és lent.",
|
"advanced_styling_field_input_padding_y_description": "Térközt ad hozzá fent és lent.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Elhalványítja a helykitöltő súgószöveget.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Elhalványítja a helykitöltő súgószöveget.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Kiszínezi a beviteli mezőkbe beírt szöveget.",
|
"advanced_styling_field_input_text_description": "Kiszínezi a beviteli mezőkbe beírt szöveget.",
|
||||||
"advanced_styling_field_option_bg": "Háttér",
|
"advanced_styling_field_option_bg": "Háttér",
|
||||||
"advanced_styling_field_option_bg_description": "Kitölti a választási lehetőség elemeit.",
|
"advanced_styling_field_option_bg_description": "Kitölti a választási lehetőség elemeit.",
|
||||||
|
"advanced_styling_field_option_border": "Szegély színe",
|
||||||
|
"advanced_styling_field_option_border_description": "A rádiógomb és jelölőnégyzet opciók körvonalát határozza meg.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Lekerekíti a választási lehetőség sarkait.",
|
"advanced_styling_field_option_border_radius_description": "Lekerekíti a választási lehetőség sarkait.",
|
||||||
"advanced_styling_field_option_font_size_description": "Átméretezi a választási lehetőség címkéjének szövegét.",
|
"advanced_styling_field_option_font_size_description": "Átméretezi a választási lehetőség címkéjének szövegét.",
|
||||||
"advanced_styling_field_option_label": "Címke színe",
|
"advanced_styling_field_option_label": "Címke színe",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Nem, köszönöm!",
|
"preview_survey_question_2_choice_2_label": "Nem, köszönöm!",
|
||||||
"preview_survey_question_2_headline": "Szeretne naprakész maradni?",
|
"preview_survey_question_2_headline": "Szeretne naprakész maradni?",
|
||||||
"preview_survey_question_2_subheader": "Ez egy példa a leírásra.",
|
"preview_survey_question_2_subheader": "Ez egy példa a leírásra.",
|
||||||
|
"preview_survey_question_open_text_headline": "Bármi egyéb, amit meg szeretne osztani?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Írja be ide a válaszát…",
|
||||||
|
"preview_survey_question_open_text_subheader": "A visszajelzése segít nekünk a fejlődésben.",
|
||||||
"preview_survey_welcome_card_headline": "Üdvözöljük!",
|
"preview_survey_welcome_card_headline": "Üdvözöljük!",
|
||||||
"prioritize_features_description": "A felhasználóknak leginkább és legkevésbé szükséges funkciók azonosítása.",
|
"prioritize_features_description": "A felhasználóknak leginkább és legkevésbé szükséges funkciók azonosítása.",
|
||||||
"prioritize_features_name": "Funkciók rangsorolása",
|
"prioritize_features_name": "Funkciók rangsorolása",
|
||||||
|
|||||||
@@ -175,9 +175,11 @@
|
|||||||
"copy": "コピー",
|
"copy": "コピー",
|
||||||
"copy_code": "コードをコピー",
|
"copy_code": "コードをコピー",
|
||||||
"copy_link": "リンクをコピー",
|
"copy_link": "リンクをコピー",
|
||||||
"count_attributes": "{value, plural, other {{value}個の属性}}",
|
"count_attributes": "{count, plural, other {{count}個の属性}}",
|
||||||
"count_contacts": "{count, plural, other {# 件の連絡先}}",
|
"count_contacts": "{count, plural, other {# 件の連絡先}}",
|
||||||
|
"count_members": "{count, plural, other {{count}人のメンバー}}",
|
||||||
"count_responses": "{count, plural, other {# 件の回答}}",
|
"count_responses": "{count, plural, other {# 件の回答}}",
|
||||||
|
"count_selections": "{count, plural, other {{count}件選択中}}",
|
||||||
"create_new_organization": "新しい組織を作成",
|
"create_new_organization": "新しい組織を作成",
|
||||||
"create_segment": "セグメントを作成",
|
"create_segment": "セグメントを作成",
|
||||||
"create_survey": "フォームを作成",
|
"create_survey": "フォームを作成",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "日",
|
"days": "日",
|
||||||
"default": "デフォルト",
|
"default": "デフォルト",
|
||||||
"delete": "削除",
|
"delete": "削除",
|
||||||
|
"delete_what": "{deleteWhat}を削除",
|
||||||
"description": "説明",
|
"description": "説明",
|
||||||
"dev_env": "開発環境",
|
"dev_env": "開発環境",
|
||||||
"development": "開発",
|
"development": "開発",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "エラー",
|
"error": "エラー",
|
||||||
"error_component_description": "この リソース は 存在 しない か、アクセス する ための 必要な 権限 が ありません。",
|
"error_component_description": "この リソース は 存在 しない か、アクセス する ための 必要な 権限 が ありません。",
|
||||||
"error_component_title": "リソース の 読み込み エラー",
|
"error_component_title": "リソース の 読み込み エラー",
|
||||||
|
"error_loading_data": "データの読み込みエラー",
|
||||||
"error_rate_limit_description": "リクエストの最大数に達しました。後でもう一度試してください。",
|
"error_rate_limit_description": "リクエストの最大数に達しました。後でもう一度試してください。",
|
||||||
"error_rate_limit_title": "レート制限を超えました",
|
"error_rate_limit_title": "レート制限を超えました",
|
||||||
"expand_rows": "行を展開",
|
"expand_rows": "行を展開",
|
||||||
"failed_to_copy_to_clipboard": "クリップボードへのコピーに失敗しました",
|
"failed_to_copy_to_clipboard": "クリップボードへのコピーに失敗しました",
|
||||||
"failed_to_load_organizations": "組織の読み込みに失敗しました",
|
"failed_to_load_organizations": "組織の読み込みに失敗しました",
|
||||||
"failed_to_load_workspaces": "ワークスペースの読み込みに失敗しました",
|
"failed_to_load_workspaces": "ワークスペースの読み込みに失敗しました",
|
||||||
|
"filter": "フィルター",
|
||||||
"finish": "完了",
|
"finish": "完了",
|
||||||
|
"first_name": "名",
|
||||||
"follow_these": "こちらの手順に従って",
|
"follow_these": "こちらの手順に従って",
|
||||||
"formbricks_version": "Formbricksバージョン",
|
"formbricks_version": "Formbricksバージョン",
|
||||||
"full_name": "氏名",
|
"full_name": "氏名",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "非表示フィールド",
|
"hidden_field": "非表示フィールド",
|
||||||
"hidden_fields": "非表示フィールド",
|
"hidden_fields": "非表示フィールド",
|
||||||
"hide_column": "列を非表示",
|
"hide_column": "列を非表示",
|
||||||
|
"id": "ID",
|
||||||
"image": "画像",
|
"image": "画像",
|
||||||
"images": "画像",
|
"images": "画像",
|
||||||
"import": "インポート",
|
"import": "インポート",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "キー",
|
"key": "キー",
|
||||||
"label": "ラベル",
|
"label": "ラベル",
|
||||||
"language": "言語",
|
"language": "言語",
|
||||||
|
"last_name": "姓",
|
||||||
"learn_more": "詳細を見る",
|
"learn_more": "詳細を見る",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "明るいオーバーレイ",
|
"light_overlay": "明るいオーバーレイ",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "デザイン",
|
"look_and_feel": "デザイン",
|
||||||
"manage": "管理",
|
"manage": "管理",
|
||||||
"marketing": "マーケティング",
|
"marketing": "マーケティング",
|
||||||
"member": "メンバー",
|
|
||||||
"members": "メンバー",
|
"members": "メンバー",
|
||||||
"members_and_teams": "メンバー&チーム",
|
"members_and_teams": "メンバー&チーム",
|
||||||
"membership_not_found": "メンバーシップが見つかりません",
|
"membership_not_found": "メンバーシップが見つかりません",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "下に移動",
|
"move_down": "下に移動",
|
||||||
"move_up": "上に移動",
|
"move_up": "上に移動",
|
||||||
"multiple_languages": "多言語",
|
"multiple_languages": "多言語",
|
||||||
|
"my_product": "マイプロダクト",
|
||||||
"name": "名前",
|
"name": "名前",
|
||||||
"new": "新規",
|
"new": "新規",
|
||||||
"new_version_available": "Formbricks {version} が利用可能です。今すぐアップグレード!",
|
"new_version_available": "Formbricks {version} が利用可能です。今すぐアップグレード!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "チームを選択",
|
"select_teams": "チームを選択",
|
||||||
"selected": "選択済み",
|
"selected": "選択済み",
|
||||||
"selected_questions": "選択した質問",
|
"selected_questions": "選択した質問",
|
||||||
"selection": "選択",
|
|
||||||
"selections": "選択",
|
|
||||||
"send_test_email": "テストメールを送信",
|
"send_test_email": "テストメールを送信",
|
||||||
"session_not_found": "セッションが見つかりません",
|
"session_not_found": "セッションが見つかりません",
|
||||||
"settings": "設定",
|
"settings": "設定",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "右上",
|
"top_right": "右上",
|
||||||
"try_again": "もう一度お試しください",
|
"try_again": "もう一度お試しください",
|
||||||
"type": "種類",
|
"type": "種類",
|
||||||
|
"unknown_survey": "不明なフォーム",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "上位プランでより多くのワークスペースを利用できます。",
|
"unlock_more_workspaces_with_a_higher_plan": "上位プランでより多くのワークスペースを利用できます。",
|
||||||
"update": "更新",
|
"update": "更新",
|
||||||
"updated": "更新済み",
|
"updated": "更新済み",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {選択した属性を削除します。この属性に関連付けられたすべてのコンタクトデータは失われます。} other {選択した属性を削除します。これらの属性に関連付けられたすべてのコンタクトデータは失われます。}}",
|
"delete_attribute_confirmation": "{value, plural, one {選択した属性を削除します。この属性に関連付けられたすべてのコンタクトデータは失われます。} other {選択した属性を削除します。これらの属性に関連付けられたすべてのコンタクトデータは失われます。}}",
|
||||||
"delete_contact_confirmation": "これにより、この連絡先に関連付けられているすべてのフォーム回答と連絡先属性が削除されます。この連絡先のデータに基づいたターゲティングとパーソナライゼーションはすべて失われます。",
|
"delete_contact_confirmation": "これにより、この連絡先に関連付けられているすべてのフォーム回答と連絡先属性が削除されます。この連絡先のデータに基づいたターゲティングとパーソナライゼーションはすべて失われます。",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {これにより この連絡先に関連するすべてのアンケート応答と連絡先属性が削除されます。この連絡先のデータに基づくターゲティングとパーソナライゼーションが失われます。この連絡先がアンケートの割当量を考慮した回答を持っている場合、割当量カウントは減少しますが、割当量の制限は変更されません。} other {これにより これらの連絡先に関連するすべてのアンケート応答と連絡先属性が削除されます。これらの連絡先のデータに基づくターゲティングとパーソナライゼーションが失われます。これらの連絡先がアンケートの割当量を考慮した回答を持っている場合、割当量カウントは減少しますが、割当量の制限は変更されません。}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {これにより この連絡先に関連するすべてのアンケート応答と連絡先属性が削除されます。この連絡先のデータに基づくターゲティングとパーソナライゼーションが失われます。この連絡先がアンケートの割当量を考慮した回答を持っている場合、割当量カウントは減少しますが、割当量の制限は変更されません。} other {これにより これらの連絡先に関連するすべてのアンケート応答と連絡先属性が削除されます。これらの連絡先のデータに基づくターゲティングとパーソナライゼーションが失われます。これらの連絡先がアンケートの割当量を考慮した回答を持っている場合、割当量カウントは減少しますが、割当量の制限は変更されません。}}",
|
||||||
|
"displays": "表示回数",
|
||||||
"edit_attribute": "属性を編集",
|
"edit_attribute": "属性を編集",
|
||||||
"edit_attribute_description": "この属性のラベルと説明を更新します。",
|
"edit_attribute_description": "この属性のラベルと説明を更新します。",
|
||||||
"edit_attribute_values": "属性を編集",
|
"edit_attribute_values": "属性を編集",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "無効なCSV列名: {columns}。新しい属性となる列名は、小文字、数字、アンダースコアのみを含み、文字で始まる必要があります。",
|
"invalid_csv_column_names": "無効なCSV列名: {columns}。新しい属性となる列名は、小文字、数字、アンダースコアのみを含み、文字で始まる必要があります。",
|
||||||
"invalid_date_format": "無効な日付形式です。有効な日付を使用してください。",
|
"invalid_date_format": "無効な日付形式です。有効な日付を使用してください。",
|
||||||
"invalid_number_format": "無効な数値形式です。有効な数値を入力してください。",
|
"invalid_number_format": "無効な数値形式です。有効な数値を入力してください。",
|
||||||
|
"no_activity_yet": "まだアクティビティがありません",
|
||||||
"no_published_link_surveys_available": "公開されたリンクフォームはありません。まずリンクフォームを公開してください。",
|
"no_published_link_surveys_available": "公開されたリンクフォームはありません。まずリンクフォームを公開してください。",
|
||||||
"no_published_surveys": "公開されたフォームはありません",
|
"no_published_surveys": "公開されたフォームはありません",
|
||||||
"no_responses_found": "回答が見つかりません",
|
"no_responses_found": "回答が見つかりません",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "フォームを選択",
|
"select_a_survey": "フォームを選択",
|
||||||
"select_attribute": "属性を選択",
|
"select_attribute": "属性を選択",
|
||||||
"select_attribute_key": "属性キーを選択",
|
"select_attribute_key": "属性キーを選択",
|
||||||
|
"survey_viewed": "フォームを閲覧",
|
||||||
|
"survey_viewed_at": "閲覧日時",
|
||||||
"system_attributes": "システム属性",
|
"system_attributes": "システム属性",
|
||||||
"unlock_contacts_description": "連絡先を管理し、特定のフォームを送信します",
|
"unlock_contacts_description": "連絡先を管理し、特定のフォームを送信します",
|
||||||
"unlock_contacts_title": "上位プランで連絡先をアンロック",
|
"unlock_contacts_title": "上位プランで連絡先をアンロック",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "こんにちは、{userName}さん",
|
"email_customization_preview_email_heading": "こんにちは、{userName}さん",
|
||||||
"email_customization_preview_email_text": "これは、メールに表示されるロゴを確認するためのプレビューメールです。",
|
"email_customization_preview_email_text": "これは、メールに表示されるロゴを確認するためのプレビューメールです。",
|
||||||
"error_deleting_organization_please_try_again": "組織の削除中にエラーが発生しました。もう一度お試しください。",
|
"error_deleting_organization_please_try_again": "組織の削除中にエラーが発生しました。もう一度お試しください。",
|
||||||
"from_your_organization": "あなたの組織から",
|
"from_your_organization": "組織から{memberName}を削除",
|
||||||
"invitation_sent_once_more": "招待状を再度送信しました。",
|
"invitation_sent_once_more": "招待状を再度送信しました。",
|
||||||
"invite_deleted_successfully": "招待を正常に削除しました",
|
"invite_deleted_successfully": "招待を正常に削除しました",
|
||||||
"invite_expires_on": "招待は{date}に期限切れ",
|
"invite_expires_on": "招待は{date}に期限切れ",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "質問がスキップされた場合に表示するプレースホルダーを追加:",
|
"add_fallback_placeholder": "質問がスキップされた場合に表示するプレースホルダーを追加:",
|
||||||
"add_hidden_field_id": "非表示フィールドIDを追加",
|
"add_hidden_field_id": "非表示フィールドIDを追加",
|
||||||
"add_highlight_border": "ハイライトボーダーを追加",
|
"add_highlight_border": "ハイライトボーダーを追加",
|
||||||
|
"add_highlight_border_description": "プロダクト内サーベイにのみ適用されます。",
|
||||||
"add_logic": "ロジックを追加",
|
"add_logic": "ロジックを追加",
|
||||||
"add_none_of_the_above": "\"いずれも該当しません\" を追加",
|
"add_none_of_the_above": "\"いずれも該当しません\" を追加",
|
||||||
"add_option": "オプションを追加",
|
"add_option": "オプションを追加",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "フォローアップ が 更新され、 アンケートを 保存すると保存されます。",
|
"follow_ups_modal_updated_successfull_toast": "フォローアップ が 更新され、 アンケートを 保存すると保存されます。",
|
||||||
"follow_ups_new": "新しいフォローアップ",
|
"follow_ups_new": "新しいフォローアップ",
|
||||||
"follow_ups_upgrade_button_text": "フォローアップを有効にするためにアップグレード",
|
"follow_ups_upgrade_button_text": "フォローアップを有効にするためにアップグレード",
|
||||||
"form_styling": "フォームのスタイル",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDKが接続されていません",
|
"formbricks_sdk_is_not_connected": "Formbricks SDKが接続されていません",
|
||||||
"four_points": "4点",
|
"four_points": "4点",
|
||||||
"heading": "見出し",
|
"heading": "見出し",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "回答数の上限、リダイレクトなど。",
|
"response_limits_redirections_and_more": "回答数の上限、リダイレクトなど。",
|
||||||
"response_options": "回答オプション",
|
"response_options": "回答オプション",
|
||||||
"roundness": "丸み",
|
"roundness": "丸み",
|
||||||
"roundness_description": "カードの角の丸みを調整します。",
|
"roundness_description": "角の丸みを調整します。",
|
||||||
"row_used_in_logic_error": "この行は質問 {questionIndex} のロジックで使用されています。まず、ロジックから削除してください。",
|
"row_used_in_logic_error": "この行は質問 {questionIndex} のロジックで使用されています。まず、ロジックから削除してください。",
|
||||||
"rows": "行",
|
"rows": "行",
|
||||||
"save_and_close": "保存して閉じる",
|
"save_and_close": "保存して閉じる",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "この無料のオープンソースフォームは閉鎖されました",
|
"survey_completed_subheading": "この無料のオープンソースフォームは閉鎖されました",
|
||||||
"survey_display_settings": "フォーム表示設定",
|
"survey_display_settings": "フォーム表示設定",
|
||||||
"survey_placement": "フォームの配置",
|
"survey_placement": "フォームの配置",
|
||||||
|
"survey_styling": "フォームのスタイル",
|
||||||
"survey_trigger": "フォームのトリガー",
|
"survey_trigger": "フォームのトリガー",
|
||||||
"switch_multi_language_on_to_get_started": "多言語機能をオンにして開始 👉",
|
"switch_multi_language_on_to_get_started": "多言語機能をオンにして開始 👉",
|
||||||
"target_block_not_found": "対象ブロックが見つかりません",
|
"target_block_not_found": "対象ブロックが見つかりません",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "ウェルカムメッセージ",
|
"welcome_message": "ウェルカムメッセージ",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "フィルターがなければ、すべてのユーザーがフォームに回答できます。",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "フィルターがなければ、すべてのユーザーがフォームに回答できます。",
|
||||||
"you_have_not_created_a_segment_yet": "まだセグメントを作成していません",
|
"you_have_not_created_a_segment_yet": "まだセグメントを作成していません",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "翻訳を使用するには、ワークスペースに2つ以上の言語を設定する必要があります。",
|
|
||||||
"your_description_here_recall_information_with": "ここにあなたの説明。@ で情報を呼び出す",
|
"your_description_here_recall_information_with": "ここにあなたの説明。@ で情報を呼び出す",
|
||||||
"your_question_here_recall_information_with": "ここにあなたの質問。@ で情報を呼び出す",
|
"your_question_here_recall_information_with": "ここにあなたの質問。@ で情報を呼び出す",
|
||||||
"your_web_app": "あなたのウェブアプリ",
|
"your_web_app": "あなたのウェブアプリ",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "フィルター済み回答 (Excel)",
|
"filtered_responses_excel": "フィルター済み回答 (Excel)",
|
||||||
"generating_qr_code": "QRコードを生成中",
|
"generating_qr_code": "QRコードを生成中",
|
||||||
"impressions": "表示回数",
|
"impressions": "表示回数",
|
||||||
|
"impressions_identified_only": "識別済みコンタクトからのインプレッションのみを表示しています",
|
||||||
"impressions_tooltip": "フォームが表示された回数。",
|
"impressions_tooltip": "フォームが表示された回数。",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "このフォームは、以下の条件に一致するあなたのウェブサイトのユーザーに表示されます",
|
"connection_description": "このフォームは、以下の条件に一致するあなたのウェブサイトのユーザーに表示されます",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "前四半期",
|
"last_quarter": "前四半期",
|
||||||
"last_year": "昨年",
|
"last_year": "昨年",
|
||||||
"limit": "制限",
|
"limit": "制限",
|
||||||
|
"no_identified_impressions": "識別済みコンタクトからのインプレッションはありません",
|
||||||
"no_responses_found": "回答が見つかりません",
|
"no_responses_found": "回答が見つかりません",
|
||||||
"other_values_found": "他の値が見つかりました",
|
"other_values_found": "他の値が見つかりました",
|
||||||
"overall": "全体",
|
"overall": "全体",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "開始",
|
"starts": "開始",
|
||||||
"starts_tooltip": "フォームが開始された回数。",
|
"starts_tooltip": "フォームが開始された回数。",
|
||||||
"survey_reset_successfully": "フォームを正常にリセットしました!{responseCount} 件の回答と {displayCount} 件の表示が削除されました。",
|
"survey_reset_successfully": "フォームを正常にリセットしました!{responseCount} 件の回答と {displayCount} 件の表示が削除されました。",
|
||||||
|
"survey_results": "{surveyName}の結果",
|
||||||
"this_month": "今月",
|
"this_month": "今月",
|
||||||
"this_quarter": "今四半期",
|
"this_quarter": "今四半期",
|
||||||
"this_year": "今年",
|
"this_year": "今年",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "バーの塗りつぶし部分に色を付けます。",
|
"advanced_styling_field_indicator_bg_description": "バーの塗りつぶし部分に色を付けます。",
|
||||||
"advanced_styling_field_input_border_radius_description": "入力フィールドの角を丸めます。",
|
"advanced_styling_field_input_border_radius_description": "入力フィールドの角を丸めます。",
|
||||||
"advanced_styling_field_input_font_size_description": "入力フィールド内の入力テキストのサイズを調整します。",
|
"advanced_styling_field_input_font_size_description": "入力フィールド内の入力テキストのサイズを調整します。",
|
||||||
"advanced_styling_field_input_height_description": "入力フィールドの最小の高さを制御します。",
|
"advanced_styling_field_input_height_description": "入力欄の最小の高さを調整します。",
|
||||||
"advanced_styling_field_input_padding_x_description": "左右にスペースを追加します。",
|
"advanced_styling_field_input_padding_x_description": "左右にスペースを追加します。",
|
||||||
"advanced_styling_field_input_padding_y_description": "上下にスペースを追加します。",
|
"advanced_styling_field_input_padding_y_description": "上下にスペースを追加します。",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "プレースホルダーのヒントテキストを薄くします。",
|
"advanced_styling_field_input_placeholder_opacity_description": "プレースホルダーのヒントテキストを薄くします。",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "入力フィールドに入力されたテキストの色を設定します。",
|
"advanced_styling_field_input_text_description": "入力フィールドに入力されたテキストの色を設定します。",
|
||||||
"advanced_styling_field_option_bg": "背景",
|
"advanced_styling_field_option_bg": "背景",
|
||||||
"advanced_styling_field_option_bg_description": "オプション項目を塗りつぶします。",
|
"advanced_styling_field_option_bg_description": "オプション項目を塗りつぶします。",
|
||||||
|
"advanced_styling_field_option_border": "枠線の色",
|
||||||
|
"advanced_styling_field_option_border_description": "ラジオボタンとチェックボックスの選択肢の輪郭を設定します。",
|
||||||
"advanced_styling_field_option_border_radius_description": "オプションの角を丸くします。",
|
"advanced_styling_field_option_border_radius_description": "オプションの角を丸くします。",
|
||||||
"advanced_styling_field_option_font_size_description": "オプションラベルのテキストサイズを調整します。",
|
"advanced_styling_field_option_font_size_description": "オプションラベルのテキストサイズを調整します。",
|
||||||
"advanced_styling_field_option_label": "ラベルの色",
|
"advanced_styling_field_option_label": "ラベルの色",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "いいえ、結構です!",
|
"preview_survey_question_2_choice_2_label": "いいえ、結構です!",
|
||||||
"preview_survey_question_2_headline": "最新情報を知りたいですか?",
|
"preview_survey_question_2_headline": "最新情報を知りたいですか?",
|
||||||
"preview_survey_question_2_subheader": "これは説明の例です。",
|
"preview_survey_question_2_subheader": "これは説明の例です。",
|
||||||
|
"preview_survey_question_open_text_headline": "他に共有したいことはありますか?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "ここに回答を入力してください...",
|
||||||
|
"preview_survey_question_open_text_subheader": "あなたのフィードバックは、私たちの改善に役立ちます。",
|
||||||
"preview_survey_welcome_card_headline": "ようこそ!",
|
"preview_survey_welcome_card_headline": "ようこそ!",
|
||||||
"prioritize_features_description": "ユーザーが最も必要とする機能と最も必要としない機能を特定する。",
|
"prioritize_features_description": "ユーザーが最も必要とする機能と最も必要としない機能を特定する。",
|
||||||
"prioritize_features_name": "機能の優先順位付け",
|
"prioritize_features_name": "機能の優先順位付け",
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Kopiëren",
|
"copy": "Kopiëren",
|
||||||
"copy_code": "Kopieer code",
|
"copy_code": "Kopieer code",
|
||||||
"copy_link": "Kopieer link",
|
"copy_link": "Kopieer link",
|
||||||
"count_attributes": "{value, plural, one {{value} attribuut} other {{value} attributen}}",
|
"count_attributes": "{count, plural, one {{count} attribuut} other {{count} attributen}}",
|
||||||
"count_contacts": "{value, plural, one {{value} contact} other {{value} contacten}}",
|
"count_contacts": "{count, plural, one {{count} contact} other {{count} contacten}}",
|
||||||
"count_responses": "{value, plural, one {{value} reactie} other {{value} reacties}}",
|
"count_members": "{count, plural, one {{count} lid} other {{count} leden}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} reactie} other {{count} reacties}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} selectie} other {{count} selecties}}",
|
||||||
"create_new_organization": "Creëer een nieuwe organisatie",
|
"create_new_organization": "Creëer een nieuwe organisatie",
|
||||||
"create_segment": "Segment maken",
|
"create_segment": "Segment maken",
|
||||||
"create_survey": "Enquête maken",
|
"create_survey": "Enquête maken",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "dagen",
|
"days": "dagen",
|
||||||
"default": "Standaard",
|
"default": "Standaard",
|
||||||
"delete": "Verwijderen",
|
"delete": "Verwijderen",
|
||||||
|
"delete_what": "Verwijder {deleteWhat}",
|
||||||
"description": "Beschrijving",
|
"description": "Beschrijving",
|
||||||
"dev_env": "Ontwikkelomgeving",
|
"dev_env": "Ontwikkelomgeving",
|
||||||
"development": "Ontwikkeling",
|
"development": "Ontwikkeling",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Fout",
|
"error": "Fout",
|
||||||
"error_component_description": "Deze bron bestaat niet of u beschikt niet over de benodigde toegangsrechten.",
|
"error_component_description": "Deze bron bestaat niet of u beschikt niet over de benodigde toegangsrechten.",
|
||||||
"error_component_title": "Fout bij het laden van bronnen",
|
"error_component_title": "Fout bij het laden van bronnen",
|
||||||
|
"error_loading_data": "Fout bij het laden van gegevens",
|
||||||
"error_rate_limit_description": "Maximaal aantal verzoeken bereikt. Probeer het later opnieuw.",
|
"error_rate_limit_description": "Maximaal aantal verzoeken bereikt. Probeer het later opnieuw.",
|
||||||
"error_rate_limit_title": "Tarieflimiet overschreden",
|
"error_rate_limit_title": "Tarieflimiet overschreden",
|
||||||
"expand_rows": "Vouw rijen uit",
|
"expand_rows": "Vouw rijen uit",
|
||||||
"failed_to_copy_to_clipboard": "Kopiëren naar klembord mislukt",
|
"failed_to_copy_to_clipboard": "Kopiëren naar klembord mislukt",
|
||||||
"failed_to_load_organizations": "Laden van organisaties mislukt",
|
"failed_to_load_organizations": "Laden van organisaties mislukt",
|
||||||
"failed_to_load_workspaces": "Laden van werkruimtes mislukt",
|
"failed_to_load_workspaces": "Laden van werkruimtes mislukt",
|
||||||
|
"filter": "Filter",
|
||||||
"finish": "Finish",
|
"finish": "Finish",
|
||||||
|
"first_name": "Voornaam",
|
||||||
"follow_these": "Volg deze",
|
"follow_these": "Volg deze",
|
||||||
"formbricks_version": "Formbricks-versie",
|
"formbricks_version": "Formbricks-versie",
|
||||||
"full_name": "Volledige naam",
|
"full_name": "Volledige naam",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Verborgen veld",
|
"hidden_field": "Verborgen veld",
|
||||||
"hidden_fields": "Verborgen velden",
|
"hidden_fields": "Verborgen velden",
|
||||||
"hide_column": "Kolom verbergen",
|
"hide_column": "Kolom verbergen",
|
||||||
|
"id": "ID",
|
||||||
"image": "Afbeelding",
|
"image": "Afbeelding",
|
||||||
"images": "Afbeeldingen",
|
"images": "Afbeeldingen",
|
||||||
"import": "Importeren",
|
"import": "Importeren",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Sleutel",
|
"key": "Sleutel",
|
||||||
"label": "Label",
|
"label": "Label",
|
||||||
"language": "Taal",
|
"language": "Taal",
|
||||||
|
"last_name": "Achternaam",
|
||||||
"learn_more": "Meer informatie",
|
"learn_more": "Meer informatie",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Lichte overlay",
|
"light_overlay": "Lichte overlay",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Kijk & voel",
|
"look_and_feel": "Kijk & voel",
|
||||||
"manage": "Beheren",
|
"manage": "Beheren",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Lid",
|
|
||||||
"members": "Leden",
|
"members": "Leden",
|
||||||
"members_and_teams": "Leden & teams",
|
"members_and_teams": "Leden & teams",
|
||||||
"membership_not_found": "Lidmaatschap niet gevonden",
|
"membership_not_found": "Lidmaatschap niet gevonden",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Ga naar beneden",
|
"move_down": "Ga naar beneden",
|
||||||
"move_up": "Ga omhoog",
|
"move_up": "Ga omhoog",
|
||||||
"multiple_languages": "Meerdere talen",
|
"multiple_languages": "Meerdere talen",
|
||||||
|
"my_product": "mijn product",
|
||||||
"name": "Naam",
|
"name": "Naam",
|
||||||
"new": "Nieuw",
|
"new": "Nieuw",
|
||||||
"new_version_available": "Formbricks {version} is hier. Upgrade nu!",
|
"new_version_available": "Formbricks {version} is hier. Upgrade nu!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Selecteer teams",
|
"select_teams": "Selecteer teams",
|
||||||
"selected": "Gekozen",
|
"selected": "Gekozen",
|
||||||
"selected_questions": "Geselecteerde vragen",
|
"selected_questions": "Geselecteerde vragen",
|
||||||
"selection": "Selectie",
|
|
||||||
"selections": "Selecties",
|
|
||||||
"send_test_email": "Test-e-mail verzenden",
|
"send_test_email": "Test-e-mail verzenden",
|
||||||
"session_not_found": "Sessie niet gevonden",
|
"session_not_found": "Sessie niet gevonden",
|
||||||
"settings": "Instellingen",
|
"settings": "Instellingen",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Rechtsboven",
|
"top_right": "Rechtsboven",
|
||||||
"try_again": "Probeer het opnieuw",
|
"try_again": "Probeer het opnieuw",
|
||||||
"type": "Type",
|
"type": "Type",
|
||||||
|
"unknown_survey": "Onbekende enquête",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Ontgrendel meer werkruimtes met een hoger abonnement.",
|
"unlock_more_workspaces_with_a_higher_plan": "Ontgrendel meer werkruimtes met een hoger abonnement.",
|
||||||
"update": "Update",
|
"update": "Update",
|
||||||
"updated": "Bijgewerkt",
|
"updated": "Bijgewerkt",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Dit verwijdert het geselecteerde attribuut. Alle contactgegevens die aan dit attribuut zijn gekoppeld, gaan verloren.} other {Dit verwijdert de geselecteerde attributen. Alle contactgegevens die aan deze attributen zijn gekoppeld, gaan verloren.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Dit verwijdert het geselecteerde attribuut. Alle contactgegevens die aan dit attribuut zijn gekoppeld, gaan verloren.} other {Dit verwijdert de geselecteerde attributen. Alle contactgegevens die aan deze attributen zijn gekoppeld, gaan verloren.}}",
|
||||||
"delete_contact_confirmation": "Hierdoor worden alle enquêtereacties en contactkenmerken verwijderd die aan dit contact zijn gekoppeld. Elke targeting en personalisatie op basis van de gegevens van dit contact gaat verloren.",
|
"delete_contact_confirmation": "Hierdoor worden alle enquêtereacties en contactkenmerken verwijderd die aan dit contact zijn gekoppeld. Elke targeting en personalisatie op basis van de gegevens van dit contact gaat verloren.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Dit verwijdert alle enquêteresultaten en contactattributen die aan dit contact zijn gekoppeld. Alle targeting en personalisatie op basis van de gegevens van dit contact gaan verloren. Als dit contact reacties heeft die meetellen voor enquêtekvota, worden de quotawaarden verlaagd maar blijven de limieten ongewijzigd.} other {Dit verwijdert alle enquêteresultaten en contactattributen die aan deze contacten zijn gekoppeld. Alle targeting en personalisatie op basis van de gegevens van deze contacten gaan verloren. Als deze contacten reacties hebben die meetellen voor enquêtekvota, worden de quotawaarden verlaagd maar blijven de limieten ongewijzigd.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Dit verwijdert alle enquêteresultaten en contactattributen die aan dit contact zijn gekoppeld. Alle targeting en personalisatie op basis van de gegevens van dit contact gaan verloren. Als dit contact reacties heeft die meetellen voor enquêtekvota, worden de quotawaarden verlaagd maar blijven de limieten ongewijzigd.} other {Dit verwijdert alle enquêteresultaten en contactattributen die aan deze contacten zijn gekoppeld. Alle targeting en personalisatie op basis van de gegevens van deze contacten gaan verloren. Als deze contacten reacties hebben die meetellen voor enquêtekvota, worden de quotawaarden verlaagd maar blijven de limieten ongewijzigd.}}",
|
||||||
|
"displays": "Weergaven",
|
||||||
"edit_attribute": "Attribuut bewerken",
|
"edit_attribute": "Attribuut bewerken",
|
||||||
"edit_attribute_description": "Werk het label en de beschrijving voor dit attribuut bij.",
|
"edit_attribute_description": "Werk het label en de beschrijving voor dit attribuut bij.",
|
||||||
"edit_attribute_values": "Attributen bewerken",
|
"edit_attribute_values": "Attributen bewerken",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Ongeldige CSV-kolomna(a)m(en): {columns}. Kolomnamen die nieuwe kenmerken worden, mogen alleen kleine letters, cijfers en underscores bevatten en moeten beginnen met een letter.",
|
"invalid_csv_column_names": "Ongeldige CSV-kolomna(a)m(en): {columns}. Kolomnamen die nieuwe kenmerken worden, mogen alleen kleine letters, cijfers en underscores bevatten en moeten beginnen met een letter.",
|
||||||
"invalid_date_format": "Ongeldig datumformaat. Gebruik een geldige datum.",
|
"invalid_date_format": "Ongeldig datumformaat. Gebruik een geldige datum.",
|
||||||
"invalid_number_format": "Ongeldig getalformaat. Voer een geldig getal in.",
|
"invalid_number_format": "Ongeldig getalformaat. Voer een geldig getal in.",
|
||||||
|
"no_activity_yet": "Nog geen activiteit",
|
||||||
"no_published_link_surveys_available": "Geen gepubliceerde link-enquêtes beschikbaar. Publiceer eerst een link-enquête.",
|
"no_published_link_surveys_available": "Geen gepubliceerde link-enquêtes beschikbaar. Publiceer eerst een link-enquête.",
|
||||||
"no_published_surveys": "Geen gepubliceerde enquêtes",
|
"no_published_surveys": "Geen gepubliceerde enquêtes",
|
||||||
"no_responses_found": "Geen reacties gevonden",
|
"no_responses_found": "Geen reacties gevonden",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Selecteer een enquête",
|
"select_a_survey": "Selecteer een enquête",
|
||||||
"select_attribute": "Selecteer Kenmerk",
|
"select_attribute": "Selecteer Kenmerk",
|
||||||
"select_attribute_key": "Selecteer kenmerksleutel",
|
"select_attribute_key": "Selecteer kenmerksleutel",
|
||||||
|
"survey_viewed": "Enquête bekeken",
|
||||||
|
"survey_viewed_at": "Bekeken op",
|
||||||
"system_attributes": "Systeemkenmerken",
|
"system_attributes": "Systeemkenmerken",
|
||||||
"unlock_contacts_description": "Beheer contacten en verstuur gerichte enquêtes",
|
"unlock_contacts_description": "Beheer contacten en verstuur gerichte enquêtes",
|
||||||
"unlock_contacts_title": "Ontgrendel contacten met een hoger abonnement",
|
"unlock_contacts_title": "Ontgrendel contacten met een hoger abonnement",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Hé {userName}",
|
"email_customization_preview_email_heading": "Hé {userName}",
|
||||||
"email_customization_preview_email_text": "Dit is een e-mailvoorbeeld om u te laten zien welk logo in de e-mails wordt weergegeven.",
|
"email_customization_preview_email_text": "Dit is een e-mailvoorbeeld om u te laten zien welk logo in de e-mails wordt weergegeven.",
|
||||||
"error_deleting_organization_please_try_again": "Fout bij verwijderen van organisatie. Probeer het opnieuw.",
|
"error_deleting_organization_please_try_again": "Fout bij verwijderen van organisatie. Probeer het opnieuw.",
|
||||||
"from_your_organization": "vanuit uw organisatie",
|
"from_your_organization": "{memberName} uit je organisatie",
|
||||||
"invitation_sent_once_more": "Uitnodiging nogmaals verzonden.",
|
"invitation_sent_once_more": "Uitnodiging nogmaals verzonden.",
|
||||||
"invite_deleted_successfully": "Uitnodiging succesvol verwijderd",
|
"invite_deleted_successfully": "Uitnodiging succesvol verwijderd",
|
||||||
"invite_expires_on": "Uitnodiging verloopt op {date}",
|
"invite_expires_on": "Uitnodiging verloopt op {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Voeg een tijdelijke aanduiding toe om aan te geven of er geen waarde is om te onthouden.",
|
"add_fallback_placeholder": "Voeg een tijdelijke aanduiding toe om aan te geven of er geen waarde is om te onthouden.",
|
||||||
"add_hidden_field_id": "Voeg een verborgen veld-ID toe",
|
"add_hidden_field_id": "Voeg een verborgen veld-ID toe",
|
||||||
"add_highlight_border": "Markeerrand toevoegen",
|
"add_highlight_border": "Markeerrand toevoegen",
|
||||||
|
"add_highlight_border_description": "Geldt alleen voor in-product enquêtes.",
|
||||||
"add_logic": "Voeg logica toe",
|
"add_logic": "Voeg logica toe",
|
||||||
"add_none_of_the_above": "Voeg 'Geen van bovenstaande' toe",
|
"add_none_of_the_above": "Voeg 'Geen van bovenstaande' toe",
|
||||||
"add_option": "Optie toevoegen",
|
"add_option": "Optie toevoegen",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Follow-up bijgewerkt en wordt opgeslagen zodra u de enquête opslaat.",
|
"follow_ups_modal_updated_successfull_toast": "Follow-up bijgewerkt en wordt opgeslagen zodra u de enquête opslaat.",
|
||||||
"follow_ups_new": "Nieuw vervolg",
|
"follow_ups_new": "Nieuw vervolg",
|
||||||
"follow_ups_upgrade_button_text": "Upgrade om follow-ups mogelijk te maken",
|
"follow_ups_upgrade_button_text": "Upgrade om follow-ups mogelijk te maken",
|
||||||
"form_styling": "Vorm styling",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK is niet verbonden",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK is niet verbonden",
|
||||||
"four_points": "4 punten",
|
"four_points": "4 punten",
|
||||||
"heading": "Rubriek",
|
"heading": "Rubriek",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Reactielimieten, omleidingen en meer.",
|
"response_limits_redirections_and_more": "Reactielimieten, omleidingen en meer.",
|
||||||
"response_options": "Reactieopties",
|
"response_options": "Reactieopties",
|
||||||
"roundness": "Rondheid",
|
"roundness": "Rondheid",
|
||||||
"roundness_description": "Bepaalt hoe afgerond de kaarthoeken zijn.",
|
"roundness_description": "Bepaalt hoe afgerond de hoeken zijn.",
|
||||||
"row_used_in_logic_error": "Deze rij wordt gebruikt in de logica van vraag {questionIndex}. Verwijder het eerst uit de logica.",
|
"row_used_in_logic_error": "Deze rij wordt gebruikt in de logica van vraag {questionIndex}. Verwijder het eerst uit de logica.",
|
||||||
"rows": "Rijen",
|
"rows": "Rijen",
|
||||||
"save_and_close": "Opslaan en sluiten",
|
"save_and_close": "Opslaan en sluiten",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Deze gratis en open source-enquête is gesloten",
|
"survey_completed_subheading": "Deze gratis en open source-enquête is gesloten",
|
||||||
"survey_display_settings": "Enquêteweergave-instellingen",
|
"survey_display_settings": "Enquêteweergave-instellingen",
|
||||||
"survey_placement": "Enquête plaatsing",
|
"survey_placement": "Enquête plaatsing",
|
||||||
|
"survey_styling": "Vorm styling",
|
||||||
"survey_trigger": "Enquêtetrigger",
|
"survey_trigger": "Enquêtetrigger",
|
||||||
"switch_multi_language_on_to_get_started": "Schakel meertaligheid in om te beginnen 👉",
|
"switch_multi_language_on_to_get_started": "Schakel meertaligheid in om te beginnen 👉",
|
||||||
"target_block_not_found": "Doelblok niet gevonden",
|
"target_block_not_found": "Doelblok niet gevonden",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Welkomstbericht",
|
"welcome_message": "Welkomstbericht",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Zonder filter kunnen al uw gebruikers worden bevraagd.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Zonder filter kunnen al uw gebruikers worden bevraagd.",
|
||||||
"you_have_not_created_a_segment_yet": "U heeft nog geen segment aangemaakt",
|
"you_have_not_created_a_segment_yet": "U heeft nog geen segment aangemaakt",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Je moet twee of meer talen hebben ingesteld in je werkruimte om met vertalingen te kunnen werken.",
|
|
||||||
"your_description_here_recall_information_with": "Uw beschrijving hier. Roep informatie op met @",
|
"your_description_here_recall_information_with": "Uw beschrijving hier. Roep informatie op met @",
|
||||||
"your_question_here_recall_information_with": "Uw vraag hier. Roep informatie op met @",
|
"your_question_here_recall_information_with": "Uw vraag hier. Roep informatie op met @",
|
||||||
"your_web_app": "Uw web-app",
|
"your_web_app": "Uw web-app",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Gefilterde reacties (Excel)",
|
"filtered_responses_excel": "Gefilterde reacties (Excel)",
|
||||||
"generating_qr_code": "QR-code genereren",
|
"generating_qr_code": "QR-code genereren",
|
||||||
"impressions": "Indrukken",
|
"impressions": "Indrukken",
|
||||||
|
"impressions_identified_only": "Alleen weergaven van geïdentificeerde contacten worden getoond",
|
||||||
"impressions_tooltip": "Aantal keren dat de enquête is bekeken.",
|
"impressions_tooltip": "Aantal keren dat de enquête is bekeken.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "De enquête wordt getoond aan gebruikers van uw website die voldoen aan de onderstaande criteria",
|
"connection_description": "De enquête wordt getoond aan gebruikers van uw website die voldoen aan de onderstaande criteria",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Laatste kwartaal",
|
"last_quarter": "Laatste kwartaal",
|
||||||
"last_year": "Vorig jaar",
|
"last_year": "Vorig jaar",
|
||||||
"limit": "Beperken",
|
"limit": "Beperken",
|
||||||
|
"no_identified_impressions": "Geen weergaven van geïdentificeerde contacten",
|
||||||
"no_responses_found": "Geen reacties gevonden",
|
"no_responses_found": "Geen reacties gevonden",
|
||||||
"other_values_found": "Andere waarden gevonden",
|
"other_values_found": "Andere waarden gevonden",
|
||||||
"overall": "Algemeen",
|
"overall": "Algemeen",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Begint",
|
"starts": "Begint",
|
||||||
"starts_tooltip": "Aantal keren dat de enquête is gestart.",
|
"starts_tooltip": "Aantal keren dat de enquête is gestart.",
|
||||||
"survey_reset_successfully": "Enquête opnieuw ingesteld! {responseCount} reacties en {displayCount} displays zijn verwijderd.",
|
"survey_reset_successfully": "Enquête opnieuw ingesteld! {responseCount} reacties en {displayCount} displays zijn verwijderd.",
|
||||||
|
"survey_results": "Resultaten van {surveyName}",
|
||||||
"this_month": "Deze maand",
|
"this_month": "Deze maand",
|
||||||
"this_quarter": "Dit kwartaal",
|
"this_quarter": "Dit kwartaal",
|
||||||
"this_year": "Dit jaar",
|
"this_year": "Dit jaar",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Kleurt het gevulde deel van de balk.",
|
"advanced_styling_field_indicator_bg_description": "Kleurt het gevulde deel van de balk.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Rondt de invoerhoeken af.",
|
"advanced_styling_field_input_border_radius_description": "Rondt de invoerhoeken af.",
|
||||||
"advanced_styling_field_input_font_size_description": "Schaalt de getypte tekst in invoervelden.",
|
"advanced_styling_field_input_font_size_description": "Schaalt de getypte tekst in invoervelden.",
|
||||||
"advanced_styling_field_input_height_description": "Bepaalt de minimale hoogte van het invoerveld.",
|
"advanced_styling_field_input_height_description": "Bepaalt de min. hoogte van het invoerveld.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Voegt ruimte toe aan de linker- en rechterkant.",
|
"advanced_styling_field_input_padding_x_description": "Voegt ruimte toe aan de linker- en rechterkant.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Voegt ruimte toe aan de boven- en onderkant.",
|
"advanced_styling_field_input_padding_y_description": "Voegt ruimte toe aan de boven- en onderkant.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Vervaagt de tijdelijke aanwijzingstekst.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Vervaagt de tijdelijke aanwijzingstekst.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Kleurt de getypte tekst in invoervelden.",
|
"advanced_styling_field_input_text_description": "Kleurt de getypte tekst in invoervelden.",
|
||||||
"advanced_styling_field_option_bg": "Achtergrond",
|
"advanced_styling_field_option_bg": "Achtergrond",
|
||||||
"advanced_styling_field_option_bg_description": "Vult de optie-items.",
|
"advanced_styling_field_option_bg_description": "Vult de optie-items.",
|
||||||
|
"advanced_styling_field_option_border": "Randkleur",
|
||||||
|
"advanced_styling_field_option_border_description": "Omlijnt radio- en checkboxopties.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Rondt de hoeken van opties af.",
|
"advanced_styling_field_option_border_radius_description": "Rondt de hoeken van opties af.",
|
||||||
"advanced_styling_field_option_font_size_description": "Schaalt de tekst van optielabels.",
|
"advanced_styling_field_option_font_size_description": "Schaalt de tekst van optielabels.",
|
||||||
"advanced_styling_field_option_label": "Labelkleur",
|
"advanced_styling_field_option_label": "Labelkleur",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Nee, dank je!",
|
"preview_survey_question_2_choice_2_label": "Nee, dank je!",
|
||||||
"preview_survey_question_2_headline": "Wil je op de hoogte blijven?",
|
"preview_survey_question_2_headline": "Wil je op de hoogte blijven?",
|
||||||
"preview_survey_question_2_subheader": "Dit is een voorbeeldbeschrijving.",
|
"preview_survey_question_2_subheader": "Dit is een voorbeeldbeschrijving.",
|
||||||
|
"preview_survey_question_open_text_headline": "Wil je nog iets delen?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Typ hier je antwoord...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Je feedback helpt ons verbeteren.",
|
||||||
"preview_survey_welcome_card_headline": "Welkom!",
|
"preview_survey_welcome_card_headline": "Welkom!",
|
||||||
"prioritize_features_description": "Identificeer functies die uw gebruikers het meest en het minst nodig hebben.",
|
"prioritize_features_description": "Identificeer functies die uw gebruikers het meest en het minst nodig hebben.",
|
||||||
"prioritize_features_name": "Geef prioriteit aan functies",
|
"prioritize_features_name": "Geef prioriteit aan functies",
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Copiar",
|
"copy": "Copiar",
|
||||||
"copy_code": "Copiar código",
|
"copy_code": "Copiar código",
|
||||||
"copy_link": "Copiar Link",
|
"copy_link": "Copiar Link",
|
||||||
"count_attributes": "{value, plural, one {{value} atributo} other {{value} atributos}}",
|
"count_attributes": "{count, plural, one {{count} atributo} other {{count} atributos}}",
|
||||||
"count_contacts": "{value, plural, one {# contato} other {# contatos} }",
|
"count_contacts": "{count, plural, one {# contato} other {# contatos} }",
|
||||||
"count_responses": "{value, plural, other {# respostas}}",
|
"count_members": "{count, plural, one {{count} membro} other {{count} membros}}",
|
||||||
|
"count_responses": "{count, plural, other {# respostas}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} seleção} other {{count} seleções}}",
|
||||||
"create_new_organization": "Criar nova organização",
|
"create_new_organization": "Criar nova organização",
|
||||||
"create_segment": "Criar segmento",
|
"create_segment": "Criar segmento",
|
||||||
"create_survey": "Criar pesquisa",
|
"create_survey": "Criar pesquisa",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "dias",
|
"days": "dias",
|
||||||
"default": "Padrão",
|
"default": "Padrão",
|
||||||
"delete": "Apagar",
|
"delete": "Apagar",
|
||||||
|
"delete_what": "Excluir {deleteWhat}",
|
||||||
"description": "Descrição",
|
"description": "Descrição",
|
||||||
"dev_env": "Ambiente de Desenvolvimento",
|
"dev_env": "Ambiente de Desenvolvimento",
|
||||||
"development": "Desenvolvimento",
|
"development": "Desenvolvimento",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Erro",
|
"error": "Erro",
|
||||||
"error_component_description": "Esse recurso não existe ou você não tem permissão para acessá-lo.",
|
"error_component_description": "Esse recurso não existe ou você não tem permissão para acessá-lo.",
|
||||||
"error_component_title": "Erro ao carregar recursos",
|
"error_component_title": "Erro ao carregar recursos",
|
||||||
|
"error_loading_data": "Erro ao carregar dados",
|
||||||
"error_rate_limit_description": "Número máximo de requisições atingido. Por favor, tente novamente mais tarde.",
|
"error_rate_limit_description": "Número máximo de requisições atingido. Por favor, tente novamente mais tarde.",
|
||||||
"error_rate_limit_title": "Limite de Taxa Excedido",
|
"error_rate_limit_title": "Limite de Taxa Excedido",
|
||||||
"expand_rows": "Expandir linhas",
|
"expand_rows": "Expandir linhas",
|
||||||
"failed_to_copy_to_clipboard": "Falha ao copiar para a área de transferência",
|
"failed_to_copy_to_clipboard": "Falha ao copiar para a área de transferência",
|
||||||
"failed_to_load_organizations": "Falha ao carregar organizações",
|
"failed_to_load_organizations": "Falha ao carregar organizações",
|
||||||
"failed_to_load_workspaces": "Falha ao carregar projetos",
|
"failed_to_load_workspaces": "Falha ao carregar projetos",
|
||||||
|
"filter": "Filtro",
|
||||||
"finish": "Terminar",
|
"finish": "Terminar",
|
||||||
|
"first_name": "Primeiro nome",
|
||||||
"follow_these": "Siga esses",
|
"follow_these": "Siga esses",
|
||||||
"formbricks_version": "Versão do Formbricks",
|
"formbricks_version": "Versão do Formbricks",
|
||||||
"full_name": "Nome completo",
|
"full_name": "Nome completo",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Campo oculto",
|
"hidden_field": "Campo oculto",
|
||||||
"hidden_fields": "Campos ocultos",
|
"hidden_fields": "Campos ocultos",
|
||||||
"hide_column": "Ocultar coluna",
|
"hide_column": "Ocultar coluna",
|
||||||
|
"id": "ID",
|
||||||
"image": "imagem",
|
"image": "imagem",
|
||||||
"images": "Imagens",
|
"images": "Imagens",
|
||||||
"import": "importar",
|
"import": "importar",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Chave",
|
"key": "Chave",
|
||||||
"label": "Etiqueta",
|
"label": "Etiqueta",
|
||||||
"language": "Língua",
|
"language": "Língua",
|
||||||
|
"last_name": "Sobrenome",
|
||||||
"learn_more": "Saiba mais",
|
"learn_more": "Saiba mais",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "sobreposição leve",
|
"light_overlay": "sobreposição leve",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Aparência e Experiência",
|
"look_and_feel": "Aparência e Experiência",
|
||||||
"manage": "gerenciar",
|
"manage": "gerenciar",
|
||||||
"marketing": "marketing",
|
"marketing": "marketing",
|
||||||
"member": "Membros",
|
|
||||||
"members": "Membros",
|
"members": "Membros",
|
||||||
"members_and_teams": "Membros e equipes",
|
"members_and_teams": "Membros e equipes",
|
||||||
"membership_not_found": "Assinatura não encontrada",
|
"membership_not_found": "Assinatura não encontrada",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Descer",
|
"move_down": "Descer",
|
||||||
"move_up": "Subir",
|
"move_up": "Subir",
|
||||||
"multiple_languages": "Vários idiomas",
|
"multiple_languages": "Vários idiomas",
|
||||||
|
"my_product": "meu produto",
|
||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"new": "Novo",
|
"new": "Novo",
|
||||||
"new_version_available": "Formbricks {version} chegou. Atualize agora!",
|
"new_version_available": "Formbricks {version} chegou. Atualize agora!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Selecionar times",
|
"select_teams": "Selecionar times",
|
||||||
"selected": "Selecionado",
|
"selected": "Selecionado",
|
||||||
"selected_questions": "Perguntas selecionadas",
|
"selected_questions": "Perguntas selecionadas",
|
||||||
"selection": "seleção",
|
|
||||||
"selections": "seleções",
|
|
||||||
"send_test_email": "Enviar e-mail de teste",
|
"send_test_email": "Enviar e-mail de teste",
|
||||||
"session_not_found": "Sessão não encontrada",
|
"session_not_found": "Sessão não encontrada",
|
||||||
"settings": "Configurações",
|
"settings": "Configurações",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Canto Superior Direito",
|
"top_right": "Canto Superior Direito",
|
||||||
"try_again": "Tenta de novo",
|
"try_again": "Tenta de novo",
|
||||||
"type": "Tipo",
|
"type": "Tipo",
|
||||||
|
"unknown_survey": "Pesquisa desconhecida",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Desbloqueie mais projetos com um plano superior.",
|
"unlock_more_workspaces_with_a_higher_plan": "Desbloqueie mais projetos com um plano superior.",
|
||||||
"update": "atualizar",
|
"update": "atualizar",
|
||||||
"updated": "atualizado",
|
"updated": "atualizado",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Isso excluirá o atributo selecionado. Todos os dados de contato associados a este atributo serão perdidos.} other {Isso excluirá os atributos selecionados. Todos os dados de contato associados a estes atributos serão perdidos.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Isso excluirá o atributo selecionado. Todos os dados de contato associados a este atributo serão perdidos.} other {Isso excluirá os atributos selecionados. Todos os dados de contato associados a estes atributos serão perdidos.}}",
|
||||||
"delete_contact_confirmation": "Isso irá apagar todas as respostas da pesquisa e atributos de contato associados a este contato. Qualquer direcionamento e personalização baseados nos dados deste contato serão perdidos.",
|
"delete_contact_confirmation": "Isso irá apagar todas as respostas da pesquisa e atributos de contato associados a este contato. Qualquer direcionamento e personalização baseados nos dados deste contato serão perdidos.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, other {Isso irá apagar todas as respostas da pesquisa e atributos de contato associados a este contato. Qualquer direcionamento e personalização baseados nos dados deste contato serão perdidos. Se este contato tiver respostas que contam para cotas da pesquisa, as contagens das cotas serão reduzidas, mas os limites das cotas permanecerão inalterados.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, other {Isso irá apagar todas as respostas da pesquisa e atributos de contato associados a este contato. Qualquer direcionamento e personalização baseados nos dados deste contato serão perdidos. Se este contato tiver respostas que contam para cotas da pesquisa, as contagens das cotas serão reduzidas, mas os limites das cotas permanecerão inalterados.}}",
|
||||||
|
"displays": "Exibições",
|
||||||
"edit_attribute": "Editar atributo",
|
"edit_attribute": "Editar atributo",
|
||||||
"edit_attribute_description": "Atualize a etiqueta e a descrição deste atributo.",
|
"edit_attribute_description": "Atualize a etiqueta e a descrição deste atributo.",
|
||||||
"edit_attribute_values": "Editar atributos",
|
"edit_attribute_values": "Editar atributos",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Nome(s) de coluna CSV inválido(s): {columns}. Os nomes de colunas que se tornarão novos atributos devem conter apenas letras minúsculas, números e sublinhados, e devem começar com uma letra.",
|
"invalid_csv_column_names": "Nome(s) de coluna CSV inválido(s): {columns}. Os nomes de colunas que se tornarão novos atributos devem conter apenas letras minúsculas, números e sublinhados, e devem começar com uma letra.",
|
||||||
"invalid_date_format": "Formato de data inválido. Por favor, use uma data válida.",
|
"invalid_date_format": "Formato de data inválido. Por favor, use uma data válida.",
|
||||||
"invalid_number_format": "Formato de número inválido. Por favor, insira um número válido.",
|
"invalid_number_format": "Formato de número inválido. Por favor, insira um número válido.",
|
||||||
|
"no_activity_yet": "Nenhuma atividade ainda",
|
||||||
"no_published_link_surveys_available": "Não há pesquisas de link publicadas disponíveis. Por favor, publique uma pesquisa de link primeiro.",
|
"no_published_link_surveys_available": "Não há pesquisas de link publicadas disponíveis. Por favor, publique uma pesquisa de link primeiro.",
|
||||||
"no_published_surveys": "Sem pesquisas publicadas",
|
"no_published_surveys": "Sem pesquisas publicadas",
|
||||||
"no_responses_found": "Nenhuma resposta encontrada",
|
"no_responses_found": "Nenhuma resposta encontrada",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Selecione uma pesquisa",
|
"select_a_survey": "Selecione uma pesquisa",
|
||||||
"select_attribute": "Selecionar Atributo",
|
"select_attribute": "Selecionar Atributo",
|
||||||
"select_attribute_key": "Selecionar chave de atributo",
|
"select_attribute_key": "Selecionar chave de atributo",
|
||||||
|
"survey_viewed": "Pesquisa visualizada",
|
||||||
|
"survey_viewed_at": "Visualizada em",
|
||||||
"system_attributes": "Atributos do sistema",
|
"system_attributes": "Atributos do sistema",
|
||||||
"unlock_contacts_description": "Gerencie contatos e envie pesquisas direcionadas",
|
"unlock_contacts_description": "Gerencie contatos e envie pesquisas direcionadas",
|
||||||
"unlock_contacts_title": "Desbloqueie contatos com um plano superior",
|
"unlock_contacts_title": "Desbloqueie contatos com um plano superior",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Oi {userName}",
|
"email_customization_preview_email_heading": "Oi {userName}",
|
||||||
"email_customization_preview_email_text": "Esta é uma pré-visualização de e-mail para mostrar qual logo será renderizado nos e-mails.",
|
"email_customization_preview_email_text": "Esta é uma pré-visualização de e-mail para mostrar qual logo será renderizado nos e-mails.",
|
||||||
"error_deleting_organization_please_try_again": "Erro ao deletar a organização. Por favor, tente novamente.",
|
"error_deleting_organization_please_try_again": "Erro ao deletar a organização. Por favor, tente novamente.",
|
||||||
"from_your_organization": "da sua organização",
|
"from_your_organization": "{memberName} da sua organização",
|
||||||
"invitation_sent_once_more": "Convite enviado de novo.",
|
"invitation_sent_once_more": "Convite enviado de novo.",
|
||||||
"invite_deleted_successfully": "Convite deletado com sucesso",
|
"invite_deleted_successfully": "Convite deletado com sucesso",
|
||||||
"invite_expires_on": "O convite expira em {date}",
|
"invite_expires_on": "O convite expira em {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Adicionar um texto padrão para mostrar se a pergunta for ignorada:",
|
"add_fallback_placeholder": "Adicionar um texto padrão para mostrar se a pergunta for ignorada:",
|
||||||
"add_hidden_field_id": "Adicionar campo oculto ID",
|
"add_hidden_field_id": "Adicionar campo oculto ID",
|
||||||
"add_highlight_border": "Adicionar borda de destaque",
|
"add_highlight_border": "Adicionar borda de destaque",
|
||||||
|
"add_highlight_border_description": "Aplica-se apenas a pesquisas no produto.",
|
||||||
"add_logic": "Adicionar lógica",
|
"add_logic": "Adicionar lógica",
|
||||||
"add_none_of_the_above": "Adicionar \"Nenhuma das opções acima\"",
|
"add_none_of_the_above": "Adicionar \"Nenhuma das opções acima\"",
|
||||||
"add_option": "Adicionar opção",
|
"add_option": "Adicionar opção",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Acompanhamento atualizado e será salvo assim que você salvar a pesquisa.",
|
"follow_ups_modal_updated_successfull_toast": "Acompanhamento atualizado e será salvo assim que você salvar a pesquisa.",
|
||||||
"follow_ups_new": "Novo acompanhamento",
|
"follow_ups_new": "Novo acompanhamento",
|
||||||
"follow_ups_upgrade_button_text": "Atualize para habilitar os Acompanhamentos",
|
"follow_ups_upgrade_button_text": "Atualize para habilitar os Acompanhamentos",
|
||||||
"form_styling": "Estilização de Formulários",
|
|
||||||
"formbricks_sdk_is_not_connected": "O SDK do Formbricks não está conectado",
|
"formbricks_sdk_is_not_connected": "O SDK do Formbricks não está conectado",
|
||||||
"four_points": "4 pontos",
|
"four_points": "4 pontos",
|
||||||
"heading": "Título",
|
"heading": "Título",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Limites de resposta, redirecionamentos e mais.",
|
"response_limits_redirections_and_more": "Limites de resposta, redirecionamentos e mais.",
|
||||||
"response_options": "Opções de Resposta",
|
"response_options": "Opções de Resposta",
|
||||||
"roundness": "Circularidade",
|
"roundness": "Circularidade",
|
||||||
"roundness_description": "Controla o arredondamento dos cantos do cartão.",
|
"roundness_description": "Controla o arredondamento dos cantos.",
|
||||||
"row_used_in_logic_error": "Esta linha é usada na lógica da pergunta {questionIndex}. Por favor, remova-a da lógica primeiro.",
|
"row_used_in_logic_error": "Esta linha é usada na lógica da pergunta {questionIndex}. Por favor, remova-a da lógica primeiro.",
|
||||||
"rows": "linhas",
|
"rows": "linhas",
|
||||||
"save_and_close": "Salvar e Fechar",
|
"save_and_close": "Salvar e Fechar",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Essa pesquisa gratuita e de código aberto foi encerrada",
|
"survey_completed_subheading": "Essa pesquisa gratuita e de código aberto foi encerrada",
|
||||||
"survey_display_settings": "Configurações de Exibição da Pesquisa",
|
"survey_display_settings": "Configurações de Exibição da Pesquisa",
|
||||||
"survey_placement": "Posicionamento da Pesquisa",
|
"survey_placement": "Posicionamento da Pesquisa",
|
||||||
|
"survey_styling": "Estilização de Formulários",
|
||||||
"survey_trigger": "Gatilho de Pesquisa",
|
"survey_trigger": "Gatilho de Pesquisa",
|
||||||
"switch_multi_language_on_to_get_started": "Ative o modo multilíngue para começar 👉",
|
"switch_multi_language_on_to_get_started": "Ative o modo multilíngue para começar 👉",
|
||||||
"target_block_not_found": "Bloco de destino não encontrado",
|
"target_block_not_found": "Bloco de destino não encontrado",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Mensagem de boas-vindas",
|
"welcome_message": "Mensagem de boas-vindas",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Sem um filtro, todos os seus usuários podem ser pesquisados.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Sem um filtro, todos os seus usuários podem ser pesquisados.",
|
||||||
"you_have_not_created_a_segment_yet": "Você ainda não criou um segmento.",
|
"you_have_not_created_a_segment_yet": "Você ainda não criou um segmento.",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Você precisa ter dois ou mais idiomas configurados em seu espaço de trabalho para trabalhar com traduções.",
|
|
||||||
"your_description_here_recall_information_with": "Sua descrição aqui. Lembre-se de informações com @",
|
"your_description_here_recall_information_with": "Sua descrição aqui. Lembre-se de informações com @",
|
||||||
"your_question_here_recall_information_with": "Sua pergunta aqui. Lembre-se de informações com @",
|
"your_question_here_recall_information_with": "Sua pergunta aqui. Lembre-se de informações com @",
|
||||||
"your_web_app": "Sua aplicação web",
|
"your_web_app": "Sua aplicação web",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Respostas filtradas (Excel)",
|
"filtered_responses_excel": "Respostas filtradas (Excel)",
|
||||||
"generating_qr_code": "Gerando código QR",
|
"generating_qr_code": "Gerando código QR",
|
||||||
"impressions": "Impressões",
|
"impressions": "Impressões",
|
||||||
|
"impressions_identified_only": "Mostrando apenas impressões de contatos identificados",
|
||||||
"impressions_tooltip": "Número de vezes que a pesquisa foi visualizada.",
|
"impressions_tooltip": "Número de vezes que a pesquisa foi visualizada.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "A pesquisa será exibida para usuários do seu site, que atendam aos critérios listados abaixo",
|
"connection_description": "A pesquisa será exibida para usuários do seu site, que atendam aos critérios listados abaixo",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Último trimestre",
|
"last_quarter": "Último trimestre",
|
||||||
"last_year": "Último ano",
|
"last_year": "Último ano",
|
||||||
"limit": "Limite",
|
"limit": "Limite",
|
||||||
|
"no_identified_impressions": "Nenhuma impressão de contatos identificados",
|
||||||
"no_responses_found": "Nenhuma resposta encontrada",
|
"no_responses_found": "Nenhuma resposta encontrada",
|
||||||
"other_values_found": "Outros valores encontrados",
|
"other_values_found": "Outros valores encontrados",
|
||||||
"overall": "No geral",
|
"overall": "No geral",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "começa",
|
"starts": "começa",
|
||||||
"starts_tooltip": "Número de vezes que a pesquisa foi iniciada.",
|
"starts_tooltip": "Número de vezes que a pesquisa foi iniciada.",
|
||||||
"survey_reset_successfully": "Pesquisa redefinida com sucesso! {responseCount} respostas e {displayCount} exibições foram deletadas.",
|
"survey_reset_successfully": "Pesquisa redefinida com sucesso! {responseCount} respostas e {displayCount} exibições foram deletadas.",
|
||||||
|
"survey_results": "Resultados de {surveyName}",
|
||||||
"this_month": "Este mês",
|
"this_month": "Este mês",
|
||||||
"this_quarter": "Este trimestre",
|
"this_quarter": "Este trimestre",
|
||||||
"this_year": "Este ano",
|
"this_year": "Este ano",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Colore a porção preenchida da barra.",
|
"advanced_styling_field_indicator_bg_description": "Colore a porção preenchida da barra.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Arredonda os cantos do campo.",
|
"advanced_styling_field_input_border_radius_description": "Arredonda os cantos do campo.",
|
||||||
"advanced_styling_field_input_font_size_description": "Ajusta o tamanho do texto digitado nos campos.",
|
"advanced_styling_field_input_font_size_description": "Ajusta o tamanho do texto digitado nos campos.",
|
||||||
"advanced_styling_field_input_height_description": "Controla a altura mínima do campo de entrada.",
|
"advanced_styling_field_input_height_description": "Controla a altura mínima da entrada.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Adiciona espaço à esquerda e à direita.",
|
"advanced_styling_field_input_padding_x_description": "Adiciona espaço à esquerda e à direita.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Adiciona espaço na parte superior e inferior.",
|
"advanced_styling_field_input_padding_y_description": "Adiciona espaço na parte superior e inferior.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Esmaece o texto de dica do placeholder.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Esmaece o texto de dica do placeholder.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Colore o texto digitado nos campos de entrada.",
|
"advanced_styling_field_input_text_description": "Colore o texto digitado nos campos de entrada.",
|
||||||
"advanced_styling_field_option_bg": "Fundo",
|
"advanced_styling_field_option_bg": "Fundo",
|
||||||
"advanced_styling_field_option_bg_description": "Preenche os itens de opção.",
|
"advanced_styling_field_option_bg_description": "Preenche os itens de opção.",
|
||||||
|
"advanced_styling_field_option_border": "Cor da borda",
|
||||||
|
"advanced_styling_field_option_border_description": "Contorna as opções de botões de rádio e caixas de seleção.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Arredonda os cantos das opções.",
|
"advanced_styling_field_option_border_radius_description": "Arredonda os cantos das opções.",
|
||||||
"advanced_styling_field_option_font_size_description": "Ajusta o tamanho do texto do rótulo da opção.",
|
"advanced_styling_field_option_font_size_description": "Ajusta o tamanho do texto do rótulo da opção.",
|
||||||
"advanced_styling_field_option_label": "Cor do rótulo",
|
"advanced_styling_field_option_label": "Cor do rótulo",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Não, obrigado!",
|
"preview_survey_question_2_choice_2_label": "Não, obrigado!",
|
||||||
"preview_survey_question_2_headline": "Quer ficar por dentro?",
|
"preview_survey_question_2_headline": "Quer ficar por dentro?",
|
||||||
"preview_survey_question_2_subheader": "Este é um exemplo de descrição.",
|
"preview_survey_question_2_subheader": "Este é um exemplo de descrição.",
|
||||||
|
"preview_survey_question_open_text_headline": "Tem mais alguma coisa que você gostaria de compartilhar?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Digite sua resposta aqui...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Seu feedback nos ajuda a melhorar.",
|
||||||
"preview_survey_welcome_card_headline": "Bem-vindo!",
|
"preview_survey_welcome_card_headline": "Bem-vindo!",
|
||||||
"prioritize_features_description": "Identifique os recursos que seus usuários mais e menos precisam.",
|
"prioritize_features_description": "Identifique os recursos que seus usuários mais e menos precisam.",
|
||||||
"prioritize_features_name": "Priorizar Funcionalidades",
|
"prioritize_features_name": "Priorizar Funcionalidades",
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Copiar",
|
"copy": "Copiar",
|
||||||
"copy_code": "Copiar código",
|
"copy_code": "Copiar código",
|
||||||
"copy_link": "Copiar Link",
|
"copy_link": "Copiar Link",
|
||||||
"count_attributes": "{value, plural, one {{value} atributo} other {{value} atributos}}",
|
"count_attributes": "{count, plural, one {{count} atributo} other {{count} atributos}}",
|
||||||
"count_contacts": "{value, plural, one {# contacto} other {# contactos} }",
|
"count_contacts": "{count, plural, one {# contacto} other {# contactos} }",
|
||||||
"count_responses": "{value, plural, other {# respostas}}",
|
"count_members": "{count, plural, one {{count} membro} other {{count} membros}}",
|
||||||
|
"count_responses": "{count, plural, other {# respostas}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} seleção} other {{count} seleções}}",
|
||||||
"create_new_organization": "Criar nova organização",
|
"create_new_organization": "Criar nova organização",
|
||||||
"create_segment": "Criar segmento",
|
"create_segment": "Criar segmento",
|
||||||
"create_survey": "Criar inquérito",
|
"create_survey": "Criar inquérito",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "dias",
|
"days": "dias",
|
||||||
"default": "Padrão",
|
"default": "Padrão",
|
||||||
"delete": "Eliminar",
|
"delete": "Eliminar",
|
||||||
|
"delete_what": "Eliminar {deleteWhat}",
|
||||||
"description": "Descrição",
|
"description": "Descrição",
|
||||||
"dev_env": "Ambiente de Desenvolvimento",
|
"dev_env": "Ambiente de Desenvolvimento",
|
||||||
"development": "Desenvolvimento",
|
"development": "Desenvolvimento",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Erro",
|
"error": "Erro",
|
||||||
"error_component_description": "Este recurso não existe ou não tem os direitos necessários para aceder a ele.",
|
"error_component_description": "Este recurso não existe ou não tem os direitos necessários para aceder a ele.",
|
||||||
"error_component_title": "Erro ao carregar recursos",
|
"error_component_title": "Erro ao carregar recursos",
|
||||||
|
"error_loading_data": "Erro ao carregar dados",
|
||||||
"error_rate_limit_description": "Número máximo de pedidos alcançado. Por favor, tente novamente mais tarde.",
|
"error_rate_limit_description": "Número máximo de pedidos alcançado. Por favor, tente novamente mais tarde.",
|
||||||
"error_rate_limit_title": "Limite de Taxa Excedido",
|
"error_rate_limit_title": "Limite de Taxa Excedido",
|
||||||
"expand_rows": "Expandir linhas",
|
"expand_rows": "Expandir linhas",
|
||||||
"failed_to_copy_to_clipboard": "Falha ao copiar para a área de transferência",
|
"failed_to_copy_to_clipboard": "Falha ao copiar para a área de transferência",
|
||||||
"failed_to_load_organizations": "Falha ao carregar organizações",
|
"failed_to_load_organizations": "Falha ao carregar organizações",
|
||||||
"failed_to_load_workspaces": "Falha ao carregar projetos",
|
"failed_to_load_workspaces": "Falha ao carregar projetos",
|
||||||
|
"filter": "Filtro",
|
||||||
"finish": "Concluir",
|
"finish": "Concluir",
|
||||||
|
"first_name": "Primeiro nome",
|
||||||
"follow_these": "Siga estes",
|
"follow_these": "Siga estes",
|
||||||
"formbricks_version": "Versão do Formbricks",
|
"formbricks_version": "Versão do Formbricks",
|
||||||
"full_name": "Nome completo",
|
"full_name": "Nome completo",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Campo oculto",
|
"hidden_field": "Campo oculto",
|
||||||
"hidden_fields": "Campos ocultos",
|
"hidden_fields": "Campos ocultos",
|
||||||
"hide_column": "Ocultar coluna",
|
"hide_column": "Ocultar coluna",
|
||||||
|
"id": "ID",
|
||||||
"image": "Imagem",
|
"image": "Imagem",
|
||||||
"images": "Imagens",
|
"images": "Imagens",
|
||||||
"import": "Importar",
|
"import": "Importar",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Chave",
|
"key": "Chave",
|
||||||
"label": "Etiqueta",
|
"label": "Etiqueta",
|
||||||
"language": "Idioma",
|
"language": "Idioma",
|
||||||
|
"last_name": "Apelido",
|
||||||
"learn_more": "Saiba mais",
|
"learn_more": "Saiba mais",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Sobreposição leve",
|
"light_overlay": "Sobreposição leve",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Aparência e Sensação",
|
"look_and_feel": "Aparência e Sensação",
|
||||||
"manage": "Gerir",
|
"manage": "Gerir",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Membro",
|
|
||||||
"members": "Membros",
|
"members": "Membros",
|
||||||
"members_and_teams": "Membros e equipas",
|
"members_and_teams": "Membros e equipas",
|
||||||
"membership_not_found": "Associação não encontrada",
|
"membership_not_found": "Associação não encontrada",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Mover para baixo",
|
"move_down": "Mover para baixo",
|
||||||
"move_up": "Mover para cima",
|
"move_up": "Mover para cima",
|
||||||
"multiple_languages": "Várias línguas",
|
"multiple_languages": "Várias línguas",
|
||||||
|
"my_product": "o meu produto",
|
||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"new": "Novo",
|
"new": "Novo",
|
||||||
"new_version_available": "Formbricks {version} está aqui. Atualize agora!",
|
"new_version_available": "Formbricks {version} está aqui. Atualize agora!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Selecionar equipas",
|
"select_teams": "Selecionar equipas",
|
||||||
"selected": "Selecionado",
|
"selected": "Selecionado",
|
||||||
"selected_questions": "Perguntas selecionadas",
|
"selected_questions": "Perguntas selecionadas",
|
||||||
"selection": "Seleção",
|
|
||||||
"selections": "Seleções",
|
|
||||||
"send_test_email": "Enviar email de teste",
|
"send_test_email": "Enviar email de teste",
|
||||||
"session_not_found": "Sessão não encontrada",
|
"session_not_found": "Sessão não encontrada",
|
||||||
"settings": "Configurações",
|
"settings": "Configurações",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Superior Direito",
|
"top_right": "Superior Direito",
|
||||||
"try_again": "Tente novamente",
|
"try_again": "Tente novamente",
|
||||||
"type": "Tipo",
|
"type": "Tipo",
|
||||||
|
"unknown_survey": "Inquérito desconhecido",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Desbloqueie mais projetos com um plano superior.",
|
"unlock_more_workspaces_with_a_higher_plan": "Desbloqueie mais projetos com um plano superior.",
|
||||||
"update": "Atualizar",
|
"update": "Atualizar",
|
||||||
"updated": "Atualizado",
|
"updated": "Atualizado",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Isto irá eliminar o atributo selecionado. Todos os dados de contacto associados a este atributo serão perdidos.} other {Isto irá eliminar os atributos selecionados. Todos os dados de contacto associados a estes atributos serão perdidos.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Isto irá eliminar o atributo selecionado. Todos os dados de contacto associados a este atributo serão perdidos.} other {Isto irá eliminar os atributos selecionados. Todos os dados de contacto associados a estes atributos serão perdidos.}}",
|
||||||
"delete_contact_confirmation": "Isto irá eliminar todas as respostas das pesquisas e os atributos de contato associados a este contato. Qualquer direcionamento e personalização baseados nos dados deste contato serão perdidos.",
|
"delete_contact_confirmation": "Isto irá eliminar todas as respostas das pesquisas e os atributos de contato associados a este contato. Qualquer direcionamento e personalização baseados nos dados deste contato serão perdidos.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, other {Isto irá eliminar todas as respostas das pesquisas e os atributos de contacto associados a este contacto. Qualquer segmentação e personalização baseados nos dados deste contacto serão perdidos. Se este contacto tiver respostas que contribuam para as quotas das pesquisas, as contagens de quotas serão reduzidas, mas os limites das quotas permanecerão inalterados.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, other {Isto irá eliminar todas as respostas das pesquisas e os atributos de contacto associados a este contacto. Qualquer segmentação e personalização baseados nos dados deste contacto serão perdidos. Se este contacto tiver respostas que contribuam para as quotas das pesquisas, as contagens de quotas serão reduzidas, mas os limites das quotas permanecerão inalterados.}}",
|
||||||
|
"displays": "Visualizações",
|
||||||
"edit_attribute": "Editar atributo",
|
"edit_attribute": "Editar atributo",
|
||||||
"edit_attribute_description": "Atualize a etiqueta e a descrição deste atributo.",
|
"edit_attribute_description": "Atualize a etiqueta e a descrição deste atributo.",
|
||||||
"edit_attribute_values": "Editar atributos",
|
"edit_attribute_values": "Editar atributos",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Nome(s) de coluna CSV inválido(s): {columns}. Os nomes de colunas que se tornarão novos atributos devem conter apenas letras minúsculas, números e underscores, e devem começar com uma letra.",
|
"invalid_csv_column_names": "Nome(s) de coluna CSV inválido(s): {columns}. Os nomes de colunas que se tornarão novos atributos devem conter apenas letras minúsculas, números e underscores, e devem começar com uma letra.",
|
||||||
"invalid_date_format": "Formato de data inválido. Por favor, usa uma data válida.",
|
"invalid_date_format": "Formato de data inválido. Por favor, usa uma data válida.",
|
||||||
"invalid_number_format": "Formato de número inválido. Por favor, introduz um número válido.",
|
"invalid_number_format": "Formato de número inválido. Por favor, introduz um número válido.",
|
||||||
|
"no_activity_yet": "Ainda sem atividade",
|
||||||
"no_published_link_surveys_available": "Não existem inquéritos de link publicados disponíveis. Por favor, publique primeiro um inquérito de link.",
|
"no_published_link_surveys_available": "Não existem inquéritos de link publicados disponíveis. Por favor, publique primeiro um inquérito de link.",
|
||||||
"no_published_surveys": "Sem inquéritos publicados",
|
"no_published_surveys": "Sem inquéritos publicados",
|
||||||
"no_responses_found": "Nenhuma resposta encontrada",
|
"no_responses_found": "Nenhuma resposta encontrada",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Selecione um inquérito",
|
"select_a_survey": "Selecione um inquérito",
|
||||||
"select_attribute": "Selecionar Atributo",
|
"select_attribute": "Selecionar Atributo",
|
||||||
"select_attribute_key": "Selecionar chave de atributo",
|
"select_attribute_key": "Selecionar chave de atributo",
|
||||||
|
"survey_viewed": "Inquérito visualizado",
|
||||||
|
"survey_viewed_at": "Visualizado em",
|
||||||
"system_attributes": "Atributos do sistema",
|
"system_attributes": "Atributos do sistema",
|
||||||
"unlock_contacts_description": "Gerir contactos e enviar inquéritos direcionados",
|
"unlock_contacts_description": "Gerir contactos e enviar inquéritos direcionados",
|
||||||
"unlock_contacts_title": "Desbloqueie os contactos com um plano superior",
|
"unlock_contacts_title": "Desbloqueie os contactos com um plano superior",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Olá {userName}",
|
"email_customization_preview_email_heading": "Olá {userName}",
|
||||||
"email_customization_preview_email_text": "Esta é uma pré-visualização de email para mostrar qual logotipo será exibido nos emails.",
|
"email_customization_preview_email_text": "Esta é uma pré-visualização de email para mostrar qual logotipo será exibido nos emails.",
|
||||||
"error_deleting_organization_please_try_again": "Erro ao eliminar a organização. Por favor, tente novamente.",
|
"error_deleting_organization_please_try_again": "Erro ao eliminar a organização. Por favor, tente novamente.",
|
||||||
"from_your_organization": "da sua organização",
|
"from_your_organization": "{memberName} da sua organização",
|
||||||
"invitation_sent_once_more": "Convite enviado mais uma vez.",
|
"invitation_sent_once_more": "Convite enviado mais uma vez.",
|
||||||
"invite_deleted_successfully": "Convite eliminado com sucesso",
|
"invite_deleted_successfully": "Convite eliminado com sucesso",
|
||||||
"invite_expires_on": "O convite expira em {date}",
|
"invite_expires_on": "O convite expira em {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Adicionar um espaço reservado para mostrar se não houver valor para recordar.",
|
"add_fallback_placeholder": "Adicionar um espaço reservado para mostrar se não houver valor para recordar.",
|
||||||
"add_hidden_field_id": "Adicionar ID do campo oculto",
|
"add_hidden_field_id": "Adicionar ID do campo oculto",
|
||||||
"add_highlight_border": "Adicionar borda de destaque",
|
"add_highlight_border": "Adicionar borda de destaque",
|
||||||
|
"add_highlight_border_description": "Aplica-se apenas a inquéritos no produto.",
|
||||||
"add_logic": "Adicionar lógica",
|
"add_logic": "Adicionar lógica",
|
||||||
"add_none_of_the_above": "Adicionar \"Nenhuma das Opções Acima\"",
|
"add_none_of_the_above": "Adicionar \"Nenhuma das Opções Acima\"",
|
||||||
"add_option": "Adicionar opção",
|
"add_option": "Adicionar opção",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Seguimento atualizado e será guardado assim que guardar o questionário.",
|
"follow_ups_modal_updated_successfull_toast": "Seguimento atualizado e será guardado assim que guardar o questionário.",
|
||||||
"follow_ups_new": "Novo acompanhamento",
|
"follow_ups_new": "Novo acompanhamento",
|
||||||
"follow_ups_upgrade_button_text": "Atualize para ativar os acompanhamentos",
|
"follow_ups_upgrade_button_text": "Atualize para ativar os acompanhamentos",
|
||||||
"form_styling": "Estilo do formulário",
|
|
||||||
"formbricks_sdk_is_not_connected": "O SDK do Formbricks não está conectado",
|
"formbricks_sdk_is_not_connected": "O SDK do Formbricks não está conectado",
|
||||||
"four_points": "4 pontos",
|
"four_points": "4 pontos",
|
||||||
"heading": "Cabeçalho",
|
"heading": "Cabeçalho",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Limites de resposta, redirecionamentos e mais.",
|
"response_limits_redirections_and_more": "Limites de resposta, redirecionamentos e mais.",
|
||||||
"response_options": "Opções de Resposta",
|
"response_options": "Opções de Resposta",
|
||||||
"roundness": "Arredondamento",
|
"roundness": "Arredondamento",
|
||||||
"roundness_description": "Controla o arredondamento dos cantos do cartão.",
|
"roundness_description": "Controla o arredondamento dos cantos.",
|
||||||
"row_used_in_logic_error": "Esta linha é usada na lógica da pergunta {questionIndex}. Por favor, remova-a da lógica primeiro.",
|
"row_used_in_logic_error": "Esta linha é usada na lógica da pergunta {questionIndex}. Por favor, remova-a da lógica primeiro.",
|
||||||
"rows": "Linhas",
|
"rows": "Linhas",
|
||||||
"save_and_close": "Guardar e Fechar",
|
"save_and_close": "Guardar e Fechar",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Este inquérito gratuito e de código aberto foi encerrado",
|
"survey_completed_subheading": "Este inquérito gratuito e de código aberto foi encerrado",
|
||||||
"survey_display_settings": "Configurações de Exibição do Inquérito",
|
"survey_display_settings": "Configurações de Exibição do Inquérito",
|
||||||
"survey_placement": "Colocação do Inquérito",
|
"survey_placement": "Colocação do Inquérito",
|
||||||
|
"survey_styling": "Estilo do formulário",
|
||||||
"survey_trigger": "Desencadeador de Inquérito",
|
"survey_trigger": "Desencadeador de Inquérito",
|
||||||
"switch_multi_language_on_to_get_started": "Ative o modo multilingue para começar 👉",
|
"switch_multi_language_on_to_get_started": "Ative o modo multilingue para começar 👉",
|
||||||
"target_block_not_found": "Bloco de destino não encontrado",
|
"target_block_not_found": "Bloco de destino não encontrado",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Mensagem de boas-vindas",
|
"welcome_message": "Mensagem de boas-vindas",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Sem um filtro, todos os seus utilizadores podem ser pesquisados.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Sem um filtro, todos os seus utilizadores podem ser pesquisados.",
|
||||||
"you_have_not_created_a_segment_yet": "Ainda não criou um segmento",
|
"you_have_not_created_a_segment_yet": "Ainda não criou um segmento",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Precisa de ter dois ou mais idiomas configurados no seu espaço de trabalho para trabalhar com traduções.",
|
|
||||||
"your_description_here_recall_information_with": "A sua descrição aqui. Recorde a informação com @",
|
"your_description_here_recall_information_with": "A sua descrição aqui. Recorde a informação com @",
|
||||||
"your_question_here_recall_information_with": "A sua pergunta aqui. Recorde a informação com @",
|
"your_question_here_recall_information_with": "A sua pergunta aqui. Recorde a informação com @",
|
||||||
"your_web_app": "A sua aplicação web",
|
"your_web_app": "A sua aplicação web",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Respostas filtradas (Excel)",
|
"filtered_responses_excel": "Respostas filtradas (Excel)",
|
||||||
"generating_qr_code": "A gerar código QR",
|
"generating_qr_code": "A gerar código QR",
|
||||||
"impressions": "Impressões",
|
"impressions": "Impressões",
|
||||||
|
"impressions_identified_only": "A mostrar apenas impressões de contactos identificados",
|
||||||
"impressions_tooltip": "Número de vezes que o inquérito foi visualizado.",
|
"impressions_tooltip": "Número de vezes que o inquérito foi visualizado.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "O questionário será exibido aos utilizadores do seu website que correspondam aos critérios listados abaixo",
|
"connection_description": "O questionário será exibido aos utilizadores do seu website que correspondam aos critérios listados abaixo",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Último trimestre",
|
"last_quarter": "Último trimestre",
|
||||||
"last_year": "Ano passado",
|
"last_year": "Ano passado",
|
||||||
"limit": "Limite",
|
"limit": "Limite",
|
||||||
|
"no_identified_impressions": "Sem impressões de contactos identificados",
|
||||||
"no_responses_found": "Nenhuma resposta encontrada",
|
"no_responses_found": "Nenhuma resposta encontrada",
|
||||||
"other_values_found": "Outros valores encontrados",
|
"other_values_found": "Outros valores encontrados",
|
||||||
"overall": "Geral",
|
"overall": "Geral",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Começa",
|
"starts": "Começa",
|
||||||
"starts_tooltip": "Número de vezes que o inquérito foi iniciado.",
|
"starts_tooltip": "Número de vezes que o inquérito foi iniciado.",
|
||||||
"survey_reset_successfully": "Inquérito reiniciado com sucesso! {responseCount} respostas e {displayCount} exibições foram eliminadas.",
|
"survey_reset_successfully": "Inquérito reiniciado com sucesso! {responseCount} respostas e {displayCount} exibições foram eliminadas.",
|
||||||
|
"survey_results": "Resultados de {surveyName}",
|
||||||
"this_month": "Este mês",
|
"this_month": "Este mês",
|
||||||
"this_quarter": "Este trimestre",
|
"this_quarter": "Este trimestre",
|
||||||
"this_year": "Este ano",
|
"this_year": "Este ano",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Colore a porção preenchida da barra.",
|
"advanced_styling_field_indicator_bg_description": "Colore a porção preenchida da barra.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Arredonda os cantos do campo.",
|
"advanced_styling_field_input_border_radius_description": "Arredonda os cantos do campo.",
|
||||||
"advanced_styling_field_input_font_size_description": "Ajusta o tamanho do texto digitado nos campos.",
|
"advanced_styling_field_input_font_size_description": "Ajusta o tamanho do texto digitado nos campos.",
|
||||||
"advanced_styling_field_input_height_description": "Controla a altura mínima do campo de entrada.",
|
"advanced_styling_field_input_height_description": "Controla a altura mínima da entrada.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Adiciona espaço à esquerda e à direita.",
|
"advanced_styling_field_input_padding_x_description": "Adiciona espaço à esquerda e à direita.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Adiciona espaço no topo e na base.",
|
"advanced_styling_field_input_padding_y_description": "Adiciona espaço no topo e na base.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Atenua o texto de sugestão do placeholder.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Atenua o texto de sugestão do placeholder.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Colore o texto digitado nos campos de entrada.",
|
"advanced_styling_field_input_text_description": "Colore o texto digitado nos campos de entrada.",
|
||||||
"advanced_styling_field_option_bg": "Fundo",
|
"advanced_styling_field_option_bg": "Fundo",
|
||||||
"advanced_styling_field_option_bg_description": "Preenche os itens de opção.",
|
"advanced_styling_field_option_bg_description": "Preenche os itens de opção.",
|
||||||
|
"advanced_styling_field_option_border": "Cor do contorno",
|
||||||
|
"advanced_styling_field_option_border_description": "Contorna as opções de botões de rádio e caixas de seleção.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Arredonda os cantos das opções.",
|
"advanced_styling_field_option_border_radius_description": "Arredonda os cantos das opções.",
|
||||||
"advanced_styling_field_option_font_size_description": "Ajusta o tamanho do texto da etiqueta da opção.",
|
"advanced_styling_field_option_font_size_description": "Ajusta o tamanho do texto da etiqueta da opção.",
|
||||||
"advanced_styling_field_option_label": "Cor da etiqueta",
|
"advanced_styling_field_option_label": "Cor da etiqueta",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Não, obrigado!",
|
"preview_survey_question_2_choice_2_label": "Não, obrigado!",
|
||||||
"preview_survey_question_2_headline": "Quer manter-se atualizado?",
|
"preview_survey_question_2_headline": "Quer manter-se atualizado?",
|
||||||
"preview_survey_question_2_subheader": "Este é um exemplo de descrição.",
|
"preview_survey_question_2_subheader": "Este é um exemplo de descrição.",
|
||||||
|
"preview_survey_question_open_text_headline": "Mais alguma coisa que gostaria de partilhar?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Escreva a sua resposta aqui...",
|
||||||
|
"preview_survey_question_open_text_subheader": "O seu feedback ajuda-nos a melhorar.",
|
||||||
"preview_survey_welcome_card_headline": "Bem-vindo!",
|
"preview_survey_welcome_card_headline": "Bem-vindo!",
|
||||||
"prioritize_features_description": "Identifique as funcionalidades que os seus utilizadores precisam mais e menos.",
|
"prioritize_features_description": "Identifique as funcionalidades que os seus utilizadores precisam mais e menos.",
|
||||||
"prioritize_features_name": "Priorizar Funcionalidades",
|
"prioritize_features_name": "Priorizar Funcionalidades",
|
||||||
|
|||||||
+29
-10
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Copiază",
|
"copy": "Copiază",
|
||||||
"copy_code": "Copiază codul",
|
"copy_code": "Copiază codul",
|
||||||
"copy_link": "Copiază legătura",
|
"copy_link": "Copiază legătura",
|
||||||
"count_attributes": "{value, plural, one {{value} atribut} few {{value} atribute} other {{value} de atribute}}",
|
"count_attributes": "{count, plural, one {{count} atribut} few {{count} atribute} other {{count} de atribute}}",
|
||||||
"count_contacts": "{value, plural, one {# contact} other {# contacte} }",
|
"count_contacts": "{count, plural, one {# contact} other {# contacte} }",
|
||||||
"count_responses": "{value, plural, one {# răspuns} other {# răspunsuri} }",
|
"count_members": "{count, plural, one {{count} membru} few {{count} membri} other {{count} de membri}}",
|
||||||
|
"count_responses": "{count, plural, one {# răspuns} other {# răspunsuri} }",
|
||||||
|
"count_selections": "{count, plural, one {{count} selecție} few {{count} selecții} other {{count} de selecții}}",
|
||||||
"create_new_organization": "Creează organizație nouă",
|
"create_new_organization": "Creează organizație nouă",
|
||||||
"create_segment": "Creați segment",
|
"create_segment": "Creați segment",
|
||||||
"create_survey": "Creează sondaj",
|
"create_survey": "Creează sondaj",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "zile",
|
"days": "zile",
|
||||||
"default": "Implicit",
|
"default": "Implicit",
|
||||||
"delete": "Șterge",
|
"delete": "Șterge",
|
||||||
|
"delete_what": "Șterge {deleteWhat}",
|
||||||
"description": "Descriere",
|
"description": "Descriere",
|
||||||
"dev_env": "Mediu de dezvoltare",
|
"dev_env": "Mediu de dezvoltare",
|
||||||
"development": "Dezvoltare",
|
"development": "Dezvoltare",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Eroare",
|
"error": "Eroare",
|
||||||
"error_component_description": "Această resursă nu există sau nu aveți drepturile necesare pentru a o accesa.",
|
"error_component_description": "Această resursă nu există sau nu aveți drepturile necesare pentru a o accesa.",
|
||||||
"error_component_title": "Eroare la încărcarea resurselor",
|
"error_component_title": "Eroare la încărcarea resurselor",
|
||||||
|
"error_loading_data": "Eroare la încărcarea datelor",
|
||||||
"error_rate_limit_description": "Numărul maxim de cereri atins. Vă rugăm să încercați din nou mai târziu.",
|
"error_rate_limit_description": "Numărul maxim de cereri atins. Vă rugăm să încercați din nou mai târziu.",
|
||||||
"error_rate_limit_title": "Limită de cereri depășită",
|
"error_rate_limit_title": "Limită de cereri depășită",
|
||||||
"expand_rows": "Extinde rândurile",
|
"expand_rows": "Extinde rândurile",
|
||||||
"failed_to_copy_to_clipboard": "Nu s-a reușit copierea în clipboard",
|
"failed_to_copy_to_clipboard": "Nu s-a reușit copierea în clipboard",
|
||||||
"failed_to_load_organizations": "Nu s-a reușit încărcarea organizațiilor",
|
"failed_to_load_organizations": "Nu s-a reușit încărcarea organizațiilor",
|
||||||
"failed_to_load_workspaces": "Nu s-au putut încărca workspaces",
|
"failed_to_load_workspaces": "Nu s-au putut încărca workspaces",
|
||||||
|
"filter": "Filtru",
|
||||||
"finish": "Finalizează",
|
"finish": "Finalizează",
|
||||||
|
"first_name": "Prenume",
|
||||||
"follow_these": "Urmați acestea",
|
"follow_these": "Urmați acestea",
|
||||||
"formbricks_version": "Versiunea Formbricks",
|
"formbricks_version": "Versiunea Formbricks",
|
||||||
"full_name": "Nume complet",
|
"full_name": "Nume complet",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Câmp ascuns",
|
"hidden_field": "Câmp ascuns",
|
||||||
"hidden_fields": "Câmpuri ascunse",
|
"hidden_fields": "Câmpuri ascunse",
|
||||||
"hide_column": "Ascunde coloana",
|
"hide_column": "Ascunde coloana",
|
||||||
|
"id": "ID",
|
||||||
"image": "Imagine",
|
"image": "Imagine",
|
||||||
"images": "Imagini",
|
"images": "Imagini",
|
||||||
"import": "Import",
|
"import": "Import",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Cheie",
|
"key": "Cheie",
|
||||||
"label": "Etichetă",
|
"label": "Etichetă",
|
||||||
"language": "Limba",
|
"language": "Limba",
|
||||||
|
"last_name": "Nume de familie",
|
||||||
"learn_more": "Află mai multe",
|
"learn_more": "Află mai multe",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Suprapunere ușoară",
|
"light_overlay": "Suprapunere ușoară",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Aspect și Comportament",
|
"look_and_feel": "Aspect și Comportament",
|
||||||
"manage": "Gestionați",
|
"manage": "Gestionați",
|
||||||
"marketing": "Marketing",
|
"marketing": "Marketing",
|
||||||
"member": "Membru",
|
|
||||||
"members": "Membri",
|
"members": "Membri",
|
||||||
"members_and_teams": "Membri și echipe",
|
"members_and_teams": "Membri și echipe",
|
||||||
"membership_not_found": "Apartenența nu a fost găsită",
|
"membership_not_found": "Apartenența nu a fost găsită",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Mută în jos",
|
"move_down": "Mută în jos",
|
||||||
"move_up": "Mută sus",
|
"move_up": "Mută sus",
|
||||||
"multiple_languages": "Mai multe limbi",
|
"multiple_languages": "Mai multe limbi",
|
||||||
|
"my_product": "produsul meu",
|
||||||
"name": "Nume",
|
"name": "Nume",
|
||||||
"new": "Nou",
|
"new": "Nou",
|
||||||
"new_version_available": "Formbricks {version} este disponibil. Actualizați acum!",
|
"new_version_available": "Formbricks {version} este disponibil. Actualizați acum!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Selectați echipele",
|
"select_teams": "Selectați echipele",
|
||||||
"selected": "Selectat",
|
"selected": "Selectat",
|
||||||
"selected_questions": "Întrebări selectate",
|
"selected_questions": "Întrebări selectate",
|
||||||
"selection": "Selecție",
|
|
||||||
"selections": "Selecții",
|
|
||||||
"send_test_email": "Trimite email de test",
|
"send_test_email": "Trimite email de test",
|
||||||
"session_not_found": "Sesiune inexistentă",
|
"session_not_found": "Sesiune inexistentă",
|
||||||
"settings": "Setări",
|
"settings": "Setări",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Dreapta Sus",
|
"top_right": "Dreapta Sus",
|
||||||
"try_again": "Încearcă din nou",
|
"try_again": "Încearcă din nou",
|
||||||
"type": "Tip",
|
"type": "Tip",
|
||||||
|
"unknown_survey": "Chestionar necunoscut",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Deblochează mai multe workspaces cu un plan superior.",
|
"unlock_more_workspaces_with_a_higher_plan": "Deblochează mai multe workspaces cu un plan superior.",
|
||||||
"update": "Actualizare",
|
"update": "Actualizare",
|
||||||
"updated": "Actualizat",
|
"updated": "Actualizat",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Acest lucru va șterge atributul selectat. Orice date de contact asociate cu acest atribut vor fi pierdute.} few {Acest lucru va șterge atributele selectate. Orice date de contact asociate cu aceste atribute vor fi pierdute.} other {Acest lucru va șterge atributele selectate. Orice date de contact asociate cu aceste atribute vor fi pierdute.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Acest lucru va șterge atributul selectat. Orice date de contact asociate cu acest atribut vor fi pierdute.} few {Acest lucru va șterge atributele selectate. Orice date de contact asociate cu aceste atribute vor fi pierdute.} other {Acest lucru va șterge atributele selectate. Orice date de contact asociate cu aceste atribute vor fi pierdute.}}",
|
||||||
"delete_contact_confirmation": "Acest lucru va șterge toate răspunsurile la sondaj și atributele de contact asociate cu acest contact. Orice țintire și personalizare bazată pe datele acestui contact vor fi pierdute.",
|
"delete_contact_confirmation": "Acest lucru va șterge toate răspunsurile la sondaj și atributele de contact asociate cu acest contact. Orice țintire și personalizare bazată pe datele acestui contact vor fi pierdute.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Această acțiune va șterge toate răspunsurile chestionarului și atributele de contact asociate cu acest contact. Orice țintire și personalizare bazată pe datele acestui contact vor fi pierdute. Dacă acest contact are răspunsuri care contează pentru cotele chestionarului, numărul cotelor va fi redus, dar limitele cotelor vor rămâne neschimbate.} other {Aceste acțiuni vor șterge toate răspunsurile chestionarului și atributele de contact asociate cu acești contacți. Orice țintire și personalizare bazată pe datele acestor contacți vor fi pierdute. Dacă acești contacți au răspunsuri care contează pentru cotele chestionarului, numărul cotelor va fi redus, dar limitele cotelor vor rămâne neschimbate.} }",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Această acțiune va șterge toate răspunsurile chestionarului și atributele de contact asociate cu acest contact. Orice țintire și personalizare bazată pe datele acestui contact vor fi pierdute. Dacă acest contact are răspunsuri care contează pentru cotele chestionarului, numărul cotelor va fi redus, dar limitele cotelor vor rămâne neschimbate.} other {Aceste acțiuni vor șterge toate răspunsurile chestionarului și atributele de contact asociate cu acești contacți. Orice țintire și personalizare bazată pe datele acestor contacți vor fi pierdute. Dacă acești contacți au răspunsuri care contează pentru cotele chestionarului, numărul cotelor va fi redus, dar limitele cotelor vor rămâne neschimbate.} }",
|
||||||
|
"displays": "Afișări",
|
||||||
"edit_attribute": "Editează atributul",
|
"edit_attribute": "Editează atributul",
|
||||||
"edit_attribute_description": "Actualizează eticheta și descrierea acestui atribut.",
|
"edit_attribute_description": "Actualizează eticheta și descrierea acestui atribut.",
|
||||||
"edit_attribute_values": "Editează atributele",
|
"edit_attribute_values": "Editează atributele",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Nume de coloană CSV nevalide: {columns}. Numele coloanelor care vor deveni atribute noi trebuie să conțină doar litere mici, cifre și caractere de subliniere și trebuie să înceapă cu o literă.",
|
"invalid_csv_column_names": "Nume de coloană CSV nevalide: {columns}. Numele coloanelor care vor deveni atribute noi trebuie să conțină doar litere mici, cifre și caractere de subliniere și trebuie să înceapă cu o literă.",
|
||||||
"invalid_date_format": "Format de dată invalid. Te rugăm să folosești o dată validă.",
|
"invalid_date_format": "Format de dată invalid. Te rugăm să folosești o dată validă.",
|
||||||
"invalid_number_format": "Format de număr invalid. Te rugăm să introduci un număr valid.",
|
"invalid_number_format": "Format de număr invalid. Te rugăm să introduci un număr valid.",
|
||||||
|
"no_activity_yet": "Nicio activitate încă",
|
||||||
"no_published_link_surveys_available": "Nu există sondaje publicate pentru linkuri disponibile. Vă rugăm să publicați mai întâi un sondaj pentru linkuri.",
|
"no_published_link_surveys_available": "Nu există sondaje publicate pentru linkuri disponibile. Vă rugăm să publicați mai întâi un sondaj pentru linkuri.",
|
||||||
"no_published_surveys": "Nu există sondaje publicate",
|
"no_published_surveys": "Nu există sondaje publicate",
|
||||||
"no_responses_found": "Nu s-au găsit răspunsuri",
|
"no_responses_found": "Nu s-au găsit răspunsuri",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Selectați un sondaj",
|
"select_a_survey": "Selectați un sondaj",
|
||||||
"select_attribute": "Selectează atributul",
|
"select_attribute": "Selectează atributul",
|
||||||
"select_attribute_key": "Selectează cheia atributului",
|
"select_attribute_key": "Selectează cheia atributului",
|
||||||
|
"survey_viewed": "Chestionar vizualizat",
|
||||||
|
"survey_viewed_at": "Vizualizat la",
|
||||||
"system_attributes": "Atribute de sistem",
|
"system_attributes": "Atribute de sistem",
|
||||||
"unlock_contacts_description": "Gestionează contactele și trimite sondaje țintite",
|
"unlock_contacts_description": "Gestionează contactele și trimite sondaje țintite",
|
||||||
"unlock_contacts_title": "Deblocați contactele cu un plan superior.",
|
"unlock_contacts_title": "Deblocați contactele cu un plan superior.",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Salut {userName}",
|
"email_customization_preview_email_heading": "Salut {userName}",
|
||||||
"email_customization_preview_email_text": "Acesta este o previzualizare a e-mailului pentru a vă arăta ce logo va fi afișat în e-mailurile.",
|
"email_customization_preview_email_text": "Acesta este o previzualizare a e-mailului pentru a vă arăta ce logo va fi afișat în e-mailurile.",
|
||||||
"error_deleting_organization_please_try_again": "Eroare la ștergerea organizației. Vă rugăm să încercați din nou.",
|
"error_deleting_organization_please_try_again": "Eroare la ștergerea organizației. Vă rugăm să încercați din nou.",
|
||||||
"from_your_organization": "din organizația ta",
|
"from_your_organization": "{memberName} din organizația ta",
|
||||||
"invitation_sent_once_more": "Invitație trimisă din nou.",
|
"invitation_sent_once_more": "Invitație trimisă din nou.",
|
||||||
"invite_deleted_successfully": "Invitație ștearsă cu succes",
|
"invite_deleted_successfully": "Invitație ștearsă cu succes",
|
||||||
"invite_expires_on": "Invitația expiră pe {date}",
|
"invite_expires_on": "Invitația expiră pe {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Adaugă un placeholder pentru a afișa dacă nu există valoare de reamintit",
|
"add_fallback_placeholder": "Adaugă un placeholder pentru a afișa dacă nu există valoare de reamintit",
|
||||||
"add_hidden_field_id": "Adăugați ID câmp ascuns",
|
"add_hidden_field_id": "Adăugați ID câmp ascuns",
|
||||||
"add_highlight_border": "Adaugă bordură evidențiată",
|
"add_highlight_border": "Adaugă bordură evidențiată",
|
||||||
|
"add_highlight_border_description": "Se aplică doar sondajelor din produs.",
|
||||||
"add_logic": "Adaugă logică",
|
"add_logic": "Adaugă logică",
|
||||||
"add_none_of_the_above": "Adăugați \"Niciuna dintre cele de mai sus\"",
|
"add_none_of_the_above": "Adăugați \"Niciuna dintre cele de mai sus\"",
|
||||||
"add_option": "Adăugați opțiune",
|
"add_option": "Adăugați opțiune",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Urmărirea a fost actualizată și va fi salvată odată ce salvați sondajul.",
|
"follow_ups_modal_updated_successfull_toast": "Urmărirea a fost actualizată și va fi salvată odată ce salvați sondajul.",
|
||||||
"follow_ups_new": "Follow-up nou",
|
"follow_ups_new": "Follow-up nou",
|
||||||
"follow_ups_upgrade_button_text": "Actualizați pentru a activa urmărările",
|
"follow_ups_upgrade_button_text": "Actualizați pentru a activa urmărările",
|
||||||
"form_styling": "Stilizare formular",
|
|
||||||
"formbricks_sdk_is_not_connected": "SDK Formbricks nu este conectat",
|
"formbricks_sdk_is_not_connected": "SDK Formbricks nu este conectat",
|
||||||
"four_points": "4 puncte",
|
"four_points": "4 puncte",
|
||||||
"heading": "Titlu",
|
"heading": "Titlu",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Limite de răspunsuri, redirecționări și altele.",
|
"response_limits_redirections_and_more": "Limite de răspunsuri, redirecționări și altele.",
|
||||||
"response_options": "Opțiuni răspuns",
|
"response_options": "Opțiuni răspuns",
|
||||||
"roundness": "Rotunjire",
|
"roundness": "Rotunjire",
|
||||||
"roundness_description": "Controlează cât de rotunjite sunt colțurile cardului.",
|
"roundness_description": "Controlează cât de rotunjite sunt colțurile.",
|
||||||
"row_used_in_logic_error": "Această linie este folosită în logica întrebării {questionIndex}. Vă rugăm să-l eliminați din logică mai întâi.",
|
"row_used_in_logic_error": "Această linie este folosită în logica întrebării {questionIndex}. Vă rugăm să-l eliminați din logică mai întâi.",
|
||||||
"rows": "Rânduri",
|
"rows": "Rânduri",
|
||||||
"save_and_close": "Salvează & Închide",
|
"save_and_close": "Salvează & Închide",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Acest sondaj gratuit și open-source a fost închis",
|
"survey_completed_subheading": "Acest sondaj gratuit și open-source a fost închis",
|
||||||
"survey_display_settings": "Setări de afișare a sondajului",
|
"survey_display_settings": "Setări de afișare a sondajului",
|
||||||
"survey_placement": "Amplasarea sondajului",
|
"survey_placement": "Amplasarea sondajului",
|
||||||
|
"survey_styling": "Stilizare formular",
|
||||||
"survey_trigger": "Declanșator sondaj",
|
"survey_trigger": "Declanșator sondaj",
|
||||||
"switch_multi_language_on_to_get_started": "Activați opțiunea multi-limbă pentru a începe 👉",
|
"switch_multi_language_on_to_get_started": "Activați opțiunea multi-limbă pentru a începe 👉",
|
||||||
"target_block_not_found": "Blocul țintă nu a fost găsit",
|
"target_block_not_found": "Blocul țintă nu a fost găsit",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Mesaj de bun venit",
|
"welcome_message": "Mesaj de bun venit",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Fără un filtru, toți utilizatorii pot fi chestionați.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Fără un filtru, toți utilizatorii pot fi chestionați.",
|
||||||
"you_have_not_created_a_segment_yet": "Nu ai creat încă un segment",
|
"you_have_not_created_a_segment_yet": "Nu ai creat încă un segment",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Trebuie să aveți cel puțin două limbi configurate în spațiul de lucru pentru a putea lucra cu traduceri.",
|
|
||||||
"your_description_here_recall_information_with": "Descrierea ta aici. Reamintiți informațiile cu @",
|
"your_description_here_recall_information_with": "Descrierea ta aici. Reamintiți informațiile cu @",
|
||||||
"your_question_here_recall_information_with": "Întrebarea ta aici. Reamintiți informațiile cu @",
|
"your_question_here_recall_information_with": "Întrebarea ta aici. Reamintiți informațiile cu @",
|
||||||
"your_web_app": "Aplicația dumneavoastră web",
|
"your_web_app": "Aplicația dumneavoastră web",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Răspunsuri filtrate (Excel)",
|
"filtered_responses_excel": "Răspunsuri filtrate (Excel)",
|
||||||
"generating_qr_code": "Se generează codul QR",
|
"generating_qr_code": "Se generează codul QR",
|
||||||
"impressions": "Impresii",
|
"impressions": "Impresii",
|
||||||
|
"impressions_identified_only": "Se afișează doar impresiile de la contactele identificate",
|
||||||
"impressions_tooltip": "Număr de ori când sondajul a fost vizualizat.",
|
"impressions_tooltip": "Număr de ori când sondajul a fost vizualizat.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "Sondajul va fi afișat utilizatorilor site-ului dvs. web, care îndeplinesc criteriile enumerate mai jos",
|
"connection_description": "Sondajul va fi afișat utilizatorilor site-ului dvs. web, care îndeplinesc criteriile enumerate mai jos",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Ultimul trimestru",
|
"last_quarter": "Ultimul trimestru",
|
||||||
"last_year": "Anul trecut",
|
"last_year": "Anul trecut",
|
||||||
"limit": "Limită",
|
"limit": "Limită",
|
||||||
|
"no_identified_impressions": "Nicio impresie de la contactele identificate",
|
||||||
"no_responses_found": "Nu s-au găsit răspunsuri",
|
"no_responses_found": "Nu s-au găsit răspunsuri",
|
||||||
"other_values_found": "Alte valori găsite",
|
"other_values_found": "Alte valori găsite",
|
||||||
"overall": "General",
|
"overall": "General",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Începuturi",
|
"starts": "Începuturi",
|
||||||
"starts_tooltip": "Număr de ori când sondajul a fost început.",
|
"starts_tooltip": "Număr de ori când sondajul a fost început.",
|
||||||
"survey_reset_successfully": "Resetarea chestionarului realizată cu succes! Au fost șterse {responseCount} răspunsuri și {displayCount} afișări.",
|
"survey_reset_successfully": "Resetarea chestionarului realizată cu succes! Au fost șterse {responseCount} răspunsuri și {displayCount} afișări.",
|
||||||
|
"survey_results": "Rezultatele {surveyName}",
|
||||||
"this_month": "Luna aceasta",
|
"this_month": "Luna aceasta",
|
||||||
"this_quarter": "Trimestrul acesta",
|
"this_quarter": "Trimestrul acesta",
|
||||||
"this_year": "Anul acesta",
|
"this_year": "Anul acesta",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Colorează textul introdus în câmpuri.",
|
"advanced_styling_field_input_text_description": "Colorează textul introdus în câmpuri.",
|
||||||
"advanced_styling_field_option_bg": "Fundal",
|
"advanced_styling_field_option_bg": "Fundal",
|
||||||
"advanced_styling_field_option_bg_description": "Umple elementele de opțiune.",
|
"advanced_styling_field_option_bg_description": "Umple elementele de opțiune.",
|
||||||
|
"advanced_styling_field_option_border": "Culoare contur",
|
||||||
|
"advanced_styling_field_option_border_description": "Evidențiază opțiunile radio și checkbox.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Rotunjește colțurile opțiunilor.",
|
"advanced_styling_field_option_border_radius_description": "Rotunjește colțurile opțiunilor.",
|
||||||
"advanced_styling_field_option_font_size_description": "Redimensionează textul etichetei opțiunii.",
|
"advanced_styling_field_option_font_size_description": "Redimensionează textul etichetei opțiunii.",
|
||||||
"advanced_styling_field_option_label": "Culoare etichetă",
|
"advanced_styling_field_option_label": "Culoare etichetă",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Nu, mulţumesc!",
|
"preview_survey_question_2_choice_2_label": "Nu, mulţumesc!",
|
||||||
"preview_survey_question_2_headline": "Vrei să fii în temă?",
|
"preview_survey_question_2_headline": "Vrei să fii în temă?",
|
||||||
"preview_survey_question_2_subheader": "Aceasta este o descriere exemplu.",
|
"preview_survey_question_2_subheader": "Aceasta este o descriere exemplu.",
|
||||||
|
"preview_survey_question_open_text_headline": "Mai vrei să împărtășești ceva?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Tastează răspunsul aici...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Feedbackul tău ne ajută să ne îmbunătățim.",
|
||||||
"preview_survey_welcome_card_headline": "Bun venit!",
|
"preview_survey_welcome_card_headline": "Bun venit!",
|
||||||
"prioritize_features_description": "Identificați caracteristicile de care utilizatorii dumneavoastră au cel mai mult și cel mai puțin nevoie.",
|
"prioritize_features_description": "Identificați caracteristicile de care utilizatorii dumneavoastră au cel mai mult și cel mai puțin nevoie.",
|
||||||
"prioritize_features_name": "Prioritizați caracteristicile",
|
"prioritize_features_name": "Prioritizați caracteristicile",
|
||||||
|
|||||||
+30
-11
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Копировать",
|
"copy": "Копировать",
|
||||||
"copy_code": "Скопировать код",
|
"copy_code": "Скопировать код",
|
||||||
"copy_link": "Скопировать ссылку",
|
"copy_link": "Скопировать ссылку",
|
||||||
"count_attributes": "{value, plural, one {{value} атрибут} few {{value} атрибута} many {{value} атрибутов} other {{value} атрибута}}",
|
"count_attributes": "{count, plural, one {{count} атрибут} few {{count} атрибута} many {{count} атрибутов} other {{count} атрибута}}",
|
||||||
"count_contacts": "{value, plural, one {{value} контакт} few {{value} контакта} many {{value} контактов} other {{value} контактов}}",
|
"count_contacts": "{count, plural, one {{count} контакт} few {{count} контакта} many {{count} контактов} other {{count} контактов}}",
|
||||||
"count_responses": "{value, plural, one {{value} ответ} few {{value} ответа} many {{value} ответов} other {{value} ответов}}",
|
"count_members": "{count, plural, one {{count} участник} few {{count} участника} many {{count} участников} other {{count} участника}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} ответ} few {{count} ответа} many {{count} ответов} other {{count} ответов}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} выбран} few {{count} выбрано} many {{count} выбрано} other {{count} выбрано}}",
|
||||||
"create_new_organization": "Создать новую организацию",
|
"create_new_organization": "Создать новую организацию",
|
||||||
"create_segment": "Создать сегмент",
|
"create_segment": "Создать сегмент",
|
||||||
"create_survey": "Создать опрос",
|
"create_survey": "Создать опрос",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "дни",
|
"days": "дни",
|
||||||
"default": "По умолчанию",
|
"default": "По умолчанию",
|
||||||
"delete": "Удалить",
|
"delete": "Удалить",
|
||||||
|
"delete_what": "Удалить {deleteWhat}",
|
||||||
"description": "Описание",
|
"description": "Описание",
|
||||||
"dev_env": "Dev Environment",
|
"dev_env": "Dev Environment",
|
||||||
"development": "Разработка",
|
"development": "Разработка",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Ошибка",
|
"error": "Ошибка",
|
||||||
"error_component_description": "Этот ресурс не существует или у вас нет необходимых прав для доступа к нему.",
|
"error_component_description": "Этот ресурс не существует или у вас нет необходимых прав для доступа к нему.",
|
||||||
"error_component_title": "Ошибка загрузки ресурсов",
|
"error_component_title": "Ошибка загрузки ресурсов",
|
||||||
|
"error_loading_data": "Ошибка загрузки данных",
|
||||||
"error_rate_limit_description": "Достигнуто максимальное количество запросов. Пожалуйста, попробуйте позже.",
|
"error_rate_limit_description": "Достигнуто максимальное количество запросов. Пожалуйста, попробуйте позже.",
|
||||||
"error_rate_limit_title": "Превышен лимит запросов",
|
"error_rate_limit_title": "Превышен лимит запросов",
|
||||||
"expand_rows": "Развернуть строки",
|
"expand_rows": "Развернуть строки",
|
||||||
"failed_to_copy_to_clipboard": "Не удалось скопировать в буфер обмена",
|
"failed_to_copy_to_clipboard": "Не удалось скопировать в буфер обмена",
|
||||||
"failed_to_load_organizations": "Не удалось загрузить организации",
|
"failed_to_load_organizations": "Не удалось загрузить организации",
|
||||||
"failed_to_load_workspaces": "Не удалось загрузить рабочие пространства",
|
"failed_to_load_workspaces": "Не удалось загрузить рабочие пространства",
|
||||||
|
"filter": "Фильтр",
|
||||||
"finish": "Завершить",
|
"finish": "Завершить",
|
||||||
|
"first_name": "Имя",
|
||||||
"follow_these": "Выполните следующие действия",
|
"follow_these": "Выполните следующие действия",
|
||||||
"formbricks_version": "Версия Formbricks",
|
"formbricks_version": "Версия Formbricks",
|
||||||
"full_name": "Полное имя",
|
"full_name": "Полное имя",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Скрытое поле",
|
"hidden_field": "Скрытое поле",
|
||||||
"hidden_fields": "Скрытые поля",
|
"hidden_fields": "Скрытые поля",
|
||||||
"hide_column": "Скрыть столбец",
|
"hide_column": "Скрыть столбец",
|
||||||
|
"id": "ID",
|
||||||
"image": "Изображение",
|
"image": "Изображение",
|
||||||
"images": "Изображения",
|
"images": "Изображения",
|
||||||
"import": "Импорт",
|
"import": "Импорт",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Ключ",
|
"key": "Ключ",
|
||||||
"label": "Метка",
|
"label": "Метка",
|
||||||
"language": "Язык",
|
"language": "Язык",
|
||||||
|
"last_name": "Фамилия",
|
||||||
"learn_more": "Подробнее",
|
"learn_more": "Подробнее",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Светлый оверлей",
|
"light_overlay": "Светлый оверлей",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Внешний вид",
|
"look_and_feel": "Внешний вид",
|
||||||
"manage": "Управление",
|
"manage": "Управление",
|
||||||
"marketing": "Маркетинг",
|
"marketing": "Маркетинг",
|
||||||
"member": "Участник",
|
|
||||||
"members": "Участники",
|
"members": "Участники",
|
||||||
"members_and_teams": "Участники и команды",
|
"members_and_teams": "Участники и команды",
|
||||||
"membership_not_found": "Участие не найдено",
|
"membership_not_found": "Участие не найдено",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Переместить вниз",
|
"move_down": "Переместить вниз",
|
||||||
"move_up": "Переместить вверх",
|
"move_up": "Переместить вверх",
|
||||||
"multiple_languages": "Несколько языков",
|
"multiple_languages": "Несколько языков",
|
||||||
|
"my_product": "мой продукт",
|
||||||
"name": "Имя",
|
"name": "Имя",
|
||||||
"new": "Новый",
|
"new": "Новый",
|
||||||
"new_version_available": "Formbricks {version} уже здесь. Обновитесь сейчас!",
|
"new_version_available": "Formbricks {version} уже здесь. Обновитесь сейчас!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Выбрать команды",
|
"select_teams": "Выбрать команды",
|
||||||
"selected": "Выбрано",
|
"selected": "Выбрано",
|
||||||
"selected_questions": "Выбранные вопросы",
|
"selected_questions": "Выбранные вопросы",
|
||||||
"selection": "Выбор",
|
|
||||||
"selections": "Выборы",
|
|
||||||
"send_test_email": "Отправить тестовое письмо",
|
"send_test_email": "Отправить тестовое письмо",
|
||||||
"session_not_found": "Сессия не найдена",
|
"session_not_found": "Сессия не найдена",
|
||||||
"settings": "Настройки",
|
"settings": "Настройки",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Вверху справа",
|
"top_right": "Вверху справа",
|
||||||
"try_again": "Попробуйте ещё раз",
|
"try_again": "Попробуйте ещё раз",
|
||||||
"type": "Тип",
|
"type": "Тип",
|
||||||
|
"unknown_survey": "Неизвестный опрос",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Откройте больше рабочих пространств с более высоким тарифом.",
|
"unlock_more_workspaces_with_a_higher_plan": "Откройте больше рабочих пространств с более высоким тарифом.",
|
||||||
"update": "Обновить",
|
"update": "Обновить",
|
||||||
"updated": "Обновлено",
|
"updated": "Обновлено",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Будет удалён выбранный атрибут. Все данные контактов, связанные с этим атрибутом, будут потеряны.} few {Будут удалены выбранные атрибуты. Все данные контактов, связанные с этими атрибутами, будут потеряны.} many {Будут удалены выбранные атрибуты. Все данные контактов, связанные с этими атрибутами, будут потеряны.} other {Будут удалены выбранные атрибуты. Все данные контактов, связанные с этими атрибутами, будут потеряны.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Будет удалён выбранный атрибут. Все данные контактов, связанные с этим атрибутом, будут потеряны.} few {Будут удалены выбранные атрибуты. Все данные контактов, связанные с этими атрибутами, будут потеряны.} many {Будут удалены выбранные атрибуты. Все данные контактов, связанные с этими атрибутами, будут потеряны.} other {Будут удалены выбранные атрибуты. Все данные контактов, связанные с этими атрибутами, будут потеряны.}}",
|
||||||
"delete_contact_confirmation": "Это удалит все ответы на опросы и атрибуты контакта, связанные с этим контактом. Любая таргетинг и персонализация на основе данных этого контакта будут потеряны.",
|
"delete_contact_confirmation": "Это удалит все ответы на опросы и атрибуты контакта, связанные с этим контактом. Любая таргетинг и персонализация на основе данных этого контакта будут потеряны.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Это удалит все ответы на опросы и атрибуты контакта, связанные с этим контактом. Любая таргетинг и персонализация на основе данных этого контакта будут потеряны. Если у этого контакта есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.} few {Это удалит все ответы на опросы и атрибуты контактов, связанные с этими контактами. Любая таргетинг и персонализация на основе данных этих контактов будут потеряны. Если у этих контактов есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.} many {Это удалит все ответы на опросы и атрибуты контактов, связанные с этими контактами. Любая таргетинг и персонализация на основе данных этих контактов будут потеряны. Если у этих контактов есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.} other {Это удалит все ответы на опросы и атрибуты контактов, связанные с этими контактами. Любая таргетинг и персонализация на основе данных этих контактов будут потеряны. Если у этих контактов есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Это удалит все ответы на опросы и атрибуты контакта, связанные с этим контактом. Любая таргетинг и персонализация на основе данных этого контакта будут потеряны. Если у этого контакта есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.} few {Это удалит все ответы на опросы и атрибуты контактов, связанные с этими контактами. Любая таргетинг и персонализация на основе данных этих контактов будут потеряны. Если у этих контактов есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.} many {Это удалит все ответы на опросы и атрибуты контактов, связанные с этими контактами. Любая таргетинг и персонализация на основе данных этих контактов будут потеряны. Если у этих контактов есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.} other {Это удалит все ответы на опросы и атрибуты контактов, связанные с этими контактами. Любая таргетинг и персонализация на основе данных этих контактов будут потеряны. Если у этих контактов есть ответы, которые учитываются в квотах опроса, количество по квотам будет уменьшено, но лимиты квот останутся без изменений.}}",
|
||||||
|
"displays": "Показы",
|
||||||
"edit_attribute": "Редактировать атрибут",
|
"edit_attribute": "Редактировать атрибут",
|
||||||
"edit_attribute_description": "Обновите метку и описание для этого атрибута.",
|
"edit_attribute_description": "Обновите метку и описание для этого атрибута.",
|
||||||
"edit_attribute_values": "Редактировать атрибуты",
|
"edit_attribute_values": "Редактировать атрибуты",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Недопустимые имена столбцов в CSV: {columns}. Имена столбцов, которые станут новыми атрибутами, должны содержать только строчные буквы, цифры и подчёркивания, а также начинаться с буквы.",
|
"invalid_csv_column_names": "Недопустимые имена столбцов в CSV: {columns}. Имена столбцов, которые станут новыми атрибутами, должны содержать только строчные буквы, цифры и подчёркивания, а также начинаться с буквы.",
|
||||||
"invalid_date_format": "Неверный формат даты. Пожалуйста, используйте корректную дату.",
|
"invalid_date_format": "Неверный формат даты. Пожалуйста, используйте корректную дату.",
|
||||||
"invalid_number_format": "Неверный формат числа. Пожалуйста, введите корректное число.",
|
"invalid_number_format": "Неверный формат числа. Пожалуйста, введите корректное число.",
|
||||||
|
"no_activity_yet": "Пока нет активности",
|
||||||
"no_published_link_surveys_available": "Нет доступных опубликованных опросов-ссылок. Пожалуйста, сначала опубликуйте опрос-ссылку.",
|
"no_published_link_surveys_available": "Нет доступных опубликованных опросов-ссылок. Пожалуйста, сначала опубликуйте опрос-ссылку.",
|
||||||
"no_published_surveys": "Нет опубликованных опросов",
|
"no_published_surveys": "Нет опубликованных опросов",
|
||||||
"no_responses_found": "Ответы не найдены",
|
"no_responses_found": "Ответы не найдены",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Выберите опрос",
|
"select_a_survey": "Выберите опрос",
|
||||||
"select_attribute": "Выберите атрибут",
|
"select_attribute": "Выберите атрибут",
|
||||||
"select_attribute_key": "Выберите ключ атрибута",
|
"select_attribute_key": "Выберите ключ атрибута",
|
||||||
|
"survey_viewed": "Опрос просмотрен",
|
||||||
|
"survey_viewed_at": "Просмотрено",
|
||||||
"system_attributes": "Системные атрибуты",
|
"system_attributes": "Системные атрибуты",
|
||||||
"unlock_contacts_description": "Управляйте контактами и отправляйте целевые опросы",
|
"unlock_contacts_description": "Управляйте контактами и отправляйте целевые опросы",
|
||||||
"unlock_contacts_title": "Откройте доступ к контактам с более высоким тарифом",
|
"unlock_contacts_title": "Откройте доступ к контактам с более высоким тарифом",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "Привет, {userName}",
|
"email_customization_preview_email_heading": "Привет, {userName}",
|
||||||
"email_customization_preview_email_text": "Это предварительный просмотр письма, чтобы показать, какой логотип будет отображаться в письмах.",
|
"email_customization_preview_email_text": "Это предварительный просмотр письма, чтобы показать, какой логотип будет отображаться в письмах.",
|
||||||
"error_deleting_organization_please_try_again": "Ошибка при удалении организации. Пожалуйста, попробуйте ещё раз.",
|
"error_deleting_organization_please_try_again": "Ошибка при удалении организации. Пожалуйста, попробуйте ещё раз.",
|
||||||
"from_your_organization": "из вашей организации",
|
"from_your_organization": "{memberName} из вашей организации",
|
||||||
"invitation_sent_once_more": "Приглашение отправлено ещё раз.",
|
"invitation_sent_once_more": "Приглашение отправлено ещё раз.",
|
||||||
"invite_deleted_successfully": "Приглашение успешно удалено",
|
"invite_deleted_successfully": "Приглашение успешно удалено",
|
||||||
"invite_expires_on": "Приглашение истекает {date}",
|
"invite_expires_on": "Приглашение истекает {date}",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Добавить плейсхолдер, который будет показан, если нет значения для отображения.",
|
"add_fallback_placeholder": "Добавить плейсхолдер, который будет показан, если нет значения для отображения.",
|
||||||
"add_hidden_field_id": "Добавить скрытый ID поля",
|
"add_hidden_field_id": "Добавить скрытый ID поля",
|
||||||
"add_highlight_border": "Добавить выделяющую рамку",
|
"add_highlight_border": "Добавить выделяющую рамку",
|
||||||
|
"add_highlight_border_description": "Применяется только к опросам внутри продукта.",
|
||||||
"add_logic": "Добавить логику",
|
"add_logic": "Добавить логику",
|
||||||
"add_none_of_the_above": "Добавить вариант «Ничего из вышеперечисленного»",
|
"add_none_of_the_above": "Добавить вариант «Ничего из вышеперечисленного»",
|
||||||
"add_option": "Добавить вариант",
|
"add_option": "Добавить вариант",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Фоллоу-ап обновлён и будет сохранён после сохранения опроса.",
|
"follow_ups_modal_updated_successfull_toast": "Фоллоу-ап обновлён и будет сохранён после сохранения опроса.",
|
||||||
"follow_ups_new": "Новый фоллоу-ап",
|
"follow_ups_new": "Новый фоллоу-ап",
|
||||||
"follow_ups_upgrade_button_text": "Обновите тариф для активации фоллоу-апов",
|
"follow_ups_upgrade_button_text": "Обновите тариф для активации фоллоу-апов",
|
||||||
"form_styling": "Оформление формы",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK не подключён",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK не подключён",
|
||||||
"four_points": "4 балла",
|
"four_points": "4 балла",
|
||||||
"heading": "Заголовок",
|
"heading": "Заголовок",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Лимиты ответов, перенаправления и другое.",
|
"response_limits_redirections_and_more": "Лимиты ответов, перенаправления и другое.",
|
||||||
"response_options": "Параметры ответа",
|
"response_options": "Параметры ответа",
|
||||||
"roundness": "Скругление",
|
"roundness": "Скругление",
|
||||||
"roundness_description": "Определяет степень скругления углов карточки.",
|
"roundness_description": "Определяет степень скругления углов.",
|
||||||
"row_used_in_logic_error": "Эта строка используется в логике вопроса {questionIndex}. Пожалуйста, сначала удалите её из логики.",
|
"row_used_in_logic_error": "Эта строка используется в логике вопроса {questionIndex}. Пожалуйста, сначала удалите её из логики.",
|
||||||
"rows": "Строки",
|
"rows": "Строки",
|
||||||
"save_and_close": "Сохранить и закрыть",
|
"save_and_close": "Сохранить и закрыть",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Этот бесплатный и открытый опрос был закрыт",
|
"survey_completed_subheading": "Этот бесплатный и открытый опрос был закрыт",
|
||||||
"survey_display_settings": "Настройки отображения опроса",
|
"survey_display_settings": "Настройки отображения опроса",
|
||||||
"survey_placement": "Размещение опроса",
|
"survey_placement": "Размещение опроса",
|
||||||
|
"survey_styling": "Оформление формы",
|
||||||
"survey_trigger": "Триггер опроса",
|
"survey_trigger": "Триггер опроса",
|
||||||
"switch_multi_language_on_to_get_started": "Включите многоязычный режим, чтобы начать 👉",
|
"switch_multi_language_on_to_get_started": "Включите многоязычный режим, чтобы начать 👉",
|
||||||
"target_block_not_found": "Целевой блок не найден",
|
"target_block_not_found": "Целевой блок не найден",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Приветственное сообщение",
|
"welcome_message": "Приветственное сообщение",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Без фильтра все ваши пользователи могут быть опрошены.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Без фильтра все ваши пользователи могут быть опрошены.",
|
||||||
"you_have_not_created_a_segment_yet": "Вы ещё не создали сегмент",
|
"you_have_not_created_a_segment_yet": "Вы ещё не создали сегмент",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Для работы с переводами необходимо настроить два или более языков в рабочем пространстве.",
|
|
||||||
"your_description_here_recall_information_with": "Ваша инструкция здесь. Вспомните информацию с помощью @",
|
"your_description_here_recall_information_with": "Ваша инструкция здесь. Вспомните информацию с помощью @",
|
||||||
"your_question_here_recall_information_with": "Ваш вопрос здесь. Вспомните информацию с помощью @",
|
"your_question_here_recall_information_with": "Ваш вопрос здесь. Вспомните информацию с помощью @",
|
||||||
"your_web_app": "Ваше веб-приложение",
|
"your_web_app": "Ваше веб-приложение",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Отфильтрованные ответы (Excel)",
|
"filtered_responses_excel": "Отфильтрованные ответы (Excel)",
|
||||||
"generating_qr_code": "Генерация QR-кода",
|
"generating_qr_code": "Генерация QR-кода",
|
||||||
"impressions": "Просмотры",
|
"impressions": "Просмотры",
|
||||||
|
"impressions_identified_only": "Показаны только показы от идентифицированных контактов",
|
||||||
"impressions_tooltip": "Количество раз, когда опрос был просмотрен.",
|
"impressions_tooltip": "Количество раз, когда опрос был просмотрен.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "Опрос будет показан пользователям вашего сайта, которые соответствуют указанным ниже критериям",
|
"connection_description": "Опрос будет показан пользователям вашего сайта, которые соответствуют указанным ниже критериям",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Прошлый квартал",
|
"last_quarter": "Прошлый квартал",
|
||||||
"last_year": "Прошлый год",
|
"last_year": "Прошлый год",
|
||||||
"limit": "Лимит",
|
"limit": "Лимит",
|
||||||
|
"no_identified_impressions": "Нет показов от идентифицированных контактов",
|
||||||
"no_responses_found": "Ответы не найдены",
|
"no_responses_found": "Ответы не найдены",
|
||||||
"other_values_found": "Найдены другие значения",
|
"other_values_found": "Найдены другие значения",
|
||||||
"overall": "В целом",
|
"overall": "В целом",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Запуски",
|
"starts": "Запуски",
|
||||||
"starts_tooltip": "Количество запусков опроса.",
|
"starts_tooltip": "Количество запусков опроса.",
|
||||||
"survey_reset_successfully": "Опрос успешно сброшен! {responseCount} ответов и {displayCount} показов были удалены.",
|
"survey_reset_successfully": "Опрос успешно сброшен! {responseCount} ответов и {displayCount} показов были удалены.",
|
||||||
|
"survey_results": "Результаты {surveyName}",
|
||||||
"this_month": "В этом месяце",
|
"this_month": "В этом месяце",
|
||||||
"this_quarter": "В этом квартале",
|
"this_quarter": "В этом квартале",
|
||||||
"this_year": "В этом году",
|
"this_year": "В этом году",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Задаёт цвет заполненной части полосы.",
|
"advanced_styling_field_indicator_bg_description": "Задаёт цвет заполненной части полосы.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Скругляет углы полей ввода.",
|
"advanced_styling_field_input_border_radius_description": "Скругляет углы полей ввода.",
|
||||||
"advanced_styling_field_input_font_size_description": "Масштабирует введённый текст в полях ввода.",
|
"advanced_styling_field_input_font_size_description": "Масштабирует введённый текст в полях ввода.",
|
||||||
"advanced_styling_field_input_height_description": "Определяет минимальную высоту поля ввода.",
|
"advanced_styling_field_input_height_description": "Управляет минимальной высотой поля ввода.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Добавляет отступы слева и справа.",
|
"advanced_styling_field_input_padding_x_description": "Добавляет отступы слева и справа.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Добавляет пространство сверху и снизу.",
|
"advanced_styling_field_input_padding_y_description": "Добавляет пространство сверху и снизу.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Делает текст подсказки менее заметным.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Делает текст подсказки менее заметным.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Задаёт цвет введённого текста в полях.",
|
"advanced_styling_field_input_text_description": "Задаёт цвет введённого текста в полях.",
|
||||||
"advanced_styling_field_option_bg": "Фон",
|
"advanced_styling_field_option_bg": "Фон",
|
||||||
"advanced_styling_field_option_bg_description": "Заливает фон элементов опций.",
|
"advanced_styling_field_option_bg_description": "Заливает фон элементов опций.",
|
||||||
|
"advanced_styling_field_option_border": "Цвет границы",
|
||||||
|
"advanced_styling_field_option_border_description": "Обводка для вариантов radio и checkbox.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Скругляет углы опций.",
|
"advanced_styling_field_option_border_radius_description": "Скругляет углы опций.",
|
||||||
"advanced_styling_field_option_font_size_description": "Изменяет размер текста метки опции.",
|
"advanced_styling_field_option_font_size_description": "Изменяет размер текста метки опции.",
|
||||||
"advanced_styling_field_option_label": "Цвет метки",
|
"advanced_styling_field_option_label": "Цвет метки",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Нет, спасибо!",
|
"preview_survey_question_2_choice_2_label": "Нет, спасибо!",
|
||||||
"preview_survey_question_2_headline": "Хотите быть в курсе событий?",
|
"preview_survey_question_2_headline": "Хотите быть в курсе событий?",
|
||||||
"preview_survey_question_2_subheader": "Это пример описания.",
|
"preview_survey_question_2_subheader": "Это пример описания.",
|
||||||
|
"preview_survey_question_open_text_headline": "Есть ли ещё что-то, чем хочешь поделиться?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Введи свой ответ здесь...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Твой отзыв помогает нам становиться лучше.",
|
||||||
"preview_survey_welcome_card_headline": "Добро пожаловать!",
|
"preview_survey_welcome_card_headline": "Добро пожаловать!",
|
||||||
"prioritize_features_description": "Определите, какие функции наиболее и наименее важны для ваших пользователей.",
|
"prioritize_features_description": "Определите, какие функции наиболее и наименее важны для ваших пользователей.",
|
||||||
"prioritize_features_name": "Приоритизация функций",
|
"prioritize_features_name": "Приоритизация функций",
|
||||||
|
|||||||
+29
-10
@@ -175,9 +175,11 @@
|
|||||||
"copy": "Kopiera",
|
"copy": "Kopiera",
|
||||||
"copy_code": "Kopiera kod",
|
"copy_code": "Kopiera kod",
|
||||||
"copy_link": "Kopiera länk",
|
"copy_link": "Kopiera länk",
|
||||||
"count_attributes": "{value, plural, one {{value} attribut} other {{value} attribut}}",
|
"count_attributes": "{count, plural, one {{count} attribut} other {{count} attribut}}",
|
||||||
"count_contacts": "{value, plural, one {{value} kontakt} other {{value} kontakter}}",
|
"count_contacts": "{count, plural, one {{count} kontakt} other {{count} kontakter}}",
|
||||||
"count_responses": "{value, plural, one {{value} svar} other {{value} svar}}",
|
"count_members": "{count, plural, one {{count} medlem} other {{count} medlemmar}}",
|
||||||
|
"count_responses": "{count, plural, one {{count} svar} other {{count} svar}}",
|
||||||
|
"count_selections": "{count, plural, one {{count} val} other {{count} val}}",
|
||||||
"create_new_organization": "Skapa ny organisation",
|
"create_new_organization": "Skapa ny organisation",
|
||||||
"create_segment": "Skapa segment",
|
"create_segment": "Skapa segment",
|
||||||
"create_survey": "Skapa enkät",
|
"create_survey": "Skapa enkät",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "dagar",
|
"days": "dagar",
|
||||||
"default": "Standard",
|
"default": "Standard",
|
||||||
"delete": "Ta bort",
|
"delete": "Ta bort",
|
||||||
|
"delete_what": "Ta bort {deleteWhat}",
|
||||||
"description": "Beskrivning",
|
"description": "Beskrivning",
|
||||||
"dev_env": "Utvecklingsmiljö",
|
"dev_env": "Utvecklingsmiljö",
|
||||||
"development": "Utveckling",
|
"development": "Utveckling",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "Fel",
|
"error": "Fel",
|
||||||
"error_component_description": "Denna resurs finns inte eller så har du inte de nödvändiga rättigheterna för att komma åt den.",
|
"error_component_description": "Denna resurs finns inte eller så har du inte de nödvändiga rättigheterna för att komma åt den.",
|
||||||
"error_component_title": "Fel vid laddning av resurser",
|
"error_component_title": "Fel vid laddning av resurser",
|
||||||
|
"error_loading_data": "Fel vid inläsning av data",
|
||||||
"error_rate_limit_description": "Maximalt antal förfrågningar har nåtts. Försök igen senare.",
|
"error_rate_limit_description": "Maximalt antal förfrågningar har nåtts. Försök igen senare.",
|
||||||
"error_rate_limit_title": "Begränsningsgräns överskriden",
|
"error_rate_limit_title": "Begränsningsgräns överskriden",
|
||||||
"expand_rows": "Visa rader",
|
"expand_rows": "Visa rader",
|
||||||
"failed_to_copy_to_clipboard": "Misslyckades att kopiera till urklipp",
|
"failed_to_copy_to_clipboard": "Misslyckades att kopiera till urklipp",
|
||||||
"failed_to_load_organizations": "Misslyckades att ladda organisationer",
|
"failed_to_load_organizations": "Misslyckades att ladda organisationer",
|
||||||
"failed_to_load_workspaces": "Det gick inte att ladda arbetsytor",
|
"failed_to_load_workspaces": "Det gick inte att ladda arbetsytor",
|
||||||
|
"filter": "Filter",
|
||||||
"finish": "Slutför",
|
"finish": "Slutför",
|
||||||
|
"first_name": "Förnamn",
|
||||||
"follow_these": "Följ dessa",
|
"follow_these": "Följ dessa",
|
||||||
"formbricks_version": "Formbricks-version",
|
"formbricks_version": "Formbricks-version",
|
||||||
"full_name": "Fullständigt namn",
|
"full_name": "Fullständigt namn",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "Dolt fält",
|
"hidden_field": "Dolt fält",
|
||||||
"hidden_fields": "Dolda fält",
|
"hidden_fields": "Dolda fält",
|
||||||
"hide_column": "Dölj kolumn",
|
"hide_column": "Dölj kolumn",
|
||||||
|
"id": "ID",
|
||||||
"image": "Bild",
|
"image": "Bild",
|
||||||
"images": "Bilder",
|
"images": "Bilder",
|
||||||
"import": "Importera",
|
"import": "Importera",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "Nyckel",
|
"key": "Nyckel",
|
||||||
"label": "Etikett",
|
"label": "Etikett",
|
||||||
"language": "Språk",
|
"language": "Språk",
|
||||||
|
"last_name": "Efternamn",
|
||||||
"learn_more": "Läs mer",
|
"learn_more": "Läs mer",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "Ljust överlägg",
|
"light_overlay": "Ljust överlägg",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "Utseende",
|
"look_and_feel": "Utseende",
|
||||||
"manage": "Hantera",
|
"manage": "Hantera",
|
||||||
"marketing": "Marknadsföring",
|
"marketing": "Marknadsföring",
|
||||||
"member": "Medlem",
|
|
||||||
"members": "Medlemmar",
|
"members": "Medlemmar",
|
||||||
"members_and_teams": "Medlemmar och team",
|
"members_and_teams": "Medlemmar och team",
|
||||||
"membership_not_found": "Medlemskap hittades inte",
|
"membership_not_found": "Medlemskap hittades inte",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "Flytta ner",
|
"move_down": "Flytta ner",
|
||||||
"move_up": "Flytta upp",
|
"move_up": "Flytta upp",
|
||||||
"multiple_languages": "Flera språk",
|
"multiple_languages": "Flera språk",
|
||||||
|
"my_product": "min produkt",
|
||||||
"name": "Namn",
|
"name": "Namn",
|
||||||
"new": "Ny",
|
"new": "Ny",
|
||||||
"new_version_available": "Formbricks {version} är här. Uppgradera nu!",
|
"new_version_available": "Formbricks {version} är här. Uppgradera nu!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "Välj team",
|
"select_teams": "Välj team",
|
||||||
"selected": "Vald",
|
"selected": "Vald",
|
||||||
"selected_questions": "Valda frågor",
|
"selected_questions": "Valda frågor",
|
||||||
"selection": "Urval",
|
|
||||||
"selections": "Urval",
|
|
||||||
"send_test_email": "Skicka testmeddelande",
|
"send_test_email": "Skicka testmeddelande",
|
||||||
"session_not_found": "Session hittades inte",
|
"session_not_found": "Session hittades inte",
|
||||||
"settings": "Inställningar",
|
"settings": "Inställningar",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "Övre höger",
|
"top_right": "Övre höger",
|
||||||
"try_again": "Försök igen",
|
"try_again": "Försök igen",
|
||||||
"type": "Typ",
|
"type": "Typ",
|
||||||
|
"unknown_survey": "Okänd enkät",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "Lås upp fler arbetsytor med ett högre abonnemang.",
|
"unlock_more_workspaces_with_a_higher_plan": "Lås upp fler arbetsytor med ett högre abonnemang.",
|
||||||
"update": "Uppdatera",
|
"update": "Uppdatera",
|
||||||
"updated": "Uppdaterad",
|
"updated": "Uppdaterad",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {Detta kommer att ta bort det valda attributet. All kontaktdata som är kopplad till detta attribut kommer att gå förlorad.} other {Detta kommer att ta bort de valda attributen. All kontaktdata som är kopplad till dessa attribut kommer att gå förlorad.}}",
|
"delete_attribute_confirmation": "{value, plural, one {Detta kommer att ta bort det valda attributet. All kontaktdata som är kopplad till detta attribut kommer att gå förlorad.} other {Detta kommer att ta bort de valda attributen. All kontaktdata som är kopplad till dessa attribut kommer att gå förlorad.}}",
|
||||||
"delete_contact_confirmation": "Detta kommer att ta bort alla enkätsvar och kontaktattribut som är kopplade till denna kontakt. All målgruppsinriktning och personalisering baserad på denna kontakts data kommer att gå förlorad.",
|
"delete_contact_confirmation": "Detta kommer att ta bort alla enkätsvar och kontaktattribut som är kopplade till denna kontakt. All målgruppsinriktning och personalisering baserad på denna kontakts data kommer att gå förlorad.",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {Detta kommer att ta bort alla enkätsvar och kontaktattribut som är kopplade till denna kontakt. All målgruppsinriktning och personalisering baserad på denna kontakts data kommer att gå förlorad. Om denna kontakt har svar som räknas mot enkätkvoter, kommer kvotantalet att minskas men kvotgränserna förblir oförändrade.} other {Detta kommer att ta bort alla enkätsvar och kontaktattribut som är kopplade till dessa kontakter. All målgruppsinriktning och personalisering baserad på dessa kontakters data kommer att gå förlorad. Om dessa kontakter har svar som räknas mot enkätkvoter, kommer kvotantalet att minskas men kvotgränserna förblir oförändrade.}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {Detta kommer att ta bort alla enkätsvar och kontaktattribut som är kopplade till denna kontakt. All målgruppsinriktning och personalisering baserad på denna kontakts data kommer att gå förlorad. Om denna kontakt har svar som räknas mot enkätkvoter, kommer kvotantalet att minskas men kvotgränserna förblir oförändrade.} other {Detta kommer att ta bort alla enkätsvar och kontaktattribut som är kopplade till dessa kontakter. All målgruppsinriktning och personalisering baserad på dessa kontakters data kommer att gå förlorad. Om dessa kontakter har svar som räknas mot enkätkvoter, kommer kvotantalet att minskas men kvotgränserna förblir oförändrade.}}",
|
||||||
|
"displays": "Visningar",
|
||||||
"edit_attribute": "Redigera attribut",
|
"edit_attribute": "Redigera attribut",
|
||||||
"edit_attribute_description": "Uppdatera etikett och beskrivning för detta attribut.",
|
"edit_attribute_description": "Uppdatera etikett och beskrivning för detta attribut.",
|
||||||
"edit_attribute_values": "Redigera attribut",
|
"edit_attribute_values": "Redigera attribut",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "Ogiltiga CSV-kolumnnamn: {columns}. Kolumnnamn som ska bli nya attribut får bara innehålla små bokstäver, siffror och understreck, och måste börja med en bokstav.",
|
"invalid_csv_column_names": "Ogiltiga CSV-kolumnnamn: {columns}. Kolumnnamn som ska bli nya attribut får bara innehålla små bokstäver, siffror och understreck, och måste börja med en bokstav.",
|
||||||
"invalid_date_format": "Ogiltigt datumformat. Ange ett giltigt datum.",
|
"invalid_date_format": "Ogiltigt datumformat. Ange ett giltigt datum.",
|
||||||
"invalid_number_format": "Ogiltigt nummerformat. Ange ett giltigt nummer.",
|
"invalid_number_format": "Ogiltigt nummerformat. Ange ett giltigt nummer.",
|
||||||
|
"no_activity_yet": "Ingen aktivitet än",
|
||||||
"no_published_link_surveys_available": "Inga publicerade länkenkäter tillgängliga. Vänligen publicera en länkenkät först.",
|
"no_published_link_surveys_available": "Inga publicerade länkenkäter tillgängliga. Vänligen publicera en länkenkät först.",
|
||||||
"no_published_surveys": "Inga publicerade enkäter",
|
"no_published_surveys": "Inga publicerade enkäter",
|
||||||
"no_responses_found": "Inga svar hittades",
|
"no_responses_found": "Inga svar hittades",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "Välj en enkät",
|
"select_a_survey": "Välj en enkät",
|
||||||
"select_attribute": "Välj attribut",
|
"select_attribute": "Välj attribut",
|
||||||
"select_attribute_key": "Välj attributnyckel",
|
"select_attribute_key": "Välj attributnyckel",
|
||||||
|
"survey_viewed": "Enkät visad",
|
||||||
|
"survey_viewed_at": "Visad kl.",
|
||||||
"system_attributes": "Systemattribut",
|
"system_attributes": "Systemattribut",
|
||||||
"unlock_contacts_description": "Hantera kontakter och skicka ut riktade enkäter",
|
"unlock_contacts_description": "Hantera kontakter och skicka ut riktade enkäter",
|
||||||
"unlock_contacts_title": "Lås upp kontakter med en högre plan",
|
"unlock_contacts_title": "Lås upp kontakter med en högre plan",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "Lägg till en platshållare att visa om det inte finns något värde att återkalla.",
|
"add_fallback_placeholder": "Lägg till en platshållare att visa om det inte finns något värde att återkalla.",
|
||||||
"add_hidden_field_id": "Lägg till dolt fält-ID",
|
"add_hidden_field_id": "Lägg till dolt fält-ID",
|
||||||
"add_highlight_border": "Lägg till markerad kant",
|
"add_highlight_border": "Lägg till markerad kant",
|
||||||
|
"add_highlight_border_description": "Gäller bara för undersökningar i produkten.",
|
||||||
"add_logic": "Lägg till logik",
|
"add_logic": "Lägg till logik",
|
||||||
"add_none_of_the_above": "Lägg till \"Inget av ovanstående\"",
|
"add_none_of_the_above": "Lägg till \"Inget av ovanstående\"",
|
||||||
"add_option": "Lägg till alternativ",
|
"add_option": "Lägg till alternativ",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "Uppföljning uppdaterad och sparas när du sparar enkäten.",
|
"follow_ups_modal_updated_successfull_toast": "Uppföljning uppdaterad och sparas när du sparar enkäten.",
|
||||||
"follow_ups_new": "Ny uppföljning",
|
"follow_ups_new": "Ny uppföljning",
|
||||||
"follow_ups_upgrade_button_text": "Uppgradera för att aktivera uppföljningar",
|
"follow_ups_upgrade_button_text": "Uppgradera för att aktivera uppföljningar",
|
||||||
"form_styling": "Formulärstil",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK är inte anslutet",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK är inte anslutet",
|
||||||
"four_points": "4 poäng",
|
"four_points": "4 poäng",
|
||||||
"heading": "Rubrik",
|
"heading": "Rubrik",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "Svarsgränser, omdirigeringar och mer.",
|
"response_limits_redirections_and_more": "Svarsgränser, omdirigeringar och mer.",
|
||||||
"response_options": "Svarsalternativ",
|
"response_options": "Svarsalternativ",
|
||||||
"roundness": "Rundhet",
|
"roundness": "Rundhet",
|
||||||
"roundness_description": "Styr hur rundade kortets hörn är.",
|
"roundness_description": "Styr hur rundade hörnen är.",
|
||||||
"row_used_in_logic_error": "Denna rad används i logiken för fråga {questionIndex}. Vänligen ta bort den från logiken först.",
|
"row_used_in_logic_error": "Denna rad används i logiken för fråga {questionIndex}. Vänligen ta bort den från logiken först.",
|
||||||
"rows": "Rader",
|
"rows": "Rader",
|
||||||
"save_and_close": "Spara och stäng",
|
"save_and_close": "Spara och stäng",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "Denna gratis och öppenkällkodsenkät har stängts",
|
"survey_completed_subheading": "Denna gratis och öppenkällkodsenkät har stängts",
|
||||||
"survey_display_settings": "Visningsinställningar för enkät",
|
"survey_display_settings": "Visningsinställningar för enkät",
|
||||||
"survey_placement": "Enkätplacering",
|
"survey_placement": "Enkätplacering",
|
||||||
|
"survey_styling": "Formulärstil",
|
||||||
"survey_trigger": "Enkätutlösare",
|
"survey_trigger": "Enkätutlösare",
|
||||||
"switch_multi_language_on_to_get_started": "Slå på flerspråkighet för att komma igång 👉",
|
"switch_multi_language_on_to_get_started": "Slå på flerspråkighet för att komma igång 👉",
|
||||||
"target_block_not_found": "Målblock hittades inte",
|
"target_block_not_found": "Målblock hittades inte",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "Välkomstmeddelande",
|
"welcome_message": "Välkomstmeddelande",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "Utan ett filter kan alla dina användare enkäteras.",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "Utan ett filter kan alla dina användare enkäteras.",
|
||||||
"you_have_not_created_a_segment_yet": "Du har inte skapat ett segment ännu",
|
"you_have_not_created_a_segment_yet": "Du har inte skapat ett segment ännu",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "Du måste ha två eller fler språk inställda i din arbetsyta för att kunna arbeta med översättningar.",
|
|
||||||
"your_description_here_recall_information_with": "Din beskrivning här. Återkalla information med @",
|
"your_description_here_recall_information_with": "Din beskrivning här. Återkalla information med @",
|
||||||
"your_question_here_recall_information_with": "Din fråga här. Återkalla information med @",
|
"your_question_here_recall_information_with": "Din fråga här. Återkalla information med @",
|
||||||
"your_web_app": "Din webbapp",
|
"your_web_app": "Din webbapp",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "Filtrerade svar (Excel)",
|
"filtered_responses_excel": "Filtrerade svar (Excel)",
|
||||||
"generating_qr_code": "Genererar QR-kod",
|
"generating_qr_code": "Genererar QR-kod",
|
||||||
"impressions": "Visningar",
|
"impressions": "Visningar",
|
||||||
|
"impressions_identified_only": "Visar bara visningar från identifierade kontakter",
|
||||||
"impressions_tooltip": "Antal gånger enkäten har visats.",
|
"impressions_tooltip": "Antal gånger enkäten har visats.",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "Enkäten kommer att visas för användare på din webbplats som matchar kriterierna nedan",
|
"connection_description": "Enkäten kommer att visas för användare på din webbplats som matchar kriterierna nedan",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "Senaste kvartalet",
|
"last_quarter": "Senaste kvartalet",
|
||||||
"last_year": "Senaste året",
|
"last_year": "Senaste året",
|
||||||
"limit": "Gräns",
|
"limit": "Gräns",
|
||||||
|
"no_identified_impressions": "Inga visningar från identifierade kontakter",
|
||||||
"no_responses_found": "Inga svar hittades",
|
"no_responses_found": "Inga svar hittades",
|
||||||
"other_values_found": "Andra värden hittades",
|
"other_values_found": "Andra värden hittades",
|
||||||
"overall": "Övergripande",
|
"overall": "Övergripande",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "Starter",
|
"starts": "Starter",
|
||||||
"starts_tooltip": "Antal gånger enkäten har startats.",
|
"starts_tooltip": "Antal gånger enkäten har startats.",
|
||||||
"survey_reset_successfully": "Enkät återställd! {responseCount} svar och {displayCount} visningar togs bort.",
|
"survey_reset_successfully": "Enkät återställd! {responseCount} svar och {displayCount} visningar togs bort.",
|
||||||
|
"survey_results": "Resultat för {surveyName}",
|
||||||
"this_month": "Denna månad",
|
"this_month": "Denna månad",
|
||||||
"this_quarter": "Detta kvartal",
|
"this_quarter": "Detta kvartal",
|
||||||
"this_year": "Detta år",
|
"this_year": "Detta år",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "Färglägger den fyllda delen av stapeln.",
|
"advanced_styling_field_indicator_bg_description": "Färglägger den fyllda delen av stapeln.",
|
||||||
"advanced_styling_field_input_border_radius_description": "Rundar av hörnen på inmatningsfält.",
|
"advanced_styling_field_input_border_radius_description": "Rundar av hörnen på inmatningsfält.",
|
||||||
"advanced_styling_field_input_font_size_description": "Ändrar storleken på texten i inmatningsfält.",
|
"advanced_styling_field_input_font_size_description": "Ändrar storleken på texten i inmatningsfält.",
|
||||||
"advanced_styling_field_input_height_description": "Styr den minsta höjden på inmatningsfältet.",
|
"advanced_styling_field_input_height_description": "Styr minsta höjden på inmatningsfältet.",
|
||||||
"advanced_styling_field_input_padding_x_description": "Lägger till utrymme till vänster och höger.",
|
"advanced_styling_field_input_padding_x_description": "Lägger till utrymme till vänster och höger.",
|
||||||
"advanced_styling_field_input_padding_y_description": "Lägger till utrymme upptill och nedtill.",
|
"advanced_styling_field_input_padding_y_description": "Lägger till utrymme upptill och nedtill.",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "Tonar ut platshållartexten.",
|
"advanced_styling_field_input_placeholder_opacity_description": "Tonar ut platshållartexten.",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "Färgar den inmatade texten i fälten.",
|
"advanced_styling_field_input_text_description": "Färgar den inmatade texten i fälten.",
|
||||||
"advanced_styling_field_option_bg": "Bakgrund",
|
"advanced_styling_field_option_bg": "Bakgrund",
|
||||||
"advanced_styling_field_option_bg_description": "Fyller alternativraderna.",
|
"advanced_styling_field_option_bg_description": "Fyller alternativraderna.",
|
||||||
|
"advanced_styling_field_option_border": "Kantfärg",
|
||||||
|
"advanced_styling_field_option_border_description": "Markerar radio- och kryssrutealternativ.",
|
||||||
"advanced_styling_field_option_border_radius_description": "Rundar hörnen på alternativen.",
|
"advanced_styling_field_option_border_radius_description": "Rundar hörnen på alternativen.",
|
||||||
"advanced_styling_field_option_font_size_description": "Skalar textstorleken på alternativetiketten.",
|
"advanced_styling_field_option_font_size_description": "Skalar textstorleken på alternativetiketten.",
|
||||||
"advanced_styling_field_option_label": "Etikettfärg",
|
"advanced_styling_field_option_label": "Etikettfärg",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "Nej, tack!",
|
"preview_survey_question_2_choice_2_label": "Nej, tack!",
|
||||||
"preview_survey_question_2_headline": "Vill du hållas uppdaterad?",
|
"preview_survey_question_2_headline": "Vill du hållas uppdaterad?",
|
||||||
"preview_survey_question_2_subheader": "Det här är ett exempel på en beskrivning.",
|
"preview_survey_question_2_subheader": "Det här är ett exempel på en beskrivning.",
|
||||||
|
"preview_survey_question_open_text_headline": "Något mer du vill dela med dig av?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "Skriv ditt svar här...",
|
||||||
|
"preview_survey_question_open_text_subheader": "Din feedback hjälper oss att bli bättre.",
|
||||||
"preview_survey_welcome_card_headline": "Välkommen!",
|
"preview_survey_welcome_card_headline": "Välkommen!",
|
||||||
"prioritize_features_description": "Identifiera vilka funktioner dina användare behöver mest och minst.",
|
"prioritize_features_description": "Identifiera vilka funktioner dina användare behöver mest och minst.",
|
||||||
"prioritize_features_name": "Prioritera funktioner",
|
"prioritize_features_name": "Prioritera funktioner",
|
||||||
|
|||||||
@@ -175,9 +175,11 @@
|
|||||||
"copy": "复制",
|
"copy": "复制",
|
||||||
"copy_code": "复制 代码",
|
"copy_code": "复制 代码",
|
||||||
"copy_link": "复制 链接",
|
"copy_link": "复制 链接",
|
||||||
"count_attributes": "{value, plural, one {{value} 个属性} other {{value} 个属性}}",
|
"count_attributes": "{count, plural, one {{count} 个属性} other {{count} 个属性}}",
|
||||||
"count_contacts": "{value, plural, other {{value} 联系人} }",
|
"count_contacts": "{count, plural, other {{count} 联系人} }",
|
||||||
"count_responses": "{value, plural, other {{value} 回复} }",
|
"count_members": "{count, plural, one {{count} 位成员} other {{count} 位成员}}",
|
||||||
|
"count_responses": "{count, plural, other {{count} 回复} }",
|
||||||
|
"count_selections": "{count, plural, other {已选择{count}项}}",
|
||||||
"create_new_organization": "创建 新的 组织",
|
"create_new_organization": "创建 新的 组织",
|
||||||
"create_segment": "创建 细分",
|
"create_segment": "创建 细分",
|
||||||
"create_survey": "创建 调查",
|
"create_survey": "创建 调查",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "天",
|
"days": "天",
|
||||||
"default": "默认",
|
"default": "默认",
|
||||||
"delete": "删除",
|
"delete": "删除",
|
||||||
|
"delete_what": "删除{deleteWhat}",
|
||||||
"description": "描述",
|
"description": "描述",
|
||||||
"dev_env": "开发 环境",
|
"dev_env": "开发 环境",
|
||||||
"development": "开发环境",
|
"development": "开发环境",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "错误",
|
"error": "错误",
|
||||||
"error_component_description": "这个资源不存在或您没有权限访问它。",
|
"error_component_description": "这个资源不存在或您没有权限访问它。",
|
||||||
"error_component_title": "错误 加载 资源",
|
"error_component_title": "错误 加载 资源",
|
||||||
|
"error_loading_data": "数据加载出错",
|
||||||
"error_rate_limit_description": "请求 达到 最大 上限 , 请 稍后 再试 。",
|
"error_rate_limit_description": "请求 达到 最大 上限 , 请 稍后 再试 。",
|
||||||
"error_rate_limit_title": "速率 限制 超过",
|
"error_rate_limit_title": "速率 限制 超过",
|
||||||
"expand_rows": "展开 行",
|
"expand_rows": "展开 行",
|
||||||
"failed_to_copy_to_clipboard": "复制到剪贴板失败",
|
"failed_to_copy_to_clipboard": "复制到剪贴板失败",
|
||||||
"failed_to_load_organizations": "加载组织失败",
|
"failed_to_load_organizations": "加载组织失败",
|
||||||
"failed_to_load_workspaces": "加载工作区失败",
|
"failed_to_load_workspaces": "加载工作区失败",
|
||||||
|
"filter": "筛选",
|
||||||
"finish": "完成",
|
"finish": "完成",
|
||||||
|
"first_name": "名字",
|
||||||
"follow_these": "遵循 这些",
|
"follow_these": "遵循 这些",
|
||||||
"formbricks_version": "Formbricks 版本",
|
"formbricks_version": "Formbricks 版本",
|
||||||
"full_name": "全名",
|
"full_name": "全名",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "隐藏 字段",
|
"hidden_field": "隐藏 字段",
|
||||||
"hidden_fields": "隐藏 字段",
|
"hidden_fields": "隐藏 字段",
|
||||||
"hide_column": "隐藏 列",
|
"hide_column": "隐藏 列",
|
||||||
|
"id": "ID",
|
||||||
"image": "图片",
|
"image": "图片",
|
||||||
"images": "图片",
|
"images": "图片",
|
||||||
"import": "导入",
|
"import": "导入",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "键",
|
"key": "键",
|
||||||
"label": "标签",
|
"label": "标签",
|
||||||
"language": "语言",
|
"language": "语言",
|
||||||
|
"last_name": "姓",
|
||||||
"learn_more": "了解 更多",
|
"learn_more": "了解 更多",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "浅色遮罩层",
|
"light_overlay": "浅色遮罩层",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "外观 & 感觉",
|
"look_and_feel": "外观 & 感觉",
|
||||||
"manage": "管理",
|
"manage": "管理",
|
||||||
"marketing": "市场营销",
|
"marketing": "市场营销",
|
||||||
"member": "成员",
|
|
||||||
"members": "成员",
|
"members": "成员",
|
||||||
"members_and_teams": "成员和团队",
|
"members_and_teams": "成员和团队",
|
||||||
"membership_not_found": "未找到会员资格",
|
"membership_not_found": "未找到会员资格",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "下移",
|
"move_down": "下移",
|
||||||
"move_up": "上移",
|
"move_up": "上移",
|
||||||
"multiple_languages": "多种 语言",
|
"multiple_languages": "多种 语言",
|
||||||
|
"my_product": "我的产品",
|
||||||
"name": "名称",
|
"name": "名称",
|
||||||
"new": "新建",
|
"new": "新建",
|
||||||
"new_version_available": "Formbricks {version} 在 这里。立即 升级!",
|
"new_version_available": "Formbricks {version} 在 这里。立即 升级!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "选择 团队",
|
"select_teams": "选择 团队",
|
||||||
"selected": "已选择",
|
"selected": "已选择",
|
||||||
"selected_questions": "选择的问题",
|
"selected_questions": "选择的问题",
|
||||||
"selection": "选择",
|
|
||||||
"selections": "选择",
|
|
||||||
"send_test_email": "发送 测试 电子邮件",
|
"send_test_email": "发送 测试 电子邮件",
|
||||||
"session_not_found": "会话 未找到",
|
"session_not_found": "会话 未找到",
|
||||||
"settings": "设置",
|
"settings": "设置",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "右上",
|
"top_right": "右上",
|
||||||
"try_again": "再试一次",
|
"try_again": "再试一次",
|
||||||
"type": "类型",
|
"type": "类型",
|
||||||
|
"unknown_survey": "未知调查",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "升级套餐以解锁更多工作区。",
|
"unlock_more_workspaces_with_a_higher_plan": "升级套餐以解锁更多工作区。",
|
||||||
"update": "更新",
|
"update": "更新",
|
||||||
"updated": "已更新",
|
"updated": "已更新",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {这将删除所选属性。与该属性相关的任何联系人数据都将丢失。} other {这将删除所选属性。与这些属性相关的任何联系人数据都将丢失。}}",
|
"delete_attribute_confirmation": "{value, plural, one {这将删除所选属性。与该属性相关的任何联系人数据都将丢失。} other {这将删除所选属性。与这些属性相关的任何联系人数据都将丢失。}}",
|
||||||
"delete_contact_confirmation": "这将删除与此联系人相关的所有调查问卷回复和联系人属性。基于此联系人数据的任何定位和个性化将会丢失。",
|
"delete_contact_confirmation": "这将删除与此联系人相关的所有调查问卷回复和联系人属性。基于此联系人数据的任何定位和个性化将会丢失。",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {这将删除与此联系人相关的所有调查回复和联系人属性。基于此联系人数据的任何定位和个性化将丢失。如果此联系人有影响调查配额的回复,配额数量将减少,但配额限制将保持不变。} other {这将删除与这些联系人相关的所有调查回复和联系人属性。基于这些联系人数据的任何定位和个性化将丢失。如果这些联系人有影响调查配额的回复,配额数量将减少,但配额限制将保持不变。}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {这将删除与此联系人相关的所有调查回复和联系人属性。基于此联系人数据的任何定位和个性化将丢失。如果此联系人有影响调查配额的回复,配额数量将减少,但配额限制将保持不变。} other {这将删除与这些联系人相关的所有调查回复和联系人属性。基于这些联系人数据的任何定位和个性化将丢失。如果这些联系人有影响调查配额的回复,配额数量将减少,但配额限制将保持不变。}}",
|
||||||
|
"displays": "展示次数",
|
||||||
"edit_attribute": "编辑属性",
|
"edit_attribute": "编辑属性",
|
||||||
"edit_attribute_description": "更新此属性的标签和描述。",
|
"edit_attribute_description": "更新此属性的标签和描述。",
|
||||||
"edit_attribute_values": "编辑属性",
|
"edit_attribute_values": "编辑属性",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "无效的 CSV 列名:{columns}。作为新属性的列名只能包含小写字母、数字和下划线,并且必须以字母开头。",
|
"invalid_csv_column_names": "无效的 CSV 列名:{columns}。作为新属性的列名只能包含小写字母、数字和下划线,并且必须以字母开头。",
|
||||||
"invalid_date_format": "日期格式无效。请使用有效日期。",
|
"invalid_date_format": "日期格式无效。请使用有效日期。",
|
||||||
"invalid_number_format": "数字格式无效。请输入有效的数字。",
|
"invalid_number_format": "数字格式无效。请输入有效的数字。",
|
||||||
|
"no_activity_yet": "暂无活动",
|
||||||
"no_published_link_surveys_available": "没有可用的已发布链接调查。请先发布一个链接调查。",
|
"no_published_link_surveys_available": "没有可用的已发布链接调查。请先发布一个链接调查。",
|
||||||
"no_published_surveys": "没有已发布的调查",
|
"no_published_surveys": "没有已发布的调查",
|
||||||
"no_responses_found": "未找到 响应",
|
"no_responses_found": "未找到 响应",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "选择一个调查",
|
"select_a_survey": "选择一个调查",
|
||||||
"select_attribute": "选择 属性",
|
"select_attribute": "选择 属性",
|
||||||
"select_attribute_key": "选择属性键",
|
"select_attribute_key": "选择属性键",
|
||||||
|
"survey_viewed": "已查看调查",
|
||||||
|
"survey_viewed_at": "查看时间",
|
||||||
"system_attributes": "系统属性",
|
"system_attributes": "系统属性",
|
||||||
"unlock_contacts_description": "管理 联系人 并 发送 定向 调查",
|
"unlock_contacts_description": "管理 联系人 并 发送 定向 调查",
|
||||||
"unlock_contacts_title": "通过 更 高级 划解锁 联系人",
|
"unlock_contacts_title": "通过 更 高级 划解锁 联系人",
|
||||||
@@ -1071,7 +1082,7 @@
|
|||||||
"email_customization_preview_email_heading": "嘿 {userName}",
|
"email_customization_preview_email_heading": "嘿 {userName}",
|
||||||
"email_customization_preview_email_text": "这 是 一封 电子邮件 预览,展示 哪个 徽标 将在 电子邮件 中 渲染。",
|
"email_customization_preview_email_text": "这 是 一封 电子邮件 预览,展示 哪个 徽标 将在 电子邮件 中 渲染。",
|
||||||
"error_deleting_organization_please_try_again": "删除 组织时 出错 。 请重试 。",
|
"error_deleting_organization_please_try_again": "删除 组织时 出错 。 请重试 。",
|
||||||
"from_your_organization": "来自你的组织",
|
"from_your_organization": "来自您组织的{memberName}",
|
||||||
"invitation_sent_once_more": "再次发送邀请。",
|
"invitation_sent_once_more": "再次发送邀请。",
|
||||||
"invite_deleted_successfully": "邀请 删除 成功",
|
"invite_deleted_successfully": "邀请 删除 成功",
|
||||||
"invite_expires_on": "邀请将于 {date} 过期",
|
"invite_expires_on": "邀请将于 {date} 过期",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "添加 占位符 显示 如果 没有 值以 回忆",
|
"add_fallback_placeholder": "添加 占位符 显示 如果 没有 值以 回忆",
|
||||||
"add_hidden_field_id": "添加 隐藏 字段 ID",
|
"add_hidden_field_id": "添加 隐藏 字段 ID",
|
||||||
"add_highlight_border": "添加 高亮 边框",
|
"add_highlight_border": "添加 高亮 边框",
|
||||||
|
"add_highlight_border_description": "仅适用于产品内调查。",
|
||||||
"add_logic": "添加逻辑",
|
"add_logic": "添加逻辑",
|
||||||
"add_none_of_the_above": "添加 “以上 都 不 是”",
|
"add_none_of_the_above": "添加 “以上 都 不 是”",
|
||||||
"add_option": "添加 选项",
|
"add_option": "添加 选项",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "后续 操作 已 更新, 并且 在 你 保存 调查 后 将 被 保存。",
|
"follow_ups_modal_updated_successfull_toast": "后续 操作 已 更新, 并且 在 你 保存 调查 后 将 被 保存。",
|
||||||
"follow_ups_new": "新的跟进",
|
"follow_ups_new": "新的跟进",
|
||||||
"follow_ups_upgrade_button_text": "升级 以启用 跟进",
|
"follow_ups_upgrade_button_text": "升级 以启用 跟进",
|
||||||
"form_styling": "表单 样式",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK 未连接",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK 未连接",
|
||||||
"four_points": "4 分",
|
"four_points": "4 分",
|
||||||
"heading": "标题",
|
"heading": "标题",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "响应 限制 、 重定向 和 更多 。",
|
"response_limits_redirections_and_more": "响应 限制 、 重定向 和 更多 。",
|
||||||
"response_options": "响应 选项",
|
"response_options": "响应 选项",
|
||||||
"roundness": "圆度",
|
"roundness": "圆度",
|
||||||
"roundness_description": "控制卡片角的圆润程度。",
|
"roundness_description": "控制圆角的弧度。",
|
||||||
"row_used_in_logic_error": "\"这个 行 在 问题 {questionIndex} 的 逻辑 中 使用。请 先 从 逻辑 中 删除 它。\"",
|
"row_used_in_logic_error": "\"这个 行 在 问题 {questionIndex} 的 逻辑 中 使用。请 先 从 逻辑 中 删除 它。\"",
|
||||||
"rows": "行",
|
"rows": "行",
|
||||||
"save_and_close": "保存 和 关闭",
|
"save_and_close": "保存 和 关闭",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "此 免费 & 开源 调查 已 关闭",
|
"survey_completed_subheading": "此 免费 & 开源 调查 已 关闭",
|
||||||
"survey_display_settings": "调查显示设置",
|
"survey_display_settings": "调查显示设置",
|
||||||
"survey_placement": "调查 放置",
|
"survey_placement": "调查 放置",
|
||||||
|
"survey_styling": "表单 样式",
|
||||||
"survey_trigger": "调查 触发",
|
"survey_trigger": "调查 触发",
|
||||||
"switch_multi_language_on_to_get_started": "开启多语言以开始使用 👉",
|
"switch_multi_language_on_to_get_started": "开启多语言以开始使用 👉",
|
||||||
"target_block_not_found": "未找到目标区块",
|
"target_block_not_found": "未找到目标区块",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "欢迎 信息",
|
"welcome_message": "欢迎 信息",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "没有 过滤器 时 ,所有 用户 都可以 被 调查 。",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "没有 过滤器 时 ,所有 用户 都可以 被 调查 。",
|
||||||
"you_have_not_created_a_segment_yet": "您 还没有 创建 段落",
|
"you_have_not_created_a_segment_yet": "您 还没有 创建 段落",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "要使用翻译功能,您的工作区需设置两种或以上语言。",
|
|
||||||
"your_description_here_recall_information_with": "在此输入描述。 调用信息与 @",
|
"your_description_here_recall_information_with": "在此输入描述。 调用信息与 @",
|
||||||
"your_question_here_recall_information_with": "在此输入你的问题。 调用信息与 @",
|
"your_question_here_recall_information_with": "在此输入你的问题。 调用信息与 @",
|
||||||
"your_web_app": "您的 网页应用",
|
"your_web_app": "您的 网页应用",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "过滤 反馈 (Excel)",
|
"filtered_responses_excel": "过滤 反馈 (Excel)",
|
||||||
"generating_qr_code": "正在生成二维码",
|
"generating_qr_code": "正在生成二维码",
|
||||||
"impressions": "印象",
|
"impressions": "印象",
|
||||||
|
"impressions_identified_only": "仅显示已识别联系人的展示次数",
|
||||||
"impressions_tooltip": "调查 被 查看 的 次数",
|
"impressions_tooltip": "调查 被 查看 的 次数",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "调查将显示给符合以下条件的您网站用户",
|
"connection_description": "调查将显示给符合以下条件的您网站用户",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "上季度",
|
"last_quarter": "上季度",
|
||||||
"last_year": "去年",
|
"last_year": "去年",
|
||||||
"limit": "限额",
|
"limit": "限额",
|
||||||
|
"no_identified_impressions": "没有已识别联系人的展示次数",
|
||||||
"no_responses_found": "未找到响应",
|
"no_responses_found": "未找到响应",
|
||||||
"other_values_found": "找到其他值",
|
"other_values_found": "找到其他值",
|
||||||
"overall": "整体",
|
"overall": "整体",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "开始",
|
"starts": "开始",
|
||||||
"starts_tooltip": "调查 被 开始 的 次数",
|
"starts_tooltip": "调查 被 开始 的 次数",
|
||||||
"survey_reset_successfully": "调查已重置成功!{responseCount} 个 反馈 和 {displayCount} 个 显示 已删除。",
|
"survey_reset_successfully": "调查已重置成功!{responseCount} 个 反馈 和 {displayCount} 个 显示 已删除。",
|
||||||
|
"survey_results": "{surveyName} 结果",
|
||||||
"this_month": "本月",
|
"this_month": "本月",
|
||||||
"this_quarter": "本季度",
|
"this_quarter": "本季度",
|
||||||
"this_year": "今年",
|
"this_year": "今年",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "设置进度条已填充部分的颜色。",
|
"advanced_styling_field_indicator_bg_description": "设置进度条已填充部分的颜色。",
|
||||||
"advanced_styling_field_input_border_radius_description": "设置输入框圆角。",
|
"advanced_styling_field_input_border_radius_description": "设置输入框圆角。",
|
||||||
"advanced_styling_field_input_font_size_description": "调整输入框内文字大小。",
|
"advanced_styling_field_input_font_size_description": "调整输入框内文字大小。",
|
||||||
"advanced_styling_field_input_height_description": "设置输入框的最小高度。",
|
"advanced_styling_field_input_height_description": "控制输入框的最小高度。",
|
||||||
"advanced_styling_field_input_padding_x_description": "增加输入框左右间距。",
|
"advanced_styling_field_input_padding_x_description": "增加输入框左右间距。",
|
||||||
"advanced_styling_field_input_padding_y_description": "为输入框上下添加间距。",
|
"advanced_styling_field_input_padding_y_description": "为输入框上下添加间距。",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "调整占位提示文字的透明度。",
|
"advanced_styling_field_input_placeholder_opacity_description": "调整占位提示文字的透明度。",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "设置输入框内已输入文字的颜色。",
|
"advanced_styling_field_input_text_description": "设置输入框内已输入文字的颜色。",
|
||||||
"advanced_styling_field_option_bg": "背景色",
|
"advanced_styling_field_option_bg": "背景色",
|
||||||
"advanced_styling_field_option_bg_description": "设置选项项的背景色。",
|
"advanced_styling_field_option_bg_description": "设置选项项的背景色。",
|
||||||
|
"advanced_styling_field_option_border": "边框颜色",
|
||||||
|
"advanced_styling_field_option_border_description": "为单选框和复选框选项添加轮廓。",
|
||||||
"advanced_styling_field_option_border_radius_description": "设置选项的圆角。",
|
"advanced_styling_field_option_border_radius_description": "设置选项的圆角。",
|
||||||
"advanced_styling_field_option_font_size_description": "调整选项标签文字的大小。",
|
"advanced_styling_field_option_font_size_description": "调整选项标签文字的大小。",
|
||||||
"advanced_styling_field_option_label": "标签颜色",
|
"advanced_styling_field_option_label": "标签颜色",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "不,谢谢!",
|
"preview_survey_question_2_choice_2_label": "不,谢谢!",
|
||||||
"preview_survey_question_2_headline": "想 了解 最新信息吗?",
|
"preview_survey_question_2_headline": "想 了解 最新信息吗?",
|
||||||
"preview_survey_question_2_subheader": "这是一个示例描述。",
|
"preview_survey_question_2_subheader": "这是一个示例描述。",
|
||||||
|
"preview_survey_question_open_text_headline": "还有什么想和我们分享的吗?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "请在这里输入你的答案...",
|
||||||
|
"preview_survey_question_open_text_subheader": "你的反馈能帮助我们改进。",
|
||||||
"preview_survey_welcome_card_headline": "欢迎!",
|
"preview_survey_welcome_card_headline": "欢迎!",
|
||||||
"prioritize_features_description": "确定 用户 最 需要 和 最 不 需要 的 功能。",
|
"prioritize_features_description": "确定 用户 最 需要 和 最 不 需要 的 功能。",
|
||||||
"prioritize_features_name": "优先 功能",
|
"prioritize_features_name": "优先 功能",
|
||||||
|
|||||||
@@ -175,9 +175,11 @@
|
|||||||
"copy": "複製",
|
"copy": "複製",
|
||||||
"copy_code": "複製程式碼",
|
"copy_code": "複製程式碼",
|
||||||
"copy_link": "複製連結",
|
"copy_link": "複製連結",
|
||||||
"count_attributes": "{value, plural, one {{value} 個屬性} other {{value} 個屬性}}",
|
"count_attributes": "{count, plural, one {{count} 個屬性} other {{count} 個屬性}}",
|
||||||
"count_contacts": "{value, plural, other {{value} 聯絡人} }",
|
"count_contacts": "{count, plural, other {{count} 聯絡人} }",
|
||||||
"count_responses": "{value, plural, other {{value} 回應} }",
|
"count_members": "{count, plural, one {{count} 位成員} other {{count} 位成員}}",
|
||||||
|
"count_responses": "{count, plural, other {{count} 回應} }",
|
||||||
|
"count_selections": "{count, plural, one {{count} 個選項} other {{count} 個選項}}",
|
||||||
"create_new_organization": "建立新組織",
|
"create_new_organization": "建立新組織",
|
||||||
"create_segment": "建立區隔",
|
"create_segment": "建立區隔",
|
||||||
"create_survey": "建立問卷",
|
"create_survey": "建立問卷",
|
||||||
@@ -191,6 +193,7 @@
|
|||||||
"days": "天",
|
"days": "天",
|
||||||
"default": "預設",
|
"default": "預設",
|
||||||
"delete": "刪除",
|
"delete": "刪除",
|
||||||
|
"delete_what": "刪除{deleteWhat}",
|
||||||
"description": "描述",
|
"description": "描述",
|
||||||
"dev_env": "開發環境",
|
"dev_env": "開發環境",
|
||||||
"development": "開發",
|
"development": "開發",
|
||||||
@@ -218,13 +221,16 @@
|
|||||||
"error": "錯誤",
|
"error": "錯誤",
|
||||||
"error_component_description": "此資源不存在或您沒有存取權限。",
|
"error_component_description": "此資源不存在或您沒有存取權限。",
|
||||||
"error_component_title": "載入資源錯誤",
|
"error_component_title": "載入資源錯誤",
|
||||||
|
"error_loading_data": "載入資料時發生錯誤",
|
||||||
"error_rate_limit_description": "已達 到最大 請求 次數。請 稍後 再試。",
|
"error_rate_limit_description": "已達 到最大 請求 次數。請 稍後 再試。",
|
||||||
"error_rate_limit_title": "限流超過",
|
"error_rate_limit_title": "限流超過",
|
||||||
"expand_rows": "展開列",
|
"expand_rows": "展開列",
|
||||||
"failed_to_copy_to_clipboard": "無法複製到剪貼簿",
|
"failed_to_copy_to_clipboard": "無法複製到剪貼簿",
|
||||||
"failed_to_load_organizations": "無法載入組織",
|
"failed_to_load_organizations": "無法載入組織",
|
||||||
"failed_to_load_workspaces": "載入工作區失敗",
|
"failed_to_load_workspaces": "載入工作區失敗",
|
||||||
|
"filter": "篩選",
|
||||||
"finish": "完成",
|
"finish": "完成",
|
||||||
|
"first_name": "名字",
|
||||||
"follow_these": "按照這些步驟",
|
"follow_these": "按照這些步驟",
|
||||||
"formbricks_version": "Formbricks 版本",
|
"formbricks_version": "Formbricks 版本",
|
||||||
"full_name": "全名",
|
"full_name": "全名",
|
||||||
@@ -237,6 +243,7 @@
|
|||||||
"hidden_field": "隱藏欄位",
|
"hidden_field": "隱藏欄位",
|
||||||
"hidden_fields": "隱藏欄位",
|
"hidden_fields": "隱藏欄位",
|
||||||
"hide_column": "隱藏欄位",
|
"hide_column": "隱藏欄位",
|
||||||
|
"id": "ID",
|
||||||
"image": "圖片",
|
"image": "圖片",
|
||||||
"images": "圖片",
|
"images": "圖片",
|
||||||
"import": "匯入",
|
"import": "匯入",
|
||||||
@@ -254,6 +261,7 @@
|
|||||||
"key": "金鑰",
|
"key": "金鑰",
|
||||||
"label": "標籤",
|
"label": "標籤",
|
||||||
"language": "語言",
|
"language": "語言",
|
||||||
|
"last_name": "姓氏",
|
||||||
"learn_more": "瞭解更多",
|
"learn_more": "瞭解更多",
|
||||||
"license_expired": "License Expired",
|
"license_expired": "License Expired",
|
||||||
"light_overlay": "淺色覆蓋",
|
"light_overlay": "淺色覆蓋",
|
||||||
@@ -268,7 +276,6 @@
|
|||||||
"look_and_feel": "外觀與風格",
|
"look_and_feel": "外觀與風格",
|
||||||
"manage": "管理",
|
"manage": "管理",
|
||||||
"marketing": "行銷",
|
"marketing": "行銷",
|
||||||
"member": "成員",
|
|
||||||
"members": "成員",
|
"members": "成員",
|
||||||
"members_and_teams": "成員與團隊",
|
"members_and_teams": "成員與團隊",
|
||||||
"membership_not_found": "找不到成員資格",
|
"membership_not_found": "找不到成員資格",
|
||||||
@@ -280,6 +287,7 @@
|
|||||||
"move_down": "下移",
|
"move_down": "下移",
|
||||||
"move_up": "上移",
|
"move_up": "上移",
|
||||||
"multiple_languages": "多種語言",
|
"multiple_languages": "多種語言",
|
||||||
|
"my_product": "我的產品",
|
||||||
"name": "名稱",
|
"name": "名稱",
|
||||||
"new": "新增",
|
"new": "新增",
|
||||||
"new_version_available": "Formbricks '{'version'}' 已推出。立即升級!",
|
"new_version_available": "Formbricks '{'version'}' 已推出。立即升級!",
|
||||||
@@ -375,8 +383,6 @@
|
|||||||
"select_teams": "選擇 團隊",
|
"select_teams": "選擇 團隊",
|
||||||
"selected": "已選取",
|
"selected": "已選取",
|
||||||
"selected_questions": "選取的問題",
|
"selected_questions": "選取的問題",
|
||||||
"selection": "選取",
|
|
||||||
"selections": "選取",
|
|
||||||
"send_test_email": "發送測試電子郵件",
|
"send_test_email": "發送測試電子郵件",
|
||||||
"session_not_found": "找不到工作階段",
|
"session_not_found": "找不到工作階段",
|
||||||
"settings": "設定",
|
"settings": "設定",
|
||||||
@@ -428,6 +434,7 @@
|
|||||||
"top_right": "右上",
|
"top_right": "右上",
|
||||||
"try_again": "再試一次",
|
"try_again": "再試一次",
|
||||||
"type": "類型",
|
"type": "類型",
|
||||||
|
"unknown_survey": "未知問卷",
|
||||||
"unlock_more_workspaces_with_a_higher_plan": "升級方案以解鎖更多工作區。",
|
"unlock_more_workspaces_with_a_higher_plan": "升級方案以解鎖更多工作區。",
|
||||||
"update": "更新",
|
"update": "更新",
|
||||||
"updated": "已更新",
|
"updated": "已更新",
|
||||||
@@ -655,6 +662,7 @@
|
|||||||
"delete_attribute_confirmation": "{value, plural, one {這將刪除所選屬性。與此屬性相關的聯絡人資料將會遺失。} other {這將刪除所選屬性。與這些屬性相關的聯絡人資料將會遺失。}}",
|
"delete_attribute_confirmation": "{value, plural, one {這將刪除所選屬性。與此屬性相關的聯絡人資料將會遺失。} other {這將刪除所選屬性。與這些屬性相關的聯絡人資料將會遺失。}}",
|
||||||
"delete_contact_confirmation": "這將刪除與此聯繫人相關的所有調查回應和聯繫屬性。任何基於此聯繫人數據的定位和個性化將會丟失。",
|
"delete_contact_confirmation": "這將刪除與此聯繫人相關的所有調查回應和聯繫屬性。任何基於此聯繫人數據的定位和個性化將會丟失。",
|
||||||
"delete_contact_confirmation_with_quotas": "{value, plural, one {這將刪除與這個 contact 相關的所有調查響應和聯繫人屬性。基於這個 contact 數據的任何定向和個性化功能將會丟失。如果這個 contact 有作為調查配額依據的響應,配額計數將會減少,但配額限制將保持不變。} other {這將刪除與這些 contacts 相關的所有調查響應和聯繫人屬性。基於這些 contacts 數據的任何定向和個性化功能將會丟失。如果這些 contacts 有作為調查配額依據的響應,配額計數將會減少,但配額限制將保持不變。}}",
|
"delete_contact_confirmation_with_quotas": "{value, plural, one {這將刪除與這個 contact 相關的所有調查響應和聯繫人屬性。基於這個 contact 數據的任何定向和個性化功能將會丟失。如果這個 contact 有作為調查配額依據的響應,配額計數將會減少,但配額限制將保持不變。} other {這將刪除與這些 contacts 相關的所有調查響應和聯繫人屬性。基於這些 contacts 數據的任何定向和個性化功能將會丟失。如果這些 contacts 有作為調查配額依據的響應,配額計數將會減少,但配額限制將保持不變。}}",
|
||||||
|
"displays": "顯示次數",
|
||||||
"edit_attribute": "編輯屬性",
|
"edit_attribute": "編輯屬性",
|
||||||
"edit_attribute_description": "更新此屬性的標籤與描述。",
|
"edit_attribute_description": "更新此屬性的標籤與描述。",
|
||||||
"edit_attribute_values": "編輯屬性",
|
"edit_attribute_values": "編輯屬性",
|
||||||
@@ -666,6 +674,7 @@
|
|||||||
"invalid_csv_column_names": "無效的 CSV 欄位名稱:{columns}。作為新屬性的欄位名稱只能包含小寫字母、數字和底線,且必須以字母開頭。",
|
"invalid_csv_column_names": "無效的 CSV 欄位名稱:{columns}。作為新屬性的欄位名稱只能包含小寫字母、數字和底線,且必須以字母開頭。",
|
||||||
"invalid_date_format": "日期格式無效。請使用有效的日期。",
|
"invalid_date_format": "日期格式無效。請使用有效的日期。",
|
||||||
"invalid_number_format": "數字格式無效。請輸入有效的數字。",
|
"invalid_number_format": "數字格式無效。請輸入有效的數字。",
|
||||||
|
"no_activity_yet": "尚無活動",
|
||||||
"no_published_link_surveys_available": "沒有可用的已發佈連結問卷。請先發佈一個連結問卷。",
|
"no_published_link_surveys_available": "沒有可用的已發佈連結問卷。請先發佈一個連結問卷。",
|
||||||
"no_published_surveys": "沒有已發佈的問卷",
|
"no_published_surveys": "沒有已發佈的問卷",
|
||||||
"no_responses_found": "找不到回應",
|
"no_responses_found": "找不到回應",
|
||||||
@@ -680,6 +689,8 @@
|
|||||||
"select_a_survey": "選擇問卷",
|
"select_a_survey": "選擇問卷",
|
||||||
"select_attribute": "選取屬性",
|
"select_attribute": "選取屬性",
|
||||||
"select_attribute_key": "選取屬性鍵值",
|
"select_attribute_key": "選取屬性鍵值",
|
||||||
|
"survey_viewed": "已查看問卷",
|
||||||
|
"survey_viewed_at": "查看時間",
|
||||||
"system_attributes": "系統屬性",
|
"system_attributes": "系統屬性",
|
||||||
"unlock_contacts_description": "管理聯絡人並發送目標問卷",
|
"unlock_contacts_description": "管理聯絡人並發送目標問卷",
|
||||||
"unlock_contacts_title": "使用更高等級的方案解鎖聯絡人",
|
"unlock_contacts_title": "使用更高等級的方案解鎖聯絡人",
|
||||||
@@ -1236,6 +1247,7 @@
|
|||||||
"add_fallback_placeholder": "新增 預設 以顯示是否沒 有 值 可 回憶 。",
|
"add_fallback_placeholder": "新增 預設 以顯示是否沒 有 值 可 回憶 。",
|
||||||
"add_hidden_field_id": "新增隱藏欄位 ID",
|
"add_hidden_field_id": "新增隱藏欄位 ID",
|
||||||
"add_highlight_border": "新增醒目提示邊框",
|
"add_highlight_border": "新增醒目提示邊框",
|
||||||
|
"add_highlight_border_description": "僅適用於產品內調查。",
|
||||||
"add_logic": "新增邏輯",
|
"add_logic": "新增邏輯",
|
||||||
"add_none_of_the_above": "新增 \"以上皆非\"",
|
"add_none_of_the_above": "新增 \"以上皆非\"",
|
||||||
"add_option": "新增選項",
|
"add_option": "新增選項",
|
||||||
@@ -1434,7 +1446,6 @@
|
|||||||
"follow_ups_modal_updated_successfull_toast": "後續 動作 已 更新 並 將 在 你 儲存 調查 後 儲存",
|
"follow_ups_modal_updated_successfull_toast": "後續 動作 已 更新 並 將 在 你 儲存 調查 後 儲存",
|
||||||
"follow_ups_new": "新增後續追蹤",
|
"follow_ups_new": "新增後續追蹤",
|
||||||
"follow_ups_upgrade_button_text": "升級以啟用後續追蹤",
|
"follow_ups_upgrade_button_text": "升級以啟用後續追蹤",
|
||||||
"form_styling": "表單樣式設定",
|
|
||||||
"formbricks_sdk_is_not_connected": "Formbricks SDK 未連線",
|
"formbricks_sdk_is_not_connected": "Formbricks SDK 未連線",
|
||||||
"four_points": "4 分",
|
"four_points": "4 分",
|
||||||
"heading": "標題",
|
"heading": "標題",
|
||||||
@@ -1607,7 +1618,7 @@
|
|||||||
"response_limits_redirections_and_more": "回應限制、重新導向等。",
|
"response_limits_redirections_and_more": "回應限制、重新導向等。",
|
||||||
"response_options": "回應選項",
|
"response_options": "回應選項",
|
||||||
"roundness": "圓角",
|
"roundness": "圓角",
|
||||||
"roundness_description": "調整卡片邊角的圓弧度。",
|
"roundness_description": "調整邊角的圓潤程度。",
|
||||||
"row_used_in_logic_error": "此 row 用於問題 '{'questionIndex'}' 的邏輯中。請先從邏輯中移除。",
|
"row_used_in_logic_error": "此 row 用於問題 '{'questionIndex'}' 的邏輯中。請先從邏輯中移除。",
|
||||||
"rows": "列",
|
"rows": "列",
|
||||||
"save_and_close": "儲存並關閉",
|
"save_and_close": "儲存並關閉",
|
||||||
@@ -1653,6 +1664,7 @@
|
|||||||
"survey_completed_subheading": "此免費且開源的問卷已關閉",
|
"survey_completed_subheading": "此免費且開源的問卷已關閉",
|
||||||
"survey_display_settings": "問卷顯示設定",
|
"survey_display_settings": "問卷顯示設定",
|
||||||
"survey_placement": "問卷位置",
|
"survey_placement": "問卷位置",
|
||||||
|
"survey_styling": "表單樣式設定",
|
||||||
"survey_trigger": "問卷觸發器",
|
"survey_trigger": "問卷觸發器",
|
||||||
"switch_multi_language_on_to_get_started": "請開啟多語言功能以開始使用 👉",
|
"switch_multi_language_on_to_get_started": "請開啟多語言功能以開始使用 👉",
|
||||||
"target_block_not_found": "找不到目標區塊",
|
"target_block_not_found": "找不到目標區塊",
|
||||||
@@ -1743,7 +1755,6 @@
|
|||||||
"welcome_message": "歡迎訊息",
|
"welcome_message": "歡迎訊息",
|
||||||
"without_a_filter_all_of_your_users_can_be_surveyed": "如果沒有篩選器,則可以調查您的所有使用者。",
|
"without_a_filter_all_of_your_users_can_be_surveyed": "如果沒有篩選器,則可以調查您的所有使用者。",
|
||||||
"you_have_not_created_a_segment_yet": "您尚未建立區隔",
|
"you_have_not_created_a_segment_yet": "您尚未建立區隔",
|
||||||
"you_need_to_have_two_or_more_languages_set_up_in_your_workspace_to_work_with_translations": "您必須在工作區中設定兩種或以上語言,才能進行翻譯作業。",
|
|
||||||
"your_description_here_recall_information_with": "您的描述在這裡。使用 @ 回憶資訊",
|
"your_description_here_recall_information_with": "您的描述在這裡。使用 @ 回憶資訊",
|
||||||
"your_question_here_recall_information_with": "您的問題在這裡。使用 @ 回憶資訊",
|
"your_question_here_recall_information_with": "您的問題在這裡。使用 @ 回憶資訊",
|
||||||
"your_web_app": "您的 Web 應用程式",
|
"your_web_app": "您的 Web 應用程式",
|
||||||
@@ -1951,6 +1962,7 @@
|
|||||||
"filtered_responses_excel": "篩選回應 (Excel)",
|
"filtered_responses_excel": "篩選回應 (Excel)",
|
||||||
"generating_qr_code": "正在生成 QR code",
|
"generating_qr_code": "正在生成 QR code",
|
||||||
"impressions": "曝光數",
|
"impressions": "曝光數",
|
||||||
|
"impressions_identified_only": "僅顯示已識別聯絡人的曝光次數",
|
||||||
"impressions_tooltip": "問卷已檢視的次數。",
|
"impressions_tooltip": "問卷已檢視的次數。",
|
||||||
"in_app": {
|
"in_app": {
|
||||||
"connection_description": "調查將顯示給符合以下列出條件的網站用戶",
|
"connection_description": "調查將顯示給符合以下列出條件的網站用戶",
|
||||||
@@ -1993,6 +2005,7 @@
|
|||||||
"last_quarter": "上一季",
|
"last_quarter": "上一季",
|
||||||
"last_year": "去年",
|
"last_year": "去年",
|
||||||
"limit": "限制",
|
"limit": "限制",
|
||||||
|
"no_identified_impressions": "沒有來自已識別聯絡人的曝光次數",
|
||||||
"no_responses_found": "找不到回應",
|
"no_responses_found": "找不到回應",
|
||||||
"other_values_found": "找到其他值",
|
"other_values_found": "找到其他值",
|
||||||
"overall": "整體",
|
"overall": "整體",
|
||||||
@@ -2015,6 +2028,7 @@
|
|||||||
"starts": "開始次數",
|
"starts": "開始次數",
|
||||||
"starts_tooltip": "問卷已開始的次數。",
|
"starts_tooltip": "問卷已開始的次數。",
|
||||||
"survey_reset_successfully": "調查 重置 成功!{responseCount} 條回應和 {displayCount} 個顯示被刪除。",
|
"survey_reset_successfully": "調查 重置 成功!{responseCount} 條回應和 {displayCount} 個顯示被刪除。",
|
||||||
|
"survey_results": "{surveyName} 結果",
|
||||||
"this_month": "本月",
|
"this_month": "本月",
|
||||||
"this_quarter": "本季",
|
"this_quarter": "本季",
|
||||||
"this_year": "今年",
|
"this_year": "今年",
|
||||||
@@ -2162,7 +2176,7 @@
|
|||||||
"advanced_styling_field_indicator_bg_description": "設定進度條已填滿部分的顏色。",
|
"advanced_styling_field_indicator_bg_description": "設定進度條已填滿部分的顏色。",
|
||||||
"advanced_styling_field_input_border_radius_description": "調整輸入框的圓角。",
|
"advanced_styling_field_input_border_radius_description": "調整輸入框的圓角。",
|
||||||
"advanced_styling_field_input_font_size_description": "調整輸入框內輸入文字的大小。",
|
"advanced_styling_field_input_font_size_description": "調整輸入框內輸入文字的大小。",
|
||||||
"advanced_styling_field_input_height_description": "設定輸入欄位的最小高度。",
|
"advanced_styling_field_input_height_description": "控制輸入欄的最小高度。",
|
||||||
"advanced_styling_field_input_padding_x_description": "在左右兩側增加間距。",
|
"advanced_styling_field_input_padding_x_description": "在左右兩側增加間距。",
|
||||||
"advanced_styling_field_input_padding_y_description": "在上方和下方增加間距。",
|
"advanced_styling_field_input_padding_y_description": "在上方和下方增加間距。",
|
||||||
"advanced_styling_field_input_placeholder_opacity_description": "讓提示文字變得更淡。",
|
"advanced_styling_field_input_placeholder_opacity_description": "讓提示文字變得更淡。",
|
||||||
@@ -2171,6 +2185,8 @@
|
|||||||
"advanced_styling_field_input_text_description": "設定輸入文字的顏色。",
|
"advanced_styling_field_input_text_description": "設定輸入文字的顏色。",
|
||||||
"advanced_styling_field_option_bg": "背景",
|
"advanced_styling_field_option_bg": "背景",
|
||||||
"advanced_styling_field_option_bg_description": "填滿選項項目背景。",
|
"advanced_styling_field_option_bg_description": "填滿選項項目背景。",
|
||||||
|
"advanced_styling_field_option_border": "邊框顏色",
|
||||||
|
"advanced_styling_field_option_border_description": "為單選框和核取方塊選項加上外框。",
|
||||||
"advanced_styling_field_option_border_radius_description": "讓選項的邊角變圓。",
|
"advanced_styling_field_option_border_radius_description": "讓選項的邊角變圓。",
|
||||||
"advanced_styling_field_option_font_size_description": "調整選項標籤文字的大小。",
|
"advanced_styling_field_option_font_size_description": "調整選項標籤文字的大小。",
|
||||||
"advanced_styling_field_option_label": "標籤顏色",
|
"advanced_styling_field_option_label": "標籤顏色",
|
||||||
@@ -2990,6 +3006,9 @@
|
|||||||
"preview_survey_question_2_choice_2_label": "不用了,謝謝!",
|
"preview_survey_question_2_choice_2_label": "不用了,謝謝!",
|
||||||
"preview_survey_question_2_headline": "想要緊跟最新動態嗎?",
|
"preview_survey_question_2_headline": "想要緊跟最新動態嗎?",
|
||||||
"preview_survey_question_2_subheader": "這是一個範例說明。",
|
"preview_survey_question_2_subheader": "這是一個範例說明。",
|
||||||
|
"preview_survey_question_open_text_headline": "還有什麼想和我們分享的嗎?",
|
||||||
|
"preview_survey_question_open_text_placeholder": "在此輸入您的答案...",
|
||||||
|
"preview_survey_question_open_text_subheader": "您的回饋能幫助我們進步。",
|
||||||
"preview_survey_welcome_card_headline": "歡迎!",
|
"preview_survey_welcome_card_headline": "歡迎!",
|
||||||
"prioritize_features_description": "找出您的使用者最需要和最不需要的功能。",
|
"prioritize_features_description": "找出您的使用者最需要和最不需要的功能。",
|
||||||
"prioritize_features_name": "優先排序功能",
|
"prioritize_features_name": "優先排序功能",
|
||||||
|
|||||||
+1
-1
@@ -42,7 +42,7 @@ export const SingleResponseCardBody = ({
|
|||||||
return (
|
return (
|
||||||
<span
|
<span
|
||||||
key={index}
|
key={index}
|
||||||
className="mr-0.5 ml-0.5 rounded-md border border-slate-200 bg-slate-50 px-1 py-0.5 text-sm first:ml-0">
|
className="ml-0.5 mr-0.5 rounded-md border border-slate-200 bg-slate-50 px-1 py-0.5 text-sm first:ml-0">
|
||||||
@{part}
|
@{part}
|
||||||
</span>
|
</span>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ export const EmailChangeWithoutVerificationSuccessPage = async () => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="bg-gradient-radial flex min-h-screen from-slate-200 to-slate-50">
|
<div className="flex min-h-screen bg-gradient-radial from-slate-200 to-slate-50">
|
||||||
<FormWrapper>
|
<FormWrapper>
|
||||||
<h1 className="leading-2 mb-4 text-center font-bold">
|
<h1 className="leading-2 mb-4 text-center font-bold">
|
||||||
{t("auth.email-change.email_change_success")}
|
{t("auth.email-change.email_change_success")}
|
||||||
|
|||||||
@@ -60,7 +60,7 @@ export const ForgotPasswordForm = () => {
|
|||||||
onChange={(e) => field.onChange(e)}
|
onChange={(e) => field.onChange(e)}
|
||||||
autoComplete="email"
|
autoComplete="email"
|
||||||
required
|
required
|
||||||
className="focus:border-brand-dark focus:ring-brand-dark block w-full rounded-md border-slate-300 shadow-sm sm:text-sm"
|
className="block w-full rounded-md border-slate-300 shadow-sm focus:border-brand-dark focus:ring-brand-dark sm:text-sm"
|
||||||
/>
|
/>
|
||||||
</FormControl>
|
</FormControl>
|
||||||
{error?.message && <FormError className="text-left">{error.message}</FormError>}
|
{error?.message && <FormError className="text-left">{error.message}</FormError>}
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
import { Invite } from "@prisma/client";
|
import { Invite } from "@prisma/client";
|
||||||
import { TUserLocale } from "@formbricks/types/user";
|
import { TUserLocale } from "@formbricks/types/user";
|
||||||
|
|
||||||
export interface InviteWithCreator
|
export interface InviteWithCreator extends Pick<
|
||||||
extends Pick<Invite, "id" | "expiresAt" | "organizationId" | "role" | "teamIds"> {
|
Invite,
|
||||||
|
"id" | "expiresAt" | "organizationId" | "role" | "teamIds"
|
||||||
|
> {
|
||||||
creator: {
|
creator: {
|
||||||
name: string | null;
|
name: string | null;
|
||||||
email: string;
|
email: string;
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ export const AuthLayout = async ({ children }: { children: React.ReactNode }) =>
|
|||||||
<Toaster />
|
<Toaster />
|
||||||
<div className="min-h-screen bg-slate-50">
|
<div className="min-h-screen bg-slate-50">
|
||||||
<div className="isolate bg-white">
|
<div className="isolate bg-white">
|
||||||
<div className="bg-gradient-radial flex min-h-screen from-slate-200 to-slate-50">{children}</div>
|
<div className="flex min-h-screen bg-gradient-radial from-slate-200 to-slate-50">{children}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
|
|||||||
@@ -195,6 +195,7 @@ describe("authOptions", () => {
|
|||||||
vi.mocked(applyIPRateLimit).mockRejectedValue(
|
vi.mocked(applyIPRateLimit).mockRejectedValue(
|
||||||
new Error("Maximum number of requests reached. Please try again later.")
|
new Error("Maximum number of requests reached. Please try again later.")
|
||||||
);
|
);
|
||||||
|
const findUniqueSpy = vi.spyOn(prisma.user, "findUnique");
|
||||||
|
|
||||||
const credentials = { email: mockUser.email, password: mockPassword };
|
const credentials = { email: mockUser.email, password: mockPassword };
|
||||||
|
|
||||||
@@ -202,7 +203,7 @@ describe("authOptions", () => {
|
|||||||
"Maximum number of requests reached. Please try again later."
|
"Maximum number of requests reached. Please try again later."
|
||||||
);
|
);
|
||||||
|
|
||||||
expect(prisma.user.findUnique).not.toHaveBeenCalled();
|
expect(findUniqueSpy).not.toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should use correct rate limit configuration", async () => {
|
test("should use correct rate limit configuration", async () => {
|
||||||
@@ -281,6 +282,7 @@ describe("authOptions", () => {
|
|||||||
vi.mocked(applyIPRateLimit).mockRejectedValue(
|
vi.mocked(applyIPRateLimit).mockRejectedValue(
|
||||||
new Error("Maximum number of requests reached. Please try again later.")
|
new Error("Maximum number of requests reached. Please try again later.")
|
||||||
);
|
);
|
||||||
|
const findUniqueSpy = vi.spyOn(prisma.user, "findUnique");
|
||||||
|
|
||||||
const credentials = { token: "sometoken" };
|
const credentials = { token: "sometoken" };
|
||||||
|
|
||||||
@@ -288,7 +290,7 @@ describe("authOptions", () => {
|
|||||||
"Maximum number of requests reached. Please try again later."
|
"Maximum number of requests reached. Please try again later."
|
||||||
);
|
);
|
||||||
|
|
||||||
expect(prisma.user.findUnique).not.toHaveBeenCalled();
|
expect(findUniqueSpy).not.toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -184,7 +184,7 @@ export const LoginForm = ({
|
|||||||
value={field.value}
|
value={field.value}
|
||||||
onChange={(email) => field.onChange(email)}
|
onChange={(email) => field.onChange(email)}
|
||||||
placeholder="work@email.com"
|
placeholder="work@email.com"
|
||||||
className="focus:border-brand-dark focus:ring-brand-dark block w-full rounded-md border-slate-300 shadow-sm sm:text-sm"
|
className="block w-full rounded-md border-slate-300 shadow-sm focus:border-brand-dark focus:ring-brand-dark sm:text-sm"
|
||||||
/>
|
/>
|
||||||
{error?.message && <FormError className="text-left">{error.message}</FormError>}
|
{error?.message && <FormError className="text-left">{error.message}</FormError>}
|
||||||
</div>
|
</div>
|
||||||
@@ -207,7 +207,7 @@ export const LoginForm = ({
|
|||||||
aria-label="password"
|
aria-label="password"
|
||||||
aria-required="true"
|
aria-required="true"
|
||||||
required
|
required
|
||||||
className="focus:border-brand-dark focus:ring-brand-dark block w-full rounded-md border-slate-300 pr-8 shadow-sm sm:text-sm"
|
className="block w-full rounded-md border-slate-300 pr-8 shadow-sm focus:border-brand-dark focus:ring-brand-dark sm:text-sm"
|
||||||
value={field.value}
|
value={field.value}
|
||||||
onChange={(password) => field.onChange(password)}
|
onChange={(password) => field.onChange(password)}
|
||||||
/>
|
/>
|
||||||
@@ -221,7 +221,7 @@ export const LoginForm = ({
|
|||||||
<div className="ml-1 text-right transition-all duration-500 ease-in-out">
|
<div className="ml-1 text-right transition-all duration-500 ease-in-out">
|
||||||
<Link
|
<Link
|
||||||
href="/auth/forgot-password"
|
href="/auth/forgot-password"
|
||||||
className="hover:text-brand-dark text-xs text-slate-500">
|
className="text-xs text-slate-500 hover:text-brand-dark">
|
||||||
{t("auth.login.forgot_your_password")}
|
{t("auth.login.forgot_your_password")}
|
||||||
</Link>
|
</Link>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -222,7 +222,7 @@ export const SignupForm = ({
|
|||||||
placeholder="*******"
|
placeholder="*******"
|
||||||
aria-placeholder="password"
|
aria-placeholder="password"
|
||||||
required
|
required
|
||||||
className="focus:border-brand-dark focus:ring-brand-dark block w-full rounded-md shadow-sm sm:text-sm"
|
className="block w-full rounded-md shadow-sm focus:border-brand-dark focus:ring-brand-dark sm:text-sm"
|
||||||
/>
|
/>
|
||||||
{error?.message && <FormError className="text-left">{error.message}</FormError>}
|
{error?.message && <FormError className="text-left">{error.message}</FormError>}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ export const VerifyEmailChangePage = async ({ searchParams }) => {
|
|||||||
const { token } = await searchParams;
|
const { token } = await searchParams;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="bg-gradient-radial flex min-h-screen from-slate-200 to-slate-50">
|
<div className="flex min-h-screen bg-gradient-radial from-slate-200 to-slate-50">
|
||||||
<FormWrapper>
|
<FormWrapper>
|
||||||
<EmailChangeSignIn token={token} />
|
<EmailChangeSignIn token={token} />
|
||||||
<BackToLoginButton />
|
<BackToLoginButton />
|
||||||
|
|||||||
@@ -138,7 +138,7 @@ export const PricingTable = ({
|
|||||||
<div className="flex flex-col gap-8">
|
<div className="flex flex-col gap-8">
|
||||||
<div className="flex flex-col">
|
<div className="flex flex-col">
|
||||||
<div className="flex w-full">
|
<div className="flex w-full">
|
||||||
<h2 className="mr-2 mb-3 inline-flex w-full text-2xl font-bold text-slate-700">
|
<h2 className="mb-3 mr-2 inline-flex w-full text-2xl font-bold text-slate-700">
|
||||||
{t("environments.settings.billing.current_plan")}:{" "}
|
{t("environments.settings.billing.current_plan")}:{" "}
|
||||||
<span className="capitalize">{organization.billing.plan}</span>
|
<span className="capitalize">{organization.billing.plan}</span>
|
||||||
{cancellingOn && (
|
{cancellingOn && (
|
||||||
@@ -203,7 +203,7 @@ export const PricingTable = ({
|
|||||||
<div
|
<div
|
||||||
className={cn(
|
className={cn(
|
||||||
"relative mx-8 mb-8 flex flex-col gap-4",
|
"relative mx-8 mb-8 flex flex-col gap-4",
|
||||||
peopleUnlimitedCheck && "mt-4 mb-0 flex-row pb-0"
|
peopleUnlimitedCheck && "mb-0 mt-4 flex-row pb-0"
|
||||||
)}>
|
)}>
|
||||||
<p className="text-md font-semibold text-slate-700">
|
<p className="text-md font-semibold text-slate-700">
|
||||||
{t("environments.settings.billing.monthly_identified_users")}
|
{t("environments.settings.billing.monthly_identified_users")}
|
||||||
@@ -226,7 +226,7 @@ export const PricingTable = ({
|
|||||||
<div
|
<div
|
||||||
className={cn(
|
className={cn(
|
||||||
"relative mx-8 flex flex-col gap-4 pb-6",
|
"relative mx-8 flex flex-col gap-4 pb-6",
|
||||||
projectsUnlimitedCheck && "mt-4 mb-0 flex-row pb-0"
|
projectsUnlimitedCheck && "mb-0 mt-4 flex-row pb-0"
|
||||||
)}>
|
)}>
|
||||||
<p className="text-md font-semibold text-slate-700">{t("common.workspaces")}</p>
|
<p className="text-md font-semibold text-slate-700">{t("common.workspaces")}</p>
|
||||||
{organization.billing.limits.projects && (
|
{organization.billing.limits.projects && (
|
||||||
@@ -264,7 +264,7 @@ export const PricingTable = ({
|
|||||||
</button>
|
</button>
|
||||||
<button
|
<button
|
||||||
aria-pressed={planPeriod === "yearly"}
|
aria-pressed={planPeriod === "yearly"}
|
||||||
className={`flex-1 items-center rounded-md py-0.5 pr-2 pl-4 text-center whitespace-nowrap ${
|
className={`flex-1 items-center whitespace-nowrap rounded-md py-0.5 pl-4 pr-2 text-center ${
|
||||||
planPeriod === "yearly" ? "bg-slate-200 font-semibold" : "bg-transparent"
|
planPeriod === "yearly" ? "bg-slate-200 font-semibold" : "bg-transparent"
|
||||||
}`}
|
}`}
|
||||||
onClick={() => handleMonthlyToggle("yearly")}>
|
onClick={() => handleMonthlyToggle("yearly")}>
|
||||||
@@ -276,7 +276,7 @@ export const PricingTable = ({
|
|||||||
</div>
|
</div>
|
||||||
<div className="relative mx-auto grid max-w-md grid-cols-1 gap-y-8 lg:mx-0 lg:-mb-14 lg:max-w-none lg:grid-cols-3">
|
<div className="relative mx-auto grid max-w-md grid-cols-1 gap-y-8 lg:mx-0 lg:-mb-14 lg:max-w-none lg:grid-cols-3">
|
||||||
<div
|
<div
|
||||||
className="hidden lg:absolute lg:inset-x-px lg:top-4 lg:bottom-0 lg:block lg:rounded-xl lg:rounded-t-2xl lg:border lg:border-slate-200 lg:bg-slate-100 lg:pb-8 lg:ring-1 lg:ring-white/10"
|
className="hidden lg:absolute lg:inset-x-px lg:bottom-0 lg:top-4 lg:block lg:rounded-xl lg:rounded-t-2xl lg:border lg:border-slate-200 lg:bg-slate-100 lg:pb-8 lg:ring-1 lg:ring-white/10"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
/>
|
/>
|
||||||
{getCloudPricingData(t).plans.map((plan) => (
|
{getCloudPricingData(t).plans.map((plan) => (
|
||||||
|
|||||||
+18
-11
@@ -2,6 +2,7 @@ import { getServerSession } from "next-auth";
|
|||||||
import { TEnvironment } from "@formbricks/types/environment";
|
import { TEnvironment } from "@formbricks/types/environment";
|
||||||
import { TSurvey } from "@formbricks/types/surveys/types";
|
import { TSurvey } from "@formbricks/types/surveys/types";
|
||||||
import { TTag } from "@formbricks/types/tags";
|
import { TTag } from "@formbricks/types/tags";
|
||||||
|
import { getDisplaysByContactId } from "@/lib/display/service";
|
||||||
import { getProjectByEnvironmentId } from "@/lib/project/service";
|
import { getProjectByEnvironmentId } from "@/lib/project/service";
|
||||||
import { getResponsesByContactId } from "@/lib/response/service";
|
import { getResponsesByContactId } from "@/lib/response/service";
|
||||||
import { getSurveys } from "@/lib/survey/service";
|
import { getSurveys } from "@/lib/survey/service";
|
||||||
@@ -10,27 +11,34 @@ import { findMatchingLocale } from "@/lib/utils/locale";
|
|||||||
import { getTranslate } from "@/lingodotdev/server";
|
import { getTranslate } from "@/lingodotdev/server";
|
||||||
import { authOptions } from "@/modules/auth/lib/authOptions";
|
import { authOptions } from "@/modules/auth/lib/authOptions";
|
||||||
import { getProjectPermissionByUserId } from "@/modules/ee/teams/lib/roles";
|
import { getProjectPermissionByUserId } from "@/modules/ee/teams/lib/roles";
|
||||||
import { ResponseTimeline } from "./response-timeline";
|
import { ActivityTimeline } from "./activity-timeline";
|
||||||
|
|
||||||
interface ResponseSectionProps {
|
interface ActivitySectionProps {
|
||||||
environment: TEnvironment;
|
environment: TEnvironment;
|
||||||
contactId: string;
|
contactId: string;
|
||||||
environmentTags: TTag[];
|
environmentTags: TTag[];
|
||||||
}
|
}
|
||||||
|
|
||||||
export const ResponseSection = async ({ environment, contactId, environmentTags }: ResponseSectionProps) => {
|
export const ActivitySection = async ({ environment, contactId, environmentTags }: ActivitySectionProps) => {
|
||||||
const responses = await getResponsesByContactId(contactId);
|
const [responses, displays] = await Promise.all([
|
||||||
const surveyIds = responses?.map((response) => response.surveyId) || [];
|
getResponsesByContactId(contactId),
|
||||||
const surveys: TSurvey[] = surveyIds.length === 0 ? [] : ((await getSurveys(environment.id)) ?? []);
|
getDisplaysByContactId(contactId),
|
||||||
const session = await getServerSession(authOptions);
|
]);
|
||||||
|
|
||||||
|
const allSurveyIds = [
|
||||||
|
...new Set([...(responses?.map((r) => r.surveyId) || []), ...displays.map((d) => d.surveyId)]),
|
||||||
|
];
|
||||||
|
|
||||||
|
const surveys: TSurvey[] = allSurveyIds.length === 0 ? [] : ((await getSurveys(environment.id)) ?? []);
|
||||||
|
|
||||||
|
const session = await getServerSession(authOptions);
|
||||||
const t = await getTranslate();
|
const t = await getTranslate();
|
||||||
|
|
||||||
if (!session) {
|
if (!session) {
|
||||||
throw new Error(t("common.session_not_found"));
|
throw new Error(t("common.session_not_found"));
|
||||||
}
|
}
|
||||||
|
|
||||||
const user = await getUser(session.user.id);
|
const user = await getUser(session.user.id);
|
||||||
|
|
||||||
if (!user) {
|
if (!user) {
|
||||||
throw new Error(t("common.user_not_found"));
|
throw new Error(t("common.user_not_found"));
|
||||||
}
|
}
|
||||||
@@ -40,20 +48,19 @@ export const ResponseSection = async ({ environment, contactId, environmentTags
|
|||||||
}
|
}
|
||||||
|
|
||||||
const project = await getProjectByEnvironmentId(environment.id);
|
const project = await getProjectByEnvironmentId(environment.id);
|
||||||
|
|
||||||
if (!project) {
|
if (!project) {
|
||||||
throw new Error(t("common.workspace_not_found"));
|
throw new Error(t("common.workspace_not_found"));
|
||||||
}
|
}
|
||||||
|
|
||||||
const projectPermission = await getProjectPermissionByUserId(session.user.id, project.id);
|
const projectPermission = await getProjectPermissionByUserId(session.user.id, project.id);
|
||||||
|
|
||||||
const locale = await findMatchingLocale();
|
const locale = await findMatchingLocale();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ResponseTimeline
|
<ActivityTimeline
|
||||||
user={user}
|
user={user}
|
||||||
surveys={surveys}
|
surveys={surveys}
|
||||||
responses={responses}
|
responses={responses}
|
||||||
|
displays={displays}
|
||||||
environment={environment}
|
environment={environment}
|
||||||
environmentTags={environmentTags}
|
environmentTags={environmentTags}
|
||||||
locale={locale}
|
locale={locale}
|
||||||
@@ -0,0 +1,138 @@
|
|||||||
|
"use client";
|
||||||
|
|
||||||
|
import { ArrowDownUpIcon } from "lucide-react";
|
||||||
|
import { useEffect, useMemo, useState } from "react";
|
||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { TDisplay } from "@formbricks/types/displays";
|
||||||
|
import { TEnvironment } from "@formbricks/types/environment";
|
||||||
|
import { TResponseWithQuotas } from "@formbricks/types/responses";
|
||||||
|
import { TSurvey } from "@formbricks/types/surveys/types";
|
||||||
|
import { TTag } from "@formbricks/types/tags";
|
||||||
|
import { TUser, TUserLocale } from "@formbricks/types/user";
|
||||||
|
import { useMembershipRole } from "@/lib/membership/hooks/useMembershipRole";
|
||||||
|
import { getAccessFlags } from "@/lib/membership/utils";
|
||||||
|
import { TTeamPermission } from "@/modules/ee/teams/project-teams/types/team";
|
||||||
|
import { getTeamPermissionFlags } from "@/modules/ee/teams/utils/teams";
|
||||||
|
import { EmptyState } from "@/modules/ui/components/empty-state";
|
||||||
|
import { DisplayCard } from "./display-card";
|
||||||
|
import { ResponseSurveyCard } from "./response-survey-card";
|
||||||
|
|
||||||
|
type TTimelineItem =
|
||||||
|
| { type: "display"; data: Pick<TDisplay, "id" | "createdAt" | "surveyId"> }
|
||||||
|
| { type: "response"; data: TResponseWithQuotas };
|
||||||
|
|
||||||
|
interface ActivityTimelineProps {
|
||||||
|
surveys: TSurvey[];
|
||||||
|
user: TUser;
|
||||||
|
responses: TResponseWithQuotas[];
|
||||||
|
displays: Pick<TDisplay, "id" | "createdAt" | "surveyId">[];
|
||||||
|
environment: TEnvironment;
|
||||||
|
environmentTags: TTag[];
|
||||||
|
locale: TUserLocale;
|
||||||
|
projectPermission: TTeamPermission | null;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ActivityTimeline = ({
|
||||||
|
surveys,
|
||||||
|
user,
|
||||||
|
responses: initialResponses,
|
||||||
|
displays,
|
||||||
|
environment,
|
||||||
|
environmentTags,
|
||||||
|
locale,
|
||||||
|
projectPermission,
|
||||||
|
}: ActivityTimelineProps) => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
const [responses, setResponses] = useState(initialResponses);
|
||||||
|
const [isReversed, setIsReversed] = useState(false);
|
||||||
|
|
||||||
|
const { membershipRole } = useMembershipRole(environment.id, user.id);
|
||||||
|
|
||||||
|
const isReadOnly = useMemo(() => {
|
||||||
|
const { isMember } = getAccessFlags(membershipRole);
|
||||||
|
const { hasReadAccess } = getTeamPermissionFlags(projectPermission);
|
||||||
|
return isMember && hasReadAccess;
|
||||||
|
}, [membershipRole, projectPermission]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
setResponses(initialResponses);
|
||||||
|
}, [initialResponses]);
|
||||||
|
|
||||||
|
const updateResponseList = (responseIds: string[]) => {
|
||||||
|
setResponses((prev) => prev.filter((r) => !responseIds.includes(r.id)));
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateResponse = (responseId: string, updatedResponse: TResponseWithQuotas) => {
|
||||||
|
setResponses((prev) => prev.map((r) => (r.id === responseId ? updatedResponse : r)));
|
||||||
|
};
|
||||||
|
|
||||||
|
const timelineItems = useMemo(() => {
|
||||||
|
const displayItems: TTimelineItem[] = displays.map((d) => ({
|
||||||
|
type: "display" as const,
|
||||||
|
data: d,
|
||||||
|
}));
|
||||||
|
|
||||||
|
const responseItems: TTimelineItem[] = responses.map((r) => ({
|
||||||
|
type: "response" as const,
|
||||||
|
data: r,
|
||||||
|
}));
|
||||||
|
|
||||||
|
const merged = [...displayItems, ...responseItems].sort((a, b) => {
|
||||||
|
const aTime = new Date(a.data.createdAt).getTime();
|
||||||
|
const bTime = new Date(b.data.createdAt).getTime();
|
||||||
|
return bTime - aTime;
|
||||||
|
});
|
||||||
|
|
||||||
|
return isReversed ? [...merged].reverse() : merged;
|
||||||
|
}, [displays, responses, isReversed]);
|
||||||
|
|
||||||
|
const toggleSort = () => {
|
||||||
|
setIsReversed((prev) => !prev);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="col-span-3">
|
||||||
|
<div className="flex items-center justify-between pb-6">
|
||||||
|
<h2 className="text-lg font-bold text-slate-700">{t("common.activity")}</h2>
|
||||||
|
<div className="text-right">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
onClick={toggleSort}
|
||||||
|
className="flex items-center px-1 text-slate-800 hover:text-brand-dark">
|
||||||
|
<ArrowDownUpIcon className="inline h-4 w-4" />
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{timelineItems.length === 0 ? (
|
||||||
|
<EmptyState text={t("environments.contacts.no_activity_yet")} />
|
||||||
|
) : (
|
||||||
|
<div className="space-y-4">
|
||||||
|
{timelineItems.map((item) =>
|
||||||
|
item.type === "display" ? (
|
||||||
|
<DisplayCard
|
||||||
|
key={`display-${item.data.id}`}
|
||||||
|
display={item.data}
|
||||||
|
surveys={surveys}
|
||||||
|
environmentId={environment.id}
|
||||||
|
locale={locale}
|
||||||
|
/>
|
||||||
|
) : (
|
||||||
|
<ResponseSurveyCard
|
||||||
|
key={`response-${item.data.id}`}
|
||||||
|
response={item.data}
|
||||||
|
surveys={surveys}
|
||||||
|
user={user}
|
||||||
|
environmentTags={environmentTags}
|
||||||
|
environment={environment}
|
||||||
|
updateResponseList={updateResponseList}
|
||||||
|
updateResponse={updateResponse}
|
||||||
|
locale={locale}
|
||||||
|
isReadOnly={isReadOnly}
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
@@ -1,3 +1,4 @@
|
|||||||
|
import { getDisplaysByContactId } from "@/lib/display/service";
|
||||||
import { getResponsesByContactId } from "@/lib/response/service";
|
import { getResponsesByContactId } from "@/lib/response/service";
|
||||||
import { getTranslate } from "@/lingodotdev/server";
|
import { getTranslate } from "@/lingodotdev/server";
|
||||||
import { getContactAttributesWithKeyInfo } from "@/modules/ee/contacts/lib/contact-attributes";
|
import { getContactAttributesWithKeyInfo } from "@/modules/ee/contacts/lib/contact-attributes";
|
||||||
@@ -17,8 +18,12 @@ export const AttributesSection = async ({ contactId }: { contactId: string }) =>
|
|||||||
throw new Error(t("environments.contacts.contact_not_found"));
|
throw new Error(t("environments.contacts.contact_not_found"));
|
||||||
}
|
}
|
||||||
|
|
||||||
const responses = await getResponsesByContactId(contactId);
|
const [responses, displays] = await Promise.all([
|
||||||
|
getResponsesByContactId(contactId),
|
||||||
|
getDisplaysByContactId(contactId),
|
||||||
|
]);
|
||||||
const numberOfResponses = responses?.length || 0;
|
const numberOfResponses = responses?.length || 0;
|
||||||
|
const numberOfDisplays = displays?.length || 0;
|
||||||
|
|
||||||
const systemAttributes = attributesWithKeyInfo
|
const systemAttributes = attributesWithKeyInfo
|
||||||
.filter((attr) => attr.type === "default")
|
.filter((attr) => attr.type === "default")
|
||||||
@@ -85,6 +90,11 @@ export const AttributesSection = async ({ contactId }: { contactId: string }) =>
|
|||||||
<dt className="text-sm font-medium text-slate-500">{t("common.responses")}</dt>
|
<dt className="text-sm font-medium text-slate-500">{t("common.responses")}</dt>
|
||||||
<dd className="mt-1 text-sm text-slate-900">{numberOfResponses}</dd>
|
<dd className="mt-1 text-sm text-slate-900">{numberOfResponses}</dd>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<dt className="text-sm font-medium text-slate-500">{t("environments.contacts.displays")}</dt>
|
||||||
|
<dd className="mt-1 text-sm text-slate-900">{numberOfDisplays}</dd>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -99,7 +99,7 @@ export const ContactControlBar = ({
|
|||||||
<DeleteDialog
|
<DeleteDialog
|
||||||
open={deleteDialogOpen}
|
open={deleteDialogOpen}
|
||||||
setOpen={setDeleteDialogOpen}
|
setOpen={setDeleteDialogOpen}
|
||||||
deleteWhat="person"
|
deleteWhat={t("common.person")}
|
||||||
onDelete={handleDeletePerson}
|
onDelete={handleDeletePerson}
|
||||||
isDeleting={isDeletingPerson}
|
isDeleting={isDeletingPerson}
|
||||||
text={
|
text={
|
||||||
|
|||||||
@@ -66,7 +66,7 @@ export const DeleteContactButton = ({
|
|||||||
<DeleteDialog
|
<DeleteDialog
|
||||||
open={deleteDialogOpen}
|
open={deleteDialogOpen}
|
||||||
setOpen={setDeleteDialogOpen}
|
setOpen={setDeleteDialogOpen}
|
||||||
deleteWhat="person"
|
deleteWhat={t("common.person")}
|
||||||
onDelete={handleDeletePerson}
|
onDelete={handleDeletePerson}
|
||||||
isDeleting={isDeletingPerson}
|
isDeleting={isDeletingPerson}
|
||||||
text={
|
text={
|
||||||
|
|||||||
@@ -0,0 +1,44 @@
|
|||||||
|
"use client";
|
||||||
|
|
||||||
|
import { EyeIcon } from "lucide-react";
|
||||||
|
import Link from "next/link";
|
||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { TDisplay } from "@formbricks/types/displays";
|
||||||
|
import { TSurvey } from "@formbricks/types/surveys/types";
|
||||||
|
import { TUserLocale } from "@formbricks/types/user";
|
||||||
|
import { timeSince } from "@/lib/time";
|
||||||
|
|
||||||
|
interface DisplayCardProps {
|
||||||
|
display: Pick<TDisplay, "id" | "createdAt" | "surveyId">;
|
||||||
|
surveys: TSurvey[];
|
||||||
|
environmentId: string;
|
||||||
|
locale: TUserLocale;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const DisplayCard = ({ display, surveys, environmentId, locale }: DisplayCardProps) => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
const survey = surveys.find((s) => s.id === display.surveyId);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="flex items-center justify-between rounded-xl border border-slate-200 bg-white p-4 shadow-sm">
|
||||||
|
<div className="flex items-center gap-3">
|
||||||
|
<div className="flex h-8 w-8 items-center justify-center rounded-full bg-slate-100">
|
||||||
|
<EyeIcon className="h-4 w-4 text-slate-600" />
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<p className="text-xs text-slate-500">{t("environments.contacts.survey_viewed")}</p>
|
||||||
|
{survey ? (
|
||||||
|
<Link
|
||||||
|
href={`/environments/${environmentId}/surveys/${survey.id}/summary`}
|
||||||
|
className="text-sm font-medium text-slate-700 hover:underline">
|
||||||
|
{survey.name}
|
||||||
|
</Link>
|
||||||
|
) : (
|
||||||
|
<span className="text-sm font-medium text-slate-500">{t("common.unknown_survey")}</span>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<span className="text-sm text-slate-500">{timeSince(display.createdAt.toString(), locale)}</span>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
@@ -1,125 +0,0 @@
|
|||||||
"use client";
|
|
||||||
|
|
||||||
import { useEffect, useState } from "react";
|
|
||||||
import { useTranslation } from "react-i18next";
|
|
||||||
import { TEnvironment } from "@formbricks/types/environment";
|
|
||||||
import { TResponseWithQuotas } from "@formbricks/types/responses";
|
|
||||||
import { TSurvey } from "@formbricks/types/surveys/types";
|
|
||||||
import { TTag } from "@formbricks/types/tags";
|
|
||||||
import { TUser, TUserLocale } from "@formbricks/types/user";
|
|
||||||
import { useMembershipRole } from "@/lib/membership/hooks/useMembershipRole";
|
|
||||||
import { getAccessFlags } from "@/lib/membership/utils";
|
|
||||||
import { replaceHeadlineRecall } from "@/lib/utils/recall";
|
|
||||||
import { SingleResponseCard } from "@/modules/analysis/components/SingleResponseCard";
|
|
||||||
import { TTeamPermission } from "@/modules/ee/teams/project-teams/types/team";
|
|
||||||
import { getTeamPermissionFlags } from "@/modules/ee/teams/utils/teams";
|
|
||||||
import { EmptyState } from "@/modules/ui/components/empty-state";
|
|
||||||
|
|
||||||
interface ResponseTimelineProps {
|
|
||||||
surveys: TSurvey[];
|
|
||||||
user: TUser;
|
|
||||||
responses: TResponseWithQuotas[];
|
|
||||||
environment: TEnvironment;
|
|
||||||
environmentTags: TTag[];
|
|
||||||
locale: TUserLocale;
|
|
||||||
projectPermission: TTeamPermission | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
export const ResponseFeed = ({
|
|
||||||
responses,
|
|
||||||
environment,
|
|
||||||
surveys,
|
|
||||||
user,
|
|
||||||
environmentTags,
|
|
||||||
locale,
|
|
||||||
projectPermission,
|
|
||||||
}: ResponseTimelineProps) => {
|
|
||||||
const { t } = useTranslation();
|
|
||||||
const [fetchedResponses, setFetchedResponses] = useState(responses);
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
setFetchedResponses(responses);
|
|
||||||
}, [responses]);
|
|
||||||
|
|
||||||
const updateResponseList = (responseIds: string[]) => {
|
|
||||||
setFetchedResponses((prev) => prev.filter((r) => !responseIds.includes(r.id)));
|
|
||||||
};
|
|
||||||
|
|
||||||
const updateResponse = (responseId: string, updatedResponse: TResponseWithQuotas) => {
|
|
||||||
setFetchedResponses((prev) => prev.map((r) => (r.id === responseId ? updatedResponse : r)));
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
|
||||||
<>
|
|
||||||
{fetchedResponses.length === 0 ? (
|
|
||||||
<EmptyState text={t("environments.contacts.no_responses_found")} />
|
|
||||||
) : (
|
|
||||||
fetchedResponses.map((response) => (
|
|
||||||
<ResponseSurveyCard
|
|
||||||
key={response.id}
|
|
||||||
response={response}
|
|
||||||
surveys={surveys}
|
|
||||||
user={user}
|
|
||||||
environmentTags={environmentTags}
|
|
||||||
environment={environment}
|
|
||||||
updateResponseList={updateResponseList}
|
|
||||||
updateResponse={updateResponse}
|
|
||||||
locale={locale}
|
|
||||||
projectPermission={projectPermission}
|
|
||||||
/>
|
|
||||||
))
|
|
||||||
)}
|
|
||||||
</>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
const ResponseSurveyCard = ({
|
|
||||||
response,
|
|
||||||
surveys,
|
|
||||||
user,
|
|
||||||
environmentTags,
|
|
||||||
environment,
|
|
||||||
updateResponseList,
|
|
||||||
updateResponse,
|
|
||||||
locale,
|
|
||||||
projectPermission,
|
|
||||||
}: {
|
|
||||||
response: TResponseWithQuotas;
|
|
||||||
surveys: TSurvey[];
|
|
||||||
user: TUser;
|
|
||||||
environmentTags: TTag[];
|
|
||||||
environment: TEnvironment;
|
|
||||||
updateResponseList: (responseIds: string[]) => void;
|
|
||||||
updateResponse: (responseId: string, response: TResponseWithQuotas) => void;
|
|
||||||
locale: TUserLocale;
|
|
||||||
projectPermission: TTeamPermission | null;
|
|
||||||
}) => {
|
|
||||||
const survey = surveys.find((survey) => {
|
|
||||||
return survey.id === response.surveyId;
|
|
||||||
});
|
|
||||||
|
|
||||||
const { membershipRole } = useMembershipRole(survey?.environmentId || "", user.id);
|
|
||||||
const { isMember } = getAccessFlags(membershipRole);
|
|
||||||
|
|
||||||
const { hasReadAccess } = getTeamPermissionFlags(projectPermission);
|
|
||||||
|
|
||||||
const isReadOnly = isMember && hasReadAccess;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div key={response.id}>
|
|
||||||
{survey && (
|
|
||||||
<SingleResponseCard
|
|
||||||
response={response}
|
|
||||||
survey={replaceHeadlineRecall(survey, "default")}
|
|
||||||
user={user}
|
|
||||||
environmentTags={environmentTags}
|
|
||||||
environment={environment}
|
|
||||||
updateResponseList={updateResponseList}
|
|
||||||
updateResponse={updateResponse}
|
|
||||||
isReadOnly={isReadOnly}
|
|
||||||
locale={locale}
|
|
||||||
/>
|
|
||||||
)}
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
@@ -0,0 +1,51 @@
|
|||||||
|
"use client";
|
||||||
|
|
||||||
|
import { TEnvironment } from "@formbricks/types/environment";
|
||||||
|
import { TResponseWithQuotas } from "@formbricks/types/responses";
|
||||||
|
import { TSurvey } from "@formbricks/types/surveys/types";
|
||||||
|
import { TTag } from "@formbricks/types/tags";
|
||||||
|
import { TUser, TUserLocale } from "@formbricks/types/user";
|
||||||
|
import { replaceHeadlineRecall } from "@/lib/utils/recall";
|
||||||
|
import { SingleResponseCard } from "@/modules/analysis/components/SingleResponseCard";
|
||||||
|
|
||||||
|
interface ResponseSurveyCardProps {
|
||||||
|
response: TResponseWithQuotas;
|
||||||
|
surveys: TSurvey[];
|
||||||
|
user: TUser;
|
||||||
|
environmentTags: TTag[];
|
||||||
|
environment: TEnvironment;
|
||||||
|
updateResponseList: (responseIds: string[]) => void;
|
||||||
|
updateResponse: (responseId: string, response: TResponseWithQuotas) => void;
|
||||||
|
locale: TUserLocale;
|
||||||
|
isReadOnly: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ResponseSurveyCard = ({
|
||||||
|
response,
|
||||||
|
surveys,
|
||||||
|
user,
|
||||||
|
environmentTags,
|
||||||
|
environment,
|
||||||
|
updateResponseList,
|
||||||
|
updateResponse,
|
||||||
|
locale,
|
||||||
|
isReadOnly,
|
||||||
|
}: ResponseSurveyCardProps) => {
|
||||||
|
const survey = surveys.find((s) => s.id === response.surveyId);
|
||||||
|
|
||||||
|
if (!survey) return null;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<SingleResponseCard
|
||||||
|
response={response}
|
||||||
|
survey={replaceHeadlineRecall(survey, "default")}
|
||||||
|
user={user}
|
||||||
|
environmentTags={environmentTags}
|
||||||
|
environment={environment}
|
||||||
|
updateResponseList={updateResponseList}
|
||||||
|
updateResponse={updateResponse}
|
||||||
|
isReadOnly={isReadOnly}
|
||||||
|
locale={locale}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
};
|
||||||
@@ -1,68 +0,0 @@
|
|||||||
"use client";
|
|
||||||
|
|
||||||
import { ArrowDownUpIcon } from "lucide-react";
|
|
||||||
import { useEffect, useState } from "react";
|
|
||||||
import { useTranslation } from "react-i18next";
|
|
||||||
import { TEnvironment } from "@formbricks/types/environment";
|
|
||||||
import { TResponseWithQuotas } from "@formbricks/types/responses";
|
|
||||||
import { TSurvey } from "@formbricks/types/surveys/types";
|
|
||||||
import { TTag } from "@formbricks/types/tags";
|
|
||||||
import { TUser, TUserLocale } from "@formbricks/types/user";
|
|
||||||
import { TTeamPermission } from "@/modules/ee/teams/project-teams/types/team";
|
|
||||||
import { ResponseFeed } from "./response-feed";
|
|
||||||
|
|
||||||
interface ResponseTimelineProps {
|
|
||||||
surveys: TSurvey[];
|
|
||||||
user: TUser;
|
|
||||||
responses: TResponseWithQuotas[];
|
|
||||||
environment: TEnvironment;
|
|
||||||
environmentTags: TTag[];
|
|
||||||
locale: TUserLocale;
|
|
||||||
projectPermission: TTeamPermission | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
export const ResponseTimeline = ({
|
|
||||||
surveys,
|
|
||||||
user,
|
|
||||||
environment,
|
|
||||||
responses,
|
|
||||||
environmentTags,
|
|
||||||
locale,
|
|
||||||
projectPermission,
|
|
||||||
}: ResponseTimelineProps) => {
|
|
||||||
const { t } = useTranslation();
|
|
||||||
const [sortedResponses, setSortedResponses] = useState(responses);
|
|
||||||
const toggleSortResponses = () => {
|
|
||||||
setSortedResponses([...sortedResponses].reverse());
|
|
||||||
};
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
setSortedResponses(responses);
|
|
||||||
}, [responses]);
|
|
||||||
|
|
||||||
return (
|
|
||||||
// <div className="md:col-span-3">
|
|
||||||
<div className="col-span-3">
|
|
||||||
<div className="flex items-center justify-between pb-6">
|
|
||||||
<h2 className="text-lg font-bold text-slate-700">{t("common.responses")}</h2>
|
|
||||||
<div className="text-right">
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
onClick={toggleSortResponses}
|
|
||||||
className="hover:text-brand-dark flex items-center px-1 text-slate-800">
|
|
||||||
<ArrowDownUpIcon className="inline h-4 w-4" />
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<ResponseFeed
|
|
||||||
responses={sortedResponses}
|
|
||||||
environment={environment}
|
|
||||||
surveys={surveys}
|
|
||||||
user={user}
|
|
||||||
environmentTags={environmentTags}
|
|
||||||
locale={locale}
|
|
||||||
projectPermission={projectPermission}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
@@ -11,7 +11,7 @@ import { getEnvironmentAuth } from "@/modules/environments/lib/utils";
|
|||||||
import { GoBackButton } from "@/modules/ui/components/go-back-button";
|
import { GoBackButton } from "@/modules/ui/components/go-back-button";
|
||||||
import { PageContentWrapper } from "@/modules/ui/components/page-content-wrapper";
|
import { PageContentWrapper } from "@/modules/ui/components/page-content-wrapper";
|
||||||
import { PageHeader } from "@/modules/ui/components/page-header";
|
import { PageHeader } from "@/modules/ui/components/page-header";
|
||||||
import { ResponseSection } from "./components/response-section";
|
import { ActivitySection } from "./components/activity-section";
|
||||||
|
|
||||||
export const SingleContactPage = async (props: {
|
export const SingleContactPage = async (props: {
|
||||||
params: Promise<{ environmentId: string; contactId: string }>;
|
params: Promise<{ environmentId: string; contactId: string }>;
|
||||||
@@ -64,7 +64,7 @@ export const SingleContactPage = async (props: {
|
|||||||
<section className="pb-24 pt-6">
|
<section className="pb-24 pt-6">
|
||||||
<div className="grid grid-cols-4 gap-x-8">
|
<div className="grid grid-cols-4 gap-x-8">
|
||||||
<AttributesSection contactId={params.contactId} />
|
<AttributesSection contactId={params.contactId} />
|
||||||
<ResponseSection
|
<ActivitySection
|
||||||
environment={environment}
|
environment={environment}
|
||||||
contactId={params.contactId}
|
contactId={params.contactId}
|
||||||
environmentTags={environmentTags}
|
environmentTags={environmentTags}
|
||||||
|
|||||||
+75
-26
@@ -7,10 +7,9 @@ import { validateInputs } from "@/lib/utils/validate";
|
|||||||
import { segmentFilterToPrismaQuery } from "@/modules/ee/contacts/segments/lib/filter/prisma-query";
|
import { segmentFilterToPrismaQuery } from "@/modules/ee/contacts/segments/lib/filter/prisma-query";
|
||||||
import { getPersonSegmentIds, getSegments } from "./segments";
|
import { getPersonSegmentIds, getSegments } from "./segments";
|
||||||
|
|
||||||
// Mock the cache functions
|
|
||||||
vi.mock("@/lib/cache", () => ({
|
vi.mock("@/lib/cache", () => ({
|
||||||
cache: {
|
cache: {
|
||||||
withCache: vi.fn(async (fn) => await fn()), // Just execute the function without caching for tests
|
withCache: vi.fn(async (fn) => await fn()),
|
||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
|
|
||||||
@@ -30,15 +29,15 @@ vi.mock("@formbricks/database", () => ({
|
|||||||
contact: {
|
contact: {
|
||||||
findFirst: vi.fn(),
|
findFirst: vi.fn(),
|
||||||
},
|
},
|
||||||
|
$transaction: vi.fn(),
|
||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
|
|
||||||
// Mock React cache
|
|
||||||
vi.mock("react", async () => {
|
vi.mock("react", async () => {
|
||||||
const actual = await vi.importActual("react");
|
const actual = await vi.importActual("react");
|
||||||
return {
|
return {
|
||||||
...actual,
|
...actual,
|
||||||
cache: <T extends (...args: any[]) => any>(fn: T): T => fn, // Return the function with the same type signature
|
cache: <T extends (...args: any[]) => any>(fn: T): T => fn,
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -97,22 +96,20 @@ describe("segments lib", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe("getPersonSegmentIds", () => {
|
describe("getPersonSegmentIds", () => {
|
||||||
|
const mockWhereClause = { AND: [{ environmentId: mockEnvironmentId }, {}] };
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
vi.mocked(prisma.segment.findMany).mockResolvedValue(
|
vi.mocked(prisma.segment.findMany).mockResolvedValue(
|
||||||
mockSegmentsData as Prisma.Result<typeof prisma.segment, unknown, "findMany">
|
mockSegmentsData as Prisma.Result<typeof prisma.segment, unknown, "findMany">
|
||||||
);
|
);
|
||||||
vi.mocked(segmentFilterToPrismaQuery).mockResolvedValue({
|
vi.mocked(segmentFilterToPrismaQuery).mockResolvedValue({
|
||||||
ok: true,
|
ok: true,
|
||||||
data: { whereClause: { AND: [{ environmentId: mockEnvironmentId }, {}] } },
|
data: { whereClause: mockWhereClause },
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should return person segment IDs successfully", async () => {
|
test("should return person segment IDs successfully", async () => {
|
||||||
vi.mocked(prisma.contact.findFirst).mockResolvedValue({ id: mockContactId } as Prisma.Result<
|
vi.mocked(prisma.$transaction).mockResolvedValue([{ id: mockContactId }, { id: mockContactId }]);
|
||||||
typeof prisma.contact,
|
|
||||||
unknown,
|
|
||||||
"findFirst"
|
|
||||||
>);
|
|
||||||
|
|
||||||
const result = await getPersonSegmentIds(
|
const result = await getPersonSegmentIds(
|
||||||
mockEnvironmentId,
|
mockEnvironmentId,
|
||||||
@@ -128,12 +125,12 @@ describe("segments lib", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(mockSegmentsData.length);
|
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(mockSegmentsData.length);
|
||||||
expect(prisma.contact.findFirst).toHaveBeenCalledTimes(mockSegmentsData.length);
|
expect(prisma.$transaction).toHaveBeenCalledTimes(1);
|
||||||
expect(result).toEqual(mockSegmentsData.map((s) => s.id));
|
expect(result).toEqual(mockSegmentsData.map((s) => s.id));
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should return empty array if no segments exist", async () => {
|
test("should return empty array if no segments exist", async () => {
|
||||||
vi.mocked(prisma.segment.findMany).mockResolvedValue([]); // No segments
|
vi.mocked(prisma.segment.findMany).mockResolvedValue([]);
|
||||||
|
|
||||||
const result = await getPersonSegmentIds(
|
const result = await getPersonSegmentIds(
|
||||||
mockEnvironmentId,
|
mockEnvironmentId,
|
||||||
@@ -144,10 +141,11 @@ describe("segments lib", () => {
|
|||||||
|
|
||||||
expect(result).toEqual([]);
|
expect(result).toEqual([]);
|
||||||
expect(segmentFilterToPrismaQuery).not.toHaveBeenCalled();
|
expect(segmentFilterToPrismaQuery).not.toHaveBeenCalled();
|
||||||
|
expect(prisma.$transaction).not.toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should return empty array if segments exist but none match", async () => {
|
test("should return empty array if segments exist but none match", async () => {
|
||||||
vi.mocked(prisma.contact.findFirst).mockResolvedValue(null);
|
vi.mocked(prisma.$transaction).mockResolvedValue([null, null]);
|
||||||
|
|
||||||
const result = await getPersonSegmentIds(
|
const result = await getPersonSegmentIds(
|
||||||
mockEnvironmentId,
|
mockEnvironmentId,
|
||||||
@@ -155,16 +153,14 @@ describe("segments lib", () => {
|
|||||||
mockContactUserId,
|
mockContactUserId,
|
||||||
mockDeviceType
|
mockDeviceType
|
||||||
);
|
);
|
||||||
|
|
||||||
expect(result).toEqual([]);
|
expect(result).toEqual([]);
|
||||||
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(mockSegmentsData.length);
|
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(mockSegmentsData.length);
|
||||||
|
expect(prisma.$transaction).toHaveBeenCalledTimes(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("should call validateInputs with correct parameters", async () => {
|
test("should call validateInputs with correct parameters", async () => {
|
||||||
vi.mocked(prisma.contact.findFirst).mockResolvedValue({ id: mockContactId } as Prisma.Result<
|
vi.mocked(prisma.$transaction).mockResolvedValue([{ id: mockContactId }, { id: mockContactId }]);
|
||||||
typeof prisma.contact,
|
|
||||||
unknown,
|
|
||||||
"findFirst"
|
|
||||||
>);
|
|
||||||
|
|
||||||
await getPersonSegmentIds(mockEnvironmentId, mockContactId, mockContactUserId, mockDeviceType);
|
await getPersonSegmentIds(mockEnvironmentId, mockContactId, mockContactUserId, mockDeviceType);
|
||||||
expect(validateInputs).toHaveBeenCalledWith(
|
expect(validateInputs).toHaveBeenCalledWith(
|
||||||
@@ -175,14 +171,7 @@ describe("segments lib", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("should return only matching segment IDs", async () => {
|
test("should return only matching segment IDs", async () => {
|
||||||
// First segment matches, second doesn't
|
vi.mocked(prisma.$transaction).mockResolvedValue([{ id: mockContactId }, null]);
|
||||||
vi.mocked(prisma.contact.findFirst)
|
|
||||||
.mockResolvedValueOnce({ id: mockContactId } as Prisma.Result<
|
|
||||||
typeof prisma.contact,
|
|
||||||
unknown,
|
|
||||||
"findFirst"
|
|
||||||
>) // First segment matches
|
|
||||||
.mockResolvedValueOnce(null); // Second segment does not match
|
|
||||||
|
|
||||||
const result = await getPersonSegmentIds(
|
const result = await getPersonSegmentIds(
|
||||||
mockEnvironmentId,
|
mockEnvironmentId,
|
||||||
@@ -193,6 +182,66 @@ describe("segments lib", () => {
|
|||||||
|
|
||||||
expect(result).toEqual([mockSegmentsData[0].id]);
|
expect(result).toEqual([mockSegmentsData[0].id]);
|
||||||
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(mockSegmentsData.length);
|
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(mockSegmentsData.length);
|
||||||
|
expect(prisma.$transaction).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("should include segments with no filters as always-matching", async () => {
|
||||||
|
const segmentsWithEmptyFilters = [
|
||||||
|
{ id: "segment-no-filter", filters: [] },
|
||||||
|
{ id: "segment-with-filter", filters: [{}] as TBaseFilter[] },
|
||||||
|
];
|
||||||
|
vi.mocked(prisma.segment.findMany).mockResolvedValue(
|
||||||
|
segmentsWithEmptyFilters as Prisma.Result<typeof prisma.segment, unknown, "findMany">
|
||||||
|
);
|
||||||
|
vi.mocked(prisma.$transaction).mockResolvedValue([{ id: mockContactId }]);
|
||||||
|
|
||||||
|
const result = await getPersonSegmentIds(
|
||||||
|
mockEnvironmentId,
|
||||||
|
mockContactId,
|
||||||
|
mockContactUserId,
|
||||||
|
mockDeviceType
|
||||||
|
);
|
||||||
|
|
||||||
|
expect(result).toContain("segment-no-filter");
|
||||||
|
expect(result).toContain("segment-with-filter");
|
||||||
|
expect(segmentFilterToPrismaQuery).toHaveBeenCalledTimes(1);
|
||||||
|
expect(prisma.$transaction).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("should skip segments where filter query building fails", async () => {
|
||||||
|
vi.mocked(segmentFilterToPrismaQuery)
|
||||||
|
.mockResolvedValueOnce({
|
||||||
|
ok: true,
|
||||||
|
data: { whereClause: mockWhereClause },
|
||||||
|
})
|
||||||
|
.mockResolvedValueOnce({
|
||||||
|
ok: false,
|
||||||
|
error: { type: "bad_request", message: "Invalid filters", details: [] },
|
||||||
|
});
|
||||||
|
vi.mocked(prisma.$transaction).mockResolvedValue([{ id: mockContactId }]);
|
||||||
|
|
||||||
|
const result = await getPersonSegmentIds(
|
||||||
|
mockEnvironmentId,
|
||||||
|
mockContactId,
|
||||||
|
mockContactUserId,
|
||||||
|
mockDeviceType
|
||||||
|
);
|
||||||
|
|
||||||
|
expect(result).toEqual(["segment1"]);
|
||||||
|
expect(prisma.$transaction).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("should return empty array on unexpected error", async () => {
|
||||||
|
vi.mocked(prisma.segment.findMany).mockRejectedValue(new Error("Unexpected"));
|
||||||
|
|
||||||
|
const result = await getPersonSegmentIds(
|
||||||
|
mockEnvironmentId,
|
||||||
|
mockContactId,
|
||||||
|
mockContactUserId,
|
||||||
|
mockDeviceType
|
||||||
|
);
|
||||||
|
|
||||||
|
expect(result).toEqual([]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -37,47 +37,6 @@ export const getSegments = reactCache(
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks if a contact matches a segment using Prisma query
|
|
||||||
* This leverages native DB types (valueDate, valueNumber) for accurate comparisons
|
|
||||||
* Device filters are evaluated at query build time using the provided deviceType
|
|
||||||
*/
|
|
||||||
const isContactInSegment = async (
|
|
||||||
contactId: string,
|
|
||||||
segmentId: string,
|
|
||||||
filters: TBaseFilters,
|
|
||||||
environmentId: string,
|
|
||||||
deviceType: "phone" | "desktop"
|
|
||||||
): Promise<boolean> => {
|
|
||||||
// If no filters, segment matches all contacts
|
|
||||||
if (!filters || filters.length === 0) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
const queryResult = await segmentFilterToPrismaQuery(segmentId, filters, environmentId, deviceType);
|
|
||||||
|
|
||||||
if (!queryResult.ok) {
|
|
||||||
logger.warn(
|
|
||||||
{ segmentId, environmentId, error: queryResult.error },
|
|
||||||
"Failed to build Prisma query for segment"
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const { whereClause } = queryResult.data;
|
|
||||||
|
|
||||||
// Check if this specific contact matches the segment filters
|
|
||||||
const matchingContact = await prisma.contact.findFirst({
|
|
||||||
where: {
|
|
||||||
id: contactId,
|
|
||||||
...whereClause,
|
|
||||||
},
|
|
||||||
select: { id: true },
|
|
||||||
});
|
|
||||||
|
|
||||||
return matchingContact !== null;
|
|
||||||
};
|
|
||||||
|
|
||||||
export const getPersonSegmentIds = async (
|
export const getPersonSegmentIds = async (
|
||||||
environmentId: string,
|
environmentId: string,
|
||||||
contactId: string,
|
contactId: string,
|
||||||
@@ -89,29 +48,58 @@ export const getPersonSegmentIds = async (
|
|||||||
|
|
||||||
const segments = await getSegments(environmentId);
|
const segments = await getSegments(environmentId);
|
||||||
|
|
||||||
// fast path; if there are no segments, return an empty array
|
if (!segments || !Array.isArray(segments) || segments.length === 0) {
|
||||||
if (!segments || !Array.isArray(segments)) {
|
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
// Device filters are evaluated at query build time using the provided deviceType
|
// Phase 1: Build WHERE clauses sequentially to avoid connection pool contention.
|
||||||
const segmentPromises = segments.map(async (segment) => {
|
// segmentFilterToPrismaQuery can itself hit the DB (e.g. unmigrated-row checks),
|
||||||
const filters = segment.filters;
|
// so running all builds concurrently would saturate the pool.
|
||||||
const isIncluded = await isContactInSegment(contactId, segment.id, filters, environmentId, deviceType);
|
const alwaysMatchIds: string[] = [];
|
||||||
return isIncluded ? segment.id : null;
|
const dbChecks: { segmentId: string; whereClause: Prisma.ContactWhereInput }[] = [];
|
||||||
});
|
|
||||||
|
|
||||||
const results = await Promise.all(segmentPromises);
|
for (const segment of segments) {
|
||||||
|
const filters = segment.filters as TBaseFilters;
|
||||||
|
|
||||||
return results.filter((id): id is string => id !== null);
|
if (!filters?.length) {
|
||||||
|
alwaysMatchIds.push(segment.id);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const queryResult = await segmentFilterToPrismaQuery(segment.id, filters, environmentId, deviceType);
|
||||||
|
|
||||||
|
if (!queryResult.ok) {
|
||||||
|
logger.warn(
|
||||||
|
{ segmentId: segment.id, environmentId, error: queryResult.error },
|
||||||
|
"Failed to build Prisma query for segment, skipping"
|
||||||
|
);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
dbChecks.push({ segmentId: segment.id, whereClause: queryResult.data.whereClause });
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dbChecks.length === 0) {
|
||||||
|
return alwaysMatchIds;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Phase 2: Execute all membership checks in a single transaction.
|
||||||
|
// Uses one connection instead of N concurrent ones, eliminating pool contention.
|
||||||
|
const txResults = await prisma.$transaction(
|
||||||
|
dbChecks.map(({ whereClause }) =>
|
||||||
|
prisma.contact.findFirst({
|
||||||
|
where: { id: contactId, ...whereClause },
|
||||||
|
select: { id: true },
|
||||||
|
})
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
const matchedIds = dbChecks.filter((_, i) => txResults[i] !== null).map(({ segmentId }) => segmentId);
|
||||||
|
|
||||||
|
return [...alwaysMatchIds, ...matchedIds];
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Log error for debugging but don't throw to prevent "segments is not iterable" error
|
|
||||||
logger.warn(
|
logger.warn(
|
||||||
{
|
{ environmentId, contactId, error },
|
||||||
environmentId,
|
|
||||||
contactId,
|
|
||||||
error,
|
|
||||||
},
|
|
||||||
"Failed to get person segment IDs, returning empty array"
|
"Failed to get person segment IDs, returning empty array"
|
||||||
);
|
);
|
||||||
return [];
|
return [];
|
||||||
|
|||||||
-139
@@ -1,139 +0,0 @@
|
|||||||
import { afterEach, beforeEach, describe, expect, test, vi } from "vitest";
|
|
||||||
import { prisma } from "@formbricks/database";
|
|
||||||
import { TJsPersonState } from "@formbricks/types/js";
|
|
||||||
import { getPersonSegmentIds } from "./segments";
|
|
||||||
import { getUserState } from "./user-state";
|
|
||||||
|
|
||||||
vi.mock("@formbricks/database", () => ({
|
|
||||||
prisma: {
|
|
||||||
contact: {
|
|
||||||
findUniqueOrThrow: vi.fn(),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}));
|
|
||||||
|
|
||||||
vi.mock("./segments", () => ({
|
|
||||||
getPersonSegmentIds: vi.fn(),
|
|
||||||
}));
|
|
||||||
|
|
||||||
const mockEnvironmentId = "test-environment-id";
|
|
||||||
const mockUserId = "test-user-id";
|
|
||||||
const mockContactId = "test-contact-id";
|
|
||||||
const mockDevice = "desktop";
|
|
||||||
|
|
||||||
describe("getUserState", () => {
|
|
||||||
beforeEach(() => {
|
|
||||||
vi.clearAllMocks();
|
|
||||||
});
|
|
||||||
|
|
||||||
afterEach(() => {
|
|
||||||
vi.clearAllMocks();
|
|
||||||
});
|
|
||||||
|
|
||||||
test("should return user state with empty responses and displays", async () => {
|
|
||||||
const mockContactData = {
|
|
||||||
id: mockContactId,
|
|
||||||
responses: [],
|
|
||||||
displays: [],
|
|
||||||
};
|
|
||||||
vi.mocked(prisma.contact.findUniqueOrThrow).mockResolvedValue(mockContactData as any);
|
|
||||||
vi.mocked(getPersonSegmentIds).mockResolvedValue(["segment1"]);
|
|
||||||
|
|
||||||
const result = await getUserState({
|
|
||||||
environmentId: mockEnvironmentId,
|
|
||||||
userId: mockUserId,
|
|
||||||
contactId: mockContactId,
|
|
||||||
device: mockDevice,
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(prisma.contact.findUniqueOrThrow).toHaveBeenCalledWith({
|
|
||||||
where: { id: mockContactId },
|
|
||||||
select: {
|
|
||||||
id: true,
|
|
||||||
responses: {
|
|
||||||
select: { surveyId: true },
|
|
||||||
},
|
|
||||||
displays: {
|
|
||||||
select: { surveyId: true, createdAt: true },
|
|
||||||
orderBy: { createdAt: "desc" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
expect(getPersonSegmentIds).toHaveBeenCalledWith(
|
|
||||||
mockEnvironmentId,
|
|
||||||
mockContactId,
|
|
||||||
mockUserId,
|
|
||||||
mockDevice
|
|
||||||
);
|
|
||||||
expect(result).toEqual<TJsPersonState["data"]>({
|
|
||||||
contactId: mockContactId,
|
|
||||||
userId: mockUserId,
|
|
||||||
segments: ["segment1"],
|
|
||||||
displays: [],
|
|
||||||
responses: [],
|
|
||||||
lastDisplayAt: null,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
test("should return user state with responses and displays, and sort displays by createdAt", async () => {
|
|
||||||
const mockDate1 = new Date("2023-01-01T00:00:00.000Z");
|
|
||||||
const mockDate2 = new Date("2023-01-02T00:00:00.000Z");
|
|
||||||
|
|
||||||
const mockContactData = {
|
|
||||||
id: mockContactId,
|
|
||||||
responses: [{ surveyId: "survey1" }, { surveyId: "survey2" }],
|
|
||||||
displays: [
|
|
||||||
{ surveyId: "survey4", createdAt: mockDate2 }, // most recent (already sorted by desc)
|
|
||||||
{ surveyId: "survey3", createdAt: mockDate1 },
|
|
||||||
],
|
|
||||||
};
|
|
||||||
vi.mocked(prisma.contact.findUniqueOrThrow).mockResolvedValue(mockContactData as any);
|
|
||||||
vi.mocked(getPersonSegmentIds).mockResolvedValue(["segment2", "segment3"]);
|
|
||||||
|
|
||||||
const result = await getUserState({
|
|
||||||
environmentId: mockEnvironmentId,
|
|
||||||
userId: mockUserId,
|
|
||||||
contactId: mockContactId,
|
|
||||||
device: mockDevice,
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(result).toEqual<TJsPersonState["data"]>({
|
|
||||||
contactId: mockContactId,
|
|
||||||
userId: mockUserId,
|
|
||||||
segments: ["segment2", "segment3"],
|
|
||||||
displays: [
|
|
||||||
{ surveyId: "survey4", createdAt: mockDate2 },
|
|
||||||
{ surveyId: "survey3", createdAt: mockDate1 },
|
|
||||||
],
|
|
||||||
responses: ["survey1", "survey2"],
|
|
||||||
lastDisplayAt: mockDate2,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
test("should handle empty arrays from prisma", async () => {
|
|
||||||
// This case tests with proper empty arrays instead of null
|
|
||||||
const mockContactData = {
|
|
||||||
id: mockContactId,
|
|
||||||
responses: [],
|
|
||||||
displays: [],
|
|
||||||
};
|
|
||||||
vi.mocked(prisma.contact.findUniqueOrThrow).mockResolvedValue(mockContactData as any);
|
|
||||||
vi.mocked(getPersonSegmentIds).mockResolvedValue([]);
|
|
||||||
|
|
||||||
const result = await getUserState({
|
|
||||||
environmentId: mockEnvironmentId,
|
|
||||||
userId: mockUserId,
|
|
||||||
contactId: mockContactId,
|
|
||||||
device: mockDevice,
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(result).toEqual<TJsPersonState["data"]>({
|
|
||||||
contactId: mockContactId,
|
|
||||||
userId: mockUserId,
|
|
||||||
segments: [],
|
|
||||||
displays: [],
|
|
||||||
responses: [],
|
|
||||||
lastDisplayAt: null,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
@@ -1,80 +0,0 @@
|
|||||||
import { prisma } from "@formbricks/database";
|
|
||||||
import { TJsPersonState } from "@formbricks/types/js";
|
|
||||||
import { getPersonSegmentIds } from "./segments";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Optimized single query to get all user state data
|
|
||||||
* Replaces multiple separate queries with one efficient query
|
|
||||||
*/
|
|
||||||
const getUserStateDataOptimized = async (contactId: string) => {
|
|
||||||
return prisma.contact.findUniqueOrThrow({
|
|
||||||
where: { id: contactId },
|
|
||||||
select: {
|
|
||||||
id: true,
|
|
||||||
responses: {
|
|
||||||
select: { surveyId: true },
|
|
||||||
},
|
|
||||||
displays: {
|
|
||||||
select: {
|
|
||||||
surveyId: true,
|
|
||||||
createdAt: true,
|
|
||||||
},
|
|
||||||
orderBy: { createdAt: "desc" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Optimized user state fetcher without caching
|
|
||||||
* Uses single database query and efficient data processing
|
|
||||||
* NO CACHING - user state changes frequently with contact updates
|
|
||||||
*
|
|
||||||
* @param environmentId - The environment id
|
|
||||||
* @param userId - The user id
|
|
||||||
* @param device - The device type
|
|
||||||
* @returns The person state
|
|
||||||
* @throws {ValidationError} - If the input is invalid
|
|
||||||
* @throws {ResourceNotFoundError} - If the environment or organization is not found
|
|
||||||
*/
|
|
||||||
export const getUserState = async ({
|
|
||||||
environmentId,
|
|
||||||
userId,
|
|
||||||
contactId,
|
|
||||||
device,
|
|
||||||
}: {
|
|
||||||
environmentId: string;
|
|
||||||
userId: string;
|
|
||||||
contactId: string;
|
|
||||||
device: "phone" | "desktop";
|
|
||||||
}): Promise<TJsPersonState["data"]> => {
|
|
||||||
// Single optimized query for all contact data
|
|
||||||
const contactData = await getUserStateDataOptimized(contactId);
|
|
||||||
|
|
||||||
// Get segments using Prisma-based evaluation (no attributes needed - fetched from DB)
|
|
||||||
const segments = await getPersonSegmentIds(environmentId, contactId, userId, device);
|
|
||||||
|
|
||||||
// Process displays efficiently
|
|
||||||
const displays = (contactData.displays ?? []).map((display) => ({
|
|
||||||
surveyId: display.surveyId,
|
|
||||||
createdAt: display.createdAt,
|
|
||||||
}));
|
|
||||||
|
|
||||||
// Get latest display date
|
|
||||||
const lastDisplayAt =
|
|
||||||
contactData.displays && contactData.displays.length > 0 ? contactData.displays[0].createdAt : null;
|
|
||||||
|
|
||||||
// Process responses efficiently
|
|
||||||
const responses = (contactData.responses ?? []).map((response) => response.surveyId);
|
|
||||||
|
|
||||||
const userState: TJsPersonState["data"] = {
|
|
||||||
contactId,
|
|
||||||
userId,
|
|
||||||
segments,
|
|
||||||
displays,
|
|
||||||
responses,
|
|
||||||
lastDisplayAt,
|
|
||||||
};
|
|
||||||
|
|
||||||
return userState;
|
|
||||||
};
|
|
||||||
@@ -46,7 +46,7 @@ export const generateAttributeTableColumns = (
|
|||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
const description = row.original.description;
|
const description = row.original.description;
|
||||||
return description ? (
|
return description ? (
|
||||||
<div className={isExpanded ? "break-words whitespace-normal" : "truncate"}>
|
<div className={isExpanded ? "whitespace-normal break-words" : "truncate"}>
|
||||||
<HighlightedText value={description} searchValue={searchValue} />
|
<HighlightedText value={description} searchValue={searchValue} />
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
import { getLocale } from "@/lingodotdev/language";
|
import { getLocale } from "@/lingodotdev/language";
|
||||||
|
import { getTranslate } from "@/lingodotdev/server";
|
||||||
import { ContactsPageLayout } from "@/modules/ee/contacts/components/contacts-page-layout";
|
import { ContactsPageLayout } from "@/modules/ee/contacts/components/contacts-page-layout";
|
||||||
import { getContactAttributeKeys } from "@/modules/ee/contacts/lib/contact-attribute-keys";
|
import { getContactAttributeKeys } from "@/modules/ee/contacts/lib/contact-attribute-keys";
|
||||||
import { getIsContactsEnabled } from "@/modules/ee/license-check/lib/utils";
|
import { getIsContactsEnabled } from "@/modules/ee/license-check/lib/utils";
|
||||||
@@ -13,7 +14,7 @@ export const AttributesPage = async ({
|
|||||||
}) => {
|
}) => {
|
||||||
const params = await paramsProps;
|
const params = await paramsProps;
|
||||||
const locale = await getLocale();
|
const locale = await getLocale();
|
||||||
|
const t = await getTranslate();
|
||||||
const [{ isReadOnly }, contactAttributeKeys] = await Promise.all([
|
const [{ isReadOnly }, contactAttributeKeys] = await Promise.all([
|
||||||
getEnvironmentAuth(params.environmentId),
|
getEnvironmentAuth(params.environmentId),
|
||||||
getContactAttributeKeys(params.environmentId),
|
getContactAttributeKeys(params.environmentId),
|
||||||
@@ -23,7 +24,7 @@ export const AttributesPage = async ({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<ContactsPageLayout
|
<ContactsPageLayout
|
||||||
pageTitle="Contacts"
|
pageTitle={t("common.contacts")}
|
||||||
activeId="attributes"
|
activeId="attributes"
|
||||||
environmentId={params.environmentId}
|
environmentId={params.environmentId}
|
||||||
isContactsEnabled={isContactsEnabled}
|
isContactsEnabled={isContactsEnabled}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
"use client";
|
"use client";
|
||||||
|
|
||||||
import { ColumnDef } from "@tanstack/react-table";
|
import { ColumnDef } from "@tanstack/react-table";
|
||||||
|
import { TFunction } from "i18next";
|
||||||
import { formatAttributeValue } from "@/modules/ee/contacts/lib/format-attribute-value";
|
import { formatAttributeValue } from "@/modules/ee/contacts/lib/format-attribute-value";
|
||||||
import { getSelectionColumn } from "@/modules/ui/components/data-table";
|
import { getSelectionColumn } from "@/modules/ui/components/data-table";
|
||||||
import { HighlightedText } from "@/modules/ui/components/highlighted-text";
|
import { HighlightedText } from "@/modules/ui/components/highlighted-text";
|
||||||
@@ -10,12 +11,13 @@ import { TContactTableData } from "../types/contact";
|
|||||||
export const generateContactTableColumns = (
|
export const generateContactTableColumns = (
|
||||||
searchValue: string,
|
searchValue: string,
|
||||||
data: TContactTableData[],
|
data: TContactTableData[],
|
||||||
isReadOnly: boolean
|
isReadOnly: boolean,
|
||||||
|
t: TFunction
|
||||||
): ColumnDef<TContactTableData>[] => {
|
): ColumnDef<TContactTableData>[] => {
|
||||||
const userColumn: ColumnDef<TContactTableData> = {
|
const userColumn: ColumnDef<TContactTableData> = {
|
||||||
id: "contactsTableUser",
|
id: "contactsTableUser",
|
||||||
accessorKey: "contactsTableUser",
|
accessorKey: "contactsTableUser",
|
||||||
header: "ID",
|
header: t("common.id"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
const contactId = row.original.id;
|
const contactId = row.original.id;
|
||||||
return <HighlightedText value={contactId} searchValue={searchValue} />;
|
return <HighlightedText value={contactId} searchValue={searchValue} />;
|
||||||
@@ -25,7 +27,7 @@ export const generateContactTableColumns = (
|
|||||||
const userIdColumn: ColumnDef<TContactTableData> = {
|
const userIdColumn: ColumnDef<TContactTableData> = {
|
||||||
id: "userId",
|
id: "userId",
|
||||||
accessorKey: "userId",
|
accessorKey: "userId",
|
||||||
header: "User ID",
|
header: t("common.user_id"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
const userId = row.original.userId;
|
const userId = row.original.userId;
|
||||||
return <IdBadge id={userId} />;
|
return <IdBadge id={userId} />;
|
||||||
@@ -35,7 +37,7 @@ export const generateContactTableColumns = (
|
|||||||
const emailColumn: ColumnDef<TContactTableData> = {
|
const emailColumn: ColumnDef<TContactTableData> = {
|
||||||
id: "email",
|
id: "email",
|
||||||
accessorKey: "email",
|
accessorKey: "email",
|
||||||
header: "Email",
|
header: t("common.email"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
const email = row.original.email;
|
const email = row.original.email;
|
||||||
if (email) {
|
if (email) {
|
||||||
@@ -47,7 +49,7 @@ export const generateContactTableColumns = (
|
|||||||
const firstNameColumn: ColumnDef<TContactTableData> = {
|
const firstNameColumn: ColumnDef<TContactTableData> = {
|
||||||
id: "firstName",
|
id: "firstName",
|
||||||
accessorKey: "firstName",
|
accessorKey: "firstName",
|
||||||
header: "First Name",
|
header: t("common.first_name"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
const firstName = row.original.firstName;
|
const firstName = row.original.firstName;
|
||||||
return <HighlightedText value={firstName} searchValue={searchValue} />;
|
return <HighlightedText value={firstName} searchValue={searchValue} />;
|
||||||
@@ -57,7 +59,7 @@ export const generateContactTableColumns = (
|
|||||||
const lastNameColumn: ColumnDef<TContactTableData> = {
|
const lastNameColumn: ColumnDef<TContactTableData> = {
|
||||||
id: "lastName",
|
id: "lastName",
|
||||||
accessorKey: "lastName",
|
accessorKey: "lastName",
|
||||||
header: "Last Name",
|
header: t("common.last_name"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
const lastName = row.original.lastName;
|
const lastName = row.original.lastName;
|
||||||
return <HighlightedText value={lastName} searchValue={searchValue} />;
|
return <HighlightedText value={lastName} searchValue={searchValue} />;
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ export const ContactsTable = ({
|
|||||||
|
|
||||||
// Generate columns
|
// Generate columns
|
||||||
const columns = useMemo(() => {
|
const columns = useMemo(() => {
|
||||||
return generateContactTableColumns(searchValue, data, isReadOnly);
|
return generateContactTableColumns(searchValue, data, isReadOnly, t);
|
||||||
}, [searchValue, data, isReadOnly]);
|
}, [searchValue, data, isReadOnly]);
|
||||||
|
|
||||||
// Load saved settings from localStorage
|
// Load saved settings from localStorage
|
||||||
|
|||||||
@@ -132,7 +132,7 @@ export const UploadContactsAttributes = ({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<span className="overflow-hidden font-medium text-ellipsis text-slate-700">{csvColumn}</span>
|
<span className="overflow-hidden text-ellipsis font-medium text-slate-700">{csvColumn}</span>
|
||||||
<div className="flex items-center gap-2">
|
<div className="flex items-center gap-2">
|
||||||
<UploadContactsAttributeCombobox
|
<UploadContactsAttributeCombobox
|
||||||
open={open}
|
open={open}
|
||||||
|
|||||||
@@ -682,10 +682,18 @@ export const createContactsFromCSV = async (
|
|||||||
environmentId,
|
environmentId,
|
||||||
};
|
};
|
||||||
|
|
||||||
const contactPromises = csvData.map((record) => processCsvRecord(record, processingContext));
|
const CHUNK_SIZE = 50;
|
||||||
|
const allResults: (TContact | null)[] = [];
|
||||||
|
|
||||||
const results = await Promise.all(contactPromises);
|
for (let i = 0; i < csvData.length; i += CHUNK_SIZE) {
|
||||||
return { contacts: results.filter((contact): contact is TContact => contact !== null) };
|
const chunk = csvData.slice(i, i + CHUNK_SIZE);
|
||||||
|
const chunkResults = await Promise.all(
|
||||||
|
chunk.map((record) => processCsvRecord(record, processingContext))
|
||||||
|
);
|
||||||
|
allResults.push(...chunkResults);
|
||||||
|
}
|
||||||
|
|
||||||
|
return { contacts: allResults.filter((contact): contact is TContact => contact !== null) };
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (error instanceof Prisma.PrismaClientKnownRequestError) {
|
if (error instanceof Prisma.PrismaClientKnownRequestError) {
|
||||||
throw new DatabaseError(error.message);
|
throw new DatabaseError(error.message);
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ export const EditSegmentModal = ({
|
|||||||
key={tab.title}
|
key={tab.title}
|
||||||
className={`mr-4 px-1 pb-3 focus:outline-none ${
|
className={`mr-4 px-1 pb-3 focus:outline-none ${
|
||||||
activeTab === index
|
activeTab === index
|
||||||
? "border-brand-dark border-b-2 font-semibold text-slate-900"
|
? "border-b-2 border-brand-dark font-semibold text-slate-900"
|
||||||
: "text-slate-500 hover:text-slate-700"
|
: "text-slate-500 hover:text-slate-700"
|
||||||
}`}
|
}`}
|
||||||
onClick={() => handleTabClick(index)}>
|
onClick={() => handleTabClick(index)}>
|
||||||
|
|||||||
@@ -2,14 +2,15 @@
|
|||||||
|
|
||||||
import { ColumnDef } from "@tanstack/react-table";
|
import { ColumnDef } from "@tanstack/react-table";
|
||||||
import { format, formatDistanceToNow } from "date-fns";
|
import { format, formatDistanceToNow } from "date-fns";
|
||||||
|
import { TFunction } from "i18next";
|
||||||
import { UsersIcon } from "lucide-react";
|
import { UsersIcon } from "lucide-react";
|
||||||
import { TSegmentWithSurveyNames } from "@formbricks/types/segment";
|
import { TSegmentWithSurveyNames } from "@formbricks/types/segment";
|
||||||
|
|
||||||
export const generateSegmentTableColumns = (): ColumnDef<TSegmentWithSurveyNames>[] => {
|
export const generateSegmentTableColumns = (t: TFunction): ColumnDef<TSegmentWithSurveyNames>[] => {
|
||||||
const titleColumn: ColumnDef<TSegmentWithSurveyNames> = {
|
const titleColumn: ColumnDef<TSegmentWithSurveyNames> = {
|
||||||
id: "title",
|
id: "title",
|
||||||
accessorKey: "title",
|
accessorKey: "title",
|
||||||
header: "Title",
|
header: t("common.title"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
return (
|
return (
|
||||||
<div className="flex items-center gap-4">
|
<div className="flex items-center gap-4">
|
||||||
@@ -30,7 +31,7 @@ export const generateSegmentTableColumns = (): ColumnDef<TSegmentWithSurveyNames
|
|||||||
const updatedAtColumn: ColumnDef<TSegmentWithSurveyNames> = {
|
const updatedAtColumn: ColumnDef<TSegmentWithSurveyNames> = {
|
||||||
id: "updatedAt",
|
id: "updatedAt",
|
||||||
accessorKey: "updatedAt",
|
accessorKey: "updatedAt",
|
||||||
header: "Updated",
|
header: t("common.updated_at"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
return (
|
return (
|
||||||
<span className="text-sm text-slate-900">
|
<span className="text-sm text-slate-900">
|
||||||
@@ -43,7 +44,7 @@ export const generateSegmentTableColumns = (): ColumnDef<TSegmentWithSurveyNames
|
|||||||
const createdAtColumn: ColumnDef<TSegmentWithSurveyNames> = {
|
const createdAtColumn: ColumnDef<TSegmentWithSurveyNames> = {
|
||||||
id: "createdAt",
|
id: "createdAt",
|
||||||
accessorKey: "createdAt",
|
accessorKey: "createdAt",
|
||||||
header: "Created",
|
header: t("common.created_at"),
|
||||||
cell: ({ row }) => {
|
cell: ({ row }) => {
|
||||||
return (
|
return (
|
||||||
<span className="text-sm text-slate-900">{format(row.original.createdAt, "do 'of' MMMM, yyyy")}</span>
|
<span className="text-sm text-slate-900">{format(row.original.createdAt, "do 'of' MMMM, yyyy")}</span>
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user