R/server.R

Defines functions server.scfind

Documented in server.scfind

#' Server handler for scfind
#'
#' @param object An SCFind object that the shiny app will be deployed upon
#'
#' @name scfindShinyServer
#' @aliases scfindShinyServer
#'
#' @importFrom shiny reactive updateCheckboxGroupInput renderPlot stopApp checkboxGroupInput observeEvent observe reactiveVal renderText renderPrint
#' @importFrom DT renderDataTable datatable
#' @importFrom data.table as.data.table data.table
#' @importFrom ggplot2 ggplot geom_bar geom_col ggtitle xlab ylab aes coord_flip theme_minimal
server.scfind <- function(object)
{
    message(getwd())
    return(
        function(input, output, session)
        {
            observeEvent(
                input$geneCheckbox,
                {
                    last.query.state("checkbox")
                })
            
            observeEvent(
                input$queryOptimizer_rows_selected,
                {
                    last.query.state("query_optimizer")
                })
            
            output$title <- renderText({
                if(all(startsWith(object@index$genes(), "chr") == T)) "What's your peak list today ?" else "What's your gene list today ?"
            })
            
            observeEvent(input$keyPressed,{
                TxtInput(input$geneList)
                
                # This is necessary, because users are allowed to input chromosome as the format chrX:XXXXX-YYYYY instead of chrX_XXXXX_YYYYY
                text <- gsub("\\s|,", ",", TxtInput())
                gene.list.input <- unlist(strsplit(text, ","))
                chr.list.input <- c()
                
                if(all(startsWith(object@index$genes(), "chr") == T)){
                    gene.names.all <- object@index$genes()
                    
                    p.pos <- list(p.chr = c(), p.start = 0, p.end = 0)
                    p.pos$p.chr <- gsub("_.*$", "", gene.names.all)
                    p.pos$p.start <- as.numeric(gsub(".*_(.*)\\_.*", "\\1", gene.names.all))
                    p.pos$p.end <- as.numeric(gsub(".*_", "", gene.names.all))
                    p.pos <- data.frame(p.pos)
                    
                    for(i in 1: length(gene.list.input)){
                        chr.list.input <- c(chr.list.input, gene.names.all[which(p.pos$p.chr == tolower(gsub(":.*$", "", gene.list.input[i])) & p.pos$p.start >= as.numeric(gsub(".*:(.*)\\-.*", "\\1", gene.list.input[i])) & p.pos$p.end <= as.numeric(gsub(".*-", "", gene.list.input[i])))])
                    }
                }
                
                gene.list.input <- if(length(chr.list.input) != 0) gsub(':|-','_',chr.list.input) else gene.list.input
                last.query.state("genelist")
                
                gene.list.input <- caseCorrect(object, gene.list.input)
                gene.list(gene.list.input)
                
            })
            
            recommended.queries <- reactive({
                progress <- Progress$new(session, min=0)
                on.exit(progress$close())
                progress$set(message = 'Dream, dream, dream...',
                             detail = 'Genes come true!')
                selected.genes <- gene.list()
                selected.datasets <- input$datasetCheckbox
                
                if (length(selected.genes) > 1 && any(caseCorrect(object, selected.genes) %in% object@index$genes()) && !is.null(selected.datasets))
                {
                    #print(paste("QO gene:",selected.genes))
                    #print(paste("QO selected:",selected.datasets))
                    available.queries <-  as.data.table(markerGenes(object, selected.genes, selected.datasets))
                }
                else
                {
                    available.queries <- data.table()
                }
                
                if(length(available.queries) != 0){
                    available.queries$tfidf <- signif(available.queries$tfidf, digits = 5)
                    available.queries
                } else {
                    available.queries
                }
                
            })
            
            
            qo.output <- reactive({
                selected.index <- input$queryOptimizer_rows_selected
                available.queries <-  recommended.queries()
                
                selected.query <- if(all(startsWith(object@index$genes(), "chr") == T)) gsub(":|-", "_", available.queries$Query[selected.index]) else available.queries$Query[selected.index]
                unlist(strsplit(gsub("\\s", "", selected.query), ","))
            })
            
            output$geneCheckbox <- renderUI({
                genes.in.list <- caseCorrect(object, as.character(gene.list()))
                ## else fallback
                
                selection <- caseCorrect(object, gene.list())
                
                list.indx <- intersect(grep('chr', genes.in.list), grep('_', genes.in.list))
                if(length(list.indx) != 0) {
                    genes.in.list <- gsub('_', '-', sub('_', ':', genes.in.list[list.indx]))
                    selection <- gsub('_', '-', sub('_', ':', selection[list.indx]))
                }
                
                
                
                if(last.query.state() == "query_optimizer" && !is.null(input$queryOptimizer_rows_selected))
                {
                    selection <- qo.output()
                }
                else if (last.query.state() == "checkbox" )
                {
                    selection <-  input$geneCheckbox
                }
                
                if(length(list.indx) != 0) selection <- gsub('_', '-', sub('_', ':', selection[list.indx]))
                
                if(length(gene.list()) != 0  && sum(gene.support()$support) != 0 && !is.null(input$datasetCheckbox)) {
                    checkboxGroupInput("geneCheckbox", label='', choices = genes.in.list , selected = selection, inline = F)
                }
            })
            
            
            output$selectedDataset <- renderText({
                datasetName <- gsub("/", "", session$clientData$url_pathname)
                datasets <- object@datasets
                box.selection <-  input$datasetCheckbox
                
                datasetName <- if(any(names(dataset_def_names) %in% datasetName)) dataset_def_names[[datasetName]] else ''
                
                if(length(box.selection) == 0){
                    paste("Please select at least 1 dataset below:")
                }
                else if(length(box.selection) < 2){
                    paste(datasetName, length(box.selection), "/", length(datasets), "dataset")
                } else {
                    paste(datasetName, length(box.selection), "/", length(datasets), "datasets")
                }
            })
            
            output$datasetCheckbox <-  renderUI({
                datasets <- object@datasets
                box.selection <-  object@datasets
                
                if (initial.datasets == "initial")
                {
                    ## set the flag down
                    initial.datasets <- "initialized"
                }
                else
                {
                    box.selection <-  input@datasetCheckbox
                    
                }
                
                checkboxGroupInput("datasetCheckbox", label = '', choices = datasets, selected = box.selection, inline = T)
                
                
            })
            
            observe({
                progress <- Progress$new(session, min=0)
                on.exit(progress$close())
                progress$set(message = 'Initialising index...',
                             detail = '')
                
                exampleCT <- sample(cellTypeNames(object), 1)
                exampleQuery <- cellTypeMarkers(object, exampleCT)$genes
                
                if(all(startsWith(object@index$genes(), "chr") == T)) exampleQuery <- gsub("_", "-", sub("_", ":", exampleQuery))
                
                updateTextInput(session, "geneList", value = "", placeholder = exampleQuery)
            })
            
            observe({
                datasets <- object@datasets
                box.selection <- object@datasets
                
                if(input$selectall == 0) {
                    return(NULL)
                } else if (input$selectall%%2 == 0)  {
                    updateCheckboxGroupInput(session, "datasetCheckbox", label = '', choices = datasets, selected = box.selection, inline = T)
                    last.query.state("query_optimizer")
                }  else {
                    updateCheckboxGroupInput(session, "datasetCheckbox", label = '', choices = datasets, inline = T)
                    print('dataset not defined')
                }
            })
            
            output$logicPanel <- renderUI ({
                df <- gene.support()
                
                number.of.choices <- length(gene.list())
                if(number.of.choices < 4){
                    histoHeight = 52.5*4
                } else {
                    histoHeight = 100 + (number.of.choices-4) * 30
                }
                
                if (nrow(df) != 0 && any(df$`genes` %in% object@index$genes()))
                {
                    tabsetPanel(type = "tabs",
                                tabPanel(paste(if(all(startsWith(tolower(df$`genes`), "chr"))) "Peaks" else "Genes", "Summary"),
                                         uiOutput("geneCheckbox"),
                                         plotOutput("geneSupportHisto", width = 250, height = histoHeight)
                                )
                    )
                } else {
                    ""
                }
            })
            
            output$evaluateSum <- renderUI ({
                s = input$cellTypesData_rows_selected
                
                if(!is.null(s) && length(object@metadata) != 0){
                    tabsetPanel(type = "tabs",
                                tabPanel("UMAP",
                                         selectInput('subdataset', 'Datasets', selected = NULL, choices = NULL, selectize=TRUE),
                                         plotOutput("cellUMAP", width = 400, height = 500)),
                                tabPanel("Evaluate Markers",
                                         dataTableOutput("evaluateCtMarkers"))
                                
                    )
                } else {
                    ""
                }
            })
            
            
            observe({
                s = input$cellTypesData_rows_selected
                df <- cell.types()
                if(!is.null(s) && length(object@metadata) != 0 && nrow(df) != 0 && !is.null(input$datasetCheckbox)){ 
                    
                    rdt <- phyper.test(object, df, input$datasetCheckbox)
                    
                    selectedCellTypes <- as.character(rdt$cell_type[s])
                    subdataset <- unique(sub("\\..*", "", selectedCellTypes))
                    
                    if(length(subdataset) > 1){
                        updateSelectInput(session, 'subdataset', label = 'Datasets', choices = subdataset,  selected = subdataset[length(subdataset)])
                    } else {
                        updateSelectInput(session, 'subdataset', label = 'Datasets', choices = subdataset,  selected = subdataset)
                    }
                    
                }
            })
            
            output$queryOptimizer <- renderDataTable({
                if(!is.null(recommended.queries())){
                    col <- if(all(startsWith(object@index$genes(), "chr") == T)) "Peaks" else "Genes"
                    
                    datatable(recommended.queries(), selection = 'single',
                              options = list(columnDefs = list(list(width = '70px', targets = c(2, 3)), list(width = '10px', targets = c(0))), pageLength = 5,
                                             autoWidth = TRUE,
                                             dom = 'Bfrtip',
                                             buttons = c('copy', 'csv', 'excel')),
                              extensions = 'Scroller', colnames = c(col , 'Sub-queries', 'TF-IDF', 'Cell No.'),
                              rownames = F)
                } else {
                    data.table()
                }
            })
            
            cell.types <- reactive({
                selection <- if(all(startsWith(object@index$genes(), "chr") == T)) input$geneCheckbox else caseCorrect(object, input$geneCheckbox)
                
                if (length(selection) != 0 && !is.null(input$datasetCheckbox)){
                    if(all(startsWith(object@index$genes(), "chr") == T)) {
                        selection <- gsub(":|-", "_", selection)
                    }
                    df <- query.result.as.dataframe(findCellTypes.geneList(object, selection, input$datasetCheckbox))
                    #print("yo")
                    #print(df)
                }
                else
                {
                    df <- data.frame(cell_type = c(), cell_id = c())
                }
                df
            })
            
            gene.support <- reactive({
                gene.selection <- if(all(startsWith(object@index$genes(), "chr") == T)) gene.list() else caseCorrect(object,gene.list())
                dataset.selection <- input$datasetCheckbox
                if(!is.null(dataset.selection) && length(gene.selection) != 0){
                    gene.support <- as.data.frame(object@index$genesSupport(gene.selection, dataset.selection))
                    dimnames(gene.support)[[2]] <- 'support'
                    gene.support$genes <- rownames(gene.support)
                } else {
                    
                    gene.support <- data.frame()
                    gene.support$support <- c()
                    gene.support$genes <-  c()
                }
                gene.support
            })
            
            
            output$cellTypesData <- renderDataTable({
                df <- cell.types()
                
                if (nrow(df) != 0 && !is.null(input$datasetCheckbox) && TxtInput() != ''  && nrow(gene.support()) != 0)
                {
                    rdt <- phyper.test(object, df, input$datasetCheckbox)
                    rdt$pval <- as.numeric(signif(rdt$pval, digits = 6))
                    rdt <- data.frame(rdt)
                }
                else
                {
                    rdt <- data.table()
                }
                
            }, server = TRUE, extensions = c('Scroller', 'Buttons')
            , options = list(columnDefs = list(list(width = '60px', targets = c(1, 2)), list(width = '70px', targets = c(3))),
                             deferRender = TRUE,
                             scrollY = 200,
                             scroller = TRUE,
                             dom = 'Bfrtip',
                             buttons = c('copy', 'csv', 'excel')
            ), colnames = c('Cell types', 'Cell hits', 'Cell No.', 'p-value'), rownames = F)
            
            
            output$evaluateCtMarkers <- renderDataTable({
                
                s = input$cellTypesData_rows_selected
                
                selection <- input$geneCheckbox
                if(all(startsWith(object@index$genes(), "chr") == T)) {
                    selection <- gsub(":|-", "_", selection)
                }
                
                df <- cell.types()
                
                if(!is.null(df$cell_type) && nrow(df) != 0 && !is.null(input$datasetCheckbox) && !is.null(selection)) { #!#
                    rdt <- phyper.test(object, df, input$datasetCheckbox)
                    mge <- if(length(unique(df$cell_type)) < 2) evaluateMarkers(object, selection, as.character(unique(df$cell_type))) else evaluateMarkers(object, selection, rdt$cell_type[s])
                    if(nrow(mge) != 0){
                        mge <- mge[order(mge$genes),]
                        mge <- mge[order(mge[,1]),]
                        mge$genes <- if(all(startsWith(object@index$genes(), "chr") == T)) gsub("_", "-", sub("_", ":", mge$genes)) else mge$genes
                        mge$precision <- paste(as.character(mge$genes), ": ", round((mge$precision), digits = 3))
                        mge$recall <- paste(mge$genes, ": ", round((mge$recall), digits = 3))
                        mge$f1 <- paste(mge$genes, ": ", round((mge$f1), digits = 3))
                        mge <- aggregate(.~cellType, mge[,c("cellType", "precision", "recall", "f1")], FUN=toString)
                    }
                } else {
                    data.table()
                }
                
            }, extensions = 'Buttons' , options = list(columnDefs = list(list(width = '90px', targets = c(1, 2, 3))), dom = 'Bfrtip', buttons = c('copy', 'csv', 'excel')),
            colnames = c('Cell types', 'Precision', 'Recall', 'F1 score'),
            rownames = F)
            
            output$ctData <- renderText({
                s = input$cellTypesData_rows_selected
                selection <- toString(input$geneCheckbox)
                
                df <- cell.types()
                if (nrow(df) != 0 && !is.null(input$datasetCheckbox) && TxtInput() != '' && nrow(gene.support()) != 0)
                {
                    rdt <- phyper.test(object, df, input$datasetCheckbox)
                    
                    if(nrow(rdt) > 0){
                        if(nrow(rdt) == 1){
                            paste0("Marker evaluation of ", selection, " in ", rdt$cell_type, ": ")
                        } else {
                            if(!is.null(selection) && !is.null(s)){
                                paste0("Marker evaluation of ", selection, " in ", length(s), if(length(s) < 2) " cell type:" else " cell types:")
                            } else {
                                paste0("<span style = 'color: rgb(0, 180, 204);'>Select cell types from cell type table to start evaluation of ", selection, "</span>")
                            }
                        }
                        
                    } else {
                        ""
                    }
                }
                
            })
            
            
            output$selectedQuery <- renderText({
                selectedList = input$queryOptimizer_rows_selected
                df <- cell.types()
                
                if(!is.null(df$cell_type) && TxtInput() != '' && nrow(gene.support()) != 0) {
                    list.indx <- intersect(grep('chr', input$geneCheckbox), grep('_', input$geneCheckbox))
                    
                    paste("Scfind found ", length(unique(cell.types()$cell_type)), if ((length(unique(cell.types()$cell_type))) < 2) " cell type" else " cell types for the <I>selected query</I>:")
                } else {
                    if (nrow(recommended.queries()) != 0 && length(gene.list()) != 0 && !is.null(input$datasetCheckbox) && nrow(gene.support()) != 0)  paste("<span style = 'color: rgb(0, 180, 204);'>Expecting specific cell types?", "Select above recommended query!</span>", sep="<br>") else ""
                }
            })
            
            output$suggestHyper <- renderText({
                if(!is.null(TxtInput())) {
                    if(is.null(input$datasetCheckbox) && TxtInput() != '' ){
                        "Oops! dataset is missing."
                    } else if(TxtInput() != '' && sum(gene.support()$support) == 0){
                        
                        if(all(startsWith(object@index$genes(), "chr") == T)){
                            paste("Please follow the format below for your query: ",
                                  "",
                                  "chr13:56515712-56516189 , chr5:136247792-136248036",
                                  "",
                                  "for search of",
                                  "'chromosome 13, Start at 56515712, End at 56516189",
                                  "and chromosome 5, Start at 136247792, End at 136248036'",
                                  sep="<br>")
                        } else {
                            paste("Please follow the format below for your query: ",
                                  "",
                                  paste(sample(object@index$genes(), 5), collapse = ' , '),
                                  sep="<br>")
                        }
                        
                    } else if(length(gene.list()) != 0){
                        if(sum(gene.support()$support) != 0 && length(recommended.queries()) != 0){
                            "Recommended queries for the initial gene set: "
                        }
                        else
                        {
                            if(nrow(cell.types()) == 0)
                            {
                                paste0(
                                    "<p>Hmm,<br>", "There's no cell type representing your query in<br>",
                                    toString(input$datasetCheckbox), ".<br></p>",
                                    "<p>Please try other datasets or gene combinations</p>"
                                )
                            }
                        }
                    } else {
                        ""
                    }
                } else {
                    ""
                }
                
            })
            
            
            output$lociRegions <- renderText({
                if(all(startsWith(object@index$genes(), "chr") == T)){
                    text <- gsub("\\s|,", ",", TxtInput())
                    gene.list.input <- unlist(strsplit(text, ","))
                    gene.list.input <- unique(grep("chr",gsub("_", "-", sub("_", ":", tolower(gene.list.input))), value = T))
                    gene.list.input <- grep(":", gene.list.input, value = T)
                    gene.list.input <- gene.list.input[which(as.numeric(gsub(".*:(.*)\\-.*", "\\1", gene.list.input)) < as.numeric(gsub(".*-", "", gene.list.input)))]
                    
                    
                    if(length(gene.list.input) != 0){
                        peak.indx <- list()
                        gene.names.all <- object@index$genes()
                        
                        p.pos <- list(p.chr = c(), p.start = 0, p.end = 0)
                        p.pos$p.chr <- gsub("_.*$", "", gene.names.all)
                        p.pos$p.start <- as.numeric(gsub(".*_(.*)\\_.*", "\\1", gene.names.all))
                        p.pos$p.end <- as.numeric(gsub(".*_", "", gene.names.all))
                        p.pos <- data.frame(p.pos)
                        
                        for(i in 1: length(gene.list.input)){
                            peak.tmp <- which(p.pos$p.chr == tolower(gsub(":.*$", "", gene.list.input[i])) & p.pos$p.start >= as.numeric(gsub(".*:(.*)\\-.*", "\\1", gene.list.input[i])) & p.pos$p.end <= as.numeric(gsub(".*-", "", gene.list.input[i])))
                            peak.indx$index <- c(peak.indx$index, peak.tmp)
                            for(j in 1:length(peak.tmp)){
                                peak.indx$input <- c(peak.indx$input, gene.list.input[i])
                                peak.indx$loc_1 <- c(peak.indx$loc_1, as.numeric(gsub(".*:(.*)\\-.*", "\\1", gene.list.input[i])))
                                peak.indx$loc_4 <- c(peak.indx$loc_4, as.numeric(gsub(".*-", "", gene.list.input[i])))
                                
                            }
                        }
                        
                        peak.indx <- data.frame(peak.indx)
                        peak.indx$chromosome <- p.pos$p.chr[peak.indx$index]
                        peak.indx$loc_2 <- as.numeric(p.pos$p.start[peak.indx$index])
                        peak.indx$loc_3 <- as.numeric(p.pos$p.end[peak.indx$index])
                        peak.indx <- peak.indx[c(3,6,7,4,5,2)]
                        
                        ucsc <- "<a href='https://genome.ucsc.edu/cgi-bin/hgTracks?db=mm9&position="
                        
                        chr.chart <- paste0("<br><h4>Available Peak Locations</h4><p>(Click locus to view in UCSC Genome Browser)</p><table>")
                        
                        for(i in 1: nrow(peak.indx)){
                            
                            locus <- peak.indx[i,]
                            
                            ucsc_end <- paste0("' class='ucsc' target='_blank' title='Click to view Mouse mm9: ", locus$input, " UCSC Genome Browser'>", " [")
                            ucsc_a <- paste(ucsc, locus$chromosome, "%3A", locus[2], "%2D", locus[3], ucsc_end, sep="")
                            
                            gap <- locus[2] - locus[1]
                            
                            chromosome <- if(gap < 200) c() else paste0(locus[1], (if(gap<=400) paste(rep("&#8594;", (gap/200))) else paste("&#8594;", "...", "&#8594;")))
                            
                            gap <- locus[3] - locus[2]
                            chromosome <- paste0(chromosome, ucsc_a, locus[2], paste(rep("&#187;", (gap/100)),collapse = ""), locus[3], "] ", "</a>" )
                            
                            gap <- locus[4] - locus[3]
                            
                            chromosome <- if(gap < 200) chromosome else paste0(chromosome, (if(gap<=400) paste(rep("&#8594;", (gap/200))) else paste("&#8594;", "...", "&#8594;")), locus[4])
                            chromosome <- paste("<tr><td>", locus$chromosome, "</td><td", if(i == nrow(peak.indx)) " class='border-lb'>" else " class='border-l'>", "...", chromosome, "...", "</td></tr>")
                            chr.chart <- paste(chr.chart, chromosome, (if(i == nrow(peak.indx))"<tr><td></td><td style = 'text-align: center; font-size: 10px;'>base (Mouse mm9)</td></tr></table>" else ""))
                        }
                        
                        chr.chart
                    }
                } else {
                    ''
                }
                
                
            })
            output$geneHisto <- renderUI({
                
                number.of.choices <- length(gene.list())
                if(number.of.choices < 4){
                    histoHeight = 52.5*4
                } else {
                    histoHeight = 100 + (number.of.choices-4) * 30
                }
                plotOutput("geneSupportHisto", width = 250, height = histoHeight)
            })
            
            
            output$geneSupportHisto <- renderPlot({
                df <- gene.support()
                if (nrow(df) != 0 && length(grep(TRUE, (df$`genes` %in% object@index$genes()))) != 0)
                {
                    max.axis <- max(df$support)
                    g <- ggplot(df, aes(x = genes, y = support), colour = support) +
                        xlab("") +
                        ylab("Cells") +
                        ylim(0, max.axis) +
                        geom_text(aes(label=df$`genes`), vjust = "inward", hjust = "inward", size = 4) +
                        geom_col(fill = rainbow(length(df$`genes`)), position = "dodge", width = 1, alpha = .5, colour = "black") +
                        theme_minimal() +
                        coord_flip() +
                        theme(panel.grid.minor = element_blank(), axis.text.y = element_blank(),
                              panel.background = element_blank(), axis.line = element_line(colour = "black")) +
                        scale_x_discrete(limits = rev(df$`genes`))
                }
                else
                {
                    g <- 0
                }
                g
                
            })
            
            
            output$cellUMAP <- renderPlot({
                s = input$cellTypesData_rows_selected
                selection <- if(all(startsWith(object@index$genes(), "chr") == T)) gsub(":|-", "_", input$geneCheckbox) else caseCorrect(object, input$geneCheckbox)
                
                umap_highlight <- data.frame()
                
                
                df <- cell.types()
                
                if(!is.null(s) && length(object@metadata) != 0 && nrow(df) != 0 && !is.null(input$datasetCheckbox)){
                    
                    rdt <- phyper.test(object, df, input$datasetCheckbox)
                    
                    
                    umapChoice = input$subdataset[length(input$subdataset)]
                    
                    getDatasetUmap <- object@metadata[[paste0("umap.", umapChoice)]]
                    
                    selectedCellTypes <- as.character(rdt$cell_type[s])
                    
                    subCellTypes <- grep(paste0(umapChoice, "."), selectedCellTypes, value = T)
                    subCellTypes <- sub(paste0(umapChoice, "."), "", subCellTypes)
                    # get hits
                    if (length(selection) != 0 && length(subCellTypes) != 0){ 
                        true.hits <- findCellTypes.geneList(object, selection, umapChoice)
                        
                        for( j in subCellTypes)
                        {
                            getCluster <- subset(getDatasetUmap, rownames(getDatasetUmap) == j )
                            getCluster <- data.frame(x = getCluster[,1], y = getCluster[,2], col = rownames(getCluster), shape = F)
                            getCluster$shape[true.hits[[paste0(umapChoice, ".", j)]]] <- T
                            umap_highlight <- data.frame(rbind(umap_highlight, getCluster))
                        }
                    } 
                    
                    umap_plot <- data.frame(x = getDatasetUmap[,1], y = getDatasetUmap[,2], col = rownames(getDatasetUmap))
                    umap_truehits <- data.frame(subset(umap_highlight, shape == T))
                    
                    
                    g <- ggplot() + geom_point(aes(x, y, group = col), data = umap_plot, colour = alpha("grey", .3)) +
                        geom_point(aes(x, y, colour = col), data = umap_highlight, alpha = .5, shape = 21)+
                        geom_point(aes(x, y), data = umap_truehits, shape = 21, colour = "black")+
                        labs(x = "UMAP1", y = "UMAP2", color = "") +
                        theme_bw() + 
                        theme(axis.line = element_line(colour = "black"),
                              panel.border = element_rect(colour = "black", fill=NA, size=2),
                              plot.background = element_blank(),
                              legend.position = "bottom",
                              axis.text.x = element_blank(),
                              axis.text.y = element_blank(),
                              axis.ticks = element_blank(),
                              panel.grid.major = element_blank(),
                              panel.grid.minor = element_blank(),
                              text = element_text(size=20),
                              legend.text = element_text(size=14),
                              aspect.ratio = 1) +
                        guides(colour = guide_legend(nrow = 4,byrow = TRUE))
                    
                    g
                } else {
                    g <- plot(0,type='n',axes=FALSE,ann=FALSE)
                }
                
            })
            
            session$onSessionEnded(function() {
                stopApp()
            })
        }
    )
}




#' @rdname scfindShinyServer
#' @aliases scfindShinyServer
setMethod("scfindShinyServer", signature(object = "SCFind"), server.scfind)
hemberg-lab/scfind documentation built on March 27, 2022, 8:56 p.m.