1
0
Fork 0

wip: Work on account/patterns pages

This commit is contained in:
joostdecock 2024-12-22 19:00:06 +01:00
parent dbe1a04552
commit 196bf6decf
16 changed files with 874 additions and 1020 deletions

View file

@ -0,0 +1,40 @@
import React, { useState } from 'react'
export const useSelection = (items) => {
const [selection, setSelection] = useState({})
/*
* This variable keeps track of how many are selected
*/
const count = Object.keys(selection).length
/*
* This method toggles a single item in the selection
*/
const toggle = (id) => {
const newSelection = { ...selection }
if (newSelection[id]) delete newSelection[id]
else newSelection[id] = 1
setSelection(newSelection)
}
/*
* This method toggles all on or off
*/
const toggleAll = () => {
if (count === items.length) setSelection({})
else {
const newSelection = {}
for (const item of items) newSelection[item.id] = 1
setSelection(newSelection)
}
}
return {
count,
selection,
setSelection,
toggle,
toggleAll,
}
}