123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- import {useContext} from 'react';
- import styled from '@emotion/styled';
- import Access from 'sentry/components/acl/access';
- import PluginIcon from 'sentry/plugins/components/pluginIcon';
- import {space} from 'sentry/styles/space';
- import {trackAnalytics} from 'sentry/utils/analytics';
- import useOrganization from 'sentry/utils/useOrganization';
- import IntegrationButton from 'sentry/views/settings/organizationIntegrations/integrationButton';
- import {IntegrationContext} from 'sentry/views/settings/organizationIntegrations/integrationContext';
- type Props = {
- onClick: () => void;
- };
- function AddIntegrationRow({onClick}: Props) {
- const organization = useOrganization();
- const integration = useContext(IntegrationContext);
- if (!integration) {
- return null;
- }
- const provider = integration.provider;
- const onAddIntegration = () => {
- integration.onAddIntegration?.();
- onClick();
- };
- const onExternalClick = () => {
- trackAnalytics('onboarding.messaging_integration_external_install_clicked', {
- provider_key: provider.key,
- organization,
- });
- onClick();
- };
- const buttonProps = {
- size: 'sm',
- priority: 'primary',
- 'data-test-id': 'install-button',
- };
- return (
- <RowWrapper>
- <IconTextWrapper>
- <PluginIcon pluginId={provider.slug} size={40} />
- <NameHeader>Connect {provider.name}</NameHeader>
- </IconTextWrapper>
- <Access access={['org:integrations']} organization={organization}>
- {({hasAccess}) => {
- return (
- <StyledButton
- userHasAccess={hasAccess}
- onAddIntegration={onAddIntegration}
- onExternalClick={onExternalClick}
- externalInstallText="Add Installation"
- buttonProps={buttonProps}
- />
- );
- }}
- </Access>
- </RowWrapper>
- );
- }
- const RowWrapper = styled('div')`
- display: flex;
- border-radius: 4px;
- border: 1px solid ${p => p.theme.gray200};
- justify-content: space-between;
- align-items: center;
- padding: ${space(3)} ${space(4)};
- `;
- const IconTextWrapper = styled('div')`
- display: flex;
- align-items: center;
- gap: ${space(3)};
- `;
- const NameHeader = styled('h6')`
- margin: 0;
- `;
- const StyledButton = styled(IntegrationButton)`
- margin: 0;
- `;
- export default AddIntegrationRow;
|