Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/frappe/charts
Simple, responsive, modern SVG Charts with zero dependencies
https://github.com/frappe/charts
chart graph hacktoberfest javascript svg svg-chart zero-dependency
Last synced: 1 day ago
JSON representation
Simple, responsive, modern SVG Charts with zero dependencies
- Host: GitHub
- URL: https://github.com/frappe/charts
- Owner: frappe
- License: mit
- Created: 2017-10-26T10:13:21.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-04-12T09:37:33.000Z (10 months ago)
- Last Synced: 2024-04-14T10:09:04.362Z (10 months ago)
- Topics: chart, graph, hacktoberfest, javascript, svg, svg-chart, zero-dependency
- Language: JavaScript
- Homepage: https://frappe.io/charts
- Size: 6.7 MB
- Stars: 14,888
- Watchers: 218
- Forks: 715
- Open Issues: 141
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-frontend - charts - Simple, responsive, modern SVG Charts with zero dependencies. ![](https://img.shields.io/github/stars/frappe/charts.svg?style=social&label=Star) (Repository / Data Visualization)
- awesome - frappe/charts - Simple, responsive, modern SVG Charts with zero dependencies (JavaScript)
- my-awesome-list - charts
- studyLogs - charts - 一个简单的图表插件 (Uncategorized / Uncategorized)
- awesome-ccamel - frappe/charts - Simple, responsive, modern SVG Charts with zero dependencies (JavaScript)
- awesome-starred-test - frappe/charts - Simple, responsive, modern SVG Charts with zero dependencies (JavaScript)
- awesome - charts
- awesome-repositories - frappe/charts
- awesome-starred - charts - Simple, responsive, modern SVG Charts with zero dependencies (JavaScript)
- awesome-coding-startup - Frappe Charts
- awesome-list - charts
- best-of-react - GitHub - 48% open · ⏱️ 27.09.2023): (Data Visualization)
- starred-awesome - charts - Simple, responsive, modern SVG Charts with zero dependencies (JavaScript)
- StarryDivineSky - frappe/charts
- awesome-starred - frappe/charts - Simple, responsive, modern SVG Charts with zero dependencies (javascript)
README
# Frappe Charts
**GitHub-inspired modern, intuitive and responsive charts with zero dependencies**[Explore Demos](https://frappe.io/charts) - [Edit at CodeSandbox](https://codesandbox.io/s/frappe-charts-demo-viqud) - [Documentation](https://frappe.io/charts/docs)
## Frappe Charts
Frappe Charts is a simple charting library with a focus on a simple API. The design is inspired by various charts you see on GitHub.### Motivation
ERPNext needed a simple sales history graph for its user company master to help users track sales. While using c3.js for reports, the library didn’t align well with our product’s classic design. Existing JS libraries were either too complex or rigid in their structure and behavior. To address this, I decided to create a library for translating value pairs into relative shapes or positions, focusing on simplicity.
### Key Features
- **Variety of chart types**: Frappe Charts supports various chart types, including Axis Charts, Area and Trends, Bar, Line, Pie, Percentage, Mixed Axis, and Heatmap.
- **Annotations and tooltips**: Charts can be annotated with x and y markers, regions, and tooltips for enhanced data context and clarity.
- **Dynamic data handling**: Add, remove, or update individual data points in place, or refresh the entire dataset to reflect changes.
- **Customizable configurations**: Flexible options like colors, animations, and custom titles allow for a highly personalized chart experience.## Usage
```sh
npm install frappe-charts
```Import in your project:
```js
import { Chart } from 'frappe-charts'
// or esm import
import { Chart } from 'frappe-charts/dist/frappe-charts.esm.js'
// import css
import 'frappe-charts/dist/frappe-charts.min.css'
```Or directly include script in your HTML
```html
```
```js
const data = {
labels: ["12am-3am", "3am-6pm", "6am-9am", "9am-12am",
"12pm-3pm", "3pm-6pm", "6pm-9pm", "9am-12am"
],
datasets: [
{
name: "Some Data", chartType: "bar",
values: [25, 40, 30, 35, 8, 52, 17, -4]
},
{
name: "Another Set", chartType: "line",
values: [25, 50, -10, 15, 18, 32, 27, 14]
}
]
}const chart = new frappe.Chart("#chart", { // or a DOM element,
// new Chart() in case of ES6 module with above usage
title: "My Awesome Chart",
data: data,
type: 'axis-mixed', // or 'bar', 'line', 'scatter', 'pie', 'percentage'
height: 250,
colors: ['#7cd6fd', '#743ee2']
})
```## Contributing
1. Clone this repo.
2. `cd` into project directory
3. `npm install`
4. `npm i npm-run-all -D` (*optional --> might be required for some developers*)
5. `npm run dev`## Links
- [Read the blog](https://medium.com/@pratu16x7/so-we-decided-to-create-our-own-charts-a95cb5032c97)