Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/JohnCoene/countup

⏱️ countup.js R htmlwidget
https://github.com/JohnCoene/countup

countup htlmwidgets r rmarkdown rstats

Last synced: about 2 months ago
JSON representation

⏱️ countup.js R htmlwidget

Awesome Lists containing this project

README

        

---
output:
github_document:
html_preview: false
---

```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "README-"
)
```

[![Travis build status](https://travis-ci.org/JohnCoene/countup.svg?branch=master)](https://travis-ci.org/JohnCoene/countup)

![](./man/figures/logo.png)

The underlying JavaScript libraries are [CountUp.js](https://github.com/inorganik/CountUp.js), and [Odometer](https://github.hubspot.com/odometer/docs/welcome/).

## Install

Install from Github with `remotes`:

```{r, eval=FALSE}
# install.packages("remotes")
remotes::install_github("JohnCoene/countup")
```

## News

Since version `0.1.1` the package also includes the [odometer](https://github.hubspot.com/odometer/docs/welcome/) widget.

## Examples

In the R console or R markdown.

```{r, eval=FALSE}
library(countup)

countup(25)

opts = list(
useEasing = TRUE,
useGrouping = TRUE,
separator = ',',
decimal = '.',
prefix = 'US$',
suffix = ' bejillion'
)

countup(count = 1729, start = 10, options = opts)
```

In Shiny (since version `0.1.0`), there are methods to programatically interact with the counter.

```r
library(shiny)
library(countup)

ui <- fluidPage(
h1(countupOutput("cnt")),
actionButton("start", "start"),
actionButton("pause", "pause / resume"),
numericInput("value", "update to:", min = 1, max = 1000, value = 24)
)

server <- function(input, output, session) {

output$cnt <- renderCountup({
countup(1000, duration = 10, start = FALSE)
})

observeEvent(input$start, {
countupProxy("cnt") %>%
countup_start()
})

observeEvent(input$value, {
countupProxy("cnt") %>%
countup_update(input$value)
})

observeEvent(input$pause, {
countupProxy("cnt") %>%
countup_pause_resume()
})

}

shinyApp(ui, server)
```