UNPKG

fusioncharts

Version:

FusionCharts JavaScript charting framework

361 lines (296 loc) 20.1 kB
<p align="center"> <img src="https://cdn.fusioncharts.com/fusioncharts/assets/fusioncharts-logo.svg" width="234px" alt="FusionCharts - Build beautiful web & mobile dashboards"> </p> <p align="center"> <img alt="FusionCharts jsDelivr Hits" src="https://img.shields.io/jsdelivr/npm/hm/fusioncharts.svg"> <img alt="FusionCharts Downloads" src="https://img.shields.io/npm/dm/fusioncharts.svg"> <img alt="FusionCharts NPM Version" src="https://img.shields.io/npm/v/fusioncharts.svg"> </p> FusionCharts is a JavaScript charting library providing 100+ charts and 2,000+ maps for your web and mobile applications. All the visualizations are interactive and animated, which are rendered in SVG and VML (for IE 6/7/8). This package also contains FusionTime (timeseries charts), FusionWidgets (gauges, real-time charts), PowerCharts (statistical and advanced charts), and FusionMaps (choropleth geo maps). - Official Website: [https://www.fusioncharts.com/](https://www.fusioncharts.com/) - Documentation: [https://www.fusioncharts.com/dev/](https://www.fusioncharts.com/dev/) - Download page: [https://www.fusioncharts.com/download/](https://www.fusioncharts.com/download/) - Licensing: [Legal Terms & Customer Agreements](https://www.ideracorp.com/legal/FusionCharts#tabs-2) - Support: [https://www.fusioncharts.com/contact-support](https://www.fusioncharts.com/contact-support) - Issues: [https://github.com/fusioncharts/fusioncharts-dist/issues](https://github.com/fusioncharts/fusioncharts-dist/issues) ### What's New #### New Features - FusionCharts version 4.0.0 introduces `Ask FusionDev AI` knowledge base and documentation assistant which: - Improves discoverability and unblocks developers by finding instant answers to questions about using FusionCharts. - Increases developer productivity by providing instant access to clear, concise, and up-to-date documentation. - Improves development efficiency with automated code generation. - An attribute called `autoUpdateStartEndDateColumn` was introduced. This attribute updates the actual start date / actual end date columns in the Gantt Chart when taskbars are getting dragged. - An attribute called `allowTaskbarOverlap` was introduced. When this attribute is set to 1, it allows the dragging of the taskbar over adjacent taskbars in the Gantt Chart. - The attributes `marginLeft`, `marginRight`, `marginTop`, and `marginBottom` were introduced in the milestone option of Gantt Chart. These attributes are used to position the milestone per the numeric value provided. #### Improvements - FusionCharts version 4.0.0 improved the behavior of **taskbar dragging** in Gantt charts. Now you will also drag the connectors along with the taskbar, and they will stay connected until the drag ends. - FusionCharts version 4.0.0 introduced the **increase/decrease width functionality** for taskbars. Whenever the taskbar hovers, the stretch icon at both ends of the taskbar can be used to increase/decrease the same width. An arrow icon was added at the end of taskbars for increasing/decreasing width. - FusionCharts version 4.0.0 improved the behavior of **taskbar dragging** in the case of parent and child taskbars. The parent taskbars will auto-extend in case the child taskbars are dragged. - Upgraded framework integrations for React, Angular, Vue & Svelte. - React FusionCharts upgraded to v18. React upgraded to version 18 in package.json file. - Angular FusionCharts upgraded to v17. Angular packages version upgraded to 17 in package.json folder. Typescript packages are also upgraded to support Angular 17. - Vue FusionCharts upgraded to v3. Vue package already had v3, only a minor version upgrade was done in package.json file. - Svelte FusionCharts upgraded to v4. Svelte was upgraded to the latest version 4 in package.json file. The bundler used in the Avelte package was rollup which had some old APIs, they were replaced with the new APIs. - FusionCharts ASP.Net has been updated to support **.NET versions** (6.0, 7.0, and 8.0). - FusionCharts 4.0.0 enhanced **product stability** and **security** through Automation Repository Upgrade & Optimization. #### Fixes - Resolved the issue of `plotHighlightEffect` attribute resetting all the dataset-level attributes when series were shown/hidden using legends. - Fixed the issue of `resizeTo` method not working when the chart was rendered using XML data format. - Fixed the issue where charts were not exported on **iPad** with Safari browser. - Fixed the issue where taskbar drags position update event `dataplotdragmove` was logging duplicate values in Gantt charts. - Resolved the issue when the tooltip was not visible on the delayed part of taskbars in Gantt charts. - Resolved the visual bug with data labels and their background when `transposeAxis` was enabled for multi-series bar charts. Improved the visual clarity of Multi-series Bar charts by addressing `transposeAxis` attribute bug. - Resolved an issue where inline styles used for Pie chart watermarks and tooltips triggered CSP errors, potentially hindering chart display. - Fixed the bug where the scroll bar position was getting reset to the initial position, when `setChartData` is used to update the chart’s data. - Handled the case of negative values for radial bar in Radial Bar charts. For **negative values**, the radial bar will stick to the 0 position. - Fixed the issue where React FusionCharts wrapper was not working in strict mode. In react wrapper, if the chart is already rendered then the `dispose` method is used to delete the instance to avoid render callback in loop. - Resolved the issue where data values were not visible for plots in the Bar2D chart when the bar width value was very low. - Optimized user experience with Gauge charts through seamless resizing. --- ### Table of Contents - [Installing FusionCharts](#installing-fusioncharts) - [Getting Started](#getting-started) - [Using FusionCharts as an ES Module](#using-fusioncharts-as-an-es-module) - [Related Packages](#related-packages) - [Front-end Integrations](#front-end-integrations) - [Back-end Integrations](#back-end-integrations) - [Using Themes](#using-themes) - [FusionMaps](#fusionmaps) - [Going beyond Charts](#going-beyond-charts) - [Version History](#version-history) - [Contact Support](#contact-support) - [Folder Structure](#folder-structure) ## Installing FusionCharts There are multiple ways to install FusionCharts. For general instructions, refer to this [developer docs page](https://www.fusioncharts.com/dev/getting-started/plain-javascript/install-using-plain-javascript). ### Direct Download All binaries are located on our [github repository](https://github.com/fusioncharts/fusioncharts-dist). You can also download zipped version [here](https://www.fusioncharts.com/download/). ### Using CDN Instead of downloading, you can also use FusionCharts’s CDN to access files directly. See below for details ```html <script src="https://cdn.fusioncharts.com/fusioncharts/latest/fusioncharts.js"></script> ``` ### Install from NPM ```sh npm install --save fusioncharts [node version v14.12.0 (npm v6.14.8)] ``` See [npm documentation](https://docs.npmjs.com/) to know more about npm usage. ## Getting Started Easiest way to start with FusionCharts is to include the JavaScript library in your webpage, create a `<div>` container and chart instance, configure the data and render. Check this HTML snippet below: ```javascript <!doctype html> <html> <head> <script src="https://cdn.fusioncharts.com/fusioncharts/latest/fusioncharts.js"></script> </head> <body> <div id="chart-container"></div> <script> FusionCharts.ready(function () { // chart instance var chart = new FusionCharts({ type: "column2d", renderAt: "chart-container", // container where chart will render width: "600", height: "400", dataFormat: "json", dataSource: { // chart configuration chart: { caption: "Countries With Most Oil Reserves [2017-18]", subcaption: "In MMbbl = One Million barrels" }, // chart data data: [ { label: "Venezuela", value: "290000" }, { label: "Saudi", value: "260000" }, { label: "Canada", value: "180000" }, { label: "Iran", value: "140000" }, { label: "Russia", value: "115000" }, { label: "UAE", value: "100000" }, { label: "US", value: "30000" }, { label: "China", value: "30000" } ] } }).render(); }); </script> </body> </html> ``` Here’re links to quick start guides: - [FusionCharts](https://www.fusioncharts.com/dev/getting-started/plain-javascript/your-first-chart-using-plain-javascript#create-your-first-chart-1) - [FusionTime](https://www.fusioncharts.com/dev/fusiontime/getting-started/create-your-first-chart-in-fusiontime) - [FusionWidgets](https://www.fusioncharts.com/dev/getting-started/plain-javascript/your-first-chart-using-plain-javascript#create-your-first-gauge-8) - [FusionMaps](https://www.fusioncharts.com/dev/getting-started/plain-javascript/your-first-chart-using-plain-javascript#create-your-first-map-13) ## Using FusionCharts as an ES Module FusionCharts can be loaded as an ES module via transpilers. _The following examples presumes you are using npm to install FusionCharts, see Install FusionCharts for more details._ ```javascript import FusionCharts from "fusioncharts/core"; // include chart from viz folder - import ChartType from fusioncharts/viz/[ChartType]; import Column2D from "fusioncharts/viz/column2d"; // add chart as dependency - FusionCharts.addDep(ChartType); FusionCharts.addDep(Column2D); // instantiate the chart. var chartInstance = new FusionCharts({ type: "Column2D", renderAt: "chart-container", // div container where chart will render width: "600", height: "400", dataFormat: "json", dataSource: { // chart configuration chart: { caption: "Countries With Most Oil Reserves [2017-18]", subcaption: "In MMbbl = One Million barrels", }, // chart data data: [ { label: "Venezuela", value: "290000" }, { label: "Saudi", value: "260000" }, { label: "Canada", value: "180000" }, { label: "Iran", value: "140000" }, { label: "Russia", value: "115000" }, { label: "UAE", value: "100000" }, { label: "US", value: "30000" }, { label: "China", value: "30000" }, ], }, }); // render the chart chartInstance.render(); ``` Want to render data-driven maps (FusionMaps) - check out [this link](https://www.npmjs.com/package/fusionmaps). ## Related Packages ### Front-end Integrations | | | | | :------------------------ | :-------------------------------------------------------------------------- | :------------------------------------------------------------------------------------------------------------------- | | AngularJS (1.x and above) | [Github Repo](https://github.com/fusioncharts/angularjs-fusioncharts) | [Documentation](https://www.fusioncharts.com/dev/getting-started/angular/angularjs/your-first-chart-using-angularjs) | | Angular (2.x and above) | [Github Repo](https://github.com/fusioncharts/angular-fusioncharts) | [Documentation](https://www.fusioncharts.com/dev/getting-started/angular/angular/your-first-chart-using-angular) | | jQuery | [Github Repo](https://github.com/fusioncharts/fusioncharts-jquery-plugin) | [Documentation](https://www.fusioncharts.com/dev/getting-started/jquery/your-first-chart-using-jquery) | | React | [Github Repo](https://github.com/fusioncharts/react-fusioncharts-component) | [Documentation](https://www.fusioncharts.com/dev/getting-started/react/your-first-chart-using-react) | | Vue | [Github Repo](https://github.com/fusioncharts/vue-fusioncharts) | [Documentation](https://www.fusioncharts.com/dev/getting-started/vue/your-first-chart-using-vuejs) | | Ember | [Github Repo](https://github.com/fusioncharts/ember-fusioncharts) | [Documentation](https://www.fusioncharts.com/dev/getting-started/ember/your-first-chart-using-ember) | ### Back-end Integrations | | | | | :------------ | :------------------------------------------------------------- | :------------------------------------------------------------------------------------------------------------------- | | ASP.NET (C#) | [Github Repo](https://github.com/fusioncharts/asp-net-wrapper) | [Documentation](https://www.fusioncharts.com/dev/getting-started/aspnet/your-first-chart-using-aspnet) | | ASP.NET (VB) | [Github Repo](https://github.com/fusioncharts/vb-net-wrapper) | [Documentation](https://www.fusioncharts.com/dev/getting-started/aspnet/your-first-chart-using-aspnet) | | Java (JSP) | [Github Repo](https://github.com/fusioncharts/jsp-wrapper) | [Documentation](https://www.fusioncharts.com/dev/getting-started/java/your-first-chart-using-java) | | Django | [Github Repo](https://github.com/fusioncharts/django-wrapper) | [Documentation](https://www.fusioncharts.com/dev/getting-started/django/your-first-chart-using-django) | | PHP | [Github Repo](https://github.com/fusioncharts/php-wrapper) | [Documentation](https://www.fusioncharts.com/dev/getting-started/php/your-first-chart-using-php) | | Ruby on Rails | [Github Repo](https://github.com/fusioncharts/rails-wrapper) | [Documentation](https://www.fusioncharts.com/dev/getting-started/ruby-on-rails/your-first-chart-using-ruby-on-rails) | ## Using Themes FusionCharts provides several out-of-the box themes that can be applied to all the charts to configure the visual appearance of the charts. Below is an example on how to use a theme: ```html <!DOCTYPE html> <html> <head> <script src="https://cdn.fusioncharts.com/fusioncharts/latest/fusioncharts.js"></script> <script src="https://cdn.fusioncharts.com/fusioncharts/latest/themes/fusioncharts.theme.fusion.js"></script> </head> <body> <div id="chart-container"></div> <script> FusionCharts.ready(function () { // chart instance var chart = new FusionCharts({ type: "column2d", renderAt: "chart-container", // container where chart will render width: "600", height: "400", dataFormat: "json", dataSource: { // chart configuration chart: { caption: "Countries With Most Oil Reserves [2017-18]", subcaption: "In MMbbl = One Million barrels", theme: "fusion", //Specifying which theme to use }, // chart data data: [ { label: "Venezuela", value: "290000" }, { label: "Saudi", value: "260000" }, { label: "Canada", value: "180000" }, { label: "Iran", value: "140000" }, { label: "Russia", value: "115000" }, { label: "UAE", value: "100000" }, { label: "US", value: "30000" }, { label: "China", value: "30000" }, ], }, }).render(); }); </script> </body> </html> ``` ### Using themes in ES6 ```javascript import FusionCharts from "fusioncharts/core"; // include chart from viz folder - import ChartType from fusioncharts/viz/[ChartType]; import Column2D from "fusioncharts/viz/column2d"; // include theme from themes folder import fusionTheme from "fusioncharts/themes/es/fusioncharts.theme.fusion"; // add chart as dependency - FusionCharts.addDep(ChartType); FusionCharts.addDep(Column2D); FusionCharts.addDep(fusionTheme); // instantiate the chart. var chartInstance = new FusionCharts({ type: "Column2D", renderAt: "chart-container", // container where chart will render width: "600", height: "400", dataFormat: "json", dataSource: { // chart configuration chart: { caption: "Countries With Most Oil Reserves [2017-18]", subcaption: "In MMbbl = One Million barrels", theme: "fusion", }, // chart data data: [ { label: "Venezuela", value: "290000" }, { label: "Saudi", value: "260000" }, { label: "Canada", value: "180000" }, { label: "Iran", value: "140000" }, { label: "Russia", value: "115000" }, { label: "UAE", value: "100000" }, { label: "US", value: "30000" }, { label: "China", value: "30000" }, ], }, }); // render the chart chartInstance.render(); ``` See all the themes live [here](https://www.fusioncharts.com/explore/chart-gallery/stacked-charts/stacked-columns). Check out [this link](https://www.fusioncharts.com/dev/themes/introduction-to-themes) to know more about themes. Want us to build a theme to suit your corporate branding? [Request one here](https://www.fusioncharts.com/contact-support)! ## FusionMaps FusionMaps is a companion package meant to be used in conjunction with FusionCharts to render choropleth geo maps. FusionMaps provide over 1,400+ geographical maps, including all countries, US states, and regions in Europe for plotting business data like revenue by regions, employment levels by state and office locations. See below links to know more: - [Examples](https://www.fusioncharts.com/explore/chart-gallery?product=fusionmaps) - [Documentation](https://www.fusioncharts.com/dev/map-guide/setup) - [Github Repo](https://github.com/fusioncharts/fusionmaps-dist) and [NPM Package](https://www.npmjs.com/package/fusionmaps) ## Going beyond Charts - Explore 20+ pre-built business specific dashboards for different industries like energy and manufacturing to business functions like sales, marketing and operations [here](https://www.fusioncharts.com/explore/dashboards). - See [Data Stories](https://www.fusioncharts.com/explore/data-stories) built using FusionCharts’ interactive JavaScript visualizations and learn how to communicate real-world narratives through underlying data to tell compelling stories. ## Version History - [What’s New](https://www.fusioncharts.com/dev/upgrading/whats-new) - [Change Log](https://www.fusioncharts.com/dev/upgrading/change-log) - [Changed Behaviour & Depreciation](https://www.fusioncharts.com/dev/upgrading/changed-behavior) ## Contact Support Fill [this form](https://www.fusioncharts.com/contact-support) or drop an email to [support@fusioncharts.com](mailto:support@fusioncharts.com) ## Folder Structure ``` fusioncharts/ ├── core/ - Contains the FusionCharts core. ├── viz/ - Contains all the individual vizualizations (Column2D, SplineArea, AngularGauge etc.) ├── charts/ - Contains all the visualizations of the Charts package (similar to fusioncharts.charts.js). ├── powercharts/ - Contains all the visualizations of the PowerCharts package. ├── timeseries/ - Contains all the visualizations of the FusionTime package. ├── widgets/ - Contains all the visualizations of the FusionWidgets package. ├── maps/ - Contains the map renderer │ └── es/ - Contains the map definition files of World and USA └── themes/es - Contains all the theme files. ```