1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- import {css} from '@emotion/react';
- import styled from '@emotion/styled';
- import FieldGroup from 'sentry/components/forms/fieldGroup';
- import {InputGroup} from 'sentry/components/inputGroup';
- import {Tooltip} from 'sentry/components/tooltip';
- import {t} from 'sentry/locale';
- import {organizationSamplingForm} from 'sentry/views/settings/dynamicSampling/utils/organizationSamplingForm';
- import {useAccess} from 'sentry/views/settings/projectMetrics/access';
- const {useFormField} = organizationSamplingForm;
- export function OrganizationSampleRateField({}) {
- const field = useFormField('targetSampleRate');
- const {hasAccess} = useAccess({access: ['org:write']});
- return (
- <FieldGroup
- disabled={!hasAccess}
- required
- label={t('Target Sample Rate')}
- help={t(
- 'Sentry automatically adapts the sample rates of your projects based on this organization-wide target.'
- )}
- error={field.error}
- >
- <InputWrapper
- css={css`
- width: 150px;
- `}
- >
- <Tooltip
- disabled={hasAccess}
- title={t('You do not have permission to change the sample rate.')}
- >
- <InputGroup>
- <InputGroup.Input
- width={100}
- type="number"
- min={0}
- max={100}
- disabled={!hasAccess}
- value={field.value}
- onChange={event => field.onChange(event.target.value)}
- />
- <InputGroup.TrailingItems>
- <TrailingPercent>%</TrailingPercent>
- </InputGroup.TrailingItems>
- </InputGroup>
- </Tooltip>
- {field.hasChanged ? (
- <PreviousValue>{t('previous: %f%%', field.initialValue)}</PreviousValue>
- ) : null}
- </InputWrapper>
- </FieldGroup>
- );
- }
- const PreviousValue = styled('span')`
- font-size: ${p => p.theme.fontSizeExtraSmall};
- color: ${p => p.theme.subText};
- `;
- const InputWrapper = styled('div')`
- padding-top: 8px;
- height: 58px;
- display: flex;
- flex-direction: column;
- gap: 4px;
- `;
- const TrailingPercent = styled('strong')`
- padding: 0 2px;
- `;
|