import { useMemo } from 'react'; import { useParams, Link, useOutletContext } from 'react-router-dom'; import { ArrowLeft, Package, DollarSign } from 'lucide-react'; import { BarChart, Bar, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer } from 'recharts'; import DateRangePicker from '../components/DateRangePicker'; import type { OrderData, DateRange } from '../types'; import { parseOrderDate } from '../dataService'; const CustomTooltip = ({ active, payload, label }: any) => { if (active && payload && payload.length) { return (

{label}

Vendas: {payload[0].value}

); } return null; }; const ProductDetails = () => { const { id } = useParams<{ id: string }>(); const { dateRange, setDateRange, ordersData } = useOutletContext<{ dateRange: DateRange, setDateRange: (range: DateRange) => void, ordersData: OrderData[], refreshInterval: number, setRefreshInterval: (interval: number) => void, loadData: (showLoading?: boolean) => void }>(); const { productInfo, chartData, totalSold, totalRevenue } = useMemo(() => { const orders = ordersData.filter(order => order.ID_Produto === id); if (orders.length === 0) return { productInfo: null, chartData: [], totalSold: 0, totalRevenue: 0 }; const info = { id: orders[0].ID_Produto, name: orders[0].Descricao_Produto.split(' TAMANHO')[0], price: orders[0].Valor_Unitario }; const salesByDate: Record = {}; let sold = 0; let revenue = 0; orders.forEach(order => { const orderDate = parseOrderDate(order.Data_Pedido); if (orderDate >= dateRange.start && orderDate <= dateRange.end) { const dateStr = order.Data_Pedido; salesByDate[dateStr] = (salesByDate[dateStr] || 0) + order.Quantidade; sold += order.Quantidade; revenue += (order.Quantidade * order.Valor_Unitario); } }); const chart = Object.keys(salesByDate).map(date => ({ date, value: salesByDate[date] })).sort((a, b) => { const [da, ma, ya] = a.date.split('-').map(Number); const [db, mb, yb] = b.date.split('-').map(Number); return new Date(ya, ma - 1, da).getTime() - new Date(yb, mb - 1, db).getTime(); }); return { productInfo: info, chartData: chart, totalSold: sold, totalRevenue: revenue }; }, [id, dateRange, ordersData]); const formatCurrency = (value: number) => { return new Intl.NumberFormat('pt-BR', { style: 'currency', currency: 'BRL' }).format(value); }; if (!productInfo) { return (

Produto não encontrado.

Voltar para produtos
); } return (
Voltar
ID: #{productInfo.id}

{productInfo.name}

Unidades Vendidas

{totalSold}

Receita Total

{formatCurrency(totalRevenue)}

Volume de Vendas por Data

} cursor={{ fill: '#222222' }} />
); }; export default ProductDetails;