R/shiny_modules.R

Defines functions genesets_Server genesets_UI

Documented in genesets_Server genesets_UI

#' Shiny interface module for geneset selection
#' 
#' @param id A unique namespace identifier
#' @return Shiny ui elements
#'
#' @importFrom shiny NS tagList uiOutput selectizeInput actionButton
#' 
#' @export
genesets_UI <- function(id) {
    genesets <- readRDS(file.path(system.file("extdata", package="hypeR"), "genesets.rds"))
    
    ns <- NS(id)
    tagList(
        selectizeInput(ns("db"), label="Database", choices=names(genesets)),
        uiOutput(ns("species")),
        uiOutput(ns("genesets")),
        actionButton(ns("fetch"), label="Fetch Genesets"),
        uiOutput(ns("status"), inline=TRUE)
    )
}

#' Shiny server module for geneset selection
#' 
#' @param id A unique namespace identifier matching to interface
#' @param clean Use true to clean geneset names
#' @return Shiny server code
#'
#' @importFrom shiny moduleServer renderUI validate need icon selectizeInput eventReactive
#' 
#' @export
genesets_Server <- function(id, clean=FALSE) {
    genesets <- readRDS(file.path(system.file("extdata", package="hypeR"), "genesets.rds"))
    
    moduleServer(
        id,
        function(input, output, session) {
            
            # Build species selection
            output$species <- renderUI({
                ns <- session$ns
                validate(need(input$db, message=FALSE))
                choices <- names(genesets[[input$db]])
                selectizeInput(ns("species"), label="Species", choices=choices)
            })
            
            # Build genesets selection
            output$genesets <- renderUI({
                ns <- session$ns
                validate(need(input$db, message=FALSE))
                validate(need(input$species, message=FALSE))
                choices <- names(genesets[[input$db]][[input$species]])
                selectizeInput(ns("genesets"), label="Genesets", choices=choices)
            })
            
            # Download selected geneset and put into a reactive expression
            reactive.genesets <- eventReactive(input$fetch, {
                validate(need(input$db, message=FALSE))
                validate(need(input$species, message=FALSE))
                validate(need(input$genesets, message=FALSE))
                if (input$db == "msigdb") {
                    kwargs <- genesets[[input$db]][[input$species]][[input$genesets]]
                    gs <- do.call(msigdb_download, kwargs)
                }   
                else if (input$db == "enrichr") {
                    kwargs <- genesets[[input$db]][[input$species]][[input$genesets]]
                    gs <- do.call(enrichr_download, kwargs)
                }
                else {
                    gs <- NULL
                }
                if (!is.null(gs) & clean) {
                    names(gs) <- clean_genesets(names(gs))
                }
                return(gs)
            })
            
            # Check status of loaded genesets
            output$status <- renderUI({
                if (is.null(reactive.genesets())) {
                    icon("times-circle fa-lg", lib="font-awesome")
                } else {
                    ic <- icon("check-circle fa-lg", lib="font-awesome")
                }
            })
            
            return(reactive.genesets)
        }
    )
}

Try the hypeR package in your browser

Any scripts or data that you put into this service are public.

hypeR documentation built on Nov. 8, 2020, 8:19 p.m.