817e20f11e
* Add payment option to schema * Add payment option to Stripe zod * Set payment option on event type * Create manual payment intent in Stripe * Set payment option from Stripe app * Add payment option to DB * Pass React.ReactNode to checkbox * Create uncaptured payment intent * WIP * Capture card in setup intent * Show charge card option * Charge card from booking page * Bug fixes * Clean up * Clean up app card * Add no-show fee messaging on booking page * Send payment email on payment & add price * Fix messaging * Create no show fee charged email * Send charge fee collected email * Disable submit on card failure * Clean up * Serverside prevent charging card again if already charged * Only confirm booking if paid for * Type fixes * More type fixes * More type fixes * Type fix * Type fixes * UI changes * Payment component rework * Update apps/web/public/static/locales/en/common.json Co-authored-by: Alex van Andel <me@alexvanandel.com> * Update apps/web/public/static/locales/en/common.json Co-authored-by: Alex van Andel <me@alexvanandel.com> * Update apps/web/components/dialog/ChargeCardDialog.tsx Co-authored-by: Alex van Andel <me@alexvanandel.com> * Update packages/trpc/server/routers/viewer/payments.tsx Co-authored-by: Alex van Andel <me@alexvanandel.com> * Revert GTM config * Adjust payment option dropdown * Show alert when seats are set * Small bug fixes * Create collect card method * clean up * Prevent seats & charge no-show fee to be enabled together * Do not charge no-show fee on unconfirmed bookings * Add check to collect card method * Webhook send request emails * Fix some dark mode colours * Change awaiting payment language * Type fixes * Set height of Select and TextField both to 38px to fix alignment * Fix message seats & payment error message * Type fix --------- Co-authored-by: Alex van Andel <me@alexvanandel.com>
47 lines
1.8 KiB
TypeScript
47 lines
1.8 KiB
TypeScript
import type { z } from "zod";
|
|
|
|
import { getEventTypeAppData } from "@calcom/app-store/_utils/getEventTypeAppData";
|
|
import type { appDataSchemas } from "@calcom/app-store/apps.schemas.generated";
|
|
import type { appDataSchema, paymentOptionEnum } from "@calcom/app-store/stripepayment/zod";
|
|
import type { EventTypeAppsList } from "@calcom/app-store/utils";
|
|
|
|
export default function getPaymentAppData(
|
|
eventType: Parameters<typeof getEventTypeAppData>[0],
|
|
forcedGet?: boolean
|
|
) {
|
|
const metadataApps = eventType?.metadata?.apps as unknown as EventTypeAppsList;
|
|
if (!metadataApps) {
|
|
return { enabled: false, price: 0, currency: "usd", appId: null };
|
|
}
|
|
type appId = keyof typeof metadataApps;
|
|
// @TODO: a lot of unknowns types here can be improved later
|
|
const paymentAppIds = (Object.keys(metadataApps) as Array<keyof typeof appDataSchemas>).filter(
|
|
(app) =>
|
|
(metadataApps[app as appId] as unknown as z.infer<typeof appDataSchema>)?.price &&
|
|
(metadataApps[app as appId] as unknown as z.infer<typeof appDataSchema>)?.enabled
|
|
);
|
|
|
|
// Event type should only have one payment app data
|
|
let paymentAppData: {
|
|
enabled: boolean;
|
|
price: number;
|
|
currency: string;
|
|
appId: EventTypeAppsList | null;
|
|
paymentOption: typeof paymentOptionEnum;
|
|
} | null = null;
|
|
for (const appId of paymentAppIds) {
|
|
const appData = getEventTypeAppData(eventType, appId, forcedGet);
|
|
if (appData && paymentAppData === null) {
|
|
paymentAppData = {
|
|
...appData,
|
|
appId,
|
|
};
|
|
}
|
|
}
|
|
// This is the current expectation of system to have price and currency set always(using DB Level defaults).
|
|
// Newly added apps code should assume that their app data might not be set.
|
|
return (
|
|
paymentAppData || { enabled: false, price: 0, currency: "usd", appId: null, paymentOption: "ON_BOOKING" }
|
|
);
|
|
}
|