1
I found an issue on your code like in len
property of the BarChart
that gets the error Cannot read property ‘length’ of undefined. After I used null checking with question mark, I am not getting any error but printing 1 to 20. I am not sure it helps you or not. May be after changing that, you will get it solved.
len={this.state.countries[Object.keys(this.state.countries)[0]].length}
replaced by
len={this.state.countries[Object.keys(this.state.countries)[0]]?.length}
- [Chartjs]-How to disable a tooltip for a specific dataset in ChartJS
- [Chartjs]-Chart.js xAxes Date Labels are altered based on screen width
0
You should just wait until countries is filled before trying to render anything. You can for example render BarChart component only if countries array has at least one element :
[...]
{this.state.countries.length > 0 && <BarChart
start={true}
data = {this.state.countries}
len = {this.state.countries[Object.keys(this.state.countries)[0]].length}
keys = {Object.keys(this.state.countries)}
timeout={400}
delay={100}
colors = {Object.keys(this.state.countries).reduce((res, item) => ({
...res,
...{ [item]: randomColor() }
}), {})}
labels = {Object.keys(this.state.countries).reduce((res, item, idx) => {
return{
...res,
...{[item]: (
<div style={{textAlign:"center",}}>
<div>{item}</div>
</div>
)}
}}, {})}
timeline = {Array(20).fill(0).map((itm, idx) => idx + 1)}
timelineStyle={{
textAlign: "center",
fontSize: "50px",
color: "rgb(148, 148, 148)",
marginBottom: "100px"
}}
textBoxStyle={{
textAlign: "right",
color: "rgb(133, 131, 131)",
fontSize: "30px",
}}
barStyle={{
height: "60px",
marginTop: "10px",
borderRadius: "10px",
}}
width={[15, 75, 10]}
maxItems = {this.state.countries.length}
/>}
{this.state.countries.length === 0 && <span>Loading...</span>}
[...]
Note the conditional rendering syntax.
Source:stackexchange.com