diff options
| author | Eugene Sokolov <eug-vs@keemail.me> | 2020-06-30 02:40:10 +0300 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-06-30 02:40:10 +0300 | 
| commit | fc552cbf3ffcba6d2cc7003936f4b55378541525 (patch) | |
| tree | 3968694e3b21149e129f60a255b53c6f2dcff09f /src | |
| parent | 720a32c4cb1697f3a8f90973f28c334551ab87ff (diff) | |
| parent | be0a035e662e3b7c1b7c8d62abd16b0c7f37bca1 (diff) | |
| download | which-ui-fc552cbf3ffcba6d2cc7003936f4b55378541525.tar.gz | |
Merge pull request #53 from which-ecosystem/urlValidation
Url validation
Diffstat (limited to 'src')
| -rw-r--r-- | src/components/UploadImage/UploadImage.tsx | 20 | ||||
| -rw-r--r-- | src/pages/FeedPage/PollSubmissionImage.tsx | 10 | 
2 files changed, 24 insertions, 6 deletions
| diff --git a/src/components/UploadImage/UploadImage.tsx b/src/components/UploadImage/UploadImage.tsx index e6f6d05..f5e680d 100644 --- a/src/components/UploadImage/UploadImage.tsx +++ b/src/components/UploadImage/UploadImage.tsx @@ -6,6 +6,7 @@ import DialogActions from '@material-ui/core/DialogActions';  import DialogContent from '@material-ui/core/DialogContent';  import DialogContentText from '@material-ui/core/DialogContentText';  import DialogTitle from '@material-ui/core/DialogTitle'; +import get from 'axios';  interface PropTypes {    isOpen: boolean; @@ -15,14 +16,27 @@ interface PropTypes {  const UploadImage: React.FC<PropTypes> = ({ setIsOpen, isOpen, callback }) => {    const [url, setUrl] = useState(''); +  const [isError, setIsError] = useState(false); +    const handleClose = () => {      setIsOpen(false);    };    const handleSubmit = () => { -    callback(url || ''); -    setIsOpen(false); +    get(url).then(res => { +      if (res.headers['content-type'] === 'image/jpeg') { +        callback(url || ''); +        setIsOpen(false); +        setIsError(false); +      } else { +        // console.warn(res); TODO: handle error if response status is ok but not an image +        setIsError(true); +      } +    }).catch(() => { +      // console.warn(err); TODO: handle error if resposne status is not ok +      setIsError(true); +    });    };    const handleChange = (event:React.ChangeEvent<HTMLInputElement>) => { @@ -46,6 +60,8 @@ const UploadImage: React.FC<PropTypes> = ({ setIsOpen, isOpen, callback }) => {              fullWidth              autoComplete="off"              onChange={handleChange} +            error={isError} +            helperText={isError === true ? 'invalid Url!' : ''}            />          </DialogContent>          <DialogActions> diff --git a/src/pages/FeedPage/PollSubmissionImage.tsx b/src/pages/FeedPage/PollSubmissionImage.tsx index e2ffad3..a8ec437 100644 --- a/src/pages/FeedPage/PollSubmissionImage.tsx +++ b/src/pages/FeedPage/PollSubmissionImage.tsx @@ -57,7 +57,6 @@ const PollSubmissionImage: React.FC<PropTypes> = ({ url, setUrl }) => {      <>        <CloudUploadIcon fontSize="large" color="primary" />        <Typography variant="h5"> Upload an image </Typography> -      <UploadImage isOpen={isModalOpen} setIsOpen={setIsModalOpen} callback={setUrl} />      </>    ); @@ -73,9 +72,12 @@ const PollSubmissionImage: React.FC<PropTypes> = ({ url, setUrl }) => {    );    return ( -    <CardActionArea onClick={handleClick} className={classes.root}> -      {url ? Media : Upload} -    </CardActionArea> +    <> +      <CardActionArea onClick={handleClick} className={classes.root}> +        {url ? Media : Upload} +      </CardActionArea> +      <UploadImage isOpen={isModalOpen} setIsOpen={setIsModalOpen} callback={setUrl} /> +    </>    );  }; | 
