Welcome to the official GitHub repository for the React Native FusionCharts component! This component provides seamless bindings for the FusionCharts JavaScript Charting Library, allowing you to effortlessly integrate rich and interactive charts into your React Native projects.
Enhance your applications with our diverse range of charts designed to meet all your data visualization needs. Get started today and bring your data to life!
Here's the updated GitHub documentation with rephrased section headings and modified slugs:
- Important Links
- Introduction
- Overview
- Getting Started
- Developing Applications with FusionCharts and Expo
- Creating an App with FusionCharts using React Native CLI
- Quick Start
- Going Beyond Charts
- Contributor Guidelines
- License Information
React Native FusionCharts version 6.0.0 is compatible with the following versions of Expo and React Native. While it is possible that version 6.0.0 may function with newer versions of React Native and Expo, it has only been tested up to React Native 74.5.
Expo SDK Versions | React Native Versions |
---|---|
47, 48, 49, 50 & 51 | >=0.70.8 & <=0.74.5 |
To quickly integrate React Native FusionCharts into your existing application, follow these essential steps. This process installs all required dependencies, allowing those already familiar with FusionCharts to get up and running quickly. If you are new to FusionCharts, referring the Getting Started section will be more helpful.
-
Initial Dependencies Installation: Begin by running the following command in your project directory to install the necessary dependencies:
npm i react-native-webview @notifee/react-native @react-native-camera-roll/camera-roll react-native-fs react-native-share
-
Installing React Native FusionCharts: Next, install the
react-native-fusioncharts
package:npm install react-native-fusioncharts
-
iOS Setup: For iOS applications, navigate to your
ios
directory and execute:pod install
-
Enabling Chart Export Functionality on iOS: To add export functionality for your charts in iOS, modify your
info.plist
file by adding the following code to request photo library access:<key>NSPhotoLibraryUsageDescription</key> <string>Photo Library Access for downloading the chart</string>
Now that you have all essential components integrated into your project. You can now check the the quick start guide to render a chart or explore the APIs.
Node.js, NPM/Yarn installed globally in your OS.
React Native FusionCharts can be integrated into applications using Expo tools or bare React Native environments.
-
Make sure you have Node.js and Git installed in your environment. Check the official Expo’s documentation for more details.
-
Run the following command in terminal to create a new application and navigate in the project directory. You can check here for more details on creating an new expo app.
npx create-expo-app FusionApp --template blank && cd FusionApp
- Install React Native FusionCharts:
npm i react-native-fusioncharts
- Install dependencies for React Native FusionCharts:
npm i react-native-webview @notifee/react-native @react-native-camera-roll/camera-roll react-native-fs react-native-share
-
Replace the code in the "App.js" file and replace it with the example here
-
Run the
npx expo start
in the project directory and expo should generate a QR-code that you can scan from your iOS camera app to open Expo Go or directly from the Expo Go app in an android device. Make sure your device and system is on the same network. -
If everything went well so far then you should be able to see FusionCharts sample column2D chart on the app.
This guide is for building an app from scratch using React Native without any framework. If you already have an existing app, then please check the overview section and examples to setup FusionCharts.
The initial steps(1-5) to setup the React Native app is taken from the official React Native guide to setup a new app. Please refer to the React Native documentation in case you encounter an issue setting up your app.
- If you previously installed a global react-native-cli package, please remove it as it may cause unexpected issues:
npm uninstall -g react-native-cli @react-native-community/cli
- Use React Native Community CLI to generate a new project.
npx @react-native-community/cli@latest init FusionApp
- Start Metro (Metro is the JavaScript build tool for React Native. To start the Metro development server, run the following from your project folder)
npm start
- Start your application. Let Metro Bundler run in its own terminal. Open a new terminal inside your React Native project folder. Run the following:
npm run android
# or
npm run ios
-
If everything is set up correctly, you should see your new app running in your Android/iOS emulator shortly.
-
A new application named 'FusionApp' has been created. Open App.tsx in your text editor of choice and add chart samples from the quick start section. You can find more chart samples in our official documentation
Include the react-native-fusioncharts
library as follows:
The App.js
file:
import React from "react";
import { Text, View } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
const Chart = () => {
const chartData = [
{ label: "Venezuela", value: "250" },
{ 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 chartConfig = {
type: "column2D",
width: "300",
height: "400",
dataFormat: "json",
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",
exportEnabled: 1, // to enable the export chart functionality
},
data: chartData,
},
};
return (
<View
style={{
flex: 1,
justifyContent: "center",
alignItems: "center",
marginTop: 50,
}}
>
<Text>Fusioncharts</Text>
<ReactNativeFusionCharts chartConfig={chartConfig} />
</View>
);
};
export default Chart;
In this sample we are attaching dataplotclick event in the chart.
import { StatusBar } from "expo-status-bar";
import { StyleSheet, Text, View, Alert } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
export default function App() {
const chartData = [
{ label: "Venezuela", value: "250" },
{ 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 chartConfig = {
type: "column2D",
width: "300",
height: "400",
dataFormat: "json",
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",
exportEnabled: 1, // to enable the export chart functionality
},
data: chartData,
},
};
const events = {
// Add your events method here:
// Event name should be in small letters.
dataplotclick: (e, a) => {
Alert.alert(`You clicked on ${e.data.categoryLabel}`);
},
};
return (
<View style={styles.container}>
<Text>Fusioncharts</Text>
<ReactNativeFusionCharts chartConfig={chartConfig} events={events} />
<StatusBar style="auto" />
</View>
);
}
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: "#fff",
alignItems: "center",
justifyContent: "center",
marginTop: 50,
},
});
In this sample we can change the chart type dynamically using chart APIs.
import React, { Component } from "react";
import { Platform, StyleSheet, Text, View, Button, Alert } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
export default class ChartRunTime extends Component {
constructor(props) {
super(props);
// Create a property(e.g: apiCaller) which will get attached to a function
// where you can pass Chart API methods you want to run.
this.apiCaller = null;
const chartConfig = {
type: "column2d",
width: "100%",
height: "100%",
dataFormat: "json",
dataSource: {
chart: {
caption: "Recommended Portfolio Split",
subCaption: "For a net-worth of $1M",
showValues: "1",
showPercentInTooltip: "0",
numberPrefix: "$",
enableMultiSlicing: "1",
theme: "fusion",
exportEnabled: 1,
},
data: [
{
label: "Equity",
value: "300000",
},
{
label: "Debt",
value: "230000",
},
{
label: "Bullion",
value: "180000",
},
{
label: "Real-estate",
value: "270000",
},
{
label: "Insurance",
value: "20000",
},
],
},
};
this.state = {
chartConfig,
chartType: "",
};
}
changeType(type) {
this.setState({ chartType: type }, () => {
// Chart instance is available here.
// Passing js code to run chart api method.
this.apiCaller(`chartType('${type}')`); // This method accepts js code in string.
});
}
// Bind the argument from onInitialized with the property you created in your constructor
bindApiCaller(caller) {
// Now this.apiCaller will be a function where you can pass js code for the WebView
// to access the chart Object. See the method changeType.
this.apiCaller = caller;
if (this.state.chartType === "") this.setState({ chartType: this.state.type });
}
render() {
return (
<View style={styles.container}>
<Text style={styles.header}>Change chart type at runtime</Text>
<View style={styles.chartContainer}>
<ReactNativeFusionCharts
chartConfig={this.state.chartConfig}
onInitialized={(caller) => {
this.bindApiCaller(caller);
}}
/>
</View>
<Text style={styles.info}>Press button to change chart type</Text>
<View style={styles.buttonContainer}>
<Button
disabled={this.state.chartType === "" || this.state.chartType == "column2d"}
style={{ margin: 8 }}
title="Column2D"
onPress={() => this.changeType("column2d")}
/>
<Button
disabled={this.state.chartType === "" || this.state.chartType == "pie2d"}
title="Pie2D"
onPress={() => this.changeType("pie2d")}
/>
<Button
disabled={this.state.chartType === "" || this.state.chartType == "bar2d"}
title="Bar2D"
onPress={() => this.changeType("bar2d")}
/>
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
padding: 10,
},
header: {
fontWeight: "bold",
fontSize: 20,
textAlign: "center",
paddingBottom: 10,
},
chartContainer: {
height: 400,
borderColor: "#000",
borderWidth: 1,
},
buttonContainer: {
padding: 10,
display: "flex",
justifyContent: "space-around",
flexDirection: "row",
alignItems: "center",
},
info: {
fontSize: 16,
textAlign: "center",
marginTop: 5,
},
});
In this sample we can add the modules dynamically e.g gantt, timeseries, powercharts etc
import React, { Component } from "react";
import { StyleSheet, View } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
export default class App extends Component {
constructor(props) {
super(props);
const chartConfig = {
type: "gantt", // your chart type goes here
width: "100%",
height: "400",
dataFormat: "json",
dataSource: {
// your data goes here
// for gantt chart data please visit https://www.fusioncharts.com/dev/chart-attributes/gantt
},
};
this.state = {
chartConfig,
};
}
render() {
const modules = ["gantt"]; // module names goes here
return (
<View style={styles.container}>
<View style={styles.chartContainer}>
<ReactNativeFusionCharts chartConfig={this.state.chartConfig} modules={modules} />
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
padding: 10,
},
chartContainer: {
height: "60%",
borderColor: "#000",
borderWidth: 1,
},
});
In this sample we can add the theme modules dynamically e.g candy, carbon, gammel etc
import React, { Component } from "react";
import { Platform, StyleSheet, Text, View, Alert } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
export default class ListenEvents extends Component {
constructor(props) {
super(props);
const chartConfig = {
type: "column2d",
width: "100%",
height: "100%",
dataFormat: "json",
dataSource: {
chart: {
caption: "Countries With Most Oil Reserves [2017-18]",
subCaption: "In MMbbl = One Million barrels",
xAxisName: "Country",
yAxisName: "Reserves (MMbbl)",
numberSuffix: "K",
theme: "carbon", // your theme name goes here
exportEnabled: 1,
},
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" },
],
},
};
this.state = {
chartConfig,
};
}
render() {
const modules = ["carbon"]; // theme module name
return (
<View style={styles.container}>
<Text style={styles.header}>Listen to events from chart</Text>
<View style={styles.chartContainer}>
<ReactNativeFusionCharts chartConfig={this.state.chartConfig} modules={modules} />
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
padding: 10,
},
header: {
fontWeight: "bold",
fontSize: 20,
textAlign: "center",
paddingBottom: 10,
},
chartContainer: {
height: 400,
borderColor: "#000",
borderWidth: 1,
},
});
If you are using a licensed verison of fusioncharts and have a valid license key, add the license object by either creating a new file with your license configuration inside it and import it in app.js or add ‘global.licenseConfig’ object to the app.js file as shown below
import React, { Component } from "react";
import { StyleSheet, View } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
global.licenseConfig = {
key: "your key goes here",
creditLabel: false, // true/false to show/hide watermark respectively
};
export default class App extends Component {
constructor(props) {
super(props);
const chartConfig = {
type: "column2D",
width: "100%",
height: "400",
dataFormat: "json",
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",
exportEnabled: 1,
},
data: [
{ label: "Venezuela", value: "250" },
{ 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" },
],
},
};
this.state = {
chartConfig,
};
}
render() {
return (
<View style={styles.container}>
<View style={styles.chartContainer}>
<ReactNativeFusionCharts chartConfig={this.state.chartConfig} />
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
padding: 10,
},
chartContainer: {
height: "60%",
borderColor: "#000",
borderWidth: 1,
},
});
From fusioncharts@3.13.3-sr.1
and react-native-fusioncharts@3.0.0
, You can visualize timeseries data easily on react.
Learn more about FusionTime here.
// In App.js
import React, { Component } from "react";
import { AppRegistry, StyleSheet, Text, View, Platform } from "react-native";
import ReactNativeFusionCharts from "react-native-fusioncharts";
export default class App extends Component {
constructor(props) {
super(props);
const chartConfig = {
type: "timeseries",
width: "100%",
height: "100%",
dataFormat: "json",
dataSource: {
data: null,
caption: {
text: "Sales Analysis",
},
subcaption: {
text: "Grocery",
},
yAxis: [
{
plot: {
value: "Grocery Sales Value",
type: "line",
},
format: {
prefix: "$",
},
title: "Sale Value",
},
],
},
schemaJson: null,
dataJson: null,
};
this.state = {
chartConfig,
};
}
componentDidMount() {
this.fetchDataAndSchema();
}
fetchDataAndSchema() {
const jsonify = (res) => res.json();
const dFetch = fetch(
"https://s3.eu-central-1.amazonaws.com/fusion.store/ft/data/line-chart-with-time-axis-data.json"
).then(jsonify);
// This is the remote url to fetch the schema.
const sFetch = fetch(
"https://s3.eu-central-1.amazonaws.com/fusion.store/ft/schema/line-chart-with-time-axis-schema.json"
).then(jsonify);
Promise.all([dFetch, sFetch]).then((res) => {
const data = res[0];
const schema = res[1];
const updatedChartConfig = { ...this.state.chartConfig, dataJson: data, schemaJson: schema };
this.setState({ chartConfig: updatedChartConfig });
});
}
render() {
const modules = ["timeseries"];
return (
<View style={styles.container}>
<Text style={styles.heading}>FusionCharts Integration with React Native</Text>
<View style={styles.chartContainer}>
<ReactNativeFusionCharts chartConfig={this.state.chartConfig} modules={modules} />
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
padding: 10,
},
heading: {
fontSize: 20,
textAlign: "center",
marginBottom: 10,
},
chartContainer: {
height: 500,
},
});
- Explore 20+ pre-built business specific dashboards for different industries like energy and manufacturing to business functions like sales, marketing and operations here.
- See Data Stories built using FusionCharts’ interactive JavaScript visualizations and learn how to communicate real-world narratives through underlying data to tell compelling stories.
# Clone repo
git clone git@github.com:fusioncharts/react-native-fusioncharts.git
cd react-native-fusioncharts
# Install dependencies
npm install
# Run
npm run start
# Build
npm run build
# Publish
npm publish
The FusionCharts React Native integration 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.