import {RouteComponentProps} from 'react-router'; import styled from '@emotion/styled'; import {Location} from 'history'; import cloneDeep from 'lodash/cloneDeep'; import {addErrorMessage} from 'sentry/actionCreators/indicator'; import {updateOrganization} from 'sentry/actionCreators/organizations'; import Feature from 'sentry/components/acl/feature'; import FeatureDisabled from 'sentry/components/acl/featureDisabled'; import AsyncComponent from 'sentry/components/asyncComponent'; import AvatarChooser from 'sentry/components/avatarChooser'; import Form from 'sentry/components/forms/form'; import JsonForm from 'sentry/components/forms/jsonForm'; import HookOrDefault from 'sentry/components/hookOrDefault'; import {Hovercard} from 'sentry/components/hovercard'; import Tag from 'sentry/components/tag'; import organizationSettingsFields from 'sentry/data/forms/organizationGeneralSettings'; import {IconCodecov, IconLock} from 'sentry/icons'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {Organization, Scope} from 'sentry/types'; import withOrganization from 'sentry/utils/withOrganization'; const HookCodecovSettingsLink = HookOrDefault({ hookName: 'component:codecov-integration-settings-link', }); type Props = { access: Set; initialData: Organization; location: Location; onSave: (previous: Organization, updated: Organization) => void; organization: Organization; } & RouteComponentProps<{}, {}>; type State = AsyncComponent['state'] & { authProvider: object; }; class OrganizationSettingsForm extends AsyncComponent { getEndpoints(): ReturnType { const {organization} = this.props; return [['authProvider', `/organizations/${organization.slug}/auth-provider/`]]; } render() { const {initialData, organization, onSave, access} = this.props; const {authProvider} = this.state; const endpoint = `/organizations/${organization.slug}/`; const jsonFormSettings = { additionalFieldProps: {hasSsoEnabled: !!authProvider}, features: new Set(organization.features), access, location: this.props.location, disabled: !access.has('org:write'), }; const forms = cloneDeep(organizationSettingsFields); forms[0].fields = [ ...forms[0].fields, { name: 'codecovAccess', type: 'boolean', disabled: !organization.features.includes('codecov-integration'), label: ( {t('Enable Code Coverage Insights')}{' '} ( } > }> {t('disabled')} )} features={['organizations:codecov-integration']} > {() => null} ), formatMessageValue: (value: boolean) => { const onOff = value ? t('on') : t('off'); return t('Codecov access was turned %s', onOff); }, help: ( {t('powered by')} Codecov{' '} ), }, ]; return (
{ // Special case for slug, need to forward to new slug if (typeof onSave === 'function') { onSave(initialData, updated); } }} onSubmitError={() => addErrorMessage('Unable to save change')} > ); } } export default withOrganization(OrganizationSettingsForm); const PoweredByCodecov = styled('div')` display: flex; align-items: center; gap: ${space(0.5)}; & > span { display: flex; align-items: center; } `;