Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EdgeLine options is undefined when re-rendering. #126

Open
benmusson opened this issue Oct 20, 2024 · 3 comments
Open

EdgeLine options is undefined when re-rendering. #126

benmusson opened this issue Oct 20, 2024 · 3 comments
Labels
bug Something isn't working

Comments

@benmusson
Copy link

benmusson commented Oct 20, 2024

The chart will render once, but when I do anything that causes the chart to render (for instance, update the data props), I get an error message in the browser console and the chart fails to draw.

Error Message: Uncaught TypeError: Cannot read properties of undefined (reading 'borderCapStyle')

Full Error Message:

Uncaught TypeError: Cannot read properties of undefined (reading 'borderCapStyle')
    at Gn.draw (embr-charts-client.j…9444891635:39:51697)
    at embr-charts-client.j…9444891635:39:57945
    at Array.forEach (<anonymous>)
    at pr.draw (embr-charts-client.j…9444891635:39:57927)
    at Ki._drawDataset (embr-charts-client.j…9444891635:16:88866)
    at Ki._drawDatasets (embr-charts-client.j…9444891635:16:88456)
    at Ki.draw (embr-charts-client.j…9444891635:16:87985)
    at embr-charts-client.j…729444891635:16:658
    at Map.forEach (<anonymous>)
    at ev._update (embr-charts-client.j…729444891635:16:438)

Source Location:

ctx.lineCap = options.borderCapStyle;

To Reproduce

I don't have a codepen yet, can try to put one together if it is helpful.

Expected behavior

I am using the react-chartjs-2 wrapper. If I enable the redraw option (which destroys/rebuilds the chart on every render) no errors occur.

I should not need to use the redraw option.

Screenshots
20241020_134348

Context

  • Version: 4.3.1
  • Browser: Chrome 129.0.6668.101

Additional context

There are differences in how the default line element and EdgeLine get their options references in the draw function. I do not understand why options would be undefined on subsequent renders, but I think this explains the behavior difference.

// Default `Chart.js` line element
const options = this.options || {};

// EdgeLine
const { options } = this;
@benmusson benmusson added the bug Something isn't working label Oct 20, 2024
@sgratzl
Copy link
Owner

sgratzl commented Oct 20, 2024

please provide a simple reproducible example without react to rule out that the react wrapper causes it.

@benmusson
Copy link
Author

benmusson commented Oct 20, 2024

Here's a simple example:
https://codepen.io/benmusson/pen/bGXrRGL

I am intentionally creating a new data object on each button press, because this is representative of my real use case.

EDIT: Bumped to Chartjs v4 and chartjs-chart-graph v4

@benmusson benmusson changed the title (react-chartjs-2) EdgeLine options is undefined when re-rendering. EdgeLine options is undefined when re-rendering. Oct 20, 2024
@AndrewC-1845
Copy link

AndrewC-1845 commented Nov 21, 2024

Having the same issue as described when trying the update() function on a tree chart. Using the function as described here: https://www.chartjs.org/docs/latest/developers/updates.html

Behaviour is consistent between all update methods except none and reset. For these two, the previous tree's lines are left rendered but none of the nodes themselves are rendered.

Seems the only workaround currently is to destroy the chart and recreate it with the data already set.

Using:

  • chart.js@4.4.6
  • chartjs-chart-graph@4.3.4

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants