import React, { Fragment } from 'react'; import { useDispatch, useSelector } from 'react-redux'; import makeStyles from '@mui/styles/makeStyles'; import { Divider, List, ListItemButton, ListItemText, } from '@mui/material'; import { geofencesActions } from '../store'; import CollectionActions from '../settings/components/CollectionActions'; import { useCatchCallback } from '../reactHelper'; import { useTranslation } from '../common/components/LocalizationProvider'; const useStyles = makeStyles(() => ({ list: { maxHeight: '100%', overflow: 'auto', }, icon: { width: '25px', height: '25px', filter: 'brightness(0) invert(1)', }, })); const GeofencesList = ({ onGeofenceSelected }) => { const classes = useStyles(); const dispatch = useDispatch(); const t = useTranslation(); const items = useSelector((state) => state.geofences.items); const refreshGeofences = useCatchCallback(async () => { const response = await fetch('/api/geofences'); if (response.ok) { dispatch(geofencesActions.refresh(await response.json())); } else { throw Error(await response.text()); } }, [dispatch]); return ( {Object.values(items).map((item, index, list) => ( onGeofenceSelected(item.id)}> {index < list.length - 1 ? : null} ))} ); }; export default GeofencesList;