2023-03-29 15:49:45 +02:00
|
|
|
import React, { useContext } from 'react';
|
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
|
|
import {
|
|
|
|
JustifyContent,
|
|
|
|
DISPLAY,
|
|
|
|
TextColor,
|
|
|
|
FLEX_DIRECTION,
|
2023-03-30 12:40:37 +02:00
|
|
|
TextVariant,
|
|
|
|
BorderStyle,
|
|
|
|
BorderColor,
|
2023-03-29 15:49:45 +02:00
|
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
import { I18nContext } from '../../../contexts/i18n';
|
|
|
|
import { mmiActionsFactory } from '../../../store/institutional/institution-background';
|
2023-07-14 19:59:30 +02:00
|
|
|
import { Button, BUTTON_VARIANT, BUTTON_SIZES } from '../../component-library';
|
|
|
|
import { Text } from '../../component-library/text/deprecated';
|
2023-03-29 15:49:45 +02:00
|
|
|
import Box from '../../ui/box';
|
|
|
|
|
|
|
|
const ComplianceSettings = () => {
|
|
|
|
const t = useContext(I18nContext);
|
|
|
|
const dispatch = useDispatch();
|
|
|
|
const mmiActions = mmiActionsFactory();
|
|
|
|
|
|
|
|
const complianceActivated = useSelector((state) =>
|
|
|
|
Boolean(state.metamask.institutionalFeatures?.complianceProjectId),
|
|
|
|
);
|
|
|
|
|
2023-03-30 12:40:37 +02:00
|
|
|
const linkButton = (
|
|
|
|
<Button
|
2023-04-26 18:17:25 +02:00
|
|
|
variant={BUTTON_VARIANT.LINK}
|
2023-03-30 12:40:37 +02:00
|
|
|
size={BUTTON_SIZES.LG}
|
|
|
|
data-testid="start-compliance"
|
|
|
|
onClick={() => {
|
|
|
|
global.platform.openTab({
|
|
|
|
url: 'https://start.compliance.codefi.network/',
|
|
|
|
});
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{t('openCodefiCompliance')}
|
|
|
|
</Button>
|
|
|
|
);
|
2023-03-29 15:49:45 +02:00
|
|
|
|
|
|
|
return complianceActivated ? (
|
|
|
|
<Box>
|
2023-03-30 12:40:37 +02:00
|
|
|
<Text
|
|
|
|
variant={TextVariant.bodySm}
|
|
|
|
as="h6"
|
|
|
|
className="institutional-feature__content"
|
|
|
|
>
|
2023-03-29 15:49:45 +02:00
|
|
|
{t('complianceSettingsExplanation')}
|
2023-03-30 12:40:37 +02:00
|
|
|
</Text>
|
|
|
|
<Box
|
|
|
|
padding={[4, 6]}
|
|
|
|
borderWidth={1}
|
|
|
|
borderStyle={BorderStyle.solid}
|
|
|
|
borderColor={BorderColor.borderMuted}
|
|
|
|
className="institutional-feature__footer"
|
|
|
|
>
|
|
|
|
<Button
|
|
|
|
size={BUTTON_SIZES.LG}
|
|
|
|
onClick={() => {
|
|
|
|
dispatch(mmiActions.deleteComplianceAuthData());
|
|
|
|
}}
|
|
|
|
data-testid="disconnect-compliance"
|
|
|
|
>
|
|
|
|
{t('disconnect')}
|
|
|
|
</Button>
|
|
|
|
{linkButton}
|
2023-03-29 15:49:45 +02:00
|
|
|
</Box>
|
|
|
|
</Box>
|
|
|
|
) : (
|
|
|
|
<Box
|
|
|
|
padding={[0, 6]}
|
|
|
|
color={TextColor.textAlternative}
|
|
|
|
data-testid="institutional-content"
|
|
|
|
>
|
2023-03-30 12:40:37 +02:00
|
|
|
<Box
|
|
|
|
variant={TextVariant.bodySm}
|
|
|
|
className="institutional-feature__content"
|
|
|
|
>
|
2023-03-29 15:49:45 +02:00
|
|
|
<Text paddingBottom={3}>{t('complianceBlurb0')}</Text>
|
|
|
|
<Text paddingBottom={3}>{t('complianceBlurb1')}</Text>
|
|
|
|
<Text paddingBottom={3}>{t('complianceBlurpStep0')}</Text>
|
|
|
|
<ol>
|
|
|
|
<li>{t('complianceBlurbStep1')}</li>
|
|
|
|
<li>{t('complianceBlurbStep2')}</li>
|
|
|
|
<li>{t('complianceBlurbStep3')}</li>
|
|
|
|
<li>{t('complianceBlurbStep4')}</li>
|
|
|
|
<li>{t('complianceBlurbStep5')}</li>
|
|
|
|
</ol>
|
|
|
|
</Box>
|
|
|
|
<Box
|
|
|
|
display={DISPLAY.FLEX}
|
|
|
|
flexDirection={FLEX_DIRECTION.ROW}
|
|
|
|
justifyContent={JustifyContent.center}
|
|
|
|
>
|
2023-03-30 12:40:37 +02:00
|
|
|
<Box
|
|
|
|
padding={[4, 6]}
|
|
|
|
borderWidth={1}
|
|
|
|
borderStyle={BorderStyle.solid}
|
|
|
|
borderColor={BorderColor.borderMuted}
|
|
|
|
className="institutional-feature__footer"
|
|
|
|
>
|
|
|
|
{linkButton}
|
|
|
|
</Box>
|
2023-03-29 15:49:45 +02:00
|
|
|
</Box>
|
|
|
|
</Box>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ComplianceSettings;
|