R/Module_TableModule.R

Defines functions TableModuleUI TableModule

Documented in TableModule TableModuleUI

#' TableModule
#' 
#' Module to show a Table in the UI. Deprecated, use \code{\link{TableModule2}}
#' 
#' @inherit MseekModules
#' 
#' @describeIn TableModule Server logic
#' 
#' @return Returns its internalValues
#' @param tag id to be used in ns()
#' @param set Import data from the shiny session
#' 
#' 
#' @export 
TableModule <- function(input,output, session,
                        tag, set = list(df =  NULL,
                                        update = 1, #change this to trigger update of the df or set to NULL to update anytime df changes
                                        layout = list(
                                          perpage = 100,
                                          height = 300,
                                          readOnly = T,
                                          contextMenu = T,
                                          fixedColumnsLeft = 1,
                                          invertReadOnly = NULL,
                                          format = list(col = NULL,
                                                        format = NULL)
                                        ))
){
  
  ns <- NS(tag)
  
  tableProperties <- reactiveValues(inpage = NULL,
                                    page = 1,
                                    showTable = NULL,
                                    updating = F,
                                    
                                    row_order = NULL,
                                    selected_rows = NULL,
                                    selected_cols = NULL,
                                    
                                    sortCheck = F,
                                    decreasing = T,
                                    sortby = NULL,
                                    set = NULL)
  
  observeEvent(set(),{
    if(length(set()$df) == 0 ){
      tableProperties$set <- set()
      tableProperties$selected_cols <- NULL
      tableProperties$selected_rows <- NULL
      tableProperties$df <- NULL
      tableProperties$showTable <- NULL
      
    }
    
    if(!is.null(set()$df) && (is.null(tableProperties$set$update) || set()$update != tableProperties$set$update)){
      
      tableProperties$row_order <- seq(nrow(set()$df))
      
      tableProperties$set <- set()
      #force this table to behave like a regular data.frame
      tableProperties$set$df <- as.data.frame(tableProperties$set$df)
      tableProperties$updating <- T
      tableProperties$selected_cols <- NULL
      tableProperties$selected_rows <- NULL
      
    }
    
    
  })
  
  observeEvent(c(tableProperties$page,
                 tableProperties$decreasing,
                 tableProperties$sortBy,
                 tableProperties$sortCheck,
                 tableProperties$set$update,
                 tableProperties$set$df),{
                   if(!is.null(tableProperties$set$df) && length(tableProperties$set$df) > 0){
                     
                     
                     if(tableProperties$sortCheck && length(tableProperties$sortBy) > 0){
                       tableProperties$row_order <- order(tableProperties$set$df[,tableProperties$sortBy], decreasing = tableProperties$decreasing)
                       
                     }else{
                       tableProperties$row_order <- seq(nrow(tableProperties$set$df))
                     }
                     
                     tableProperties$inpage <- if(is.null(set()$layout$perpage)){
                       tableProperties$row_order}
                     else if(tableProperties$page >= ceiling(length(tableProperties$row_order)/set()$layout$perpage)){
                       tableProperties$page <- ceiling(length(tableProperties$row_order)/set()$layout$perpage)
                       tableProperties$row_order[c((tableProperties$page*set()$layout$perpage-(set()$layout$perpage-1)):(length(tableProperties$row_order)))]}
                     else{
                       if(tableProperties$page < 1){tableProperties$page <- 1}
                       tableProperties$row_order[c((tableProperties$page*set()$layout$perpage-(set()$layout$perpage-1)):(tableProperties$page*set()$layout$perpage))]}
                     
                     tableProperties$showTable <- tableProperties$set$df[tableProperties$inpage,]
                     
                   }
                 })
  
  
  output$maintable <- renderRHandsontable({
    if(!is.null(tableProperties$showTable) 
       && (is.null(isolate(input$maintable)) || !identical(tableProperties$showTable,isolate(hot_to_r(input$maintable))))){
      
      #  rheight <- if(nrow(combino()[inpage(),])<40){NULL}else{500}
      
      rhandsontable(tableProperties$showTable,
                    readOnly = set()$layout$readOnly,
                    contextMenu = set()$layout$contextMenu,
                    selectCallback = TRUE,
                    height = set()$layout$height,
                    outsideClickDeselects = FALSE,
                    # width = 1000,
                    digits=8,
                    row_highlight = 1,
                    #format = "0.0000",
                    highlightCol = TRUE,
                    highlightRow = TRUE,
                    autoWrapCol = FALSE,
                    autoWrapRow = FALSE) %>%
        hot_col(col = set()$layout$format$col[which(set()$layout$format$col %in% colnames(tableProperties$showTable))], format=set()$layout$format$format)%>%
        hot_col(col = set()$layout$invertReadOnly[which(set()$layout$invertReadOnly %in% colnames(tableProperties$showTable))], readOnly = !set()$layout$readOnly)%>%
        hot_cols(fixedColumnsLeft = set()$layout$fixedColumnsLeft)%>%
        hot_cols(columnSorting = FALSE)
      
      
    }
  })
  
  output$tabUI <- renderUI({
    
    # if(!is.null(tableProperties$set$df)){
    fluidRow(
      rHandsontableOutput(ns("maintable"))
    )
    #  }
  })
  
  
  output$tableInfo <- renderText({
    if(!is.null(set()$layout$perpage)){
      paste0(nrow(tableProperties$set$df),
             " items (",
             ceiling(nrow(tableProperties$set$df)/set()$layout$perpage),"page(s))"
      )
    }
    
  })
  
  output$tabCtrls <- renderUI({
    if(!is.null(tableProperties$set$df)){
      fluidRow(
        column(3,
               checkboxInput(ns('sortCheck'), 'sort', value = tableProperties$sortCheck),
               checkboxInput(ns('decreasingCheck'), 'decreasing', value = tableProperties$decreasing)),
        column(3,
               
               selectizeInput(ns('sortBy'), "Sort by column", choices = colnames(tableProperties$set$df), selected = tableProperties$sortBy)
        ),
        column(3,
               if(!is.null(set()$layout$perpage)){
                 numericInput(ns('page'), "page", value = tableProperties$page, min = 1)
               }
        ),
        column(3,
               if(!is.null(set()$layout$perpage)){
                 textOutput(ns('tableInfo'))
               }
        )
      )
    }
  })
  
  observeEvent(input$sortCheck,{
    tableProperties$sortCheck <- input$sortCheck
  })
  
  observeEvent(input$decreasingCheck,{
    tableProperties$decreasing <- input$decreasingCheck
  })
  
  observeEvent(input$sortBy,{
    tableProperties$sortBy <- input$sortBy
  })
  
  observeEvent(input$page,{
    tableProperties$page <- input$page
  })
  
  observeEvent(input$maintable_select$select,{
    if(!is.null(input$maintable_select$select)){
      tableProperties$selected_cols <- as.integer(input$maintable_select$select$c):as.integer(input$maintable_select$select$c2)
      tableProperties$selected_rows <- as.integer(input$maintable_select$select$r):as.integer(input$maintable_select$select$r2)
      
      
    }
    
  })
  
  
  
  return(reactive({list(props = tableProperties#,
                        #live = if(!is.null(input$maintable)){hot_to_r(input$maintable)}else{NULL})
  )}))
  
}

#' @describeIn TableModule UI elements
#' @export
TableModuleUI <- function(id){
  ns <- NS(id)
  fluidPage(
    
    htmlOutput(ns("tabUI")),
    htmlOutput(ns('tabCtrls'))
    
  )
  
  
}
mjhelf/Metaboseek documentation built on April 23, 2022, 12:09 p.m.