cal.pub0.org/packages/emails/src/templates/DisabledAppEmail.tsx

86 lines
2.5 KiB
TypeScript
Raw Normal View History

Admin apps UI (#5494) * Abstract app category navigation * Send key schema to frontend Co-authored-by: Omar López <zomars@users.noreply.github.com> * Render keys for apps on admin * Add enabled col for apps * Save app keys to DB * Add checks for admin role * Abstract setup components * Add AdminAppsList to setup wizard * Migrate to v10 tRPC * Default hide keys * Display enabled apps * Merge branch 'main' into admin-apps-ui * Toggle calendars * WIP * Add params and include AppCategoryNavigation * Refactor getEnabledApps * Add warning for disabling apps * Fallback to cal video when a video app is disabled * WIP send disabled email * Send email to all users of event types with payment app * Disable Stripe when app is disabled * Disable apps in event types * Send email to users on disabled apps * Send email based on what app was disabled * WIP type fix * Disable navigation to apps list if already setup * UI import fixes * Waits for session data before redirecting * Updates admin seeded password To comply with admin password requirements * Update yarn.lock * Flex fixes * Adds admin middleware * Clean up * WIP * WIP * NTS * Add dirName to app metadata * Upsert app if not in db * Upsert app if not in db * Add dirName to app metadata * Add keys to app packages w/ keys * Merge with main * Toggle show keys & on enable * Fix empty keys * Fix lark calendar metadata * Fix some type errors * Fix Lark metadata & check for category when upserting * More type fixes * Fix types & add keys to google cal * WIP * WIP * WIP * More type fixes * Fix type errors * Fix type errors * More type fixes * More type fixes * More type fixes * Feedback * Fixes default value * Feedback * Migrate credential invalid col default value "false" * Upsert app on saving keys * Clean up * Validate app keys on frontend * Add nonempty to app keys schemas * Add web3 * Listlocale filter on categories / category * Grab app metadata via category or categories * Show empty screen if no apps are enabled * Fix type checks * Fix type checks * Fix type checks * Fix type checks * Fix type checks * Fix type checks * Replace .nonempty() w/ .min(1) * Fix type error * Address feedback * Added migration to keep current apps enabled * Update apps.tsx * Fix bug * Add keys schema to Plausible app * Add appKeysSchema to zod.ts template * Update AdminAppsList.tsx Co-authored-by: Omar López <zomars@users.noreply.github.com> Co-authored-by: Peer Richelsen <peeroke@gmail.com> Co-authored-by: zomars <zomars@me.com> Co-authored-by: sean-brydon <55134778+sean-brydon@users.noreply.github.com>
2022-12-07 21:47:02 +00:00
import { TFunction } from "next-i18next";
import { CAL_URL } from "@calcom/lib/constants";
import { BaseEmailHtml, CallToAction } from "../components";
export const DisabledAppEmail = (
props: {
appName: string;
appType: string[];
t: TFunction;
title?: string;
eventTypeId?: number;
} & Partial<React.ComponentProps<typeof BaseEmailHtml>>
) => {
const { title, appName, eventTypeId, t, appType } = props;
return (
<BaseEmailHtml subject={t("app_disabled", { appName: appName })}>
{appType.some((type) => type === "payment") ? (
<>
<p>
<>{t("disabled_app_affects_event_type", { appName: appName, eventType: title })}</>
</p>
<p style={{ fontWeight: 400, lineHeight: "24px" }}>
<>{t("payment_disabled_still_able_to_book")}</>
</p>
<hr style={{ marginBottom: "24px" }} />
<CallToAction
label={t("edit_event_type")}
href={`${CAL_URL}/event-types/${eventTypeId}?tabName=apps`}
/>
</>
) : title && eventTypeId ? (
<>
<p>
<>{(t("app_disabled_with_event_type"), { appName: appName, title: title })}</>
</p>
<hr style={{ marginBottom: "24px" }} />
<CallToAction
label={t("edit_event_type")}
href={`${CAL_URL}/event-types/${eventTypeId}?tabName=apps`}
/>
</>
) : appType.some((type) => type === "video") ? (
<>
<p>
<>{t("app_disabled_video", { appName: appName })}</>
</p>
<hr style={{ marginBottom: "24px" }} />
<CallToAction label={t("navigate_installed_apps")} href={`${CAL_URL}/apps/installed`} />
</>
) : appType.some((type) => type === "calendar") ? (
<>
<p>
<>{t("admin_has_disabled", { appName: appName })}</>
</p>
<p style={{ fontWeight: 400, lineHeight: "24px" }}>
<>{t("disabled_calendar")}</>
</p>
<hr style={{ marginBottom: "24px" }} />
<CallToAction label={t("navigate_installed_apps")} href={`${CAL_URL}/apps/installed`} />
</>
) : (
<>
<p>
<>{t("admin_has_disabled", { appName: appName })}</>
</p>
<hr style={{ marginBottom: "24px" }} />
<CallToAction label={t("navigate_installed_apps")} href={`${CAL_URL}/apps/installed`} />
</>
)}
</BaseEmailHtml>
);
};