inst/dpcReport/server.R

library(shiny)
library(dpcR)
library(ggplot2)
library(shinythemes)
library(DT)
library(rhandsontable)
library(dplyr)
library(digest)

source("server_data.R")

shinyServer(function(input, output, session) {
  
  # Input file panel --------------------------------
  
  #read and process data from different vendors
  input_dat <- reactive({
    #after loading any file it would be possible to start an example
    dat <- if(is.null(input[["input_file"]])) {
      six_panels
    } else {
      processed_dat <- raw_input_dat()
      
      validate(
        need(class(processed_dat) != "try-error", "Input file cannot be processed. Change file or filetype.")
      )

      processed_dat
    }
    
    # if(!is.null(input[["input_file"]])) 
    #   if(input[["input_file"]][["name"]] == "RawData.zip")
    #     browser()

    if(!is.null(input[["input_table"]])) {
      
      #if(!input[["input_table"]][["changes"]][["rInitInput"]]) 
        merged_dat <- try(merge_dpcr(dat, df2dpcr(unorder_df(hot_to_r(input[["input_table"]])))))

        if(class(merged_dat) != "try-error") {
          dat <- merged_dat
        } else {
          dat <- dat
        }
    }
    
    dat
  })
  
  raw_input_dat <- reactive({
    if(is.null(input[["input_file"]])) {
      NULL
    } else {
      #read extension of the file
      ext <- strsplit(input[["input_file"]][["name"]], ".", fixed = TRUE)[[1]]
      new_name <- paste0(input[["input_file"]][["datapath"]], ".", ext[length(ext)])
      
      file.rename(input[["input_file"]][["datapath"]], new_name)
      
      #choose which function use to process tha dPCR data
      process_function <- switch(input[["input_type"]],
                                 redf = function(x) read_dpcr(x, format = "redf"),
                                 QX100 = function(x) read_dpcr(x, format = "QX100"),
                                 QX200 = function(x) read_dpcr(x, format = "QX200"),
                                 BioMark_det = function(x) read_dpcr(x, format = "BioMark", detailed = TRUE),
                                 BioMark_sum = function(x) read_dpcr(x, format = "BioMark", detailed = FALSE),
                                 amp = function(x) read_dpcr(x, format = "amp"))
      
      processed_dat <- try(process_function(new_name))
    }
  })
  
  
  output[["input_table"]] = renderRHandsontable({
    hot_table(rhandsontable(dpcr2df(input_dat()), useTypes = FALSE, 
                            readOnly = FALSE, selectCallback = TRUE,
                            highlightRow = TRUE), highlightCol = TRUE, highlightRow = TRUE)
  })
  
  #information if input file is loaded
  output[["input_information"]] <- renderPrint({
    if(is.null(input[["input_file"]])) {
      p("No input detected. Example data loaded.")
    } else {
      p("Detected input file: ", strong(input[["input_file"]][["name"]]), ".")
    }
  })
  
  
  # Data summary table panel --------------------------------
  summary_table <- reactive({
    new_dat <- input_dat()
    source("./data_summary/summary_input.R", local = TRUE)
    res
  })
  
  
  output[["summary_input"]] <- DT::renderDataTable({
    formatRound(my_DT(summary_table()), 6L:11, app_digits)
  })
  
  #   output[["summary_table_download_button"]] <- downloadHandler("summary.csv",
  #                                                                content = function(file) {
  #                                                                  write.csv(summary_table(), file, row.names = FALSE)
  #                                                                })
  
  # Data summary scatter chart panel --------------------------------
  summary_plot_dat <- reactive({
    new_dat <- input_dat()
    summ <- summary(new_dat, print = FALSE)[["summary"]]
    summ[summ[["method"]] == input[["CI_method"]], ]
  })
  
  
  #clicking a point in the summary boxplot
  summary_point <- reactiveValues(
    selected = NULL
  )
  
  observeEvent(input[["summary_plot_dbl"]], {
    summary_point[["selected"]] <- summary_plot_dbl()[["row"]]
  })
  
  summary_plot_dbl <- reactive({
    choose_xy_point(input[["summary_plot_dbl"]], 
                    data = summary_plot_dat()[, c("lambda", "experiment")])
  })
  
  output[["summary_plot"]] <- renderPlot({
    source("./summary_plots/summary_plot.R", local = TRUE)
    p
  })
  
  output[["summary_plot_download_button"]] <- downloadHandler("summary.svg",
                                                              content = function(file) {
                                                                source("./summary_plots/summary_plot.R", local = TRUE)
                                                                ggsave(file, p, device = svg, height = 210, width = 297,
                                                                       units = "mm")
                                                              })
  observe({
    if(input[["summary_plot_reset"]] > 0)
      summary_point[["selected"]] <- NULL
  })
  
  output[["summary_plot_dbl"]] <- renderPrint({
    summ <- summary_plot_dat()
    dat <- cbind(summ, selected = rep(FALSE, nrow(summary_plot_dat())))
    dat[as.numeric(summary_point[["selected"]]), "selected"] <- TRUE
    
    epilogue <- list(strong("Double-click"), "point on the chart to learn its properties.", br()) 
    
    prologue <- if(is.null(summary_point[["selected"]])) {
      list()
    } else {
      dat <- dat[dat[["selected"]] == TRUE, ]
      list("Experiment name: ", as.character(dat[["experiment"]]), br(), 
           HTML("&lambda;"), ":", round(dat[["lambda"]], app_digits), br())
    }
    
    do.call(p, c(prologue, epilogue))
  })
  
  # Data summary experiment-replicate scatter chart panel --------------------------------
  summary_exprep_plot_dat <- reactive({
    summ <- summary_plot_dat()
    summ[["exprep"]] <- factor(paste0(summ[["experiment"]], "\n", summ[["replicate"]]))
    summ
  })
  
  #clicking a point in the summary experiment-replicate scatter chart
  summary_exprep_point <- reactiveValues(
    selected = NULL
  )
  
  observeEvent(input[["summary_exprep_plot_dbl"]], {
    summary_exprep_point[["selected"]] <- summary_exprep_plot_dbl()[["row"]]
  })
  
  summary_exprep_plot_dbl <- reactive({
    choose_xy_point(input[["summary_exprep_plot_dbl"]], 
                    data = summary_exprep_plot_dat()[, c("exprep", "lambda")])
  })
  
  output[["summary_exprep_plot"]] <- renderPlot({
    source("./summary_plots/summary_exprep_plot.R", local = TRUE)
    p
  })
  
  output[["summary_exprep_plot_download_button"]] <- downloadHandler("summary_exprep.svg",
                                                                     content = function(file) {
                                                                       source("./summary_plots/summary_exprep_plot.R", local = TRUE)
                                                                       ggsave(file, p, device = svg, 
                                                                              height = 100 + 10 * nrow(summary_exprep_plot_dat()), width = 297,
                                                                              units = "mm")
                                                                     })
  
  observe({
    if(input[["summary_exprep_plot_reset"]] > 0)
      summary_exprep_point[["selected"]] <- NULL
  })
  
  output[["summary_exprep_plot_ui"]] <- renderUI({
    plotOutput("summary_exprep_plot",
               dblclick = dblclickOpts(id = "summary_exprep_plot_dbl"),
               height = 260 + 40 * nrow(summary_exprep_plot_dat()))
  })
  
  output[["summary_exprep_plot_dbl"]] <- renderPrint({
    summ <- summary_exprep_plot_dat()
    dat <- cbind(summ, selected = rep(FALSE, nrow(summary_exprep_plot_dat())))
    dat[as.numeric(summary_exprep_point[["selected"]]), "selected"] <- TRUE
    
    epilogue <- list(strong("Double-click"), "point on the chart to learn its properties.", br()) 
    
    prologue <- if(is.null(summary_exprep_point[["selected"]])) {
      list()
    } else {
      dat <- dat[dat[["selected"]] == TRUE, ]
      list("Experiment name: ", as.character(dat[["experiment"]]), br(), 
           "Replicate ID: ", as.character(dat[["replicate"]]), br(),
           HTML("&lambda;"), ": ", round(dat[["lambda"]], app_digits), br(),
           HTML("&lambda;"), "(lower confidence interval): ", round(dat[["lambda.low"]], app_digits), br(),
           HTML("&lambda;"), "(upper confidence interval): ", round(dat[["lambda.up"]], app_digits), br())
    }
    
    do.call(p, c(prologue, epilogue))
  })
  
  
  # Test counts (compare experiments) --------------------- 
  test_counts_dat <- reactive({
    new_dat <- input_dat()
    test_counts(new_dat, model = "ratio")
  })
  
  test_counts_groups_summary <- reactive({
    source("./test_counts/test_counts_group.R", local = TRUE)
    dat
  })
  
  
  test_counts_groups_summary_nice <- reactive({
    dat <- test_counts_groups_summary()
    dat <- dat[, c("run", "group", "lambda", "lambda.low", "lambda.up", "experiment", "replicate", "k", "n")]
    colnames(dat) <- c("Run", "Assigned group", "&lambda;", "&lambda; (lower CI)", "&lambda; (upper CI)", 
                       "Experiment name", "Replicate ID", "k", "n")
    dat
  })
  
  output[["test_counts_groups"]] <- DT::renderDataTable({
    formatRound(my_DT(test_counts_groups_summary_nice()), 3L:5, app_digits)
  })
  
  output[["test_counts_groups_download_button"]] <- downloadHandler("comparison_summary.csv",
                                                                    content = function(file) {
                                                                      write.csv(test_counts_groups_summary_nice(), file, row.names = FALSE)
                                                                    })
  
  test_counts_res <- reactive({
    source("./test_counts/test_counts_res.R", local = TRUE)
    res
  })
  
  output[["test_counts_res"]] <- DT::renderDataTable({
    formatRound(my_DT(test_counts_res()), 2, app_digits)
  })
  
  
  output[["test_counts_res_download_button"]] <- downloadHandler("comparison_results.csv",
                                                                 content = function(file) {
                                                                   write.csv(test_counts_res(), file, row.names = FALSE)
                                                                 })
  
  #clicking a point in the summary experiment-replicate scatter chart
  test_count_point <- reactiveValues(
    selected = NULL
  )
  
  observeEvent(input[["test_count_dbl"]], {
    test_count_point[["selected"]] <- test_count_dbl()[["row"]]
  })
  
  test_count_dbl <- reactive({
    choose_xy_point(input[["test_count_dbl"]], 
                    data = test_counts_groups_summary()[, c("run", "lambda")])
  })
  
  
  output[["test_counts_plot"]] <- renderPlot({
    source("./test_counts/test_counts_plot.R", local = TRUE)
    p
  })
  
  output[["test_counts_plot_ui"]] <- renderUI({
    plotOutput("test_counts_plot", 
               dblclick = dblclickOpts(id = "test_count_dbl"),
               height = 260 + nrow(test_counts_groups_summary()) * 40)
  })
  
  output[["test_counts_plot_download_button"]] <- downloadHandler("comparison_plot.svg",
                                                                  content = function(file) {
                                                                    source("./test_counts/test_counts_plot.R", local = TRUE)
                                                                    ggsave(file, p, device = svg, 
                                                                           height = 100 + 10 * nrow(test_counts_groups_summary()), width = 297,
                                                                           units = "mm")
                                                                  })
  
  observe({
    if(input[["test_counts_plot_reset"]] > 0)
      test_count_point[["selected"]] <- NULL
  })
  
  
  output[["test_count_dbl"]] <- renderPrint({
    dat <- test_counts_groups_summary()
    dat[["selected"]] <- rep(FALSE, nrow(dat))
    dat[as.numeric(test_count_point[["selected"]]), "selected"] <- TRUE
    
    epilogue <- list(strong("Double-click"), "point on the chart to learn its properties.", br()) 
    
    prologue <- if(is.null(test_count_point[["selected"]])) {
      list()
    } else {
      dat <- dat[dat[["selected"]] == TRUE, ]
      list("Experiment name: ", as.character(dat[["experiment"]]), br(), 
           "Replicate ID: ", as.character(dat[["replicate"]]), br(),
           "Assigned group: ", as.character(dat[["group"]]), br(),
           HTML("&lambda;"), ": ", round(dat[["lambda"]], app_digits), br(),
           HTML("&lambda;"), "(lower confidence interval): ", round(dat[["lambda.low"]], app_digits), br(),
           HTML("&lambda;"), "(upper confidence interval): ", round(dat[["lambda.up"]], app_digits), br())
    }
    
    do.call(p, c(prologue, epilogue))
  })
  
  
  
  
  # plot panel --------------------------
  
  output[["plot_panel_tab"]] <- renderUI({
    if(class(input_dat()) == "adpcr") {
      list(includeMarkdown("./plot_panel/plot_panel1.md"),
           htmlOutput("array_choice"),
           htmlOutput("plot_panel_stat"),
           numericInput("nx", "Numbers of quadrats in the x direction:", 
                        5, min = 1, max = NA, step = NA),
           numericInput("ny", "Numbers of quadrats in the y direction:", 
                        5, min = 1, max = NA, step = 1),
           list(plotOutput("plot_panel", height = 600,
                           brush  = brushOpts(id = "plot_panel_brush")),
                fluidRow(
                  column(3, downloadButton("plot_panel_download_button", 
                                           "Save chart (.svg)")),
                  column(3, actionButton("plot_panel_reset", 
                                         "Reset chart"))
                ),
                br(),
                includeMarkdown("./plot_panel/plot_panel2.md"),
                htmlOutput("plot_panel_brush"),
                DT::dataTableOutput("plot_panel_region_summary"),
                downloadButton("plot_panel_region_summary_download_button", "Save table (.csv)"))
      )
    } else {
      includeMarkdown("./plot_panel/plot_panel0.md")
    }
  })
  
  array_dat <- reactive({
    new_dat <- input_dat()
    adpcr2panel(new_dat)
  })
  
  output[["array_choice"]] <- renderUI({
    choices <- names(array_dat())
    names(choices) <- choices
    
    selectInput("array_choice", label = h4("Select array"), 
                choices = as.list(choices))
  })
  
  
  plot_panel_dat <- reactive({
    df <- calc_coordinates(array_dat()[[input[["array_choice"]]]], 
                           half = "none")[["ggplot_coords"]]
    #browser()
    df[["selected"]] <- rep(FALSE, nrow(df))
    df
  })
  
  array_val <- reactiveValues(selected = NULL)
  
  observeEvent(input[["plot_panel_brush"]], {
    array_val[["selected"]] <- choose_xy_region(input[["plot_panel_brush"]], 
                                                data = plot_panel_dat()[, c("col", "row")])
  })
  
  output[["plot_panel"]] <- renderPlot({
    df <- try(plot_panel_dat())
    
    validate(
      need(class(df) != "try-error", "Please wait: processing data.")
    )
    
    df[array_val[["selected"]], "selected"] <- TRUE
    #browser()
    source("./plot_panel/plot_panel.R", local = TRUE)
    
    p + ggtitle(input[["array_choice"]])
  })
  
  
  output[["plot_panel_download_button"]] <- downloadHandler("array.svg",
                                                            content = function(file) {
                                                              df <- plot_panel_dat()
                                                              
                                                              df[array_val[["selected"]], "selected"] <- TRUE
                                                              
                                                              source("./plot_panel/plot_panel.R", local = TRUE)
                                                              
                                                              p <- p + ggtitle(input[["array_choice"]])
                                                              
                                                              ggsave(file, p, device = svg, height = 210, width = 297,
                                                                     units = "mm")
                                                            })
  
  observe({
    if(!is.null(input[["plot_panel_reset"]]))
      if(input[["plot_panel_reset"]] > 0)
        array_val[["selected"]] <- NULL
  })
  
  output[["plot_panel_brush"]] <- renderPrint({
    do.call(p, list(strong("Click and sweep"), "over the partitions to select them.", br()) )
  })
  
  output[["plot_panel_stat"]] <- renderPrint({
    single_array <- try(array_dat()[[input[["array_choice"]]]])
    
    validate(
      need(class(single_array) != "try-error", "Please wait: processing data.")
    )
    
    source("./plot_panel/test_panel.R", local = TRUE)
    
    prologue <- list("Run name: ", input[["array_choice"]], br(), 
                     "Complete Spatial Randomness test statistic (", HTML("&Chi;"), "): ", 
                     round(res[["statistic"]], app_digits), br(),
                     "Df: ", res[["parameter"]], br(),
                     "Complete Spatial Randomness test p-value: ", 
                     round(res[["p.value"]], app_digits), br(),
                     "Method: ", res[["method"]][1], br(),
                     "Alternative: ", res[["alternative"]], br())
    
    do.call(p, prologue)
  })
  
  plot_panel_region_summary <- reactive({
    source("./plot_panel/subpanel_summary.R", local = TRUE)
    summs
  })
  
  output[["plot_panel_region_summary"]] <- DT::renderDataTable({
    summ <- try(plot_panel_region_summary())
    validate(
      need(class(summ) != "try-error", "Only empty partitions are chosen.")
    )
    formatRound(my_DT(summ), 6L:11, app_digits)
  })
  
  
  output[["plot_panel_region_summary_download_button"]] <- downloadHandler(filename = "subpanel_summary.csv",
                                                                           content = function(file) {
                                                                             write.csv(plot_panel_region_summary(), file, row.names = FALSE)
                                                                           })
  
  # Poisson distribution --------------------- 
  
  kn_coef <- reactive({
    new_dat <- input_dat()
    
    single_run <- extract_run(new_dat, input[["run_choice"]])
    
    source("./prob_distr/get_kn.R", local = TRUE)
    
    list(kn = kn,
         dens = dens,
         conf = conf)
  })
  
  output[["run_choice"]] <- renderUI({
    new_dat <- input_dat()

    choices <- as.list(colnames(new_dat))
    names(choices) <- colnames(new_dat)
    selectInput("run_choice", label = h4("Select run"), choices = choices)
  })
  
  moments_table <- reactive({
    new_dat <- input_dat()
    
    single_run <- extract_run(new_dat, input[["run_choice"]])
    
    source("./prob_distr/single_run_moments.R", local = TRUE)
    
    mom_tab
  })
  
  output[["moments_table"]] <- DT::renderDataTable({
    try_moments_table <- try(moments_table())
    
    validate(
      need(class(try_moments_table) != "try-error", "Please wait: processing data.")
    )
    
    formatRound(my_DT(try_moments_table), 2L:3, app_digits)
  })
  
  
  
  #output[["moments_table_download_button"]] <- download_table(moments_table(), "moments.csv")
  output[["moments_table_download_button"]] <- downloadHandler(filename = "moments.csv",
                                                               content = function(file) {
                                                                 write.csv(moments_table(), file, row.names = FALSE)
                                                               })
  
  
  output[["density_plot"]] <- renderPlot({
    dens <- try(kn_coef()[["dens"]])
    
    validate(
      need(class(dens) != "try-error", "Please wait: processing data.")
    )
    
    
    source("./prob_distr/plot_density.R", local = TRUE)
    
    p
  })
  
  output[["density_plot_download_button"]] <- downloadHandler("density.svg",
                                                              content = function(file) {
                                                                dens <- kn_coef()[["dens"]]
                                                                
                                                                source("./prob_distr/plot_density.R", local = TRUE)
                                                                
                                                                ggsave(file, p, device = svg, height = 210, width = 297,
                                                                       units = "mm")
                                                              })
  
  
  # report download ---------------------------------------------------
  output[["report_download_button"]] <- downloadHandler(
    filename  = "dpcReport.html",
    content = function(file) {
      knitr::knit(input = "report_template.Rmd", 
                  output = "dpcReport.md", quiet = TRUE)
      on.exit(unlink(c("dpcReport.md", "figure"), recursive = TRUE))
      markdown::markdownToHTML("dpcReport.md", file, stylesheet = "report.css", 
                               options = c('toc', markdown::markdownHTMLOptions(TRUE)))
    })
  
  output[["input_download_button"]] <- downloadHandler(
    filename  = "dpcReport_input.csv",
    content = function(file) {
      write.csv(dpcr2df(input_dat()), file, row.names = FALSE)
    })
  
  # observe({
  #   if(input[["quit_button"]] > 0)
  #     stopApp()
  # })
  # 
  # session$onSessionEnded(function() { 
  #   stopApp()
  # })
  
})

Try the dpcR package in your browser

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

dpcR documentation built on May 2, 2019, 7:04 a.m.