From 55dc96085df26e120d72137fd35b4dff41805445 Mon Sep 17 00:00:00 2001 From: Rodolfo Ruiz Date: Sat, 6 Sep 2025 18:34:09 -0600 Subject: [PATCH] chore: add filters --- .../catalogs/products/ProductCollections.jsx | 28 ++++++++++++++----- 1 file changed, 21 insertions(+), 7 deletions(-) diff --git a/src/private/catalogs/products/ProductCollections.jsx b/src/private/catalogs/products/ProductCollections.jsx index 08e18a7..b8cf900 100644 --- a/src/private/catalogs/products/ProductCollections.jsx +++ b/src/private/catalogs/products/ProductCollections.jsx @@ -3,7 +3,7 @@ import { useEffect, useMemo, useState } from 'react'; import { DataGrid } from '@mui/x-data-grid'; import { Typography, Button, Dialog, DialogTitle, DialogContent, - IconButton, Box, FormControlLabel, Switch, Tooltip + IconButton, Box, Tooltip, ToggleButtonGroup, ToggleButton } from '@mui/material'; import EditRoundedIcon from '@mui/icons-material/EditRounded'; import DeleteRoundedIcon from '@mui/icons-material/DeleteRounded'; @@ -48,9 +48,10 @@ export default function ProductCollections() { const [rawRows, setRawRows] = useState([]); const [open, setOpen] = useState(false); const [editRow, setEditRow] = useState(null); - const [showInactive, setShowInactive] = useState(false); const [loading, setLoading] = useState(true); + const [statusFilter, setStatusFilter] = useState('All'); + // Tags const [loadingTags, setLoadingTags] = useState(true); const [typeMap, setTypeMap] = useState({}); @@ -154,7 +155,6 @@ export default function ProductCollections() { createdBy: r.createdBy ?? null, })); setRawRows(normalized); - setRows(normalized.filter(r => showInactive ? true : r.status !== 'Inactive')); } catch (err) { console.error(err); toast.error(err?.message || 'Error loading variants'); @@ -165,8 +165,13 @@ export default function ProductCollections() { useEffect(() => { load(); /* eslint-disable-next-line */ }, []); useEffect(() => { - setRows(rawRows.filter(r => showInactive ? true : r.status !== 'Inactive')); - }, [showInactive, rawRows]); + if (statusFilter === 'All') { + setRows(rawRows); + } else { + const want = statusFilter.toLowerCase(); + setRows(rawRows.filter(r => String(r.status ?? 'Active').toLowerCase() === want)); + } + }, [statusFilter, rawRows]); const columns = [ { field: 'modelId', headerName: 'Model Id', width: 220 }, @@ -233,10 +238,19 @@ export default function ProductCollections() { return ( - + Furniture Variants - setShowInactive(v)} />} label="Show Inactive" /> + v && setStatusFilter(v)} + size="small" + > + Active + All + Inactive +