import { useState } from 'react'; import { msg } from '@lingui/core/macro'; import { useLingui } from '@lingui/react'; import { Trans } from '@lingui/react/macro'; import { SubscriptionStatus } from '@prisma/client'; import { AlertTriangle } from 'lucide-react'; import { Link } from 'react-router'; import { match } from 'ts-pattern'; import { useOptionalCurrentOrganisation } from '@documenso/lib/client-only/providers/organisation'; import { SUPPORT_EMAIL } from '@documenso/lib/constants/app'; import { canExecuteOrganisationAction } from '@documenso/lib/utils/organisations'; import { trpc } from '@documenso/trpc/react'; import { cn } from '@documenso/ui/lib/utils'; import { Alert, AlertDescription } from '@documenso/ui/primitives/alert'; import { Button } from '@documenso/ui/primitives/button'; import { Dialog, DialogClose, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, } from '@documenso/ui/primitives/dialog'; import { useToast } from '@documenso/ui/primitives/use-toast'; export const OrganisationBillingBanner = () => { const { _ } = useLingui(); const { toast } = useToast(); const [isOpen, setIsOpen] = useState(false); const organisation = useOptionalCurrentOrganisation(); const { mutateAsync: manageSubscription, isPending } = trpc.enterprise.billing.subscription.manage.useMutation(); const handleCreatePortal = async (organisationId: string) => { try { const { redirectUrl } = await manageSubscription({ organisationId }); window.open(redirectUrl, '_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, }); } }; const subscriptionStatus = organisation?.subscription?.status; if ( !organisation || subscriptionStatus === undefined || subscriptionStatus === SubscriptionStatus.ACTIVE ) { return null; } return ( <>
{match(subscriptionStatus) .with(SubscriptionStatus.PAST_DUE, () => Payment overdue) .with(SubscriptionStatus.INACTIVE, () => Restricted Access) .exhaustive()}
!isPending && setIsOpen(value)}> {match(subscriptionStatus) .with(SubscriptionStatus.PAST_DUE, () => ( Payment overdue Your payment is overdue. Please settle the payment to avoid any service disruptions. {canExecuteOrganisationAction( 'MANAGE_BILLING', organisation.currentOrganisationRole, ) && ( )} )) .with(SubscriptionStatus.INACTIVE, () => ( Subscription invalid Your plan is no longer valid. Please subscribe to a new plan to continue using Documenso. If there is any issue with your subscription, please contact us at{' '} {SUPPORT_EMAIL}. {canExecuteOrganisationAction( 'MANAGE_BILLING', organisation.currentOrganisationRole, ) && ( )} )) .otherwise(() => null)} ); };