mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 17:00:15 +01:00
93 lines
2.7 KiB
TypeScript
93 lines
2.7 KiB
TypeScript
|
|
import { useLocalize } from '~/hooks';
|
||
|
|
import { OGDialog } from '~/components/ui';
|
||
|
|
import DialogTemplate from '~/components/ui/DialogTemplate';
|
||
|
|
import { useAuthContext } from '~/hooks';
|
||
|
|
import Markdown from '~/components/Chat/Messages/Content/Markdown';
|
||
|
|
import { useToastContext } from '~/Providers';
|
||
|
|
import { useAcceptTermsMutation } from '~/data-provider';
|
||
|
|
|
||
|
|
const TermsAndConditionsModal = ({
|
||
|
|
open,
|
||
|
|
onOpenChange,
|
||
|
|
onAccept,
|
||
|
|
onDecline,
|
||
|
|
title,
|
||
|
|
modalContent,
|
||
|
|
}: {
|
||
|
|
open: boolean;
|
||
|
|
onOpenChange: (isOpen: boolean) => void;
|
||
|
|
onAccept: () => void;
|
||
|
|
onDecline: () => void;
|
||
|
|
title?: string;
|
||
|
|
contentUrl?: string;
|
||
|
|
modalContent?: string;
|
||
|
|
}) => {
|
||
|
|
const localize = useLocalize();
|
||
|
|
const { showToast } = useToastContext();
|
||
|
|
const acceptTermsMutation = useAcceptTermsMutation({
|
||
|
|
onSuccess: () => {
|
||
|
|
onAccept();
|
||
|
|
onOpenChange(false);
|
||
|
|
},
|
||
|
|
onError: () => {
|
||
|
|
showToast({ message: 'Failed to accept terms' });
|
||
|
|
},
|
||
|
|
});
|
||
|
|
|
||
|
|
const handleAccept = () => {
|
||
|
|
acceptTermsMutation.mutate();
|
||
|
|
};
|
||
|
|
|
||
|
|
const handleDecline = () => {
|
||
|
|
onDecline();
|
||
|
|
onOpenChange(false);
|
||
|
|
};
|
||
|
|
|
||
|
|
const handleOpenChange = (isOpen: boolean) => {
|
||
|
|
if (open && !isOpen) {
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
onOpenChange(isOpen);
|
||
|
|
};
|
||
|
|
|
||
|
|
return (
|
||
|
|
<OGDialog open={open} onOpenChange={handleOpenChange}>
|
||
|
|
<DialogTemplate
|
||
|
|
title={title ?? localize('com_ui_terms_and_conditions')}
|
||
|
|
className="w-11/12 max-w-3xl sm:w-3/4 md:w-1/2 lg:w-2/5"
|
||
|
|
showCloseButton={false}
|
||
|
|
showCancelButton={false}
|
||
|
|
main={
|
||
|
|
<div className="max-h-[60vh] overflow-y-auto p-4">
|
||
|
|
<div className="prose dark:prose-invert w-full max-w-none !text-black dark:!text-white">
|
||
|
|
{modalContent ? (
|
||
|
|
<Markdown content={modalContent} isLatestMessage={false} />
|
||
|
|
) : (
|
||
|
|
<p>{localize('com_ui_no_terms_content')}</p>
|
||
|
|
)}
|
||
|
|
</div>
|
||
|
|
</div>
|
||
|
|
}
|
||
|
|
buttons={
|
||
|
|
<>
|
||
|
|
<button
|
||
|
|
onClick={handleDecline}
|
||
|
|
className="border-border-none bg-surface-500 dark:hover:bg-surface-600 inline-flex h-10 items-center justify-center rounded-lg px-4 py-2 text-sm text-white hover:bg-gray-600"
|
||
|
|
>
|
||
|
|
{localize('com_ui_decline')}
|
||
|
|
</button>
|
||
|
|
<button
|
||
|
|
onClick={handleAccept}
|
||
|
|
className="border-border-none bg-surface-500 inline-flex h-10 items-center justify-center rounded-lg px-4 py-2 text-sm text-white hover:bg-green-600 dark:hover:bg-green-600"
|
||
|
|
>
|
||
|
|
{localize('com_ui_accept')}
|
||
|
|
</button>
|
||
|
|
</>
|
||
|
|
}
|
||
|
|
/>
|
||
|
|
</OGDialog>
|
||
|
|
);
|
||
|
|
};
|
||
|
|
|
||
|
|
export default TermsAndConditionsModal;
|