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
            
            
            
            
                 140}
                    rows={rows}
                    columns={columns}
                    pageSize={5}
                    rowsPerPageOptions={[5]}
                    getRowSpacing={() => ({
                        top: 8,
                        bottom: 8,
                    })}
                />
                
                    
                
            
        
    );
}