Skip to content

Instantly share code, notes, and snippets.

@sag1v
Last active October 25, 2019 20:40
Show Gist options
  • Save sag1v/4a2db075d73ed1c1c26b512b7946a778 to your computer and use it in GitHub Desktop.
Save sag1v/4a2db075d73ed1c1c26b512b7946a778 to your computer and use it in GitHub Desktop.
Markdium-React state update on an unmounted component
function Pets() {
const [pets, dispatch] = useReducer(petsReducer, initialState);
const onChange = ({ target }) => {
dispatch({ type: "PET_SELECTED", payload: target.value });
};
useEffect(() => {
if (pets.selectedPet) {
dispatch({ type: "FETCH_PET" });
getPet(pets.selectedPet).then(data => {
dispatch({ type: "FETCH_PET_SUCCESS", payload: data });
});
} else {
dispatch({ type: "RESET" });
}
}, [pets.selectedPet]);
return (
<div>
<select value={pets.selectedPet} onChange={onChange}>
<option value="">Select a pet</option>
<option value="cats">Cats</option>
<option value="dogs">Dogs</option>
</select>
{pets.loading && <div>Loading...</div>}
{pets.petData && <Pet {...pets.petData} />}
</div>
);
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment