import {Fragment} from 'react'; import styled from '@emotion/styled'; import ActionButton from 'sentry/components/actions/button'; import MenuItemActionLink from 'sentry/components/actions/menuItemActionLink'; import {Button} from 'sentry/components/button'; import ButtonBar from 'sentry/components/buttonBar'; import ConfirmDelete from 'sentry/components/confirmDelete'; import DropdownLink from 'sentry/components/dropdownLink'; import {Tooltip} from 'sentry/components/tooltip'; import {IconEllipsis} from 'sentry/icons/iconEllipsis'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import TextBlock from 'sentry/views/settings/components/text/textBlock'; type Props = { hasAccess: boolean; hasFeature: boolean; onDelete: () => void; onEdit: () => void; repositoryName: string; disabled?: boolean; syncNowButton?: React.ReactElement; }; function Actions({ repositoryName, disabled, onEdit, onDelete, hasFeature, hasAccess, syncNowButton, }: Props) { function renderConfirmDelete(element: React.ReactElement) { return ( {t('Removing this repository applies instantly to new events.')} {t( 'Debug files from this repository will not be used to symbolicate future events. This may create new issues and alert members in your organization.' )} } confirmInput={repositoryName} priority="danger" onConfirm={onDelete} > {element} ); } const actionsDisabled = !hasAccess || !hasFeature || disabled; return ( {syncNowButton} {t('Configure')} {actionsDisabled ? ( {t('Delete')} ) : ( renderConfirmDelete({t('Delete')}) )} } /> } anchorRight > {t('Configure')} {renderConfirmDelete({t('Delete')})} ); } export default Actions; const StyledActionButton = styled(ActionButton)` height: 32px; `; const StyledButtonBar = styled(ButtonBar)` gap: ${space(1)}; grid-column: 2/2; grid-row: 4/4; grid-auto-flow: row; margin-top: ${space(0.5)}; @media (min-width: ${p => p.theme.breakpoints.small}) { grid-column: 3/3; grid-row: 1/3; grid-auto-flow: column; margin-top: 0; } `; const ButtonTooltip = styled(Tooltip)` @media (min-width: ${p => p.theme.breakpoints.small}) { display: none; } `; const ActionBtn = styled(Button)` width: 100%; @media (min-width: ${p => p.theme.breakpoints.small}) { display: none; } `; const DropDownWrapper = styled('div')` display: none; @media (min-width: ${p => p.theme.breakpoints.small}) { display: block; } `;