Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dreamRs/apexcharter
:bar_chart: R Htmlwidget for ApexCharts.js
https://github.com/dreamRs/apexcharter
data-visualization htmlwidgets r
Last synced: about 2 months ago
JSON representation
:bar_chart: R Htmlwidget for ApexCharts.js
- Host: GitHub
- URL: https://github.com/dreamRs/apexcharter
- Owner: dreamRs
- License: other
- Created: 2018-07-30T20:47:09.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-30T08:54:36.000Z (2 months ago)
- Last Synced: 2024-10-30T09:26:15.769Z (2 months ago)
- Topics: data-visualization, htmlwidgets, r
- Language: R
- Homepage: https://dreamrs.github.io/apexcharter
- Size: 19.7 MB
- Stars: 142
- Watchers: 11
- Forks: 15
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Changelog: NEWS.md
- License: LICENSE
Awesome Lists containing this project
- awesome-shiny-extensions - apexcharter - HTML widget for ApexCharts.js. (Visualization / General-Purpose)
- jimsghstars - dreamRs/apexcharter - :bar_chart: R Htmlwidget for ApexCharts.js (R)
README
# apexcharter
> Htmlwidget for [apexcharts.js](https://github.com/apexcharts/apexcharts.js) : A modern JavaScript charting library to build interactive charts and visualizations with simple API. See the [online documentation](https://dreamrs.github.io/apexcharter/) for examples.
[![CRAN status](https://www.r-pkg.org/badges/version/apexcharter)](https://CRAN.R-project.org/package=apexcharter)
[![cran checks](https://badges.cranchecks.info/worst/apexcharter.svg)](https://cran.r-project.org/web/checks/check_results_apexcharter.html)
[![Codecov test coverage](https://codecov.io/gh/dreamRs/apexcharter/branch/master/graph/badge.svg)](https://app.codecov.io/gh/dreamRs/apexcharter?branch=master)
[![R-CMD-check](https://github.com/dreamRs/apexcharter/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/dreamRs/apexcharter/actions/workflows/R-CMD-check.yaml)## Installation
Install from [CRAN](https://CRAN.R-project.org/package=apexcharter) with:
```r
install.packages("apexcharter")
```Or install the development version from [GitHub](https://github.com/dreamRs/apexcharter) with:
```r
# install.packages("remotes")
remotes::install_github("dreamRs/apexcharter")
```## Quick Charts
Use `apex` function to quickly create visualizations :
```r
library(apexcharter)
data("mpg", package = "ggplot2")
apex(data = mpg, type = "bar", mapping = aes(manufacturer))
```
![](man/figures/apex-bar.png)With datetime:
```r
data("economics", package = "ggplot2")
apex(data = economics, type = "line", mapping = aes(x = date, y = uempmed)) %>%
ax_stroke(width = 1)
```
![](man/figures/apex-line.png)## Full API
All methods from ApexCharts are available with function like `ax_*` compatible with pipe from `magrittr` :
```r
library(apexcharter)
data(mpg, package = "ggplot2")apexchart() %>%
ax_chart(type = "bar") %>%
ax_plotOptions(bar = bar_opts(
horizontal = FALSE,
endingShape = "flat",
columnWidth = "70%",
dataLabels = list(
position = "top"
))
) %>%
ax_grid(
show = TRUE,
position = "front",
borderColor = "#FFF"
) %>%
ax_series(list(
name = "Count",
data = tapply(mpg$manufacturer, mpg$manufacturer, length)
)) %>%
ax_colors("#112446") %>%
ax_xaxis(categories = unique(mpg$manufacturer)) %>%
ax_title(text = "Number of models") %>%
ax_subtitle(text = "Data from ggplot2")
```![](man/figures/apexcharter-full-bar.png)
## Raw API
Pass a list of parameters to the function:
```r
apexchart(ax_opts = list(
chart = list(
type = "line"
),
stroke = list(
curve = "smooth"
),
grid = list(
borderColor = "#e7e7e7",
row = list(
colors = c("#f3f3f3", "transparent"),
opacity = 0.5
)
),
dataLabels = list(
enabled = TRUE
),
markers = list(style = "inverted", size = 6),
series = list(
list(
name = "High",
data = c(28, 29, 33, 36, 32, 32, 33)
),
list(
name = "Low",
data = c(12, 11, 14, 18, 17, 13, 13)
)
),
title = list(
text = "Average High & Low Temperature",
align = "left"
),
xaxis = list(
categories = month.abb[1:7]
),
yaxis = list(
title = list(text = "Temperature"),
labels = list(
formatter = htmlwidgets::JS("function(value) {return value + '\u00b0C';}")
)
)
))
```![](man/figures/raw-api.png)
## Development
This package use [{packer}](https://github.com/JohnCoene/packer) to manage JavaScript assets, see packer's [documentation](https://packer.john-coene.com/#/) for more.
Install nodes modules with:
```r
packer::npm_install()
```Modify `srcjs/widgets/apexcharter.js`, then run:
```r
packer::bundle()
```Re-install R package and try `apexcharter()` or `apex()` functions.