import {browserHistory, RouteComponentProps} from 'react-router'; import {addErrorMessage, addSuccessMessage} from 'sentry/actionCreators/indicator'; import ApiForm from 'sentry/components/forms/apiForm'; import MultipleCheckbox from 'sentry/components/forms/controls/multipleCheckbox'; import FormField from 'sentry/components/forms/formField'; import TextareaField from 'sentry/components/forms/textareaField'; import TextField from 'sentry/components/forms/textField'; import {Panel, PanelBody, PanelHeader} from 'sentry/components/panels'; import {API_ACCESS_SCOPES} from 'sentry/constants'; import {t} from 'sentry/locale'; import {Choices, Organization} from 'sentry/types'; import recreateRoute from 'sentry/utils/recreateRoute'; import routeTitleGen from 'sentry/utils/routeTitle'; import withOrganization from 'sentry/utils/withOrganization'; import AsyncView from 'sentry/views/asyncView'; import SettingsPageHeader from 'sentry/views/settings/components/settingsPageHeader'; import {DeprecatedApiKey} from './types'; const API_CHOICES: Choices = API_ACCESS_SCOPES.map(s => [s, s]); type RouteParams = { apiKey: string; orgId: string; }; type Props = RouteComponentProps & { organization: Organization; }; type State = AsyncView['state'] & { apiKey: DeprecatedApiKey; }; class OrganizationApiKeyDetails extends AsyncView { getEndpoints(): ReturnType { return [ [ 'apiKey', `/organizations/${this.props.params.orgId}/api-keys/${this.props.params.apiKey}/`, ], ]; } getTitle() { return routeTitleGen(t('Edit API Key'), this.props.organization.slug, false); } handleSubmitSuccess = () => { addSuccessMessage('Saved changes'); // Go back to API list browserHistory.push( recreateRoute('', { stepBack: -1, routes: this.props.routes, params: this.props.params, }) ); }; handleSubmitError = () => { addErrorMessage('Unable to save changes. Please try again.'); }; renderBody() { return (
{t('API Key')} browserHistory.push( recreateRoute('', { stepBack: -1, routes: this.props.routes, params: this.props.params, }) ) } > {({value, onChange}) => ( )}
); } } export default withOrganization(OrganizationApiKeyDetails);