From 39d678daf5b03ce95b60a79679f57b0e4cdd9b71 Mon Sep 17 00:00:00 2001 From: SUNNY KUMAR Date: Sat, 9 Sep 2023 21:11:14 +0530 Subject: [PATCH 1/6] feat: implement new poll feature --- .../admin_v2/Poll/PolllDialogBox.js | 150 ++++++++++++++++++ client/src/pages/admin_v2/poll.jsx | 53 +++++++ client/src/screens/admin_v2/Poll.jsx | 77 +++++++++ 3 files changed, 280 insertions(+) create mode 100644 client/src/components/admin_v2/Poll/PolllDialogBox.js create mode 100644 client/src/pages/admin_v2/poll.jsx create mode 100644 client/src/screens/admin_v2/Poll.jsx diff --git a/client/src/components/admin_v2/Poll/PolllDialogBox.js b/client/src/components/admin_v2/Poll/PolllDialogBox.js new file mode 100644 index 00000000..6c0238e5 --- /dev/null +++ b/client/src/components/admin_v2/Poll/PolllDialogBox.js @@ -0,0 +1,150 @@ +import React, { useEffect, useState } from 'react'; +import { + Button, + Dialog, + DialogContent, + DialogTitle, + FormControl, + InputLabel, + MenuItem, + Select, + TextField, + Typography, +} from '@mui/material'; +import makeStyles from '@mui/styles/makeStyles'; + +const DialogPoll = ({ dialogBoxOpen, setDialogBoxOpen }) => { + const [value, setValue] = useState(0); + const [live, setLive] = useState('offline'); + const [Options, setOptions] = useState(''); + const DialogBoxClose = () => { + setDialogBoxOpen(false); + setValue(0); + setLive('offline'); + }; + const handleOptions = (e) => { + setOptions(e.target.value); + }; + const handleValue = (e) => { + setValue(e.target.value); + }; + const handleLive = () => { + setLive('Live'); + }; + const handleSave = () => { + DialogBoxClose(); + }; + const classes = useStyles(); + useEffect(() => { + console.log(live); + }, [live]); + return ( + <> + + + Create Poll + + {live === 'offline' ? ( + +
+ Question + +
+ + Options + + + {[...Array(value).keys()].map((num) => { + return ( +
+ handleOptions(e)} + key={num} + placeholder={`Poll Option ${num + 1}`} + variant='outlined' + margin='dense' + fullWidth + /> +
+ ); + })} +
+ ) : ( + + Poll Going Live + + )} + +
+ + +
+
+ + ); +}; +const useStyles = makeStyles((theme) => ({ + dialogtitle: { + textAlign: 'center', + }, + btnbox: { + display: 'flex', + justifyContent: 'end', + }, + livebtn: { + width: '3rem', + margin: '1rem 1rem 1rem 0', + backgroundColor: 'green', + color: '#fff', + '&:hover': { + backgroundColor: '#f50057', + }, + }, + livereturn: { + display: 'flex', + justifyContent: 'center', + alignItems: 'center', + height: '10rem', + width: '100%', + }, +})); +export default DialogPoll; diff --git a/client/src/pages/admin_v2/poll.jsx b/client/src/pages/admin_v2/poll.jsx new file mode 100644 index 00000000..737345d1 --- /dev/null +++ b/client/src/pages/admin_v2/poll.jsx @@ -0,0 +1,53 @@ +import React from 'react'; +import Poll from '../../screens/admin_v2/Poll'; +import getAccess from '../../utils/getAccess'; +import { parseCookies } from 'nookies'; +import { getGraphClient } from '../../context/ApolloContextProvider'; +import Custom500 from '../500.jsx'; + +const PollPage = ({ isError, PollList }) => { + if (isError) { + return ; + } + return ; +}; +export default PollPage; +export async function getServerSideProps(ctx) { + try { + const requiredPermissions = ['poll.write.restricted']; + const userPermissions = await getAccess({ ctx }); + + if (!userPermissions.data) { + return { + redirect: { + destination: '/', + permanent: false, + }, + }; + } + + const acsessPermitted = requiredPermissions.every((permission) => { + return userPermissions?.data?.includes(permission); + }); + + if (!acsessPermitted) { + return { + redirect: { + destination: '/', + permanent: false, + }, + }; + } + const cookies = parseCookies(ctx); + const graphClient = getGraphClient(false, cookies.firebaseToken); + return { + props: { userPermissions }, + }; + } catch { + return { + props: { + isError: true, + }, + }; + } +} diff --git a/client/src/screens/admin_v2/Poll.jsx b/client/src/screens/admin_v2/Poll.jsx new file mode 100644 index 00000000..65f328a6 --- /dev/null +++ b/client/src/screens/admin_v2/Poll.jsx @@ -0,0 +1,77 @@ +import React, { useEffect, useState } from 'react'; +import Marginals from '../../components/admin_v2/Marginals/Marginals'; +//mui +import { styled } from '@mui/material/styles'; +import Table from '@mui/material/Table'; +import TableBody from '@mui/material/TableBody'; +import TableCell, { tableCellClasses } from '@mui/material/TableCell'; +import TableHead from '@mui/material/TableHead'; +import TableRow from '@mui/material/TableRow'; +import EditIcon from '@mui/icons-material/Edit'; +import DeleteIcon from '@mui/icons-material/Delete'; +import Button from '@mui/material/Button'; +import AddCircleOutlineIcon from '@mui/icons-material/AddCircleOutline'; +import DialogPoll from '../../components/admin_v2/Poll/PolllDialogBox'; + +const StyledTableCell = styled(TableCell)(({ theme }) => ({ + [`&.${tableCellClasses.head}`]: { + backgroundColor: theme.palette.common.black, + color: theme.palette.common.white, + }, + [`&.${tableCellClasses.body}`]: { + fontSize: 13, + }, +})); + +const StyledTableRow = styled(TableRow)(({ theme }) => ({ + '&:nth-of-type(odd)': { + backgroundColor: theme.palette.action.hover, + }, + // hide last border + '&:last-child td, &:last-child th': { + border: 0, + }, +})); + +const Poll = ({ PollList }) => { + const [dialogBoxOpen, setDialogBoxOpen] = useState(false); + const handleDialogBoxOpen = () => setDialogBoxOpen(true); + return ( + <> +
+ + + + + + + Content + Date + Timer + Status + Edit + Delete + + + +
+ +
+
+ + ); +}; +export default Poll; From 03753334c0dd775dfee8c468f8bec203f98af4d4 Mon Sep 17 00:00:00 2001 From: SUNNY KUMAR <123469525+SUNNYKUMAR1232@users.noreply.github.com> Date: Fri, 15 Sep 2023 19:03:08 +0530 Subject: [PATCH 2/6] Update PolllDialogBox.js --- client/src/components/admin_v2/Poll/PolllDialogBox.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/client/src/components/admin_v2/Poll/PolllDialogBox.js b/client/src/components/admin_v2/Poll/PolllDialogBox.js index 6c0238e5..6c69d6f2 100644 --- a/client/src/components/admin_v2/Poll/PolllDialogBox.js +++ b/client/src/components/admin_v2/Poll/PolllDialogBox.js @@ -35,9 +35,7 @@ const DialogPoll = ({ dialogBoxOpen, setDialogBoxOpen }) => { DialogBoxClose(); }; const classes = useStyles(); - useEffect(() => { - console.log(live); - }, [live]); + return ( <> Date: Thu, 21 Sep 2023 12:26:47 +0530 Subject: [PATCH 3/6] Update PolllDialogBox.js --- .../admin_v2/Poll/PolllDialogBox.js | 24 +++++++++++-------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/client/src/components/admin_v2/Poll/PolllDialogBox.js b/client/src/components/admin_v2/Poll/PolllDialogBox.js index 6c69d6f2..26e2eb0e 100644 --- a/client/src/components/admin_v2/Poll/PolllDialogBox.js +++ b/client/src/components/admin_v2/Poll/PolllDialogBox.js @@ -47,7 +47,7 @@ const DialogPoll = ({ dialogBoxOpen, setDialogBoxOpen }) => { fullWidth maxWidth='md' > - + Create Poll {live === 'offline' ? ( @@ -58,7 +58,7 @@ const DialogPoll = ({ dialogBoxOpen, setDialogBoxOpen }) => { multiline variant='outlined' placeholder='Poll Question' - sx={{ width: '100%', marginBottom: '1rem ', marginTop: '1rem' }} + className={classes.QuestionInputField} > @@ -93,14 +93,14 @@ const DialogPoll = ({ dialogBoxOpen, setDialogBoxOpen }) => { })} ) : ( - + Poll Going Live )} -
+
@@ -93,14 +93,14 @@ const DialogPoll = ({ dialogBoxOpen, setDialogBoxOpen }) => { })} ) : ( - + Poll Going Live )} -
+