From 4c45a9334778a8ed76758fe52dd36ef8faa40d3f Mon Sep 17 00:00:00 2001 From: Zeno Rocha Date: Thu, 22 Mar 2018 17:09:00 -0700 Subject: [PATCH] Creates base chart component using Chart.js #91 --- packages/marble-chart/demos/index.html | 32 ++++++++++++++++- packages/marble-chart/package.json | 1 + packages/marble-chart/src/Chart.js | 50 +++++++++++++++++++++++--- packages/marble-chart/src/Chart.soy | 4 +-- 4 files changed, 79 insertions(+), 8 deletions(-) diff --git a/packages/marble-chart/demos/index.html b/packages/marble-chart/demos/index.html index 5963575..a275612 100644 --- a/packages/marble-chart/demos/index.html +++ b/packages/marble-chart/demos/index.html @@ -18,7 +18,37 @@

Chart

diff --git a/packages/marble-chart/package.json b/packages/marble-chart/package.json index 5337ce7..26d03b5 100644 --- a/packages/marble-chart/package.json +++ b/packages/marble-chart/package.json @@ -27,6 +27,7 @@ "metal" ], "dependencies": { + "chart.js": "^2.7.2", "metal-component": "^2.14.0", "metal-soy": "^2.14.0", "metal-state": "^2.14.0" diff --git a/packages/marble-chart/src/Chart.js b/packages/marble-chart/src/Chart.js index 7183204..ff939bf 100644 --- a/packages/marble-chart/src/Chart.js +++ b/packages/marble-chart/src/Chart.js @@ -1,13 +1,38 @@ +import {isServerSide} from 'metal'; import Component from 'metal-component'; import Soy from 'metal-soy'; import {Config} from 'metal-state'; +import ChartJS from 'chart.js'; import templates from './Chart.soy.js'; /** * Chart component. */ -class Chart extends Component {} +class Chart extends Component { + attached() { + if (isServerSide()) { + return; + } + + this.chart = new ChartJS(this.refs.canvas, { + type: this.type, + data: this.data, + options: this.options, + }); + } + + willReceiveState(changes) { + if (changes.data) { + this.chart.data = changes.data.newVal; + this.chart.update(); + } + } + + disposed() { + this.chart.destroy(); + } +} /** * State definition. @@ -16,11 +41,28 @@ class Chart extends Component {} */ Chart.STATE = { /** - * ID to be applied to the element. + * Built-in types for Chart.js * @type {!String} - * @default example */ - id: Config.string().value('example'), + type: { + value: Config.oneOf(['bar', 'bubble', 'line', 'pie', 'polarArea', 'radar']), + }, + + /** + * Data used to render Chart.js + * @type {!Object} + */ + data: { + value: {} + }, + + /** + * Styling options for Chart.js + * @type {!Object} + */ + options: { + value: {} + } }; Soy.register(Chart, templates); diff --git a/packages/marble-chart/src/Chart.soy b/packages/marble-chart/src/Chart.soy index 8013696..1514a4a 100644 --- a/packages/marble-chart/src/Chart.soy +++ b/packages/marble-chart/src/Chart.soy @@ -4,7 +4,5 @@ * This renders the component's whole content. */ {template .render} - {@param? id: string} - -
Hello World
+ {/template}