mirror of
https://git.v0id.ovh/n3wt-innov/n3wt-school.git
synced 2026-01-29 16:03:21 +00:00
feat: Création nouveau style / pagination profils annuaires
This commit is contained in:
@ -13,21 +13,21 @@ const Table = ({
|
||||
onRowClick,
|
||||
selectedRows,
|
||||
isSelectable = false,
|
||||
defaultTheme = 'bg-emerald-50',
|
||||
defaultTheme = 'bg-emerald-50', // Blanc cassé pour les lignes paires
|
||||
}) => {
|
||||
const handlePageChange = (newPage) => {
|
||||
onPageChange(newPage);
|
||||
};
|
||||
|
||||
return (
|
||||
<div className="bg-white rounded-lg border border-gray-200">
|
||||
<table className="min-w-full bg-white">
|
||||
<div className="bg-stone-50 rounded-lg border border-gray-300 shadow-md">
|
||||
<table className="min-w-full bg-stone-50">
|
||||
<thead>
|
||||
<tr>
|
||||
{columns.map((column, index) => (
|
||||
<th
|
||||
key={index}
|
||||
className="py-2 px-4 border-b border-gray-200 bg-gray-100 text-center text-sm font-semibold text-gray-600"
|
||||
className="py-2 px-4 border-b border-gray-300 bg-gray-100 text-center text-sm font-semibold text-gray-700"
|
||||
>
|
||||
{column.name}
|
||||
</th>
|
||||
@ -40,16 +40,21 @@ const Table = ({
|
||||
key={rowIndex}
|
||||
className={`
|
||||
${isSelectable ? 'cursor-pointer' : ''}
|
||||
${selectedRows?.includes(row.id) ? 'bg-emerald-300 text-white' : rowIndex % 2 === 0 ? `${defaultTheme}` : ''}
|
||||
${isSelectable ? 'hover:bg-emerald-200' : ''}
|
||||
${
|
||||
selectedRows?.includes(row.id)
|
||||
? 'bg-emerald-200 text-white'
|
||||
: rowIndex % 2 === 0
|
||||
? `${defaultTheme}`
|
||||
: 'bg-stone-50' // Blanc cassé pour les lignes impaires
|
||||
}
|
||||
${isSelectable ? 'hover:bg-emerald-100' : ''}
|
||||
`}
|
||||
onClick={() => {
|
||||
if (isSelectable && onRowClick) {
|
||||
// Si la ligne est déjà sélectionnée, transmettre une indication explicite de désélection
|
||||
if (selectedRows?.includes(row.id)) {
|
||||
onRowClick({ deselected: true, row }); // Désélectionner
|
||||
onRowClick({ deselected: true, row });
|
||||
} else {
|
||||
onRowClick(row); // Sélectionner
|
||||
onRowClick(row);
|
||||
}
|
||||
}
|
||||
}}
|
||||
@ -57,7 +62,11 @@ const Table = ({
|
||||
{columns.map((column, colIndex) => (
|
||||
<td
|
||||
key={colIndex}
|
||||
className={`py-2 px-4 border-b border-gray-200 text-center text-sm ${selectedRows?.includes(row.id) ? 'text-white' : 'text-gray-700'}`}
|
||||
className={`py-2 px-4 border-b border-gray-300 text-center text-sm ${
|
||||
selectedRows?.includes(row.id)
|
||||
? 'text-white'
|
||||
: 'text-gray-700'
|
||||
}`}
|
||||
>
|
||||
{renderCell
|
||||
? renderCell(row, column.name)
|
||||
|
||||
Reference in New Issue
Block a user