2023-07-21 11:04:51 +02:00
|
|
|
import React, { useContext } from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import {
|
|
|
|
BannerAlert,
|
|
|
|
ButtonLink,
|
|
|
|
Icon,
|
|
|
|
IconName,
|
|
|
|
IconSize,
|
|
|
|
Text,
|
|
|
|
} from '../../component-library';
|
|
|
|
import Disclosure from '../../ui/disclosure';
|
|
|
|
import { DisclosureVariant } from '../../ui/disclosure/disclosure.constants';
|
|
|
|
|
|
|
|
import { I18nContext } from '../../../contexts/i18n';
|
|
|
|
import {
|
|
|
|
AlignItems,
|
|
|
|
Color,
|
2023-08-14 18:38:03 +02:00
|
|
|
Display,
|
2023-07-21 11:04:51 +02:00
|
|
|
IconColor,
|
|
|
|
Severity,
|
|
|
|
Size,
|
|
|
|
TextVariant,
|
|
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
|
|
|
|
import {
|
|
|
|
SecurityProvider,
|
|
|
|
SECURITY_PROVIDER_CONFIG,
|
|
|
|
} from '../../../../shared/constants/security-provider';
|
|
|
|
|
|
|
|
function SecurityProviderBannerAlert({
|
|
|
|
description,
|
|
|
|
details,
|
|
|
|
provider,
|
|
|
|
severity,
|
|
|
|
title,
|
2023-08-30 16:05:53 +02:00
|
|
|
...props
|
2023-07-21 11:04:51 +02:00
|
|
|
}) {
|
|
|
|
const t = useContext(I18nContext);
|
|
|
|
|
|
|
|
return (
|
2023-08-30 16:05:53 +02:00
|
|
|
<BannerAlert title={title} severity={severity} {...props}>
|
2023-07-21 11:04:51 +02:00
|
|
|
<Text marginTop={2}>{description}</Text>
|
|
|
|
|
|
|
|
{details && (
|
|
|
|
<Disclosure title={t('seeDetails')} variant={DisclosureVariant.Arrow}>
|
|
|
|
{details}
|
|
|
|
</Disclosure>
|
|
|
|
)}
|
|
|
|
|
2023-08-14 18:38:03 +02:00
|
|
|
{provider && (
|
|
|
|
<Text
|
|
|
|
marginTop={3}
|
|
|
|
display={Display.Flex}
|
|
|
|
alignItems={AlignItems.center}
|
|
|
|
color={Color.textAlternative}
|
|
|
|
variant={TextVariant.bodySm}
|
|
|
|
>
|
|
|
|
<Icon
|
|
|
|
className="disclosure__summary--icon"
|
|
|
|
color={IconColor.primaryDefault}
|
|
|
|
name={IconName.SecurityTick}
|
|
|
|
size={IconSize.Sm}
|
|
|
|
marginInlineEnd={1}
|
|
|
|
/>
|
2023-09-01 19:46:20 +02:00
|
|
|
{t('securityProviderPoweredBy', [
|
2023-08-14 18:38:03 +02:00
|
|
|
<ButtonLink
|
|
|
|
key={`security-provider-button-link-${provider}`}
|
|
|
|
size={Size.inherit}
|
|
|
|
href={SECURITY_PROVIDER_CONFIG[provider].url}
|
|
|
|
externalLink
|
|
|
|
>
|
|
|
|
{t(SECURITY_PROVIDER_CONFIG[provider].tKeyName)}
|
|
|
|
</ButtonLink>,
|
|
|
|
])}
|
|
|
|
</Text>
|
|
|
|
)}
|
2023-07-21 11:04:51 +02:00
|
|
|
</BannerAlert>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
SecurityProviderBannerAlert.propTypes = {
|
|
|
|
/** Description content that may be plain text or contain hyperlinks */
|
|
|
|
description: PropTypes.oneOfType([PropTypes.string, PropTypes.element])
|
|
|
|
.isRequired,
|
|
|
|
|
|
|
|
/** Severity level */
|
2023-08-18 14:06:46 +02:00
|
|
|
severity: PropTypes.oneOf([Severity.Danger, Severity.Warning]).isRequired,
|
2023-07-21 11:04:51 +02:00
|
|
|
|
|
|
|
/** Title to be passed as <BannerAlert> param */
|
|
|
|
title: PropTypes.string.isRequired,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Optional
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** Additional details to be displayed under the description */
|
|
|
|
details: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),
|
2023-08-14 18:38:03 +02:00
|
|
|
|
|
|
|
/** Name of the security provider */
|
2023-08-18 14:06:46 +02:00
|
|
|
provider: PropTypes.oneOf(Object.values(SecurityProvider)),
|
2023-07-21 11:04:51 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
export default SecurityProviderBannerAlert;
|