| Total Complexity | 2 |
| Complexity/F | 0 |
| Lines of Code | 38 |
| Function Count | 0 |
| Duplicated Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | import { useEffect, useState } from 'react'; |
||
| 2 | |||
| 3 | const useBulkSelect = items => { |
||
| 4 | const [selectedItems, setSelectedItems] = useState([]); |
||
| 5 | const [isAllSelected, setIsAllSelected] = useState(false); |
||
| 6 | const [isIndeterminate, setIsIndeterminate] = useState(false); |
||
| 7 | |||
| 8 | const toggleSelectedItem = id => { |
||
| 9 | const isAlreadySelected = selectedItems.find(item => item === id); |
||
| 10 | if (isAlreadySelected) { |
||
| 11 | setSelectedItems(selectedItems.filter(item => item !== id)); |
||
| 12 | } else { |
||
| 13 | setSelectedItems([...selectedItems, id]); |
||
| 14 | } |
||
| 15 | }; |
||
| 16 | |||
| 17 | const toggleIsAllSelected = () => { |
||
| 18 | if (isAllSelected || isIndeterminate) { |
||
| 19 | setSelectedItems([]); |
||
| 20 | } else { |
||
| 21 | setSelectedItems(items); |
||
| 22 | } |
||
| 23 | }; |
||
| 24 | |||
| 25 | const isSelectedItem = id => { |
||
| 26 | return !!selectedItems.find(item => item === id); |
||
| 27 | }; |
||
| 28 | |||
| 29 | useEffect(() => { |
||
| 30 | setIsAllSelected(selectedItems.length === items.length); |
||
| 31 | setIsIndeterminate(!!selectedItems.length && selectedItems.length < items.length); |
||
| 32 | }, [selectedItems, items]); |
||
| 33 | |||
| 34 | return { selectedItems, isAllSelected, isIndeterminate, toggleSelectedItem, toggleIsAllSelected, isSelectedItem }; |
||
| 35 | }; |
||
| 36 | |||
| 37 | export default useBulkSelect; |
||
| 38 |