Compare commits

..

3 Commits

Author SHA1 Message Date
Vencislav Atanasov a3a2ed8c3f Hide table header when no items are available 2024-09-23 18:57:28 +03:00
Vencislav Atanasov c3d38a0fae Fix relation matching 2024-09-23 18:55:05 +03:00
Vencislav Atanasov 4128e0e68a Optimize schedule table rendering 2024-09-23 18:48:43 +03:00
3 changed files with 32 additions and 28 deletions

View File

@ -48,11 +48,11 @@ export default function Schedule({
{isComplete && <div className="schedule"> {isComplete && <div className="schedule">
<hr/> <hr/>
<table> <table>
<thead> {header.length > 0 && <thead>
<tr> <tr>
{header.map(hall => <th key={hall.id}>{hall.name[lang]}</th>)} {header.map(hall => <th key={hall.id}>{hall.name[lang]}</th>)}
</tr> </tr>
</thead> </thead>}
<tbody> <tbody>
{rows.map(row => <tr key={row.id}> {rows.map(row => <tr key={row.id}>
{row.cells.map(cell => <td key={cell.id} {...cell.attributes}> {row.cells.map(cell => <td key={cell.id} {...cell.attributes}>
@ -60,11 +60,11 @@ export default function Schedule({
</td>)} </td>)}
</tr>)} </tr>)}
</tbody> </tbody>
<tfoot> {header.length > 0 && <tfoot>
<tr> <tr>
{header.map(hall => <th key={hall.id}>{hall.name[lang]}</th>)} {header.map(hall => <th key={hall.id}>{hall.name[lang]}</th>)}
</tr> </tr>
</tfoot> </tfoot>}
</table> </table>
<div className="separator"/> <div className="separator"/>
<table> <table>

View File

@ -6,25 +6,28 @@ export default function useScheduleTable({
events = {}, events = {},
slots = {}, slots = {},
}) { }) {
const filteredEvents = useMemo(() => events.filter(event => eventTypeId > 0 ? event.event_type_id === eventTypeId : true), [eventTypeId, events]); return useMemo(() => {
const filteredEventIds = useMemo(() => filteredEvents.map(event => event.id), [filteredEvents]); const filteredEvents = events.filter(event => eventTypeId > 0 ? event.event_type_id === eventTypeId : true);
const filteredHallIds = useMemo(() => new Set(slots.filter(slot => filteredEventIds.includes(slot.event_id)).map(slot => slot.hall_id)), [filteredEventIds, slots]); const filteredEventIds = filteredEvents.map(event => event.id);
const header = useMemo(() => halls.filter(hall => filteredHallIds.has(hall.id)), [filteredHallIds, halls]); const filteredSlots = slots.filter(slot => filteredEventIds.includes(slot.event_id));
const filteredHallIds = new Set(filteredSlots.map(slot => slot.hall_id));
const header = halls.filter(hall => filteredHallIds.has(hall.id));
const rows = filteredEvents.map(event => ({ const rows = filteredEvents.map(event => ({
id: event.id, id: event.id,
cells: [{ cells: [{
id: 1, id: 1,
attributes: { attributes: {
className: 'schedule-'.concat(event.language).concat(' ').concat(event.track?.css_class), className: 'schedule-'.concat(event.language).concat(' ').concat(event.track?.css_class),
colSpan: 2, colSpan: 2,
}, },
event, event,
}], }],
})); }));
return { return {
header, header,
rows, rows,
}; };
}, [eventTypeId, events, halls, slots]);
} }

View File

@ -49,11 +49,12 @@ export const normalizeResponse = (items = [], relations = []) =>
...item, ...item,
...Object.fromEntries(relations.map(([field, collection, idField]) => { ...Object.fromEntries(relations.map(([field, collection, idField]) => {
const key = item[idField]; const key = item[idField];
const fn = Array.isArray(key) ? 'filter' : 'find';
return [ return [
field, field,
collection[fn](item => item.id === key), Array.isArray(key) ?
collection.filter(item => key.includes(item.id)) :
collection.find(item => item.id === key),
]; ];
})), })),
}) })