pleroma/app/soapbox/components/gdpr-banner.tsx

68 lines
2.3 KiB
TypeScript
Raw Normal View History

2023-02-06 10:01:03 -08:00
import clsx from 'clsx';
import React, { useState } from 'react';
import { FormattedMessage } from 'react-intl';
import { Banner, Button, HStack, Stack, Text } from 'soapbox/components/ui';
2022-11-26 08:38:16 -08:00
import { useAppSelector, useInstance, useSoapboxConfig } from 'soapbox/hooks';
const acceptedGdpr = !!localStorage.getItem('soapbox:gdpr');
/** Displays a cookie consent banner. */
const GdprBanner: React.FC = () => {
/** Track whether the banner has already been displayed once. */
const [shown, setShown] = useState<boolean>(acceptedGdpr);
2022-07-26 09:37:02 -07:00
const [slideout, setSlideout] = useState(false);
2022-11-26 08:38:16 -08:00
const instance = useInstance();
const soapbox = useSoapboxConfig();
const isLoggedIn = useAppSelector(state => !!state.me);
const handleAccept = () => {
localStorage.setItem('soapbox:gdpr', 'true');
2022-07-26 09:37:02 -07:00
setSlideout(true);
setTimeout(() => setShown(true), 200);
};
const showBanner = soapbox.gdpr && !isLoggedIn && !shown;
if (!showBanner) {
return null;
}
return (
2023-02-06 10:01:03 -08:00
<Banner theme='opaque' className={clsx('transition-transform', { 'translate-y-full': slideout })}>
2023-02-01 14:13:42 -08:00
<div className='flex flex-col space-y-4 rtl:space-x-reverse lg:flex-row lg:items-center lg:justify-between lg:space-y-0 lg:space-x-4'>
2022-07-26 11:22:13 -07:00
<Stack space={2}>
<Text size='xl' weight='bold'>
2022-11-26 08:38:16 -08:00
<FormattedMessage id='gdpr.title' defaultMessage='{siteTitle} uses cookies' values={{ siteTitle: instance.title }} />
</Text>
2022-07-26 11:22:13 -07:00
<Text weight='medium' className='opacity-60'>
<FormattedMessage
id='gdpr.message'
defaultMessage="{siteTitle} uses session cookies, which are essential to the website's functioning."
2022-11-26 08:38:16 -08:00
values={{ siteTitle: instance.title }}
/>
</Text>
</Stack>
2022-07-26 11:54:19 -07:00
<HStack space={2} alignItems='center' className='flex-none'>
{soapbox.gdprUrl && (
<a href={soapbox.gdprUrl} tabIndex={-1} className='inline-flex'>
<Button theme='secondary'>
<FormattedMessage id='gdpr.learn_more' defaultMessage='Learn more' />
</Button>
</a>
)}
<Button theme='accent' onClick={handleAccept}>
<FormattedMessage id='gdpr.accept' defaultMessage='Accept' />
</Button>
</HStack>
2022-07-26 11:22:13 -07:00
</div>
</Banner>
);
};
export default GdprBanner;