I have a function that handles React Native location. For demonstration:
const useLocation = () => {
const [fetchingLocation, setFetchingLocation] = useState(true);
...
const changeSystemPermissions = useCallback(() => {...});
useEffect(() => {
//does many things
}, [...])
}
I need to have the function changeSystemPermissions
inside useLocation as it uses the state.
I realize that I can export the changeSystemPermissions
function as a const with a return [changeSystemPermissions, ...]
and then import it in another component with:
const [
changeSystemPermissions,
...
] = useLocation();
However, it will ALSO run the useEffect function. I do want it to run once, but I need to access changeSystemPermissions
in several other components and I don't want the useEffect to run multiple times.
I was thinking I will just take out the changeSystemPermissions
function outside of useLocation
, but it needs to use the state. I suppose I COULD pass the state vars into the changeSystemPermissions
when it is outside useLocation
, but that would be verbose and ugly.
How can I export changeSystemPermissions
and just that function without having to import the whole useLocation
function?