import SectionContainer from '../../components/SectionContainer.jsx'; import { useState } from 'react'; import { DataGrid } from '@mui/x-data-grid'; import { Typography, Button, Dialog, DialogTitle, DialogContent, IconButton, Box, Avatar } from '@mui/material'; import AddOrEditProductForm from './AddOrEditProductForm.jsx'; import EditRoundedIcon from '@mui/icons-material/EditRounded'; import DeleteRoundedIcon from '@mui/icons-material/DeleteRounded'; import '../../App.css' const columnsBase = [ { field: 'representation', headerName: '', flex: 2, renderCell: (params) => { const { representation, name, provider, price } = params.row; return ( {name} {provider} ${Number(price).toFixed(2)} ); } }, { field: 'company', headerName: 'Company', flex: 1 }, { field: 'category', headerName: 'Category', flex: 1 }, { field: 'stock', headerName: 'Stock', width: 120, type: 'number' }, ]; export default function Products({ children, maxWidth = 'lg', sx = {} }) { const [rows, setRows] = useState([ { id: 1, company: 'Fendi casa', name: 'Product 1', price: 10.99, provider: 'Provider A', stock: 100, category: 'Home', representation: '/1.jpg' }, { id: 2, company: 'Fendi casa', name: 'Product 2', price: 20.0, provider: 'Provider B', stock: 50, category: 'Home', representation: '/2.jpg' }, { id: 3, company: 'Fendi casa', name: 'Product 3', price: 5.5, provider: 'Provider C', stock: 200, category: 'Home', representation: '/3.jpg' }, { id: 4, company: 'Fendi casa', name: 'Product 4', price: 15.75, provider: 'Provider D', stock: 30, category: 'Home', representation: '/4.jpg' }, { id: 5, company: 'Fendi casa', name: 'Product 5', price: 8.2, provider: 'Provider E', stock: 75, category: 'Home', representation: '/5.jpg' } ]); const [open, setOpen] = useState(false); const [editingProduct, setEditingProduct] = useState(null); const [confirmOpen, setConfirmOpen] = useState(false); const [rowToDelete, setRowToDelete] = useState(null); const handleAddOrEditProduct = (product) => { if (editingProduct) { // Update existing setRows(rows.map((row) => (row.id === editingProduct.id ? { ...editingProduct, ...product } : row))); } else { // Add new const id = rows.length + 1; setRows([...rows, { id, company: 'Fendi casa', ...product }]); } setOpen(false); setEditingProduct(null); }; const handleEditClick = (params) => { setEditingProduct(params.row); setOpen(true); }; const handleDeleteClick = (row) => { setRowToDelete(row); setConfirmOpen(true); }; const confirmDelete = () => { setRows(rows.filter((row) => row.id !== rowToDelete.id)); setRowToDelete(null); setConfirmOpen(false); }; const columns = [ ...columnsBase, { field: 'actions', headerName: '', width: 130, renderCell: (params) => ( handleEditClick(params)} > handleDeleteClick(params.row)} > ) } ]; return ( Products { setOpen(false); setEditingProduct(null); }} maxWidth="md" fullWidth> {editingProduct ? 'Edit Product' : 'Add Product'} { setOpen(false); setEditingProduct(null); }} /> setConfirmOpen(false)}> Confirm Delete Are you sure you want to delete{' '} {rowToDelete?.name}? 140} rows={rows} columns={columns} pageSize={5} rowsPerPageOptions={[5]} getRowSpacing={() => ({ top: 8, bottom: 8, })} /> ); }