Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/daattali/shinydisconnect
๐ Show a nice message when a Shiny app disconnects or errors
https://github.com/daattali/shinydisconnect
r r-package rstats shiny shiny-r
Last synced: 3 months ago
JSON representation
๐ Show a nice message when a Shiny app disconnects or errors
- Host: GitHub
- URL: https://github.com/daattali/shinydisconnect
- Owner: daattali
- License: other
- Created: 2020-06-08T06:55:01.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-08-21T13:03:45.000Z (over 1 year ago)
- Last Synced: 2024-05-16T14:44:46.385Z (8 months ago)
- Topics: r, r-package, rstats, shiny, shiny-r
- Language: R
- Homepage: https://daattali.com/shiny/shinydisconnect-demo
- Size: 396 KB
- Stars: 65
- Watchers: 3
- Forks: 3
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-shiny-extensions - shinydisconnect - Show a nice message when a Shiny app disconnects or errors. (UI Components / Loader)
- jimsghstars - daattali/shinydisconnect - ๐ Show a nice message when a Shiny app disconnects or errors (R)
README
shinydisconnect
๐ Show a nice message when a Shiny app disconnects or errors
Demo
ยท
by Dean Attali---
A shiny app can disconnect for a variety of reasons: an unrecoverable error occurred in the app, the server went down, the user lost internet connection, or any other reason that might cause the shiny app to lose connection to its server.
{shinydisconnect} allows you to add a nice message to the user when the app disconnects. The message works both locally (running Shiny apps within RStudio) and on Shiny servers (such as shinyapps.io, RStudio Connect, Shiny Server Open Source, Shiny Server Pro). See the [demo Shiny app](https://daattali.com/shiny/shinydisconnect-demo/) online for examples.
**Need Shiny help? [I'm available for consulting](https://attalitech.com/).**
**If you find {shinydisconnect} useful, please consider [supporting my work](https://github.com/sponsors/daattali)! โค**> This package is part of a larger ecosystem of packages with a shared vision: solving common Shiny issues and improving Shiny apps with minimal effort, minimal code changes, and clear documentation. Other packages for your Shiny apps:
| Package | Description | Demo |
|---|---|---|
| [shinyjs](https://deanattali.com/shinyjs/) | ๐ก Easily improve the user experience of your Shiny apps in seconds | [๐](https://deanattali.com/shinyjs/overview#demo) |
| [shinyalert](https://github.com/daattali/shinyalert/) | ๐ฏ๏ธ Easily create pretty popup messages (modals) in Shiny | [๐](https://daattali.com/shiny/shinyalert-demo/) |
| [shinyscreenshot](https://github.com/daattali/shinyscreenshot/) | ๐ท Capture screenshots of entire pages or parts of pages in Shiny apps | [๐](https://daattali.com/shiny/shinyscreenshot-demo/) |
| [timevis](https://github.com/daattali/timevis/) | ๐ Create interactive timeline visualizations in R | [๐](https://daattali.com/shiny/timevis-demo/) |
| [shinycssloaders](https://github.com/daattali/shinycssloaders/) | โ Add loading animations to a Shiny output while it's recalculating | [๐](https://daattali.com/shiny/shinycssloaders-demo/) |
| [colourpicker](https://github.com/daattali/colourpicker/) | ๐จ A colour picker tool for Shiny and for selecting colours in plots | [๐](https://daattali.com/shiny/colourInput/) |
| [shinybrowser](https://github.com/daattali/shinybrowser/) | ๐ Find out information about a user's web browser in Shiny apps | [๐](https://daattali.com/shiny/shinybrowser-demo/) |
| [shinytip](https://github.com/daattali/shinytip/) | ๐ฌ Simple flexible tooltips for Shiny apps | WIP |
| [shinymixpanel](https://github.com/daattali/shinymixpanel/) | ๐ Track user interactions with Mixpanel in Shiny apps or R scripts | WIP |
| [shinyforms](https://github.com/daattali/shinyforms/) | ๐ Easily create questionnaire-type forms with Shiny | WIP |# Table of contents
- [The problem](#problem)
- [Examples](#examples)
- [Installation](#install)
- [How to use](#usage)
- [Sponsors ๐](#sponsors)The problem
Have you ever noticed how an error in your Shiny app looks very different when it happens locally (in RStudio on your laptop) compared to when it happens in production (in shinyapps.io or Shiny Server or Connect)? Locally, when a Shiny app breaks, you just get a grey screen. But when a deployed app breaks, you also get a little strip that says "Disconnected from server. Reload."
![shiny default message](inst/img/shinydisconnect-default-message.png)
You don't have any control over that message's text or position, and you don't have a way to get that message to appear both locally and in deployed apps.
Well, at least you didn't until now. {shinydisconnect} solves exactly these two issues, by allowing you to show a customized (and pretty!) message when a Shiny app disconnects or errors, regardless of where the app is running.
Examples
For interactive examples and to see all the features, [check out the demo app](https://daattali.com/shiny/shinydisconnect-demo/).
**Example 1: basic usage ([code](inst/examples/basic/app.R))**
![basic screenshot](inst/img/basic.PNG)
**Example 2: using parameters ([code](inst/examples/advanced/app.R))**
![advanced screenshot](inst/img/advanced.PNG)
**Example 3: full-width and vertically centered ([code](inst/examples/special/app.R))**
You can also use `disconnectMessage2()` to get a similar message box to this one.
![special screenshot](inst/img/special.png)
**Example 4: hide the app**
This can be achieved by setting the opacity to 1 (fully opaque).
![special2 screenshot](inst/img/special2.PNG)
Installation
**For most users:** To install the stable CRAN version:
```r
install.packages("shinydisconnect")
```**For advanced users:** To install the latest development version from GitHub:
```r
install.packages("remotes")
remotes::install_github("daattali/shinydisconnect")
```How to use
The package only has two functions: `disconnectMessage()` and `disconnectMessage2()`.
Call `disconnectMessage()` anywhere in a Shiny app's UI to add a nice message when a shiny app disconnects. `disconnectMessage()` has many parameters to modify the text, position, and colours of the disconnect message.
Note that it's not possible to distinguish between errors and timeouts - they will both show the same message.
Without using this package, a shiny app that disconnects will either just show a greyed out screen if running locally (with no message), or will show a small message in the bottom-left corner that you cannot modify when running in a server.
Basic usage:
```
ui <- fluidPage(
disconnectMessage(),
actionButton("disconnect", "Disconnect the app")
)
server <- function(input, output, session) {
observeEvent(input$disconnect, {
session$close()
})
}
shinyApp(ui, server)
```You can use `disconnectMessage2()` as a pre-configured version of `disconnectMessage()` with a specific set of parameters.
Sponsors ๐
> There are no sponsors yet
[Become the first sponsor for
{shinydisconnect}\!](https://github.com/sponsors/daattali/sponsorships?tier_id=39856)