import {Component, Fragment} from 'react'; import styled from '@emotion/styled'; import {Observer} from 'mobx-react'; import * as qs from 'query-string'; import {addLoadingMessage} from 'sentry/actionCreators/indicator'; import Alert from 'sentry/components/alert'; import SentryProjectSelectorField from 'sentry/components/forms/fields/sentryProjectSelectorField'; import Form from 'sentry/components/forms/form'; import FormModel from 'sentry/components/forms/model'; import List from 'sentry/components/list'; import ListItem from 'sentry/components/list/listItem'; import {t} from 'sentry/locale'; import space from 'sentry/styles/space'; import {Project} from 'sentry/types'; import FooterWithButtons from './components/footerWithButtons'; import HeaderWithHelp from './components/headerWithHelp'; type Props = {projects: Project[]}; export default class AwsLambdaProjectSelect extends Component { model = new FormModel(); handleSubmit = (e: React.MouseEvent) => { e.preventDefault(); const data = this.model.getData(); addLoadingMessage(t('Submitting\u2026')); this.model.setFormSaving(); const { location: {origin}, } = window; // redirect to the extensions endpoint with the form fields as query params // this is needed so we don't restart the pipeline loading from the original // OrganizationIntegrationSetupView route const newUrl = `${origin}/extensions/aws_lambda/setup/?${qs.stringify(data)}`; window.location.assign(newUrl); }; render() { const {projects} = this.props; // TODO: Add logic if no projects return (

{t('Select a project for your AWS Lambdas')}

{t('Currently only supports Node and Python Lambda functions')}
{() => ( )}
); } } const StyledList = styled(List)` padding: 100px 50px 50px 50px; `; const StyledSentryProjectSelectorField = styled(SentryProjectSelectorField)` padding: 0 0 ${space(2)} 0; `;