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/components/UploadImage/UploadImage.tsx | |
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/components/UploadImage/UploadImage.tsx')
-rw-r--r-- | src/components/UploadImage/UploadImage.tsx | 20 |
1 files changed, 18 insertions, 2 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> |