2020-07-09 10:08:47 +01:00
|
|
|
import Component from '@ember/component';
|
|
|
|
import { set } from '@ember/object';
|
2021-12-01 11:33:33 +00:00
|
|
|
import { schedule } from '@ember/runloop';
|
2020-07-09 10:08:47 +01:00
|
|
|
import Slotted from 'block-slots';
|
|
|
|
|
|
|
|
import chart from './chart.xstate';
|
|
|
|
export default Component.extend(Slotted, {
|
|
|
|
tagName: '',
|
|
|
|
onchange: data => data,
|
|
|
|
init: function() {
|
|
|
|
this._super(...arguments);
|
|
|
|
this.chart = chart;
|
|
|
|
},
|
|
|
|
didReceiveAttrs: function() {
|
|
|
|
this._super(...arguments);
|
|
|
|
if (typeof this.items !== 'undefined') {
|
|
|
|
this.actions.change.apply(this, [this.items]);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
didInsertElement: function() {
|
|
|
|
this._super(...arguments);
|
|
|
|
this.dispatch('LOAD');
|
|
|
|
},
|
|
|
|
actions: {
|
2021-12-01 11:33:33 +00:00
|
|
|
invalidate() {
|
|
|
|
this.dispatch('INVALIDATE');
|
|
|
|
schedule('afterRender', () => {
|
|
|
|
this.dispatch('LOAD');
|
|
|
|
});
|
|
|
|
},
|
2020-07-09 10:08:47 +01:00
|
|
|
isLoaded: function() {
|
2020-07-17 14:42:45 +01:00
|
|
|
return typeof this.items !== 'undefined' || typeof this.src === 'undefined';
|
2020-07-09 10:08:47 +01:00
|
|
|
},
|
|
|
|
change: function(data) {
|
|
|
|
set(this, 'data', this.onchange(data));
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|