import styled from '@emotion/styled'; import {Button} from 'sentry/components/button'; import {TextField} from 'sentry/components/forms'; import {PanelBody, PanelHeader} from 'sentry/components/panels'; import {IconAdd, IconDelete} from 'sentry/icons'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; type Props = { envVariables: { name: string; value: string; }[]; setEnvVariables: (envVariables) => void; }; function SentryFunctionEnvironmentVariables(props: Props) { const {envVariables, setEnvVariables} = props; const addEnvVar = () => { setEnvVariables([...envVariables, {name: '', value: ''}]); }; const handleNameChange = (value: string, pos: number) => { const newEnvVariables = [...envVariables]; while (newEnvVariables.length <= pos) { newEnvVariables.push({name: '', value: ''}); } newEnvVariables[pos] = {...newEnvVariables[pos], name: value}; setEnvVariables(newEnvVariables); }; const handleValueChange = (value: string, pos: number) => { const newEnvVariables = [...envVariables]; while (newEnvVariables.length <= pos) { newEnvVariables.push({name: '', value: ''}); } newEnvVariables[pos] = {...newEnvVariables[pos], value}; setEnvVariables(newEnvVariables); }; const removeEnvVar = (pos: number) => { const newEnvVariables = [...envVariables]; newEnvVariables.splice(pos, 1); setEnvVariables(newEnvVariables); }; return (