AngularJS directive for Highcharts
A simple Angularjs directive for Highcharts.
Google Group: https://groups.google.com/forum/#!forum/highcharts-ng
Basic jsfiddle: http://jsfiddle.net/pablojim/LnkgL135/ See example in ./example/charts/general-example.html (Also served here: https://rawgit.com/pablojim/highcharts-ng/master/example/charts/general-example.html)
Note Needs Highcharts/Highstock >= 5.0.0 Only supports AngularJS >= 1.5 Configuration Format is not compatible with highcharts-ng 0.x.0
Setup:
Install with npm:
npm install highcharts-ng
or with bower:
bower install highcharts-ng --save
Add references to Highcharts/Highstocks:
<script src="http://code.highcharts.com/stock/highstock.src.js"></script>
or
<script src="http://code.highcharts.com/highcharts.src.js"></script>
Add Highcharts to your Angular app config:
var myapp = angular.module('myapp', ["highcharts-ng"]);
Make a chart!
<highchart id="chart1" config="chartConfig"></highchart>
The chartConfig
object should be the same as a normal highcharts configuration. Any options that work in highcharts should work here also.
It is Highly Recommended to give all Series and Axes a distinct ID.
All properties on the chart configuration are optional. If you don't need a feature best to leave it out completely - Highcharts will usually default to something sensible. Each property is watched for changes by angularjs.
After construction the Highcharts Chart object can be accessed with chartConfig.getChartObj()
. This is a simple way to access all the Highcharts API that is not currently managed by this directive. See the JSFiddle basic example to see how this is used to call the print function of Highcharts.
- Adding and removing series
- Setting/Updating Chart options
- Updating the chart title
- Resizes with screen size changes.
- Providing a custom changeDetection function or expression - for speed a custom changeDetection function can be provided to save dirty checking the full chart config.
- 2 way binding to chart xAxis. (use chartConfig.getChartObj() to get axis values)
- Control of Loading status though the config (use chartConfig.getChartObj() to get axis values) Both of these should be possible to add with the right PR
- Use of add and remove points on dynamically updated series
- Due to many equality checks the directive maybe slow with large datasets - try using changeDetection instead
- Whole Chart/Series is often redrawn where a simple update of data would suffice
- If you don't assign ids to your series - incremental ids will be added. This may mean extra redraws.
- Needs more tests!
- Whats different to previous 0.0.X versions?
This version is much much simpler and should be more stable. Some features however are still to be implemented e.g. 2-way binding to axes and loading functionality
- How do I get access to the chart object?
You can use config.getChartObj
. 95% of the time you should not need this and should instead change the chartConfig instead.
Be careful - if you manually change something with the chart object that is also in the chartConfig the chart and the config may end up out of sync.
- Why don't you just use the standard Highcharts format?
Since 0.1.0, vanilla Highcharts objects are supported!
- only support Highchart/Highstock >= 5.0.0
- only support AngularJS >= 1.5 (see https://github.com/toddmotto/angular-component for lower versions)
- Move to AngularJS Component
- Now supports vanilla Highcharts config
- Supports custom change detection functions
- Should be much more stable and less bugs
- 2 way axes binding no longer supported
- loading property no longer supported
- Minor bugfix
- use addPoint where possible
- seperate lazyloader - thanks @graingert
- Lots of updates and fixes - thanks @graingert
- Bug fix for console error with missing yAxis
- Bug fix for 0.0.9 - problems with deep extend
- Lazy loading - thanks @FDIM
- Better navigator support - thanks @ASethi77
- Lots of bug fixes - thanks to all contributors
- added config.getHighcharts - thanks @ValentinH
- Lots of bug fixes - thanks to all contributors
- Now with support for Highmaps - see: http://rawgit.com/pablojim/highcharts-ng/master/example/maps/example.html
- Better support for large data series - thanks @f1ghtingfalcons
- Lots of bug fixes - thanks to all contributors
- Added no data logic - thanks @eranbetzalel
- Added reflow event thanks @pajooh
- Added example for size setting
- Minor bug fixes
- Now watches size property
- More robust checks around axes
- Fix to minimised file
- Migrated to grunt, bower and npm
- Bug fixes
- Some speedups
- Removed JQuery dependency
- Allowed for null config option
<highchart id="chart1" series="chart.series" title="chart.title" options="chart.options"></highchart>
See an example here: http://jsfiddle.net/pablojim/46rhz/