Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/priyanjitdey94/svelte-fusioncharts
Svelte Component for FusionCharts JavaScript Charting Library
https://github.com/priyanjitdey94/svelte-fusioncharts
fusioncharts fusioncharts-component fusioncharts-library fusionmaps fusiontime fusionwidgets powercharts svelte svelte-charting-library svelte-charts svelte-components svelte-fusioncharts svelte-wrapper
Last synced: about 19 hours ago
JSON representation
Svelte Component for FusionCharts JavaScript Charting Library
- Host: GitHub
- URL: https://github.com/priyanjitdey94/svelte-fusioncharts
- Owner: fusioncharts
- License: mit
- Created: 2019-06-22T06:57:10.000Z (over 5 years ago)
- Default Branch: develop
- Last Pushed: 2021-02-02T09:52:36.000Z (almost 4 years ago)
- Last Synced: 2024-04-14T04:05:59.096Z (10 months ago)
- Topics: fusioncharts, fusioncharts-component, fusioncharts-library, fusionmaps, fusiontime, fusionwidgets, powercharts, svelte, svelte-charting-library, svelte-charts, svelte-components, svelte-fusioncharts, svelte-wrapper
- Language: JavaScript
- Homepage: https://fusioncharts.github.io/svelte-fusioncharts/
- Size: 5.34 MB
- Stars: 127
- Watchers: 9
- Forks: 7
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Svelte-FusionCharts
A simple and lightweight official Svelte component for FusionCharts JavaScript charting library. `svelte-fusioncharts` enables you to add JavaScript charts in your Svelte application or project without any hassle.
## [Demo](https://fusioncharts.github.io/svelte-fusioncharts/)
- Github Repo: [https://github.com/fusioncharts/svelte-fusioncharts](https://github.com/fusioncharts/svelte-fusioncharts)
- Support: [https://www.fusioncharts.com/contact-support](https://www.fusioncharts.com/contact-support)
- FusionCharts
- Official Website: [https://www.fusioncharts.com/](https://www.fusioncharts.com/)
- Official NPM Package: [https://www.npmjs.com/package/fusioncharts](https://www.npmjs.com/package/fusioncharts)
- Issues: [https://github.com/fusioncharts/svelte-fusioncharts/issues](https://github.com/fusioncharts/svelte-fusioncharts/issues)---
## Table of Contents
- [Getting Started](#getting-started)
- [Requirements](#requirements)
- [Installation](#installation)
- [Usage](#usage)
- [Working with chart API](#working-with-apis)
- [Working with events](#working-with-events)
- [Quick Start](#quick-start)
- [Going Beyond Charts](#going-beyond-charts)
- [Usage and Integration of FusionTime](#usage-and-integration-of-fusiontime)
- [For Contributors](#for-contributors)
- [Licensing](#licensing)## Getting Started
### Requirements
- **Node.js**, **NPM/Yarn** installed globally in your OS.
- **FusionCharts** and **Svelte** installed in your project, as detailed below:### Installation
There are multiple ways to install `svelte-fusioncharts` component.
**Install from NPM**
```
npm install --save svelte-fusioncharts
```See [npm documentation](https://docs.npmjs.com/) to know more about npm usage.
### Usage
Import `svelte-fusioncharts` and FusionCharts in your app:
```
import FusionCharts from 'fusioncharts/core';
import Column2d from 'fusioncharts/viz/column2d';
import SvelteFC, { fcRoot } from 'svelte-fusioncharts';fcRoot(FusionCharts, Column2d);
```
Note: This way of import will not work in IE11 and below.
## Quick Start
Here is a basic sample that shows how to create a chart using `svelte-fusioncharts`:
```javascript
import FusionCharts from 'fusioncharts';
import Charts from 'fusioncharts/fusioncharts.charts';
import FusionTheme from 'fusioncharts/themes/fusioncharts.theme.fusion';
import SvelteFC, { fcRoot } from 'svelte-fusioncharts';// Always set FusionCharts as the first parameter
fcRoot(FusionCharts, Charts, FusionTheme);const dataSource = {
chart: {
caption: 'Countries With Most Oil Reserves [2017-18]',
subCaption: 'In MMbbl = One Million barrels',
xAxisName: 'Country',
yAxisName: 'Reserves (MMbbl)',
numberSuffix: 'K',
theme: 'fusion'
},
data: [
{ label: 'Venezuela', value: '290' },
{ label: 'Saudi', value: '260' },
{ label: 'Canada', value: '180' },
{ label: 'Iran', value: '140' },
{ label: 'Russia', value: '115' },
{ label: 'UAE', value: '100' },
{ label: 'US', value: '30' },
{ label: 'China', value: '30' }
]
};const chartConfigs = {
type: 'column2d',
width: 600,
height: 400,
dataFormat: 'json',
dataSource: dataSource
};```
## Render FusionMaps
To render a map, import the FusionMaps module along with the map definition.
```javascript
import FusionCharts from 'fusioncharts';
import Maps from 'fusioncharts/fusioncharts.maps';
import World from 'fusioncharts/maps/fusioncharts.world';
import FusionTheme from 'fusioncharts/themes/fusioncharts.theme.fusion';
import SvelteFC, { fcRoot } from 'svelte-fusioncharts';// Always set FusionCharts as the first parameter
fcRoot(FusionCharts, Maps, World, FusionTheme);const dataSource = {
chart: {
caption: 'Average Annual Population Growth',
subcaption: ' 1955-2015',
numbersuffix: '%',
includevalueinlabels: '1',
labelsepchar: ': ',
entityFillHoverColor: '#FFF9C4',
theme: 'fusion'
},
colorrange: {
minvalue: '0',
code: '#FFE0B2',
gradient: '1',
color: [
{ minvalue: '0.5', maxvalue: '1.0', color: '#FFD74D' },
{ minvalue: '1.0', maxvalue: '2.0', color: '#FB8C00' },
{ minvalue: '2.0', maxvalue: '3.0', color: '#E65100' }
]
},
data: [
{ id: 'NA', value: '.82', showLabel: '1' },
{ id: 'SA', value: '2.04', showLabel: '1' },
{ id: 'AS', value: '1.78', showLabel: '1' },
{ id: 'EU', value: '.40', showLabel: '1' },
{ id: 'AF', value: '2.58', showLabel: '1' },
{ id: 'AU', value: '1.30', showLabel: '1' }
]
};const chartConfigs = {
type: 'world',
width: 600,
height: 400,
dataFormat: 'json',
dataSource: dataSource
};```
## Working with Events
To attach event callbacks to a FusionCharts component, follow the sample below.
```javascript
import FusionCharts from 'fusioncharts';
import Charts from 'fusioncharts/fusioncharts.charts';
import FusionTheme from 'fusioncharts/themes/fusioncharts.theme.fusion';
import SvelteFC, { fcRoot } from 'svelte-fusioncharts';// Always set FusionCharts as the first parameter
fcRoot(FusionCharts, Charts, FusionTheme);const dataSource = {
chart: {
caption: 'Countries With Most Oil Reserves [2017-18]',
subCaption: 'In MMbbl = One Million barrels',
xAxisName: 'Country',
yAxisName: 'Reserves (MMbbl)',
numberSuffix: 'K',
theme: 'fusion'
},
data: [
{ label: 'Venezuela', value: '290' },
{ label: 'Saudi', value: '260' },
{ label: 'Canada', value: '180' },
{ label: 'Iran', value: '140' },
{ label: 'Russia', value: '115' },
{ label: 'UAE', value: '100' },
{ label: 'US', value: '30' },
{ label: 'China', value: '30' }
]
},
dataplotClickHandler = event => {
// code for dataplotClick event handler
},
renderCompleteHandler = event => {
// code for renderComplete event handler
};const chartConfigs = {
type: 'column2d',
width: 600,
height: 400,
dataFormat: 'json',
dataSource: dataSource
};```
## Working with APIs
To call APIs we will need the chart object. To get the chart object for an SvelteFC component, bind a variable with the
chart
property of SvelteFC component.```javascript
import FusionCharts from 'fusioncharts';
import Charts from 'fusioncharts/fusioncharts.charts';import FusionTheme from 'fusioncharts/themes/fusioncharts.theme.fusion';
import SvelteFC, { fcRoot } from 'svelte-fusioncharts';fcRoot(FusionCharts, Charts, FusionTheme);
let chartObj,
dataSource = {
"chart": {
"caption": "Market Share of Web Servers",
"plottooltext": "<b>$percentValue</b> of web servers run on $label servers",
"showLegend": "1",
"showPercentValues": "1",
"legendPosition": "bottom",
"useDataPlotColorForLabels": "1",
"enablemultislicing": "0",
"showlegend": "0",
"theme": "fusion",
},
"data": [{
"label": "Apache",
"value": "32647479"
}, {
"label": "Microsoft",
"value": "22100932"
}, {
"label": "Zeus",
"value": "14376"
}, {
"label": "Other",
"value": "18674221"
}]
},
chartConfig = {
type: 'pie2d',
width: '600',
height: '400',
renderAt: 'chart-container',
dataSource
};const sliceDataPlot = (index, sliceOut = true) => {
chartObj.slicePlotItem(index, sliceOut)
};
{
sliceDataPlot(1);
}}>
Slice out{
sliceDataPlot(1, false);
}} >
Slice in```
links to help you get started:
- [Live samples with code](https://fusioncharts.github.io/svelte-fusioncharts/)
- [Documentation](https://www.fusioncharts.com/dev/getting-started/svelte/your-first-chart-using-svelte)
- [Use Chart API events & methods in Svelte](https://www.fusioncharts.com/dev/getting-started/svelte/configure-your-chart-using-svelte)
- [Chart gallery](https://www.fusioncharts.com/explore/chart-gallery)
- [FusionCharts API](https://www.fusioncharts.com/dev/api/fusioncharts)## Usage and integration of FusionTime
From `[email protected]`, You can visualize timeseries data.
Learn more about FusionTime [here](https://www.fusioncharts.com/fusiontime).
### Consider the example below for integration of FusionTime
```javascript
import FusionCharts from 'fusioncharts';
import Timeseries from 'fusioncharts/fusioncharts.timeseries';
import SvelteFC, { fcRoot } from 'svelte-fusioncharts';fcRoot(FusionCharts, Timeseries);
let promise,
jsonify = res => res.json(),
dataFetch = fetch(
'https://s3.eu-central-1.amazonaws.com/fusion.store/ft/data/line-chart-with-time-axis-data.json'
).then(jsonify),
schemaFetch = fetch(
'https://s3.eu-central-1.amazonaws.com/fusion.store/ft/schema/line-chart-with-time-axis-schema.json'
).then(jsonify);promise = Promise.all([dataFetch, schemaFetch]);
const getChartConfig = ([data, schema]) => {
const fusionDataStore = new FusionCharts.DataStore(),
fusionTable = fusionDataStore.createDataTable(data, schema);return {
type: 'timeseries',
width: '100%',
height: 450,
renderAt: 'chart-container',
dataSource: {
data: fusionTable,
caption: {
text: 'Sales Analysis'
},
subcaption: {
text: 'Grocery'
},
yAxis: [
{
plot: {
value: 'Grocery Sales Value',
type: 'line'
},
format: {
prefix: '$'
},
title: 'Sale Value'
}
]
}
};
};
{#await promise}
Fetching data and schema...
{:then value}
{:catch error}
Something went wrong: {error.message}
{/await}
```Useful links for FusionTime
- [How FusionTime works](https://www.fusioncharts.com/dev/fusiontime/getting-started/how-fusion-time-works)
- [Create your first chart](https://www.fusioncharts.com/dev/fusiontime/getting-started/create-your-first-chart-in-fusiontime)## 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.## For Contributors
- Clone the repository and install dependencies
```
git clone https://github.com/fusioncharts/svelte-fusioncharts.git
cd svelte-fusioncharts
npm i
npm run dev
```- Run `npm run build` to create a production build.
## Licensing
The FusionCharts Svelte component is open-source and distributed under the terms of the MIT/X11 License. However, you will need to download and include FusionCharts library in your page separately, which has a [separate license](https://www.fusioncharts.com/buy).