import { useState } from 'react'; import { msg } from '@lingui/core/macro'; import { useLingui } from '@lingui/react'; import { Trans } from '@lingui/react/macro'; import type { TeamMemberRole } from '@prisma/client'; import { type Subscription, SubscriptionStatus } from '@prisma/client'; import { AlertTriangle } from 'lucide-react'; import { match } from 'ts-pattern'; import { canExecuteTeamAction } from '@documenso/lib/utils/teams'; import { trpc } from '@documenso/trpc/react'; import { cn } from '@documenso/ui/lib/utils'; import { Button } from '@documenso/ui/primitives/button'; import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogTitle, } from '@documenso/ui/primitives/dialog'; import { useToast } from '@documenso/ui/primitives/use-toast'; export type TeamLayoutBillingBannerProps = { subscription: Subscription; teamId: number; userRole: TeamMemberRole; }; export const TeamLayoutBillingBanner = ({ subscription, teamId, userRole, }: TeamLayoutBillingBannerProps) => { const { _ } = useLingui(); const { toast } = useToast(); const [isOpen, setIsOpen] = useState(false); const { mutateAsync: createBillingPortal, isPending } = trpc.team.createBillingPortal.useMutation(); const handleCreatePortal = async () => { try { const sessionUrl = await createBillingPortal({ teamId }); window.open(sessionUrl, '_blank'); setIsOpen(false); } catch (err) { toast({ title: _(msg`Something went wrong`), description: _( msg`We are unable to proceed to the billing portal at this time. Please try again, or contact support.`, ), variant: 'destructive', duration: 10000, }); } }; if (subscription.status === SubscriptionStatus.ACTIVE) { return null; } return ( <>
{match(subscription.status) .with(SubscriptionStatus.PAST_DUE, () => Payment overdue) .with(SubscriptionStatus.INACTIVE, () => Teams restricted) .exhaustive()}
!isPending && setIsOpen(value)}> Payment overdue {match(subscription.status) .with(SubscriptionStatus.PAST_DUE, () => ( Your payment for teams is overdue. Please settle the payment to avoid any service disruptions. )) .with(SubscriptionStatus.INACTIVE, () => ( Due to an unpaid invoice, your team has been restricted. Please settle the payment to restore full access to your team. )) .otherwise(() => null)} {canExecuteTeamAction('MANAGE_BILLING', userRole) && ( )} ); };