mirror of
https://github.com/lemeow125/Ivy-Frontend.git
synced 2024-11-17 06:39:25 +08:00
edit product route
This commit is contained in:
parent
a21adacab1
commit
88049d0367
5 changed files with 152 additions and 14 deletions
|
@ -8,6 +8,7 @@ import Store from "./Plugins/Redux/Store/Store";
|
||||||
import { Provider } from "react-redux";
|
import { Provider } from "react-redux";
|
||||||
import Inventory from "./Routes/Inventory/Inventory";
|
import Inventory from "./Routes/Inventory/Inventory";
|
||||||
import AddProduct from "./Routes/Products/AddProduct/AddProduct";
|
import AddProduct from "./Routes/Products/AddProduct/AddProduct";
|
||||||
|
import EditProduct from "./Routes/Products/EditProduct/EditProduct";
|
||||||
|
|
||||||
const router = createBrowserRouter([
|
const router = createBrowserRouter([
|
||||||
{
|
{
|
||||||
|
@ -47,6 +48,14 @@ const router = createBrowserRouter([
|
||||||
</Container>
|
</Container>
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: "/Products/EditProduct/:id", // Updated route with dynamic id parameter
|
||||||
|
element: (
|
||||||
|
<Container>
|
||||||
|
<EditProduct />
|
||||||
|
</Container>
|
||||||
|
),
|
||||||
|
},
|
||||||
]);
|
]);
|
||||||
|
|
||||||
export default function App() {
|
export default function App() {
|
||||||
|
|
|
@ -22,7 +22,7 @@ export default function InventoryInfo(props: ProductInfoProps) {
|
||||||
<TableBody>
|
<TableBody>
|
||||||
{products.map((product) => (
|
{products.map((product) => (
|
||||||
<TableRow key={product.id}>
|
<TableRow key={product.id}>
|
||||||
<TableCell style={{ color: 'white' }}>{product.id}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.id.toString().padStart(3, '0')}</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>{product.name}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.name}</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>{product.stocks}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.stocks}</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>{product.lastModified}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.lastModified}</TableCell>
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import { Table, TableBody, TableCell, TableContainer, TableHead, TableRow } from '@mui/material';
|
import { Table, TableBody, TableCell, TableContainer, TableHead, TableRow } from '@mui/material';
|
||||||
import { ProductType } from '../ProductType/ProductType';
|
import { ProductType } from '../ProductType/ProductType';
|
||||||
|
import { useNavigate } from 'react-router-dom';
|
||||||
|
|
||||||
type ProductInfoProps = {
|
type ProductInfoProps = {
|
||||||
products: ProductType[];
|
products: ProductType[];
|
||||||
|
@ -7,6 +8,15 @@ type ProductInfoProps = {
|
||||||
|
|
||||||
export default function ProductInfo(props: ProductInfoProps) {
|
export default function ProductInfo(props: ProductInfoProps) {
|
||||||
const { products } = props;
|
const { products } = props;
|
||||||
|
const navigate = useNavigate();
|
||||||
|
|
||||||
|
const handleEdit = (id: number) => {
|
||||||
|
navigate(`/Products/EditProduct/${id.toString().padStart(3, '0')}`);
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleDelete = (id: number) => {
|
||||||
|
console.log(`Deleting product with ID ${id}`);
|
||||||
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<TableContainer>
|
<TableContainer>
|
||||||
|
@ -16,14 +26,19 @@ export default function ProductInfo(props: ProductInfoProps) {
|
||||||
<TableCell style={{ color: 'white' }}>Product ID</TableCell>
|
<TableCell style={{ color: 'white' }}>Product ID</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>Product Name</TableCell>
|
<TableCell style={{ color: 'white' }}>Product Name</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>Last Modified</TableCell>
|
<TableCell style={{ color: 'white' }}>Last Modified</TableCell>
|
||||||
|
<TableCell style={{ color: 'white' }}>Actions</TableCell>
|
||||||
</TableRow>
|
</TableRow>
|
||||||
</TableHead>
|
</TableHead>
|
||||||
<TableBody>
|
<TableBody>
|
||||||
{products.map((product) => (
|
{products.map((product) => (
|
||||||
<TableRow key={product.id}>
|
<TableRow key={product.id}>
|
||||||
<TableCell style={{ color: 'white' }}>{product.id}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.id.toString().padStart(3, '0')}</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>{product.name}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.name}</TableCell>
|
||||||
<TableCell style={{ color: 'white' }}>{product.lastModified}</TableCell>
|
<TableCell style={{ color: 'white' }}>{product.lastModified}</TableCell>
|
||||||
|
<TableCell style={{ color: 'white' }}>
|
||||||
|
<button onClick={() => handleEdit(product.id)}>Edit</button>
|
||||||
|
<button onClick={() => handleDelete(product.id)}>Delete</button>
|
||||||
|
</TableCell>
|
||||||
</TableRow>
|
</TableRow>
|
||||||
))}
|
))}
|
||||||
</TableBody>
|
</TableBody>
|
||||||
|
|
|
@ -1,10 +1,17 @@
|
||||||
import React, { useState } from "react";
|
import React, { useState } from "react";
|
||||||
import { useNavigate } from "react-router-dom";
|
import { useNavigate } from "react-router-dom";
|
||||||
import ProductsLists from "../../../Components/ProductsLists/ProductsLists";
|
|
||||||
import { ProductType } from "../../../Components/ProductType/ProductType";
|
import { ProductType } from "../../../Components/ProductType/ProductType";
|
||||||
|
import ProductsLists from "../../../Components/ProductsLists/ProductsLists";
|
||||||
import styles from "../../../styles";
|
import styles from "../../../styles";
|
||||||
import ProductsIcon from "../../../Components/Icons/ProductsIcon/ProductsIcon";
|
import ProductsIcon from "../../../Components/Icons/ProductsIcon/ProductsIcon";
|
||||||
import ProductInfo from "../../../Components/ProductInfo/ProductInfo";
|
|
||||||
|
import {
|
||||||
|
Table,
|
||||||
|
TableBody,
|
||||||
|
TableCell,
|
||||||
|
TableContainer,
|
||||||
|
TableRow,
|
||||||
|
} from "@mui/material";
|
||||||
|
|
||||||
export default function AddProduct() {
|
export default function AddProduct() {
|
||||||
const [name, setName] = useState("");
|
const [name, setName] = useState("");
|
||||||
|
@ -43,16 +50,24 @@ export default function AddProduct() {
|
||||||
<h1 style={styles.text_large}>Products</h1>
|
<h1 style={styles.text_large}>Products</h1>
|
||||||
</div>
|
</div>
|
||||||
<h1>Add Product</h1>
|
<h1>Add Product</h1>
|
||||||
<label htmlFor="name">Name:</label>
|
<TableContainer>
|
||||||
<input type="text" id="name" value={name} onChange={handleNameChange} />
|
<Table>
|
||||||
<br />
|
<TableBody>
|
||||||
<label htmlFor="stocks">Stocks:</label>
|
<TableRow>
|
||||||
<input
|
<TableCell>Name:</TableCell>
|
||||||
type="text"
|
<TableCell>
|
||||||
id="stocks"
|
<input type="text" id="name" value={name} onChange={handleNameChange} />
|
||||||
value={stocks}
|
</TableCell>
|
||||||
onChange={handleStocksChange}
|
</TableRow>
|
||||||
/>
|
<TableRow>
|
||||||
|
<TableCell>Stocks:</TableCell>
|
||||||
|
<TableCell>
|
||||||
|
<input type="text" id="stocks" value={stocks} onChange={handleStocksChange} />
|
||||||
|
</TableCell>
|
||||||
|
</TableRow>
|
||||||
|
</TableBody>
|
||||||
|
</Table>
|
||||||
|
</TableContainer>
|
||||||
<br />
|
<br />
|
||||||
<button onClick={handleAddProduct}>Add</button>
|
<button onClick={handleAddProduct}>Add</button>
|
||||||
<button onClick={handleCancel}>Cancel</button>
|
<button onClick={handleCancel}>Cancel</button>
|
||||||
|
|
99
src/routes/Products/EditProduct/EditProduct.tsx
Normal file
99
src/routes/Products/EditProduct/EditProduct.tsx
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
import React, { useState, useEffect } from "react";
|
||||||
|
import { useParams, useNavigate } from "react-router-dom";
|
||||||
|
import {
|
||||||
|
Table,
|
||||||
|
TableBody,
|
||||||
|
TableCell,
|
||||||
|
TableContainer,
|
||||||
|
TableHead,
|
||||||
|
TableRow,
|
||||||
|
TextField,
|
||||||
|
IconButton,
|
||||||
|
} from "@mui/material";
|
||||||
|
import { ProductType } from "../../../Components/ProductType/ProductType";
|
||||||
|
import ProductsLists from "../../../Components/ProductsLists/ProductsLists";
|
||||||
|
import styles from "../../../styles";
|
||||||
|
|
||||||
|
type EditProductParams = {
|
||||||
|
id?: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default function EditProduct() {
|
||||||
|
const { id } = useParams<EditProductParams>();
|
||||||
|
const navigate = useNavigate();
|
||||||
|
|
||||||
|
const [name, setName] = useState("");
|
||||||
|
const [stocks, setStocks] = useState("");
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const product = ProductsLists.find((product) => product.id.toString() === id);
|
||||||
|
if (product) {
|
||||||
|
setName(product.name);
|
||||||
|
setStocks(product.stocks.toString());
|
||||||
|
}
|
||||||
|
}, [id]);
|
||||||
|
|
||||||
|
const handleNameChange = (event: React.ChangeEvent<HTMLInputElement>) => {
|
||||||
|
setName(event.target.value);
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleStocksChange = (event: React.ChangeEvent<HTMLInputElement>) => {
|
||||||
|
setStocks(event.target.value);
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleUpdateProduct = () => {
|
||||||
|
const updatedProduct: ProductType = {
|
||||||
|
id: parseInt(id || "0"), // add a default value of "0" for id if it's undefined
|
||||||
|
name: name,
|
||||||
|
stocks: parseInt(stocks),
|
||||||
|
lastModified: new Date().toLocaleString(),
|
||||||
|
};
|
||||||
|
|
||||||
|
const index = ProductsLists.findIndex((product) => product.id.toString() === id);
|
||||||
|
ProductsLists.splice(index, 1, updatedProduct);
|
||||||
|
|
||||||
|
navigate("/Products");
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleCancel = () => {
|
||||||
|
navigate("/Products");
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div style={{ margin: 32 }}>
|
||||||
|
<div style={styles.content_row}>
|
||||||
|
<h1 style={styles.text_large}>Edit Product</h1>
|
||||||
|
</div>
|
||||||
|
<TableContainer>
|
||||||
|
<Table>
|
||||||
|
<TableHead>
|
||||||
|
<TableRow>
|
||||||
|
<TableCell>Product ID</TableCell>
|
||||||
|
<TableCell>Product Name</TableCell>
|
||||||
|
<TableCell>Stocks</TableCell>
|
||||||
|
</TableRow>
|
||||||
|
</TableHead>
|
||||||
|
<TableBody>
|
||||||
|
<TableRow>
|
||||||
|
<TableCell>{id}</TableCell>
|
||||||
|
<TableCell>{name}</TableCell>
|
||||||
|
<TableCell>
|
||||||
|
<TextField
|
||||||
|
type="number"
|
||||||
|
value={stocks}
|
||||||
|
onChange={handleStocksChange}
|
||||||
|
InputProps={{
|
||||||
|
inputProps: { min: 0 },
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</TableCell>
|
||||||
|
</TableRow>
|
||||||
|
</TableBody>
|
||||||
|
</Table>
|
||||||
|
</TableContainer>
|
||||||
|
<br />
|
||||||
|
<button onClick={handleUpdateProduct}>Update</button>
|
||||||
|
<button onClick={handleCancel}>Cancel</button>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
Loading…
Reference in a new issue