I created a pie chart that shows the pokemon catch rate. The console.logs all work at first but then it appears to continue running so the data is no longer displaying correctly. The props value is a useState variable from a different component.
Here is my code:
const [captureRate, setCaptureRate] = useState();
// const [lossRate, setLossRate] = useState();
console.log("run");
let capture=[];
let notCapture=0;
console.log((props.nameForRate));
useEffect(() => {
axios.get('https://pokeapi.co/api/v2/pokemon-species/'+(props.nameForRate)+'/')
.then((res)=>{
let data=res.data;
capture[0] = data.capture_rate;
capture[1] = 255 - (data.capture_rate);
console.log(("it works " +capture));
setCaptureRate(capture);
});
console.log("here it is again " + captureRate[0]);
}, []);
return(
<>
<div className="componentInteriorDoughnut">
{/* <h3>Chart 2: Doughnut Chart</h3> */}
<div className="CaptureRate">
<Doughnut
data={{
labels: ['Captured', 'Not Captured'],
datasets: [{
label: 'Capture Rate',
data: captureRate,
backgroundColor: [
'rgb(42, 157, 143)',
'#f1f1f1',
],
borderWidth: 0,
// borderRadius:10,
},