Skip to content

Commit

Permalink
feat MAVRICK-1#260 : Order tracking Functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
CoderSwarup committed Jun 1, 2024
1 parent 8706c70 commit 5308184
Show file tree
Hide file tree
Showing 9 changed files with 772 additions and 64 deletions.
72 changes: 72 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

12 changes: 12 additions & 0 deletions src/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ import SellerForm from './pages/SellerRegistration';
import SearchResults from './components/search/SearchResults';
import Shipping from './components/ShippingAddress/ShippingForm';
import { Account } from './components/AccountDetails/Account';
import OrderTracking from './pages/OrderTracking';
import TrackOrderDetails from './pages/OrderTracking/TrackOrderDetails';

const MyContext = createContext();

Expand Down Expand Up @@ -305,6 +307,16 @@ function App() {
element={<Shipping />}
/>
<Route exact={true} path="/my-account" element={<Account />} />
<Route
exact={true}
path="/track-my-order"
element={<OrderTracking />}
/>
<Route
exact={true}
path="/track-my-order/:orderid"
element={<TrackOrderDetails />}
/>
</Routes>
<Footer />
</MyContext.Provider>
Expand Down
128 changes: 128 additions & 0 deletions src/components/OrderTracking/OrderTable.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,128 @@
import React from 'react';
import Table from '@mui/material/Table';
import TableBody from '@mui/material/TableBody';
import TableCell from '@mui/material/TableCell';
import TableContainer from '@mui/material/TableContainer';
import TableHead from '@mui/material/TableHead';
import TableRow from '@mui/material/TableRow';
import Paper from '@mui/material/Paper';

const TAX_RATE = 0.07;

function ccyFormat(num) {
return `${num.toFixed(2)}`;
}

function priceRow(quantity, unit) {
return quantity * unit;
}

function subtotal(items) {
return items.map(({ price }) => price).reduce((sum, i) => sum + i, 0);
}

export default function OrderTable({ rows }) {
console.log(rows);
const processedRows = rows.map((row) => ({
...row,
price: priceRow(row.item_Quantity, row.item_Price)
}));

const invoiceSubtotal = subtotal(processedRows);
const invoiceTaxes = TAX_RATE * invoiceSubtotal;
const invoiceTotal = invoiceTaxes + invoiceSubtotal;

return (
<TableContainer component={Paper}>
<Table sx={{ minWidth: 700 }} aria-label="spanning table">
<TableHead>
<TableRow>
<TableCell
align="center"
colSpan={4}
sx={{ backgroundColor: '#f0f0f0', fontSize: '20px' }}
>
Details
</TableCell>
<TableCell
align="right"
sx={{ backgroundColor: '#f0f0f0', fontSize: '20px' }}
>
Price
</TableCell>
</TableRow>
<TableRow sx={{ backgroundColor: '#e0e0e0' }}>
<TableCell sx={{ fontSize: '20px' }}>Image</TableCell>
<TableCell sx={{ fontSize: '20px' }}>Product Name</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
Qty.
</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
Unit
</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
Total
</TableCell>
</TableRow>
</TableHead>
<TableBody>
{processedRows.map((row) => (
<TableRow key={row.item_Name}>
<TableCell>
<img
src={row.item_image}
alt={row.item_Name}
style={{ width: '50px', height: '50px' }}
/>
</TableCell>
<TableCell sx={{ fontSize: '20px' }}>{row.item_Name}</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
{row.item_Quantity}
</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
{row.unit}
</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
{ccyFormat(row.item_Price)}
</TableCell>
</TableRow>
))}
<TableRow sx={{ backgroundColor: '#f0f0f0', fontSize: '20px' }}>
<TableCell rowSpan={3} />
<TableCell colSpan={3} sx={{ fontSize: '20px' }}>
Subtotal
</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
{ccyFormat(invoiceSubtotal)}
</TableCell>
</TableRow>
<TableRow>
<TableCell colSpan={2} sx={{ fontSize: '20px' }}>
Tax
</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>{`${(
TAX_RATE * 100
).toFixed(0)} %`}</TableCell>
<TableCell align="right" sx={{ fontSize: '20px' }}>
{ccyFormat(invoiceTaxes)}
</TableCell>
</TableRow>
<TableRow sx={{ backgroundColor: '#f0f0f0', fontSize: '20px' }}>
<TableCell
colSpan={3}
sx={{ fontSize: '20px', fontWeight: '900', fontStyle: 'bold' }}
>
Total
</TableCell>
<TableCell
align="right"
sx={{ fontSize: '20px', fontWeight: '900', fontStyle: 'bold' }}
>
{ccyFormat(invoiceTotal)}
</TableCell>
</TableRow>
</TableBody>
</Table>
</TableContainer>
);
}
Loading

0 comments on commit 5308184

Please sign in to comment.