Skip to content
This repository has been archived by the owner on Feb 26, 2019. It is now read-only.

ryanjackman/angular-plotly.js

 
 

Repository files navigation

angular-plotly.js

angular-plotly-logo

A plotly.js Angular component from Plotly.

CircleCI Coverage Status


Content

Installation

$ npm install angular-plotly.js plotly.js

Using the angular CLI to start a new project

$ ng new my-project
$ cd my-project
$ npm install angular-plotly.js plotly.js --save

Quick start

Add the PlotlyModule into the main app module of your project

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';

import { PlotlyModule } from 'angular-plotly.js';

@NgModule({
    imports: [CommonModule, PlotlyModule],
    ...
})
export class AppModule { }

Then use the <plotly-plot> component to display the graph

import { Component } from '@angular/core';

@Component({
    selector: 'plotly-example',
    template: '<plotly-plot [data]="graph.data" [layout]="graph.layout"></plotly-plot>',
})
export class PlotlyExampleComponent {
    public graph = {
        data: [
            { x: [1, 2, 3], y: [2, 6, 3], type: 'scatter', mode: 'lines+points', marker: {color: 'red'} },
            { x: [1, 2, 3], y: [2, 5, 3], type: 'bar' },
        ],
        layout: {width: 320, height: 240, title: 'A Fancy Plot'}
    };
}

You should see a plot like this:

Example plot

For a full description of Plotly chart types and attributes see the following resources:

API Reference

Basic Props

Warning: for the time being, this component may mutate its layout and data props in response to user input, going against React rules. This behaviour will change in the near future once plotly/plotly.js#2389 is completed.

Prop Type Default Description
[data] Array [] list of trace objects (see https://plot.ly/javascript/reference/)
[layout] Object undefined layout object (see https://plot.ly/javascript/reference/#layout)
[frames] Array undefined list of frame objects (see https://plot.ly/javascript/reference/)
[config] Object undefined config object (see https://plot.ly/javascript/configuration-options/)
[revision] Number undefined When provided, causes the plot to update only when the revision is incremented.
(initialized) Function(figure, graphDiv) undefined Callback executed after plot is initialized. See below for parameter information.
(update) Function(figure, graphDiv) undefined Callback executed when when a plot is updated due to new data or layout, or when user interacts with a plot. See below for parameter information.
(purge) Function(figure, graphDiv) undefined Callback executed when component unmounts, before Plotly.purge strips the graphDiv of all private attributes. See below for parameter information.
(error) Function(err) undefined Callback executed when a plotly.js API method rejects
[divId] string undefined id assigned to the <div> into which the plot is rendered.
[className] string undefined applied to the <div> into which the plot is rendered
[style] Object {position: 'relative', display: 'inline-block'} used to style the <div> into which the plot is rendered
[debug] Boolean false Assign the graph div to window.gd for debugging
[useResizeHandler] Boolean false When true, adds a call to Plotly.Plot.resize() as a window.resize event handler

Note: To make a plot responsive, i.e. to fill its containing element and resize when the window is resized, use style or className to set the dimensions of the element (i.e. using width: 100%; height: 100% or some similar values) and set useResizeHandler to true while setting layout.autosize to true and leaving layout.height and layout.width undefined. This will implement the behaviour documented here: https://plot.ly/javascript/responsive-fluid-layout/

Event handler props

Event handlers for specific plotly.js events may be attached through the following props:

Prop Type Plotly Event
(afterExport) Function plotly_afterexport
(afterPlot) Function plotly_afterplot
(animated) Function plotly_animated
(animatingFrame) Function plotly_animatingframe
(animationInterrupted) Function plotly_animationinterrupted
(autoSize) Function plotly_autosize
(beforeExport) Function plotly_beforeexport
(buttonClicked) Function plotly_buttonclicked
(click) Function plotly_click
(clickAnnotation) Function plotly_clickannotation
(deselect) Function plotly_deselect
(doubleClick) Function plotly_doubleclick
(framework) Function plotly_framework
(hover) Function plotly_hover
(legendClick) Function plotly_legendclick
(legendDoubleClick) Function plotly_legenddoubleclick
(relayout) Function plotly_relayout
(restyle) Function plotly_restyle
(redraw) Function plotly_redraw
(selected) Function plotly_selected
(selecting) Function plotly_selecting
(sliderChange) Function plotly_sliderchange
(sliderEnd) Function plotly_sliderend
(sliderStart) Function plotly_sliderstart
(transitioning) Function plotly_transitioning
(transitionInterrupted) Function plotly_transitioninterrupted
(unhover) Function plotly_unhover

Customizing the plotly.js bundle

By default, this library bundles plotly.js from the peer dependency together within the output. This results on huge outputs, for plotly.js itself is ~3MB when bundled. It also makes the build (with ng serve --prod) really slow, for it minifies everything together.

If you wish to optimize loading plotly.js in a different way, please check both PlotlyViaCDNModule and PlotlyViaWindowModule modules below.

Plotly Via CDN Module

If you want to load plotly.js from a CDN, use the PlotlyViaCDNModule and call forRoot method with the version you want to use:

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';

import { PlotlyViaCDNModule } from 'angular-plotly.js';

@NgModule({
    imports: [
        CommonModule,
        PlotlyViaCDNModule.forRoot({version: '1.5.0'}) // can be `latest` or any version number (i.e.: '1.4.3')
    ],
    ...
})
export class AppModule { }

Plotly Via Window Module

If you want to use a different precompiled bundle or if you wish to assemble you own customized bundle, you can use PlotlyViaWindowModule to force the use of window.Plotly object. You can add the script via tag <script> direct on your code, or add it as a global script on angular.json.

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';

import { PlotlyViaWindowModule } from 'angular-plotly.js';

@NgModule({
    imports: [CommonModule, PlotlyViaWindowModule],
    ...
})
export class AppModule { }

Development

To get started:

$ npm install

To see the demo app, run:

$ npm start

To run the tests:

$ npm run test

License

© 2018 Plotly, Inc. MIT License.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 87.1%
  • HTML 9.7%
  • JavaScript 2.1%
  • Other 1.1%