Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
ngx-echarts
Advanced tools
<!-- Badges section here. --> [![npm](https://img.shields.io/npm/v/ngx-echarts.svg)][npm-badge-url] [![npm](https://img.shields.io/npm/dm/ngx-echarts.svg)][npm-badge-url] [![Build Status](https://travis-ci.org/xieziyu/ngx-echarts.svg?branch=master)][ci-ur
Angular directive for echarts (version >= 3.x) (The project is renamed from angular2-echarts)
ngx-echarts
is an Angular (ver >= 2.x) directive for ECharts (ver >= 3.x).
Latest version @npm:
v4.x
for Angular >= 6v2.3.1
for Angular < 6 (Please refer to https://github.com/xieziyu/ngx-echarts/blob/v2.x/README.md)A starter project on Github: https://github.com/xieziyu/ngx-echarts-starter
2019.06.14: v4.2.0
2019.04.16: v4.1.1
2018.12.16: v4.1.0
2018.11.11: v4.0.1
2018.08.20: v4.0.0
chartClick
and some other event-emitters become silent. demoimport * as echarts from 'echarts';
/** or */
import { graphic, registerMap } from 'echarts';
main.ts
. Refer to ECharts Extensions2018.07.24: v3.2.0 & v2.3.1:
2018.06.13: v3.1.0 & v2.2.0:
<ng-template>
such as NG-ZORRO components.2018.06.12: v3.0.1 & v2.1.1:
2018.05.08: v3.0.0:
2018.03.14: v2.1.0
[loadingOpts]
to customize loading style. Refer to APIdom.style.height
before setting default value.2018.02.07: v2.0.2. New: [autoResize]
input (default: true). PR #73 by arethore-actility
2017.12.11: v2.0.1. Fix issue: No change detection involved in event handler. Refer to issue #26, #28
2017.12.04: v2.0.0. Provide an echarts wrapper service: NgxEchartsService.
2017.11.25: v2.0.0-beta.0. It has some BREAKING CHANGES you should know.
Since v4.0
# if you use npm
npm install echarts -S
npm install ngx-echarts -S
npm install @types/echarts -D
# or if you use yarn
yarn add echarts
yarn add ngx-echarts
yarn add @types/echarts -D
If you need ECharts GL support, please install it first:
npm install echarts-gl -S
# or
yarn add echarts-gl
Import other extentions such as themes or echarts-gl
in your main.ts
: ECharts Extensions
@types/echarts
main.ts
. Refer to ECharts Extensions.echarts
related scripts in angular.json
.Please refer to the demo page.
Firstly, import NgxEchartsModule
in your app module (or any other proper angular module):
import { NgxEchartsModule } from 'ngx-echarts';
@NgModule({
imports: [
...,
NgxEchartsModule
],
...
})
export class AppModule { }
Then: use echarts
directive in a div which has pre-defined height. (From v2.0, it has default height: 400px)
Simple example:
<div echarts [options]="chartOption" class="demo-chart"></div>
.demo-chart {
height: 400px;
}
import { EChartOption } from 'echarts';
// ...
chartOption: EChartOption = {
xAxis: {
type: 'category',
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
yAxis: {
type: 'value'
},
series: [{
data: [820, 932, 901, 934, 1290, 1330, 1320],
type: 'line'
}]
}
echarts
directive support following input porperties:
Input | Type | Default | Description |
---|---|---|---|
[options] | object | null | It's the same with the options in official demo site. |
[merge] | object | null | You can use it to update part of the options , especially helpful when you need to update the chart data. In fact, the value of merge will be used in echartsInstance.setOption() with notMerge = false . So you can refer to ECharts documentation for details |
[loading] | boolean | false | Use it to toggle the echarts loading animation when your data is not ready. |
[autoResize] | boolean | true | Charts will be automatically resized when container's width changed. |
[initOpts] | object | null | The value of [initOpts] will be used in echarts.init() . It may contain devicePixelRatio , renderer , width or height properties. Refer to ECharts documentation for details |
[theme] | string | null | Use it to init echarts with theme. You need to import the theme file in main.ts . |
[loadingOpts] | object | null | Input an object to customize loading style. Refer to ECharts documentation for details. |
[detectEventChanges] | boolean | true | Whether to register mouse event handlers on echartInstance. Use it to avoid unwanted change detections. |
By default, loadingOpts
is:
{
text: 'loading',
color: '#c23531',
textColor: '#000',
maskColor: 'rgba(255, 255, 255, 0.8)',
zlevel: 0
}
If you need echarts API such as echarts.graphic
, please import it from echarts. For example:
/** import all */
import * as echarts from 'echarts/lib/echarts';
new echarts.graphic.LinearGradient(/** ... */);
/** or you can */
import { graphic } from 'echarts/lib/echarts';
new graphic.LinearGradient(/** ... */);
echartsInstance
is exposed (since v1.1.6) in (chartInit)
event. So you can directly call the APIs just like: resize()
, showLoading()
, etc. For example:
<div echarts class="demo-chart" [options]="chartOptions" (chartInit)="onChartInit($event)"></div>
onChartInit(ec) {
this.echartsIntance = ec;
}
resizeChart() {
if (this.echartsIntance) {
this.echartsIntance.resize();
}
}
Import echarts theme files or other extension files in main.ts
. For example:
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
/** echarts extensions: */
import 'echarts-gl';
import 'echarts/theme/macarons.js';
import 'echarts/dist/extension/bmap.min.js';
if (environment.production) {
enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
.catch(err => console.log(err));
NgxEchartsService
has been obsoleted since v4.0
As echarts support the 'click'
, 'dblclick'
, 'mousedown'
, 'mouseup'
, 'mouseover'
, 'mouseout'
, 'globalout'
mouse events, our ngx-echarts
directive also support the same mouse events but with additional chart
prefix.
<div echarts class="demo-chart" [options]="chartOptions" (chartClick)="onChartClick($event)"></div>
It supports following event outputs:
@Output | Event |
---|---|
chartInit | Emitted when chart is intialized |
chartClick | echarts event: 'click' |
chartDblClick | echarts event: 'dblclick' |
chartMouseDown | echarts event: 'mousedown' |
chartMouseMove | echarts event: 'mousemove' |
chartMouseUp | echarts event: 'mouseup' |
chartMouseOver | echarts event: 'mouseover' |
chartMouseOut | echarts event: 'mouseout' |
chartGlobalOut | echarts event: 'globalout' |
chartContextMenu | echarts event: 'contextmenu' |
chartLegendSelectChanged | echarts event: 'legendselectchanged' |
chartLegendSelected | echarts event: 'legendselected' |
chartLegendUnselected | echarts event: 'legendunselected' |
chartLegendScroll | echarts event: 'legendscroll' |
chartDataZoom | echarts event: 'datazoom' |
chartDataRangeSelected | echarts event: 'datarangeselected' |
chartTimelineChanged | echarts event: 'timelinechanged' |
chartTimelinePlayChanged | echarts event: 'timelineplaychanged' |
chartRestore | echarts event: 'restore' |
chartDataViewChanged | echarts event: 'dataviewchanged' |
chartMagicTypeChanged | echarts event: 'magictypechanged' |
chartPieSelectChanged | echarts event: 'pieselectchanged' |
chartPieSelected | echarts event: 'pieselected' |
chartPieUnselected | echarts event: 'pieunselected' |
chartMapSelectChanged | echarts event: 'mapselectchanged' |
chartMapSelected | echarts event: 'mapselected' |
chartMapUnselected | echarts event: 'mapunselected' |
chartAxisAreaSelected | echarts event: 'axisareaselected' |
chartFocusNodeAdjacency | echarts event: 'focusnodeadjacency' |
chartUnfocusNodeAdjacency | echarts event: 'unfocusnodeadjacency' |
chartBrush | echarts event: 'brush' |
chartBrushSelected | echarts event: 'brushselected' |
chartRendered | echarts event: 'rendered' |
chartFinished | echarts event: 'finished' |
You can refer to the echarts tutorial: Events and Actions in ECharts for more details of the event params. You can also refer to the demo page for the detailed example.
If you want to custom build echarts, just import want you need in a file:
// custom-echarts.ts
// chart examples:
import 'echarts/lib/chart/line';
import 'echarts/lib/chart/bar';
// component examples:
import 'echarts/lib/component/tooltip';
import 'echarts/lib/component/title';
import 'echarts/lib/component/toolbox';
And then import it in your main.ts
:
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
// For echarts custom build
import './custom-echarts'
if (environment.production) {
enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
.catch(err => console.log(err));
And if you want to use the global echarts
object, please import it from lib
instead:
import * as echarts from 'echarts/lib/echarts'
// Don't write:
// import * as echarts from 'echarts'
If you need to import theme files, remember to change their 'echarts'
path to 'echarts/lib/echarts'
, for example:
// ... part of echarts/theme/dark.js:
function (root, factory) {
if (typeof define === 'function' && define.amd) {
// AMD. Register as an anonymous module.
define(['exports', 'echarts/lib/echarts'], factory);
} else if (typeof exports === 'object' && typeof exports.nodeName !== 'string') {
// CommonJS
factory(exports, require('echarts/lib/echarts'));
} else {
// Browser globals
factory({}, root.echarts);
}
}
You can clone this repo to your working copy and then launch the demo page in your local machine:
npm install
npm run demo
# or
yarn install
yarn demo
The demo page server is listening to: http://localhost:4202
FAQs
NGX-ECHARTS Angular directive for <a href="https://github.com
The npm package ngx-echarts receives a total of 99,175 weekly downloads. As such, ngx-echarts popularity was classified as popular.
We found that ngx-echarts demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.