https://github.com/neuhausi/periscope
  
  
    An assistive shiny application toolkit built for scaling and standardizing application development 
    https://github.com/neuhausi/periscope
  
        Last synced: 4 months ago 
        JSON representation
    
An assistive shiny application toolkit built for scaling and standardizing application development
- Host: GitHub
- URL: https://github.com/neuhausi/periscope
- Owner: neuhausi
- Created: 2019-02-21T19:49:03.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-11-07T18:18:43.000Z (almost 2 years ago)
- Last Synced: 2024-08-13T07:15:41.480Z (about 1 year ago)
- Language: R
- Homepage: http://periscopeapps.org/
- Size: 992 KB
- Stars: 25
- Watchers: 3
- Forks: 18
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
 
Awesome Lists containing this project
- jimsghstars - neuhausi/periscope - An assistive shiny application toolkit built for scaling and standardizing application development (R)
README
          ---
title:  "Periscope Shiny Application Framework"
output: 
    html_document:
        self_contained: yes
---
[](https://cran.r-project.org/package=periscope)
[](https://cran.r-project.org/package=periscope)
[](https://app.circleci.com/pipelines/github/cb4ds/periscope?branch=master)
[](https://app.codecov.io/github/cb4ds/periscope?branch=master)
***periscope*** was originally developed as the core Shiny component for bioinformatics and systems biology analysis applications. It provides a predefined but flexible template for new Shiny applications with a default dashboard layout, three locations for user alerts, a nice busy indicator and logging features. 
One of the most important features of the shiny applications created with this framework is the separation by file of functionality that exists in one of the three shiny scopes: global, server-global, and server-local. The framework forces application developers to consciously consider scoping in Shiny applications by making scoping distinctions very clear without interfering with normal application development. Scoping consideration is important for performance and scaling, which is critical when working with large datasets and/or across many users.  In addition to providing a template application, the framework also contains a number of convenient modules: a (multi)file download button module and a downloadable table module for example.
### Installation
periscope is available for installation from 
[CRAN](https://CRAN.R-project.org/package=periscope) or you can install the
latest version of ***periscope*** from GitHub as follows:
```r
devtools::install_github('cb4ds/periscope')
```
---
### Examples
These are included to get you started. You can either start with an empty application or an application that includes samples of the components that you can use within your application.  There is extensive package documentation and full Vignettes are also available to help you with all the options.
#### Empty application
```r
library(periscope)
create_new_application('emptyapp', location = tempdir())
runApp('emptyapp')
```
#### Sample application - no right sidebar
```r
library(periscope)
create_new_application("sampleapp1", location = tempdir(), sampleapp = TRUE)
runApp('sampleapp1')
```
#### Sample application - including a right sidebar
```r
library(periscope)
create_new_application("sampleapp2", location = tempdir(), sampleapp = TRUE, rightsidebar = TRUE)
runApp('sampleapp2')
```
        
