From d04929c869dac9feb1439778f90101a40212c0eb Mon Sep 17 00:00:00 2001 From: santoniriccardo Date: Tue, 1 Mar 2022 15:29:20 -0500 Subject: [PATCH] Large improvements to order page, with inclusion of list of order items, donut picture, as well as sum over all elemnts of order --- .../src/components/Customer/CustomerMenu.tsx | 36 +-- frontend/src/components/Donuts/Donut.tsx | 5 + .../src/components/Donuts/donutImages.tsx | 20 ++ .../components/Employee/EmployeeDashboard.tsx | 102 ++++---- frontend/src/components/Employee/Orders.tsx | 228 ++++++++++-------- .../src/components/Home/ResponsiveAppBar.tsx | 27 ++- 6 files changed, 215 insertions(+), 203 deletions(-) create mode 100644 frontend/src/components/Donuts/Donut.tsx create mode 100644 frontend/src/components/Donuts/donutImages.tsx diff --git a/frontend/src/components/Customer/CustomerMenu.tsx b/frontend/src/components/Customer/CustomerMenu.tsx index 306555f..03eb0d6 100644 --- a/frontend/src/components/Customer/CustomerMenu.tsx +++ b/frontend/src/components/Customer/CustomerMenu.tsx @@ -1,5 +1,4 @@ import { - AppBar, Box, Button, Card, @@ -9,39 +8,12 @@ import { Container, CssBaseline, Grid, - Toolbar, Typography } from '@mui/material'; -import RestaurantMenuTwoToneIcon from '@mui/icons-material/RestaurantMenuTwoTone'; -import { Link } from 'react-router-dom'; import React, { useEffect } from 'react'; - -const donutImages = { - 'Apple Krumb': require('../../assets/apple_krumb.jpeg'), - 'Bavarian Kreme': require('../../assets/bavarian_kreme.jpeg'), - Blueberry: require('../../assets/blueberry.jpeg'), - 'Boston Kreme': require('../../assets/boston_kreme.jpeg'), - 'Chocolate Frosted': require('../../assets/chocolate_frosted.jpeg'), - 'Chocolate Glaze': require('../../assets/chocolate_glaze.jpeg'), - 'Cinnamon Sugar': require('../../assets/cinnamon_sugar.jpeg'), - 'Marble Frosted': require('../../assets/marble_frosted.jpeg'), - 'Old Fashioned': require('../../assets/old_fashioned.jpeg'), - 'Original Glaze': require('../../assets/original_glaze.jpeg'), - 'Powdered Sugar': require('../../assets/powdered_sugar.jpeg'), - 'Sour Cream': require('../../assets/sour_cream.jpeg'), - 'Strawberry Frosted': require('../../assets/strawberry_frosted.jpeg'), - 'Vanilla Frosted': require('../../assets/vanilla_frosted.jpeg'), - Coconut: require('../../assets/coconut.jpeg'), - Cruller: require('../../assets/cruller.jpeg'), - Jelly: require('../../assets/jelly.jpeg'), - 'Chocolate Kreme': require('../../assets/chocolate_kreme.jpeg') -}; - -export interface Donut { - id: string; - flavor: string; - price: number; -} +import { Link } from 'react-router-dom'; +import DonutInterface from '../Donuts/Donut'; +import { donutImages } from '../Donuts/donutImages'; function Copyright() { return ( @@ -57,7 +29,7 @@ function Copyright() { } function Menu() { - const [donuts, setDonuts] = React.useState>([]); + const [donuts, setDonuts] = React.useState>([]); async function fetchDonuts() { try { diff --git a/frontend/src/components/Donuts/Donut.tsx b/frontend/src/components/Donuts/Donut.tsx new file mode 100644 index 0000000..40083e5 --- /dev/null +++ b/frontend/src/components/Donuts/Donut.tsx @@ -0,0 +1,5 @@ +export default interface DonutInterface { + id: string; + flavor: string; + price: number; +} diff --git a/frontend/src/components/Donuts/donutImages.tsx b/frontend/src/components/Donuts/donutImages.tsx new file mode 100644 index 0000000..62bd450 --- /dev/null +++ b/frontend/src/components/Donuts/donutImages.tsx @@ -0,0 +1,20 @@ +export var donutImages = { + 'Apple Krumb': require('../../assets/apple_krumb.jpeg'), + 'Bavarian Kreme': require('../../assets/bavarian_kreme.jpeg'), + Blueberry: require('../../assets/blueberry.jpeg'), + 'Boston Kreme': require('../../assets/boston_kreme.jpeg'), + 'Chocolate Frosted': require('../../assets/chocolate_frosted.jpeg'), + 'Chocolate Glaze': require('../../assets/chocolate_glaze.jpeg'), + 'Cinnamon Sugar': require('../../assets/cinnamon_sugar.jpeg'), + 'Marble Frosted': require('../../assets/marble_frosted.jpeg'), + 'Old Fashioned': require('../../assets/old_fashioned.jpeg'), + 'Original Glaze': require('../../assets/original_glaze.jpeg'), + 'Powdered Sugar': require('../../assets/powdered_sugar.jpeg'), + 'Sour Cream': require('../../assets/sour_cream.jpeg'), + 'Strawberry Frosted': require('../../assets/strawberry_frosted.jpeg'), + 'Vanilla Frosted': require('../../assets/vanilla_frosted.jpeg'), + Coconut: require('../../assets/coconut.jpeg'), + Cruller: require('../../assets/cruller.jpeg'), + Jelly: require('../../assets/jelly.jpeg'), + 'Chocolate Kreme': require('../../assets/chocolate_kreme.jpeg') +}; diff --git a/frontend/src/components/Employee/EmployeeDashboard.tsx b/frontend/src/components/Employee/EmployeeDashboard.tsx index be62bb4..610009a 100644 --- a/frontend/src/components/Employee/EmployeeDashboard.tsx +++ b/frontend/src/components/Employee/EmployeeDashboard.tsx @@ -1,46 +1,42 @@ import ChevronLeftIcon from '@mui/icons-material/ChevronLeft'; import Box from '@mui/material/Box'; -import Container from '@mui/material/Container'; import Divider from '@mui/material/Divider'; import MuiDrawer from '@mui/material/Drawer'; -import Grid from '@mui/material/Grid'; import IconButton from '@mui/material/IconButton'; import List from '@mui/material/List'; -import Paper from '@mui/material/Paper'; import { styled } from '@mui/material/styles'; import Toolbar from '@mui/material/Toolbar'; import * as React from 'react'; import { mainListItems } from './listItems'; import Orders from './Orders'; - const drawerWidth: number = 240; -const Drawer = styled(MuiDrawer, { shouldForwardProp: (prop) => prop !== 'open' })( - ({ theme, open }) => ({ - '& .MuiDrawer-paper': { - position: 'relative', - whiteSpace: 'nowrap', - width: drawerWidth, +const Drawer = styled(MuiDrawer, { + shouldForwardProp: (prop) => prop !== 'open' +})(({ theme, open }) => ({ + '& .MuiDrawer-paper': { + position: 'relative', + whiteSpace: 'nowrap', + width: drawerWidth, + transition: theme.transitions.create('width', { + easing: theme.transitions.easing.sharp, + duration: theme.transitions.duration.enteringScreen + }), + boxSizing: 'border-box', + ...(!open && { + overflowX: 'hidden', transition: theme.transitions.create('width', { easing: theme.transitions.easing.sharp, - duration: theme.transitions.duration.enteringScreen, - }), - boxSizing: 'border-box', - ...(!open && { - overflowX: 'hidden', - transition: theme.transitions.create('width', { - easing: theme.transitions.easing.sharp, - duration: theme.transitions.duration.leavingScreen, - }), - width: theme.spacing(7), - [theme.breakpoints.up('sm')]: { - width: theme.spacing(9), - }, + duration: theme.transitions.duration.leavingScreen }), - }, - }), -); + width: theme.spacing(7), + [theme.breakpoints.up('sm')]: { + width: theme.spacing(9) + } + }) + } +})); function DashboardContent() { const [open, setOpen] = React.useState(true); @@ -49,41 +45,33 @@ function DashboardContent() { }; return ( - - - - - - - - - - {mainListItems} - - - + + - - - - - - - - - + + + + + + {mainListItems} + + + + + ); } diff --git a/frontend/src/components/Employee/Orders.tsx b/frontend/src/components/Employee/Orders.tsx index 9661aa7..770ce85 100644 --- a/frontend/src/components/Employee/Orders.tsx +++ b/frontend/src/components/Employee/Orders.tsx @@ -5,20 +5,25 @@ import { Card, CardActions, CardContent, - Checkbox, - FormControl, - FormControlLabel, InputLabel } from '@mui/material'; -import { grey, red } from '@mui/material/colors'; -import { styled, Theme } from '@mui/material/styles'; -import Table from '@mui/material/Table'; +import Avatar from '@mui/material/Avatar'; +import Container from '@mui/material/Container'; import Grid from '@mui/material/Grid'; +import List from '@mui/material/List'; +import ListItem from '@mui/material/ListItem'; +import ListItemAvatar from '@mui/material/ListItemAvatar'; +import ListItemIcon from '@mui/material/ListItemIcon'; +import ListItemText from '@mui/material/ListItemText'; +import { Theme } from '@mui/material/styles'; +import Table from '@mui/material/Table'; import TableBody from '@mui/material/TableBody'; import TableRow from '@mui/material/TableRow'; +import Typography from '@mui/material/Typography'; import { createStyles, makeStyles } from '@mui/styles'; import React, { useEffect } from 'react'; -import Title from './Title'; +import DonutInterface from '../Donuts/Donut'; +import { donutImages } from '../Donuts/donutImages'; // TODO (rsantoni) : Improve interface with all relevant details @@ -26,7 +31,7 @@ export interface Order { id: number; first_name: string; last_name: string; - items: string[]; + items: Array; price: number; } @@ -34,25 +39,6 @@ export interface Order { // /*TODO Funmbi --> implement order scrollable functionality */ // } -const useStyles = makeStyles((theme: Theme) => - createStyles({ - heading: { - fontSize: theme.typography.pxToRem(55), - fontWeight: theme.typography.fontWeightRegular - }, - accordionRoot: { - width: '220px', - height: '55px', - flex: '1', - flexDirection: 'row-reverse', - alignItems: 'center' - } - }) -); -// const Div = styled('div')(({ theme }) => ({ -// ...theme.typography.button, -// padding: theme.spacing(1), -// })); export default function Orders() { const [orders, setOrders] = React.useState>([]); const [checked, setChecked] = React.useState({}); @@ -78,32 +64,24 @@ export default function Orders() { }; setChecked(value); }; - const classes = useStyles(); async function fetchOrders() { try { - console.log('fetching'); const response = await fetch('/orders').then((res) => res.json()); const orders: Order[] = []; await Promise.all( response.map(async (order) => { - let new_items: string[] = []; - - order.items.forEach((item) => { - new_items.push(item.flavor); - }); - const customerResponse = await fetch( '/customers/' + order.customer ).then((res) => res.json()); - console.log(customerResponse); - - let new_order = { - id: 11, + console.log('items: '); + console.log(order.items); + let new_order: Order = { + id: order._id, first_name: customerResponse.first_name, last_name: customerResponse.last_name, - items: new_items, + items: order.items, price: order.price }; @@ -122,67 +100,113 @@ export default function Orders() { }, []); return ( - - Recent Orders - - - {orders.map((row) => ( - - - - - - Order for {row.first_name} {row.last_name}{' '} - - Drone {row.id} - - - {row.items.map((donut) => ( - - } - label={donut} - labelPlacement="start" - /> - ))} - - - - - - - - - - ))} - -
-
+ + + + + Recent Orders + + + + + + {orders.map((row) => ( + + + + + + Order for {row.first_name} {row.last_name}{' '} + + Drone Id : {row.id} + + + + {row.items.map((donut) => ( + + + + + + + + ))} + + + + sum + donut.price, + 0 + ) + } + /> + + + + + + + + + + + + ))} + +
+
+
+
); } diff --git a/frontend/src/components/Home/ResponsiveAppBar.tsx b/frontend/src/components/Home/ResponsiveAppBar.tsx index 2a49b3f..8a69837 100644 --- a/frontend/src/components/Home/ResponsiveAppBar.tsx +++ b/frontend/src/components/Home/ResponsiveAppBar.tsx @@ -12,17 +12,17 @@ import Button from '@mui/material/Button'; import Tooltip from '@mui/material/Tooltip'; import MenuItem from '@mui/material/MenuItem'; import { makeStyles } from '@mui/styles'; -import { Link } from 'react-router-dom' +import { Link } from 'react-router-dom'; -import LandingImg from "../../assets/DronutLogo.png"; +import LandingImg from '../../assets/DronutLogo.png'; const pages = ['customer', 'employee']; const settings = ['Profile', 'Account', 'Dashboard', 'Logout']; const useStyles = makeStyles({ logo: { - maxWidth: 100, - }, + maxWidth: 100 + } }); const ResponsiveAppBar = () => { @@ -70,22 +70,24 @@ const ResponsiveAppBar = () => { anchorEl={anchorElNav} anchorOrigin={{ vertical: 'bottom', - horizontal: 'left', + horizontal: 'left' }} keepMounted transformOrigin={{ vertical: 'top', - horizontal: 'left', + horizontal: 'left' }} open={Boolean(anchorElNav)} onClose={handleCloseNavMenu} sx={{ - display: { xs: 'block', md: 'none' }, + display: { xs: 'block', md: 'none' } }} > {pages.map((page) => ( - {page} + + {page} + ))} @@ -100,7 +102,8 @@ const ResponsiveAppBar = () => { {pages.map((page) => ( -