A Framework for Building, Managing, and Stitching Shiny Modules into Reproducible Workflows
Laurence Clarfeld, Caroline Tang, Therese Donovan
Laurence Clarfeld (lclarfel@uvm.edu) and Therese Donovan (tdonovan@uvm.edu)
Clarfeld, L., Tang, C., and Donovan, T. shinymgr: A framework for building, managing, and stitching shiny modules into reproducible workflows. Version 1.1.0: U.S. Geological Survey software release. Reston, VA. https://doi.org/10.5066/P9UXPOBN
Clarfeld,L. Tang, C., and Donovan, T. shinymgr: A Framework for building, managing, and stitching shiny modules into reproducible workflows. The R Journal.
Welcome. shiny is an R package that makes it easy to build interactive web apps, each with an intended purpose developed for an intended user audience. A shiny web app can permit an expedient analysis pipeline or workflow that is fully reproducible, allowing users to convey the results of an analysis to a target audience.
Figure 1. Image of a typical data analysis workflow.
From the developer perspective, complex shiny applications can result in many lines of code, creating challenges for collaborating, debugging, streamlining, and maintaining the overall product. Shiny modules are a solution to this problem. As stated by Winston Chang, "A Shiny module is a piece of a Shiny app. It canโt be directly run, as a Shiny app can. Instead, it is included as part of a larger app . . . Once created, a Shiny module can be easily reused โ whether across different apps, or multiple times in a single app." -- source: https://shiny.rstudio.com/articles/modules.html.
Developers of shiny apps that rely on a modularized system to guide a user through an analysis will naturally be faced with several questions:
๐๐ฝ The R package, shinymgr, was developed to meet these challenges. The package itself includes a general framework for managing modules, stitching them together as individuals "apps", saving reproducible analysis outputs, and offering opportunities for rapid reporting. It can be used as a stand-alone Shiny application that is housed on a local machine or a server, or can be embedded within R packages for developers who wish to provide Shiny functionality for showcasing their own package.
From the user's perspective, an โappโ consists of a series of RShiny tabs that are presented in order, establishing an analysis workflow. The inputs and outputs of a given app can be saved as an .RDS file to ensure reproducibility. Further, the .RDS file may be loaded into an R Markdown (.Rmd) template for rapid reporting.
Figure 2. A shinymgr "app" consists of a series of tabs that are executed in order, ending with the option to save the analysis steps as an RDS file.
From the developer's perspective, each tab in an "app" consists of one or more Shiny modules. The shinymgr app builder "stitches" shiny modules together so that outputs from one module serve as inputs to the next, creating an analysis pipeline that is easy to implement and maintain.
In short, developers use the shinymgr framework to write modules and seamlessly combine them into shiny apps, and users of these apps can execute reproducible analyses that can be incorporated into reports for rapid dissemination.
For version 1.1.0:
install.packages("devtools")
devtools::install_git("https://code.usgs.gov/vtcfwru/shinymgr@1.1.0", dependencies = TRUE)
Alternatively, uses may download the compiled software from https://code.usgs.gov/vtcfwru/shinymgr/-/releases.
On that page, Windows users can download shinymgr_1.1.0.zip, while Mac/Linux can download shinymgr_1.1.0.tar.gz. Then, in R Studio, click on the Install button on the Packages tab, and select Install From Package Archive File, and navigate to the downloaded file.
An overview of the package is found by typing:
library(shinymgr)
?shinymgr
Once installed, the developer must choose a directory that will store the shinymgr project. Let's say that file path is defined as:
my_parentPath <- 'c:/my_shinymgr_project'
dir.create(my_parentPath)
Next, run the shinymgr_setup
function to create the shinymgr project.
Note: In the tutorials,
you will specify demo = TRUE
and explore the full functionality of shinymgr.
# Create the shinymgr directory structure
shinymgr::shinymgr_setup(parentPath = my_parentPath, demo = TRUE)
# Set your working directory to the newly created shinymgr folder
setwd('c:/my_shinymgr_project/shinymgr')
The newly created shinymgr project directory provides a relative path
for running shinymgr's
user interface, so it is necessary to set this path as your working directory
to launch the UI, or declare this path as your shinyMgrPath
.
The shinymgr_setup()
function copies several folders and associated files to the shinymgr directory in a user-specified folder. If you set "demo" = TRUE, each directory will include several demo files.
# Look at the file structure of a shinymgr project
list.files(path = 'c:/my_shinymgr_project/shinymgr')
The analyses folder may be used to store previously run analyses as RDS files.
The data folder stores RData files that can be used by various apps (e.g., "iris.RData").
The database folder stores the shinymgr SQLite database, named "shinymgr.sqlite". The database tracks all modules, their arguments (inputs), returns (outputs), and how they are combined into an "app".
The modules folder stores stand-alone modules. These files are largely written by hand by the shinymgr developer.
The modules_app folder stores modules that are shinymgr "apps" -- the stitching together of modules into a tab-based layout that provides an analysis workflow. These files are written by shinymgr's app builder.
The modules_mgr folder stores modules that build the default shinymgr framework that you see when you run launch_shinymgr()
.
The reports folder stores R Markdown (.Rmd) files that serve as canned reports. These markdown files allow a user to navigate to a previously stored analysis (an RDS file) and use the results in the report itself, allowing for rapid reporting.
The tests folder stores both testthat and shinytest code testing scripts.
The www folder stores images that may be used by a shiny app.
In the main shinymgr directory, there are three files. Briefly, these files generate the Shiny app and the code is pasted into the next few sections.
ui.R - This file contains code to set the user interface for the master shinymgr app (ui = user interface).
server.R - The master server file.
global.R - The global.R file is sourced into the server.R file at start-up. It simply instructs R to read in all of the modules within the shinymgr framework.
Now, you're ready to launch the shinymgr UI:
shinymgr::launch_shinymgr('c:/my_shinymgr_project/shinymgr')
In summary, the shinymgr_setup()
function creates the directory structure and underlying database needed for building and running Shiny apps with shinymgr. You can create as many shinymgr projects on your machine as you'd like. In each case, the shinymgr project is simply a fixed directory structure with three R files (ui.R, server.R, and global.R), and a series of subdirectories that contain the apps and modules that you develop, along with a database for tracking everything. YOU will develop your own modules and use the shinymgr "App Builder" to create apps that stitch your modules together and guide your user through a tabbed workflow.
Once you have finished with module and app development, you can remove all dependencies on the shinymgr framework and copy it into your own package or deploy it on a server.
The package's cheatsheet can be found with the code:
browseURL(paste0(find.package("shinymgr"), "/extdata/shinymgr_cheatsheet.pdf"))
The shinymgr package comes with 12 learnr tutorials to guide users through the app-building process, including writing modules, "stitching" modules into apps, using apps to run analyses, and generating reports from a saved analysis. Tutorials should be executed in the following order:
library(learnr)
learnr::run_tutorial(name = "intro", package = "shinymgr")
learnr::run_tutorial(name = "shiny", package = "shinymgr")
learnr::run_tutorial(name = "modules", package = "shinymgr")
learnr::run_tutorial(name = "app_modules", package = "shinymgr")
learnr::run_tutorial(name = "tests", package = "shinymgr")
learnr::run_tutorial(name = "shinymgr", package = "shinymgr")
learnr::run_tutorial(name = "database", package = "shinymgr")
learnr::run_tutorial(name = "shinymgr_modules", package = "shinymgr")
learnr::run_tutorial(name = "apps", package = "shinymgr")
learnr::run_tutorial(name = "analyses", package = "shinymgr")
learnr::run_tutorial(name = "reports", package = "shinymgr")
learnr::run_tutorial(name = "deployment", package = "shinymgr")
Please join our community and consider submitting issues and/or contributions!
Contributions are welcome from the community. Questions can be asked on the
issues page. Before creating a new issue, please take a moment to search
and make sure a similar issue does not already exist. If one does exist, you
can comment (most simply even with just a :+1:
) to show your support for that
issue. Alternatively, create a new issue by sending an email to
gs_gitlab_servicedesk+vtcfwru-shinymgr-5231-issue-@usgs.gov.
If you have direct contributions you would like considered for incorporation into the project you can fork this repository and submit a pull request for review.
This software has been approved for release by the U.S. Geological Survey (USGS). Although the software has been subjected to rigorous review, the USGS reserves the right to update the software as needed pursuant to further analysis and review. No warranty, expressed or implied, is made by the USGS or the U.S. Government as to the functionality of the software and related material nor shall the fact of release constitute any such warranty. Furthermore, the software is released on condition that neither the USGS nor the U.S. Government shall be held liable for any damages resulting from its authorized or unauthorized use.
All contributions to- and interactions surrounding- this project will abide by the USGS Code of Scientific Conduct.
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.