{"version":3,"sources":["app/layout/Header/index.tsx","assets/images/boeing_blue_logo.png","app/layout/Footer/index.tsx","app/Instructions/TermsAndConditions/index.tsx","app/Instructions/GuideLines/indes.tsx","app/Instructions/index.tsx","app/Components/TextField.tsx","app/Components/Editor.tsx","app/services/lookupService.ts","app/Components/Dropdown.tsx","app/services/captchaService.ts","app/services/unsolicitedIdeasService.ts","app/Success/index.tsx","app/Form/index.tsx","app/App.tsx","reportWebVitals.ts","theme.ts","index.tsx"],"names":["useStyles","makeStyles","theme","mastHeader","margin","padding","border","backgroundColor","display","boxShadow","shadows","title","flexGrow","textAlign","color","palette","primary","main","fontWeight","fontSize","flex","image","height","Header","classes","AppBar","position","className","Toolbar","component","src","alt","Footer","id","Typography","variant","target","href","rel","TermsAndConditionsDialog","React","useState","open","setOpen","handleClose","Link","onClick","e","preventDefault","Dialog","onClose","Box","p","style","DialogContent","DialogActions","justifyContent","Button","autoFocus","GuideLinesDialog","Instructions","memo","props","formik","values","name","value","setValue","fullWidth","size","required","inputProps","label","onBlur","handleChange","error","touched","Boolean","errors","helperText","onChange","isNumber","onlyNums","replace","formats","modules","toolbar","clipboard","matchVisual","Editor","placeholder","setFieldValue","ig","nore","setCharCount","getText","trim","length","FormHelperText","charCount","ideaDescription","lookupService","Promise","resolve","reject","axios","get","then","data","catch","countryId","Dropdown","options","disabled","callback","Autocomplete","getOptionLabel","option","getOptionSelected","event","newValue","renderInput","params","captchaService","getCaptcha","unsolicitedIdeasService","submitIdea","post","response","root","width","successMessage","successSymbol","alignItems","successTitle","marginLeft","icon","Success","Done","submit","marginTop","validationSchema","yup","emailAddress","email","firstName","lastName","phoneNumber","typeError","country","state","acceptTerms","oneOf","consent","captcha","SlideTransition","Slide","direction","initialValues","Form","isLoading","setLoading","countries","setCountries","captchaUri","setCaptchaUri","states","setSates","statesLoading","setStatesLoading","useEffect","all","getCountries","svgString","encodeURIComponent","dataUri","reason","useFormik","validateOnChange","validateOnBlur","onSubmit","setErrors","setStatus","setSubmitting","phone","description","mapValuesToPayload","success","status","LinearProgress","mt","my","mb","handleSubmit","autoComplete","Grid","container","spacing","item","xs","maxLength","type","getStates","sort","a","b","localeCompare","initialValue","FormControlLabel","control","Checkbox","checked","justify","backgroundImage","IconButton","Refresh","md","isSubmitting","startIcon","CircularProgress","Snackbar","autoHideDuration","TransitionComponent","Alert","severity","App","accepted","setAccepted","Container","maxWidth","mx","_","reportWebVitals","onPerfEntry","Function","getCLS","getFID","getFCP","getLCP","getTTFB","createTheme","overrides","MuiFormLabel","asterisk","light","dark","contrastText","secondary","text","hint","typography","h1","fontFamily","join","lineHeight","h2","h3","h4","h5","h6","body1","body2","button","caption","subtitle1","subtitle2","overline","ReactDOM","render","StrictMode","ThemeProvider","CssBaseline","document","getElementById"],"mappings":"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","file":"static/js/main.77d8cdda.chunk.js","sourcesContent":["import React from \"react\";\nimport AppBar from \"@material-ui/core/AppBar\";\nimport Toolbar from \"@material-ui/core/Toolbar\";\nimport Logo from \"../../../assets/images/boeing_blue_logo.png\";\nimport {makeStyles} from \"@material-ui/core\";\n\nconst useStyles = makeStyles(theme => ({\n  mastHeader: {\n    margin: 0,\n    padding: 0,\n    border: 0,\n    backgroundColor: \"#fff\",\n    display: \"flex\",\n    boxShadow: theme.shadows[2]\n  },\n  title: {\n    flexGrow: 8,\n    textAlign: \"right\",\n    color: theme.palette.primary.main,\n    padding: 20,\n    fontWeight: 500,\n    fontSize: \"1.25rem\",\n    flex: 1\n  },\n  image: {\n    height: 35,\n  },\n}));\n\n\nexport const Header = () => {\n  const classes = useStyles();\n  return (\n    <AppBar position=\"static\" className={classes.mastHeader}>\n      <Toolbar component=\"div\">\n        <img src={Logo} className={classes.image} alt=\"logo\"/>\n        <div className={classes.title}>Boeing Unsolicited Ideas Form</div>\n      </Toolbar>\n    </AppBar>\n  );\n};\n\nexport default Header;\n","export default \"\"","import React from 'react';\nimport {Typography} from '@material-ui/core';\n\nexport const Footer = () => <footer id=\"footer\">\n  <Typography variant=\"caption\">\n    Copyright &copy; - <a target=\"_blank\" href=\"https://my.boeing.com/\"\n                          rel=\"noopener noreferrer\"><strong>Boeing </strong></a> 2021. All rights reserved.\n  </Typography>\n  <br/>\n  <Typography variant=\"caption\" data-testid=\"privacy-statement\">Boeing <a target=\"_blank\" href=\"https://www.boeing.com/privacy-and-cookie-policy.page\"\n                                          rel=\"noopener noreferrer\">Privacy Statement</a>.</Typography>\n  <Typography variant=\"caption\">The site is best viewed through Internet Explorer 11.x or higher / Mozilla Firefox® 60.x\n    or higher.</Typography>\n</footer>;\n","import React from 'react';\nimport Button from '@material-ui/core/Button';\nimport Dialog from '@material-ui/core/Dialog';\nimport DialogActions from '@material-ui/core/DialogActions';\nimport DialogContent from '@material-ui/core/DialogContent';\nimport {Box, Link, Typography} from '@material-ui/core';\n\nexport default function TermsAndConditionsDialog() {\n  const [open, setOpen] = React.useState(false);\n\n  const handleClickOpen = (e: React.SyntheticEvent) => {\n    e.preventDefault();\n    setOpen(true);\n  };\n\n  const handleClose = () => {\n    setOpen(false);\n  };\n\n  return (\n    <span>\n      <Link href=\"#\" onClick={handleClickOpen}>\n        Terms & Conditions\n      </Link>\n      <Dialog\n        open={open}\n        onClose={handleClose}\n        aria-labelledby=\"alert-dialog-title\"\n        aria-describedby=\"alert-dialog-description\"\n      >\n        <Box p={3}><Typography variant=\"h2\" id=\"alert-dialog-title\" style={{textAlign: 'center'}}\n                               data-testid=\"title\">TERMS AND CONDITIONS</Typography></Box>\n        <DialogContent>\n          <Typography id=\"alert-dialog-description\" data-testid=\"intro\" variant=\"body2\">\n            In return for the review of your submission by The Boeing Company (“Boeing”), you agree to the below terms.\n            Boeing rejects any additional or conflicting terms in your submission, and they will not form part of your\n            agreement with Boeing. If you do not agree to the below terms, do not submit your ideas to this website.\n            </Typography>\n          <Typography variant=\"body1\" component=\"div\">\n            <ol>\n              <li data-testid='term1'>Your submission is neither confidential nor proprietary, and will not be treated by Boeing as\n                confidential or proprietary.\n              </li>\n              <li data-testid='term2'>Your submission, including all ideas, unpatented inventions, drawings, software source code, technical\n                data, etc., and all associated intellectual property rights, will automatically become the property of\n                Boeing and you hereby assign to Boeing all rights in your submission, including all intellectual\n                property rights, without any expectation of compensation to you.\n              </li>\n              <li data-testid='term3'>You are at least 18 years old at the time of your submission.</li>\n              <li data-testid='term4'>You are authorized to make this submission, and your submission does not include any information that\n                belongs to a third party.\n              </li>\n              <li data-testid='term5'>These terms and conditions apply regardless of any contrary assertions you may include with your\n                submission or otherwise communicate to Boeing.\n              </li>\n              <li data-testid='term6'>Please note that Boeing is under no obligation to respond to your submission.</li>\n            </ol>\n          </Typography>\n        </DialogContent>\n        <DialogActions style={{justifyContent: 'center'}}>\n          <Button onClick={handleClose} data-testid='ok-button' color=\"primary\" autoFocus variant=\"contained\">\n            Ok\n          </Button>\n        </DialogActions>\n      </Dialog>\n    </span>\n  );\n}\n","import React from 'react';\nimport Button from '@material-ui/core/Button';\nimport Dialog from '@material-ui/core/Dialog';\nimport DialogActions from '@material-ui/core/DialogActions';\nimport DialogContent from '@material-ui/core/DialogContent';\nimport {Box, Link, Typography} from '@material-ui/core';\n\nexport default function GuideLinesDialog() {\n  const [open, setOpen] = React.useState(false);\n\n  const handleClickOpen = (e: React.SyntheticEvent) => {\n    e.preventDefault();\n    setOpen(true);\n  };\n\n  const handleClose = () => {\n    setOpen(false);\n  };\n\n  return (\n    <span>\n      <Link href=\"#\" onClick={handleClickOpen}>\n        Guidelines for Submission\n      </Link>\n      <Dialog\n        open={open}\n        onClose={handleClose}\n        aria-labelledby=\"alert-dialog-title\"\n        aria-describedby=\"alert-dialog-description\"\n      >\n         <Box p={3}><Typography variant=\"h2\" id=\"alert-dialog-title\" style={{textAlign: 'center'}}\n                                data-testid=\"title\">GUIDELINES FOR SUBMISSION</Typography></Box>\n        <DialogContent>\n          <Typography id=\"alert-dialog-description\" data-testid=\"intro\" variant=\"subtitle1\">Submissions should be in the English language.</Typography>\n\n          <Typography variant=\"body2\">Ideas that contain or relate to the following are not eligible for review by Boeing:</Typography>\n          <Typography variant=\"body1\" component=\"div\">\n            <ol>\n              <li data-testid=\"term1\">Confidential or proprietary information of any type</li>\n              <li data-testid=\"term2\">Patents, licensing requests, or patent assertions</li>\n              <li data-testid=\"term3\">Submissions from anyone under 18 years of age</li>\n              <li data-testid=\"term4\">Advertising, marketing, customer liveries or branding ideas</li>\n              <li data-testid=\"term5\">Names, logos, and slogans for products and services</li>\n              <li data-testid=\"term6\">Business methods or ways to conduct our business (e.g., joint venture proposals, diverstiture, equity investment, funding of projects)</li>\n              <li data-testid=\"term7\">Requests for employment (instead please see <a target=\"_blank\" rel=\"noopener noreferrer\" href={'https://jobs.boeing.com/'}>https://jobs.boeing.com/</a>)</li>\n              <li data-testid=\"term8\">Website development proposals</li>\n              <li data-testid=\"term9\">Any solicitations for sales or license</li>\n              <li data-testid=\"term10\">Sponsorship proposals</li>\n              <li data-testid=\"term11\">Any submissions on behalf of a third party</li>\n              <li data-testid=\"term12\">Requests to be a supplier to The Boeing Company (instead please see <a target=\"_blank\" rel=\"noopener noreferrer\" href={'http://www.boeingsuppliers.com/#/become'}>http://www.boeingsuppliers.com/#/become</a>)</li>\n            </ol>\n          </Typography>\n        </DialogContent>\n        <DialogActions style={{justifyContent: 'center'}}>\n          <Button onClick={handleClose} data-testid='ok-button' color=\"primary\" autoFocus variant=\"contained\">\n            Ok\n          </Button>\n        </DialogActions>\n      </Dialog>\n    </span>\n  );\n}\n","import React from 'react';\nimport {Typography} from '@material-ui/core';\nimport TermsAndConditionsDialog from './TermsAndConditions';\nimport GuideLinesDialog from './GuideLines/indes';\n\nexport const Instructions = () => {\n  return <Typography component=\"p\" variant=\"body1\" className=\"instructions\" data-testid=\"t&c\">\n    Please review Boeing’s <TermsAndConditionsDialog/> and <GuideLinesDialog/> before\n    submitting your idea to\n    Boeing. Please note that in return for your consent to Boeing’s terms and conditions, which include a\n    transfer of ownership and an acknowledgement that Boeing is not obligated to keep your submission or its\n    content confidential, Boeing will review your idea.\n  </Typography>\n};\n","import React, {memo, useState} from 'react';\nimport TextField from '@material-ui/core/TextField/TextField';\n\ninterface Props {\n  name: string;\n  inputProps?: any;\n  label: string;\n  isNumber?: boolean;\n  formik: any;\n}\n\nexport default memo(function Input(props: Props) {\n  const formik = props.formik;\n  const [value, setValue] = useState(props.formik.values[props.name]);\n\n  return <TextField\n    fullWidth={true}\n    size=\"small\"\n    variant=\"outlined\"\n    name={props.name}\n    required={true}\n    inputProps={props.inputProps}\n    label={props.label}\n    value={value}\n    onBlur={formik.handleChange}\n    error={formik.touched[props.name] && Boolean(formik.errors[props.name])}\n    helperText={formik.touched[props.name] && formik.errors[props.name]}\n    onChange={e => {\n      if (props.isNumber) {\n        const onlyNums = e.target.value.replace(/[^0-9]/g, '');\n        setValue(onlyNums);\n      } else {\n        setValue(e.target.value);\n      }\n    }}\n  />;\n})\n","import React, {useState} from 'react';\nimport {FormHelperText, Typography} from '@material-ui/core';\nimport ReactQuill from 'react-quill';\n\nconst formats = [\n  'header', 'size',\n  'bold', 'italic', 'underline', 'strike', 'blockquote',\n  'list', 'bullet', 'indent',\n  'link'\n];\n\nconst modules = {\n  toolbar: [\n    [{'header': '1'}, {'header': '2'}],\n    [{size: []}],\n    ['bold', 'italic', 'underline', 'strike', 'blockquote'],\n    [{'list': 'ordered'}, {'list': 'bullet'},\n      {'indent': '-1'}, {'indent': '+1'}],\n    ['link'],\n    ['clean']\n  ],\n  clipboard: {\n    // toggle to add extra line breaks when pasting HTML:\n    matchVisual: false,\n  }\n};\n\ninterface Props {\n  initialValue: any;\n  formik: any;\n  charCount: any;\n  setCharCount: any;\n}\n\nexport function Editor(props: Props) {\n  const [value, setValue] = useState('');\n  return <>\n    <Typography variant=\"subtitle1\">Describe your idea</Typography>\n    <ReactQuill theme=\"snow\" value={value}\n                formats={formats}\n                modules={modules}\n                data-testid=\"editor\"\n                placeholder={'Please enter your idea here.'}\n                onBlur={e => props.formik.setFieldValue('ideaDescription', value)}\n                onChange={(value, ig, nore, e: any) => {\n                  setValue(value);\n                  props.setCharCount(e.getText().trim().length)\n                }}/>\n    <FormHelperText error={props.charCount > 5000}>{props.charCount}/5000</FormHelperText>\n\n    <FormHelperText\n      error={props.formik.touched.ideaDescription && Boolean(props.formik.errors.ideaDescription)}>{props.formik.touched.ideaDescription && props.formik.errors.ideaDescription}</FormHelperText></>\n}\n","import axios from 'axios';\n\nclass LookupService {\n  getCountries() {\n    return new Promise((resolve, reject) => {\n      axios.get('/api/countries')\n        .then(data => resolve(data))\n        .catch(error => reject(error));\n    });\n  }\n  getStates(countryId: number){\n    return new Promise((resolve, reject) => {\n      axios.get(`/api/states/${countryId}`)\n        .then(data => resolve(data))\n        .catch(error => reject(error));\n    })\n  }\n\n}\n\nconst lookupService = new LookupService();\nexport default lookupService;\n","import React from 'react';\nimport {Autocomplete} from '@material-ui/lab';\nimport {TextField} from '@material-ui/core';\n\ninterface Props {\n  options: Array<CountryType>,\n  name: string;\n  setFieldValue: any;\n  label: string;\n  callback?: any;\n  disabled?:boolean;\n}\n\ninterface CountryType {\n  id: string;\n  name: string;\n  phone: string;\n}\n\nexport default function Dropdown(props: Props) {\n  const {options, disabled, name, setFieldValue, label, callback} = props;\n  const [value, setValue] = React.useState<CountryType | null>(null);\n  return <Autocomplete\n    id={name}\n    options={options}\n    getOptionLabel={(option: CountryType) => option.name}\n    getOptionSelected={option => option.id === value?.id}\n    value={value}\n    onBlur={(e) => {\n      setFieldValue(name, value?.name);\n    }}\n    disabled={disabled}\n    onChange={(event: any, newValue: CountryType | null) => {\n      setValue(newValue);\n      if (callback) {\n        callback(newValue?.id);\n      }\n    }}\n    renderInput={(params) => <TextField data-testid={name} {...params} required name={name} variant=\"outlined\" size=\"small\" label={label}/>}\n  />\n}\n","import axios from 'axios';\n\nclass CaptchaService {\n  getCaptcha = () => new Promise(((resolve, reject) => {\n    axios.get('/api/captcha').then(data => resolve(data)).catch(error => reject(error));\n  }));\n}\nconst captchaService = new CaptchaService();\nexport default captchaService;\n","import axios from 'axios';\n\nclass UnsolicitedIdeasService {\n  submitIdea = (data: any) => new Promise(((resolve, reject) => {\n    axios.post('/api/submit', data)\n      .then(data => resolve(data))\n      .catch(error => reject(error.response));\n  }))\n}\nconst unsolicitedIdeasService = new UnsolicitedIdeasService();\nexport default unsolicitedIdeasService;\n","import React from 'react';\nimport {makeStyles, Paper} from '@material-ui/core/index';\nimport {Done} from '@material-ui/icons';\n\nconst useStyles = makeStyles(theme => ({\n  root: {\n    margin: '50px auto',\n    width: '100%'\n  },\n  successMessage: {\n    padding: 50,\n  },\n  successSymbol: {\n    backgroundColor: '#4caf50',\n    color: '#fff',\n    display: 'flex',\n    justifyContent: 'flext-start',\n\n    alignItems: 'center',\n    height: 50,\n    padding: 10,\n    textAlign: 'center',\n  },\n  successTitle: {\n    marginLeft: 10\n  },\n  icon: {\n    color: '#fff'\n  }\n}));\nexport const Success = () => {\n  const classes = useStyles();\n  return <Paper className={classes.root}>\n    <Paper className={classes.successSymbol}>\n      <Done className={classes.icon}/> <span className={classes.successTitle}>Success</span>\n    </Paper>\n    <div className={classes.successMessage}>\n      Thank you!! Your idea has been successfully submitted for review.\n    </div>\n  </Paper>;\n};\n\n","import React, {useEffect, useState} from 'react';\nimport 'react-quill/dist/quill.snow.css';\nimport {\n  Box,\n  Checkbox, CircularProgress,\n  FormControlLabel,\n  FormHelperText,\n  Grid,\n  IconButton, LinearProgress,\n  makeStyles,\n  Slide,\n  Snackbar,\n  Typography\n} from '@material-ui/core';\nimport './form.css';\nimport {useFormik} from 'formik';\nimport * as yup from 'yup';\nimport Button from '@material-ui/core/Button';\nimport Alert from '@material-ui/lab/Alert';\nimport TextField from '../Components/TextField'\nimport {Refresh} from '@material-ui/icons';\nimport {Editor} from '../Components/Editor';\nimport lookupService from '../services/lookupService';\nimport Dropdown from '../Components/Dropdown';\nimport captchaService from '../services/captchaService';\nimport unsolicitedIdeasService from '../services/unsolicitedIdeasService';\nimport {Success} from '../Success';\n\nconst useStyles = makeStyles(theme => ({\n  submit: {\n    textAlign: 'center',\n    marginTop: 10\n  }\n}));\n\n\nconst validationSchema = yup.object({\n  emailAddress: yup\n    .string()\n    .email('Enter a valid email')\n    .required('Email is required'),\n  firstName: yup.string().required('First Name is required'),\n  lastName: yup.string().required('Last Name is required'),\n  phoneNumber: yup.number().typeError('Phone Number should be a number').required('Phone Number is required'),\n  country: yup.string().required('Country is required'),\n  state: yup.string().required('State is required'),\n  acceptTerms: yup.boolean().oneOf([true], 'This field is mandatory'),\n  consent: yup.boolean().oneOf([true], 'This field is mandatory'),\n  captcha: yup.string().required(\"Please enter the characters\"),\n});\n\nfunction SlideTransition(props: any) {\n  return <Slide {...props} direction=\"up\"/>;\n}\n\nfunction mapValuesToPayload(values: any) {\n  return {\n    firstName: values.firstName,\n    lastName: values.lastName,\n    phone: values.phoneNumber,\n    email: values.emailAddress,\n    country: values.country,\n    state: values.state,\n    description: values.ideaDescription,\n    captcha: values.captcha\n  };\n}\n\nconst initialValues = {\n  firstName: '',\n  lastName: '',\n  phoneNumber: '',\n  emailAddress: '',\n  country: '',\n  state: '',\n  ideaDescription: '',\n  acceptTerms: false,\n  consent: false,\n  captcha: ''\n};\n\nexport const Form = () => {\n  const classes = useStyles();\n  const [open, setOpen] = React.useState(false);\n  const [isLoading, setLoading] = useState(false);\n  const [charCount, setCharCount] = useState(0);\n  const [countries, setCountries] = useState([]);\n  const [captchaUri, setCaptchaUri] = useState('');\n  const [states, setSates] = useState([]);\n  const [statesLoading, setStatesLoading] = useState(false);\n  useEffect(() => {\n    setLoading(true);\n    Promise.all([lookupService.getCountries(), captchaService.getCaptcha()])\n      .then((data: any) => {\n        setLoading(false);\n        setCountries(data[0].data);\n        const svgString = encodeURIComponent(data[1].data);\n        const dataUri = `url(\"data:image/svg+xml,${svgString}\")`;\n        setCaptchaUri(dataUri);\n      });\n  }, []);\n\n  function reFreshCaptcha() {\n    captchaService.getCaptcha().then((data: any) => {\n      const svgString = encodeURIComponent(data.data);\n      const dataUri = `url(\"data:image/svg+xml,${svgString}\")`;\n      setCaptchaUri(dataUri);\n    });\n  }\n\n  function loadStates(countryId: number) {\n    if (countryId) {\n      setStatesLoading(true);\n      lookupService.getStates(countryId).then((data: any) => {\n        setSates(data.data);\n        setStatesLoading(false);\n      });\n    }\n  }\n\n  const handleClick = () => {\n    setOpen(true);\n  };\n\n  const handleClose = (event: any, reason?: any) => {\n    if (reason === 'clickaway') {\n      return;\n    }\n\n    setOpen(false);\n  };\n\n  const formik = useFormik({\n    initialValues,\n    validateOnChange: false,\n    validateOnBlur: true,\n    validationSchema: validationSchema,\n    onSubmit: (values: any, {setErrors, setStatus, setSubmitting}) => {\n\n      if (charCount === 0) {\n        setErrors({ideaDescription: 'Please enter your idea.'});\n        setSubmitting(false);\n      } else if (charCount > 5000) {\n        setErrors({ideaDescription: 'Maximum allowable characters reached.'});\n        setSubmitting(false);\n      } else {\n        unsolicitedIdeasService.submitIdea(mapValuesToPayload(values)).then(data => {\n          setSubmitting(false);\n          setStatus({success: true});\n          handleClick();\n        }).catch(error => {\n          if (error.status === 400) {\n            setErrors({captcha: 'Invalid captcha'});\n          } else {\n            setErrors({submit: 'Something went wrong, please try again later.'});\n          }\n          setSubmitting(false);\n          setStatus({success: false});\n        });\n      }\n    },\n  });\n\n  return formik.status && formik.status.success ? <Success/> : <div className=\"form\">\n    {isLoading && <LinearProgress data-testid=\"loading\" variant=\"indeterminate\"/>}\n    {!isLoading && <Box mt={8}>\n      <Typography variant=\"h2\" color=\"primary\">\n        Unsolicited Ideas – Web Submission Form\n      </Typography>\n      <Box my={4} width={'100%'}>\n        <Box mb={1}><Typography variant=\"subtitle1\">Sender’s Information:</Typography></Box>\n        <Typography component=\"div\" variant=\"body1\">\n          <form onSubmit={formik.handleSubmit} autoComplete=\"off\">\n            <Grid container spacing={2}>\n              <Grid item xs={6}>\n                <TextField\n                  name=\"firstName\"\n                  inputProps={{'data-testid': 'firstName', maxLength: 40}}\n                  label=\"First Name\"\n                  formik={formik}\n                />\n              </Grid>\n              <Grid item xs={6}>\n                <TextField\n                  name=\"lastName\"\n                  label=\"Last Name\"\n                  inputProps={{'data-testid': 'lastName', maxLength: 40}}\n                  formik={formik}\n                />\n              </Grid>\n              <Grid item xs={6}>\n                <TextField\n                  name=\"phoneNumber\"\n                  label=\"Phone Number\"\n                  isNumber={true}\n                  inputProps={{'data-testid': 'phoneNumber', maxLength: 20}}\n                  formik={formik}\n                />\n              </Grid>\n              <Grid item xs={6}>\n                <TextField\n                  name=\"emailAddress\"\n                  label=\"Email Address\"\n                  inputProps={{'data-testid': 'email', maxLength: 50, type: 'email'}}\n                  formik={formik}\n                />\n              </Grid>\n              <Grid item xs={6}>\n                <Dropdown options={countries} name=\"country\" setFieldValue={formik.setFieldValue} label=\"Country\"\n                          callback={(id: number) => {\n                            loadStates(id);\n                            formik.setFieldValue('state', '');\n                          }}/>\n                <FormHelperText\n                  error={formik.touched.country && Boolean(formik.errors.country)}>{formik.touched.country && formik.errors.country}</FormHelperText>\n              </Grid>\n              {states.length > 0 && <Grid item xs={6}>\n\n                <Dropdown options={states.sort((a: any, b: any)=> a.name.localeCompare(b.name))} name=\"state\" disabled={statesLoading} setFieldValue={formik.setFieldValue}\n                          label=\"State\"/>\n                <FormHelperText\n                  error={formik.touched.state && Boolean(formik.errors.state)}>{formik.touched.state && formik.errors.state}</FormHelperText>\n              </Grid>}\n              {states.length === 0 && <Grid item xs={6}> <TextField\n                name=\"state\"\n                label=\"State\"\n                inputProps={{'data-testid': 'state-input'}}\n                formik={formik}\n              /></Grid>}\n\n              <Grid item xs={12}>\n                <Editor initialValue={formik.values.ideaDescription} charCount={charCount} setCharCount={setCharCount}\n                        formik={formik}/>\n\n              </Grid>\n              <Grid item xs={12}>\n\n                <FormControlLabel\n                  control={<Checkbox checked={formik.values.acceptTerms} onChange={formik.handleChange}\n                                     name=\"acceptTerms\"\n                                     color=\"primary\"/>}\n                  label=\"I understand that in submitting my idea I am agreeing to Boeing’s Terms & Conditions.\"\n                />\n                {formik.touched.acceptTerms && Boolean(formik.errors.acceptTerms) &&\n                <FormHelperText error={true}>{formik.touched.acceptTerms && formik.errors.acceptTerms}</FormHelperText>}\n              </Grid>\n              <Grid item xs={12}>\n                <FormControlLabel\n                  style={{display: 'table'}}\n                  control={<div style={{display: 'table-cell'}}>\n                    <Checkbox checked={formik.values.consent}\n                              onChange={formik.handleChange} name=\"consent\"\n                              color=\"primary\"/></div>}\n                  label={<div data-testid=\"agreement2\" className=\"disclaimerandnotes\">I consent to Boeing’s use of my personal information to\n                    process this submission and for related purposes such as communicating with me. Please see our\n                    <a href={' https://www.boeing.com/privacy-and-cookie-policy.page'} target=\"_blank\" rel=\"noopener noreferrer\"> Privacy Statement</a> for details on how Boeing processes and protects your data.</div>}\n                />\n                {formik.touched.consent && Boolean(formik.errors.consent) &&\n                <FormHelperText error={true}>{formik.touched.consent && formik.errors.consent}</FormHelperText>}\n              </Grid>\n            </Grid>\n            <Box mt={3}/>\n            <Grid container justify=\"center\" alignItems=\"center\">\n              <Grid item xs={6}>\n                <Grid container justify=\"center\" alignItems=\"center\">\n                  <Grid item xs={8}>\n                    <div\n                      data-testid=\"captcha\"\n                      style={{\n                        backgroundImage: captchaUri,\n                        width: 300,\n                        height: 60,\n                      }}/>\n                  </Grid>\n                  <Grid item xs={1}>\n                    <IconButton data-testid=\"refresh-captcha\" color=\"primary\" aria-label=\"refresh captcha\"\n                                onClick={reFreshCaptcha}>\n                      <Refresh/>\n                    </IconButton>\n                  </Grid>\n                </Grid>\n              </Grid>\n\n            </Grid>\n            <Grid container justify=\"center\">\n              <Grid item xs={12} md={5}>\n                <Box mt={1}>\n                  <TextField\n                    name=\"captcha\"\n                    inputProps={{'data-testid': 'captcha-input'}}\n                    label=\"Type the characters you see in the image\"\n                    formik={formik}\n                  /></Box>\n              </Grid>\n              {formik.errors.submit && (\n                <Grid item xs={12}>\n                  <FormHelperText error className={classes.submit}>\n                    {formik.errors.submit}\n                  </FormHelperText>\n                </Grid>\n              )}\n              <Grid item xs={12} className={classes.submit}>\n                <Button color=\"primary\" variant=\"contained\" type=\"submit\" disabled={formik.isSubmitting}\n                        data-testid=\"submit\"\n                        startIcon={formik.isSubmitting && <CircularProgress size={20} variant=\"indeterminate\"/>}>\n                  Submit\n                </Button>\n              </Grid>\n            </Grid>\n          </form>\n        </Typography>\n      </Box>\n    </Box>}\n    <Snackbar open={open} autoHideDuration={6000} onClose={handleClose} TransitionComponent={SlideTransition}>\n      <Alert onClose={handleClose} severity=\"success\">\n        Thank you for sharing your idea.\n      </Alert>\n    </Snackbar>\n  </div>\n};\n","import React, {useState} from 'react';\nimport './App.css';\nimport Header from './layout/Header';\nimport {Footer} from './layout/Footer';\nimport {Box, Button, Container} from '@material-ui/core';\nimport {Instructions} from './Instructions';\nimport {Form} from './Form';\n\nfunction App() {\n  const [accepted, setAccepted] = useState(false);\n  return (\n    <div className=\"App\">\n      <Header/>\n      <Container maxWidth=\"md\" className=\"content\">\n        {!accepted && <div>\n          <Box mt={20}>\n            <Instructions/>\n          </Box>\n          <Box mx=\"auto\" mt={5} className=\"continue-button\">\n            <Button variant=\"contained\" color=\"primary\" onClick={_ => setAccepted(true)}>\n              To submit your idea, click here\n            </Button>\n          </Box>\n        </div>}\n        {accepted && <Form/>}\n      </Container>\n      <Footer/>\n    </div>\n  );\n}\n\nexport default App;\n","import { ReportHandler } from 'web-vitals';\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n  if (onPerfEntry && onPerfEntry instanceof Function) {\n    import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n      getCLS(onPerfEntry);\n      getFID(onPerfEntry);\n      getFCP(onPerfEntry);\n      getLCP(onPerfEntry);\n      getTTFB(onPerfEntry);\n    });\n  }\n};\n\nexport default reportWebVitals;\n","import {createTheme} from '@material-ui/core/styles';\n\nexport const theme = createTheme({\n  overrides: {\n    MuiFormLabel: {\n      asterisk: {\n        color: '#db3131',\n        '&$error': {\n          color: '#db3131'\n        },\n      }\n    }\n  },\n  palette: {\n    primary: {\n      light: '#335bb3',\n      main: '#0033a1',\n      dark: '#002370',\n      contrastText: '#ffffff',\n    },\n    secondary: {\n      light: '#33afe5',\n      main: '#009BDF',\n      dark: '#006c9c',\n      contrastText: '#ffffff',\n    },\n    text: {\n      disabled: \"rgba(0, 0, 0, 0.38)\",\n      hint: \"rgba(0, 0, 0, 0.38)\",\n      primary: \"rgba(0, 0, 0, 0.9)\",\n      secondary: \"rgba(0, 0, 0,.75)\",\n    }\n  },\n  typography: {\n    h1: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '32px',\n      lineHeight: '34px'\n    },\n    h2: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '24px',\n      lineHeight: '32px',\n      fontWeight: 600\n    },\n    h3: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '18px',\n      lineHeight: '24px'\n    },\n    h4: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '15px',\n      lineHeight: '20px'\n    },\n    h5: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '13px',\n      lineHeight: '16px'\n    },\n    h6: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '12px',\n      lineHeight: '15px'\n    },\n    body1: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '16px',\n    },\n    body2: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n      fontSize: '16px',\n      fontWeight: 600\n    },\n    button: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n    },\n    caption: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n    },\n    subtitle1: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n    },\n    subtitle2: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n    },\n    overline: {\n      fontFamily: ['\"HelveticaNeueW01-55Roma\"', 'Arial', 'sans-serif'].join(','),\n    },\n  }\n});\n","import 'react-app-polyfill/ie11';\nimport 'react-app-polyfill/stable';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './app/App';\nimport reportWebVitals from './reportWebVitals';\nimport {CssBaseline} from '@material-ui/core';\nimport {ThemeProvider} from '@material-ui/core/styles';\nimport {theme} from './theme';\n\nReactDOM.render(\n  <React.StrictMode>\n    <ThemeProvider theme={theme}>\n      <CssBaseline/>\n      <App/>\n    </ThemeProvider>\n  </React.StrictMode>,\n  document.getElementById(\n    'root')\n);\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"sourceRoot":""}