aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/pages/FeedPage/FeedPage.tsx8
-rw-r--r--src/pages/FeedPage/PollSubmission.tsx49
-rw-r--r--src/pages/FeedPage/PollSubmissionImage.tsx32
3 files changed, 43 insertions, 46 deletions
diff --git a/src/pages/FeedPage/FeedPage.tsx b/src/pages/FeedPage/FeedPage.tsx
index 329647e..0017275 100644
--- a/src/pages/FeedPage/FeedPage.tsx
+++ b/src/pages/FeedPage/FeedPage.tsx
@@ -20,9 +20,15 @@ const FeedPage: React.FC<PropTypes> = ({ navigate, user }) => {
});
}, []);
+ const addPoll = (poll: Poll): void => {
+ polls.unshift(poll);
+ setPolls([...polls]);
+ };
+
+
return (
<>
- {user && <PollSubmission user={user} polls={polls} setPolls={setPolls} />}
+ {user && <PollSubmission user={user} addPoll={addPoll} />}
<Feed polls={polls} navigate={navigate} />
</>
);
diff --git a/src/pages/FeedPage/PollSubmission.tsx b/src/pages/FeedPage/PollSubmission.tsx
index 9b1ac95..16c8350 100644
--- a/src/pages/FeedPage/PollSubmission.tsx
+++ b/src/pages/FeedPage/PollSubmission.tsx
@@ -7,18 +7,17 @@ import {
ClickAwayListener,
Divider
} from '@material-ui/core';
-import { User, Poll } from 'which-types';
+import { User, Poll, Which } from 'which-types';
import PollSubmissionImage from './PollSubmissionImage';
import UserStrip from '../../components/UserStrip/UserStrip';
import { post } from '../../requests';
import { Contents } from './types';
-
interface PropTypes{
user: User;
- polls: Poll[];
- setPolls: (newPoll: Poll[])=> void;
+ addPoll: (poll: Poll) => void;
}
+
const useStyles = makeStyles(theme => ({
root: {
height: theme.spacing(50),
@@ -26,30 +25,32 @@ const useStyles = makeStyles(theme => ({
}
}));
-const PollSubmission: React.FC<PropTypes> = ({ user, polls, setPolls }) => {
+const emptyContents: Contents = {
+ left: { url: '' },
+ right: { url: '' }
+};
+
+const PollSubmission: React.FC<PropTypes> = ({ user, addPoll }) => {
const classes = useStyles();
const [expanded, setExpanded] = useState(false);
- const [contents, setContents] = useState<Contents>({
- left: {
- url: ''
- },
- right: {
- url: ''
- }
- });
+ const [contents, setContents] = useState<Contents>(emptyContents);
+
+ const readyToSubmit = contents.left.url && contents.right.url;
+
+ const setUrl = (which: Which) => (url: string): void => {
+ setContents({ ...contents, [which]: { url } });
+ };
const handleClickAway = () => {
setExpanded(false);
};
const handleClick = () => {
- if (expanded) {
- if (contents.left.url && contents.right.url) {
- post('/polls/', { authorId: user._id, contents }).then(res => {
- polls.unshift({ ...res.data });
- setPolls([...polls]);
- });
- }
+ if (expanded && readyToSubmit) {
+ post('/polls/', { authorId: user._id, contents }).then(response => {
+ addPoll(response.data);
+ });
+ setContents({ ...emptyContents });
}
setExpanded(!expanded);
};
@@ -61,18 +62,18 @@ const PollSubmission: React.FC<PropTypes> = ({ user, polls, setPolls }) => {
<UserStrip user={user} info="" navigate={() => {}} />
<Divider />
<div className={classes.root}>
- <PollSubmissionImage which="left" setContents={setContents} contents={contents} />
- <PollSubmissionImage which="right" setContents={setContents} contents={contents} />
+ <PollSubmissionImage url={contents.left.url} setUrl={setUrl('left')} />
+ <PollSubmissionImage url={contents.right.url} setUrl={setUrl('right')} />
</div>
</Collapse>
<Button
color="primary"
- disabled={expanded && !(contents.left.url && contents.right.url)}
+ disabled={expanded && !readyToSubmit}
variant={expanded ? 'contained' : 'outlined'}
onClick={handleClick}
fullWidth
>
- {expanded ? 'Submit' : 'Create a Poll' }
+ {expanded ? 'Submit' : 'Create a Poll'}
</Button>
</Card>
</ClickAwayListener>
diff --git a/src/pages/FeedPage/PollSubmissionImage.tsx b/src/pages/FeedPage/PollSubmissionImage.tsx
index 3c2eb8e..1e9fa0e 100644
--- a/src/pages/FeedPage/PollSubmissionImage.tsx
+++ b/src/pages/FeedPage/PollSubmissionImage.tsx
@@ -3,15 +3,12 @@ import { makeStyles } from '@material-ui/core/styles';
import CloudUploadIcon from '@material-ui/icons/CloudUpload';
import { CardActionArea, CardMedia, Typography } from '@material-ui/core';
import CancelOutlinedIcon from '@material-ui/icons/CancelOutlined';
-import _ from 'lodash';
import UploadImage from '../../components/UploadImage/UploadImage';
-import { Contents } from './types';
interface PropTypes {
- contents: Contents;
- setContents: (newContents: Contents) => void;
- which: 'left' | 'right';
+ url: string;
+ setUrl: (url: string) => void;
}
const useStyles = makeStyles({
@@ -35,29 +32,22 @@ const useStyles = makeStyles({
});
-const PollSubmissionImage: React.FC<PropTypes> = ({ setContents, which, contents }) => {
+const PollSubmissionImage: React.FC<PropTypes> = ({ url, setUrl }) => {
const classes = useStyles();
const [isModalOpen, setIsModalOpen] = useState(false);
- const [image, setImage] = useState('');
- const [clearIconDisplay, setClearIconDisplay] = useState(false);
-
- const patchUrl = (url: string): void => {
- setImage(url);
- const newContents = _.set(contents, which, { url });
- setContents({ ...newContents });
- };
+ const [isMediaHover, setIsMediaHover] = useState(false);
const handleClick = (): void => {
- if (image) patchUrl('');
+ if (url) setUrl('');
else setIsModalOpen(!isModalOpen);
};
const handleMouseEnter = (): void => {
- setClearIconDisplay(true);
+ setIsMediaHover(true);
};
const handleMouseLeave = (): void => {
- setClearIconDisplay(false);
+ setIsMediaHover(false);
};
@@ -65,24 +55,24 @@ const PollSubmissionImage: React.FC<PropTypes> = ({ setContents, which, contents
<>
<CloudUploadIcon fontSize="large" color="primary" />
<Typography variant="h5"> Upload an image </Typography>
- <UploadImage isOpen={isModalOpen} setIsOpen={setIsModalOpen} callback={patchUrl} />
+ <UploadImage isOpen={isModalOpen} setIsOpen={setIsModalOpen} callback={setUrl} />
</>
);
const Media = (
<CardMedia
- image={image}
+ image={url}
className={classes.media}
onMouseEnter={handleMouseEnter}
onMouseLeave={handleMouseLeave}
>
- {clearIconDisplay && <CancelOutlinedIcon className={classes.clearIcon} />}
+ {isMediaHover && <CancelOutlinedIcon className={classes.clearIcon} />}
</CardMedia>
);
return (
<CardActionArea onClick={handleClick} className={classes.root}>
- {image ? Media : Upload}
+ {url ? Media : Upload}
</CardActionArea>
);
};