chartjs/chartjs-plugin-deferred

Add method to remove event listeners/cleanup

powerbuoy opened this issue · 7 comments

I really don't mean to spam you :)

But while using the deferred plugin on my Aurelia SPA I've noticed that unless you view every chart on a page (at which point the plugin unwatches the chart's scroll event https://github.com/chartjs/chartjs-plugin-deferred/blob/master/src/plugin.js#L107); if you go to another page and scroll down you'll get Uncaught TypeError: Cannot read property 'offsetParent' of null from chartInViewport() (https://github.com/chartjs/chartjs-plugin-deferred/blob/master/src/plugin.js#L53 I believe).

I might be missing something, but is there a way to manually remove the events? That way I can do so in my ViewModel's detached() (or React's componentWillUnmount()) similarly to how I can destroy the ChartJS instance with chart.destroy()?

Or perhaps there's a way for the plugin itself to detect calls to chart.destroy() and clean up after itself?

Again, sorry if I simply missed this feature or am using the plugin incorrectly, all I've done is import it and add the deferred options to my chart.

You right, that's a bug, we need to stop monitoring a chart that has been destroyed. I think it can be fixed by unwatching in the destroy extension (line 203):

Chart.plugins.register({
    // ...

    beforeDatasetsUpdate: function(chart, options) {
        //...
    },

    destroy: function(chart) {
        unwatch(chart);
    }
});

That sounds really promising. Is this something you could release along with import support?

Sure, did you get a chance to test this fix?

It does indeed work :) Nice job. Any ETA on a new version?

Fixed in 8b4dacf. @powerbuoy if you can confirm that this is fixed in master, I can trigger a new 0.3 release very soon (version 1.0 will contain breaking changes and should be released after Chart.js 2.6 is out).

Works perfectly :)

Released in v0.3.0