R/boxPlotGG_data_TreatmentDS.R

Defines functions boxPlotGG_data_TreatmentDS

Documented in boxPlotGG_data_TreatmentDS

#' @title Arrange data frame to pass it to the boxplot function
#'
#' @param table \code{data frame} Table that holds the information to be plotted later
#' @param variables \code{character vector} Name of the column(s) of the data frame to include on the boxplot
#' @param group \code{character} (default \code{NULL}) Name of the first grouping variable. 
#' @param group2 \code{character} (default \code{NULL}) Name of the second grouping variable. 
#'
#' @return \code{data frame} with the following structure: \cr
#' 
#'  Column 'x': Names on the X axis of the boxplot, aka variables to plot \cr
#'  Column 'value': Values for that variable (raw data of columns rbinded) \cr
#'  Column 'group': (Optional) Values of the grouping variable \cr
#'  Column 'group2': (Optional) Values of the second grouping variable \cr
#'  
#' @export

boxPlotGG_data_TreatmentDS <- function(table, variables, group = NULL, group2 = NULL){

  if(is.null(group) & !is.null(group2)){
    group <- group2
    group2 <- NULL
  }
  
  if(is.null(group2)){
    if(is.null(group)){
      data <- table[, c(variables)]
    }
    else{
      if(! any(c("factor") %in% class(table[[group]]))) {
        stop("Grouping variable must be of class factor")
      }
      data <- table[, c(variables, group)]
    }
    
  }
  else{
    if((! any(c("factor") %in% class(table[[group]]))) | (! any(c("factor") %in% class(table[[group2]])))){
      stop("Grouping variable must be of class factor")
    }
    data <- table[, c(variables, group, group2)]
    # Handle case group == group2 
    if(group == group2){
      data$group2 <- data[, group]
      group2 <- "group2"
    }
  }

  data <- reshape2::melt(data, measure.vars = variables, rm.na = TRUE,
                 variable.name="x")

  if(!is.null(group)){
    names(data)[names(data) == group] <- 'group'
    data[, "group"] <- as.factor(data[, "group"])
    data <- data[stats::complete.cases(data), ]
  }
  else{
    if(length(variables) == 1){
      data <- data[stats::complete.cases(data), ]
      names(data) <- variables
    }
    else{
      data <- data[stats::complete.cases(data), ]
    }
  }
  if(!is.null(group2)){
    names(data)[names(data) == group2] <- 'group2'
    data[, "group2"] <- as.factor(data[, "group2"])
    data <- data[stats::complete.cases(data), ]
  }

  return(data)
  
}
datashield/dsBase documentation built on May 16, 2023, 10:01 p.m.