aboutsummaryrefslogtreecommitdiff
path: root/src/pages/FeedPage/FeedPage.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/pages/FeedPage/FeedPage.tsx')
-rw-r--r--src/pages/FeedPage/FeedPage.tsx20
1 files changed, 17 insertions, 3 deletions
diff --git a/src/pages/FeedPage/FeedPage.tsx b/src/pages/FeedPage/FeedPage.tsx
index b7d719e..0017275 100644
--- a/src/pages/FeedPage/FeedPage.tsx
+++ b/src/pages/FeedPage/FeedPage.tsx
@@ -1,14 +1,17 @@
import React, { useState, useEffect } from 'react';
-import { Poll } from 'which-types';
+import { Poll, User } from 'which-types';
import Feed from '../../components/Feed/Feed';
import { get } from '../../requests';
+import PollSubmission from './PollSubmission';
+
interface PropTypes {
navigate: (prefix: string, id: string) => void;
+ user: User | undefined;
}
-const FeedPage: React.FC<PropTypes> = ({ navigate }) => {
+const FeedPage: React.FC<PropTypes> = ({ navigate, user }) => {
const [polls, setPolls] = useState<Poll[]>([]);
useEffect(() => {
@@ -17,7 +20,18 @@ const FeedPage: React.FC<PropTypes> = ({ navigate }) => {
});
}, []);
- return <Feed polls={polls} navigate={navigate} />;
+ const addPoll = (poll: Poll): void => {
+ polls.unshift(poll);
+ setPolls([...polls]);
+ };
+
+
+ return (
+ <>
+ {user && <PollSubmission user={user} addPoll={addPoll} />}
+ <Feed polls={polls} navigate={navigate} />
+ </>
+ );
};
export default FeedPage;