R/Select_panels_update.R

Defines functions kmer_update_select condition_update_select library_update_select frame_type_update_select tx_from_gene_list tx_update_select gene_update_select_heatmap gene_update_select_internal gene_update_select experiment_update_select

experiment_update_select <- function(org, all_exp, experiments,
                                     selected = "AUTO") {
  orgs_safe <- if (isolate(org()) == "ALL") {
    unique(all_exp$organism)
  } else isolate(org())
  picks <- experiments[all_exp$organism %in% orgs_safe]
  selected <-
  if (selected == "AUTO") {
    picks[1]
  } else selected
  updateSelectizeInput(
    inputId = "dff",
    choices = picks,
    selected = selected,
    server = FALSE
  )
}

gene_update_select <- function(gene_name_list,
                               selected = choices[1],
                               id = "gene",
                               choices = unique(gene_name_list()[,2][[1]]),
                               server = TRUE) {

  gene_update_select_internal(gene_name_list(),
                              selected = selected,
                              id = id,
                              choices = choices,
                              server = server)
}

gene_update_select_internal <- function(gene_name_list,
                                        selected = choices[1],
                                        id = "gene",
                                        choices = unique(gene_name_list[,2][[1]]),
                                        server = TRUE) {
  print(paste("Updating", paste0(id, ":"), selected))
  updateSelectizeInput(
    inputId = id,
    choices = choices,
    selected = selected,
    server = server
  )
}

gene_update_select_heatmap <- function(gene_name_list, selected = "all") {
  updateSelectizeInput(
    inputId = "gene",
    choices = unique(c(selected, gene_name_list()[,2][[1]])),
    selected = selected,
    server = TRUE
  )
}

tx_update_select <- function(gene = NULL, gene_name_list, additionals = NULL,
                             selected = NULL) {
  print(paste("Updating isoform:"))
  isoforms <- tx_from_gene_list(isolate(gene_name_list()), gene, selected,
                                additionals)

  if (is.null(selected)) selected <- isoforms[1]
  if (length(selected) > 1) {
    print(isolate(gene_name_list())[value == selected,][1])
  } else if (selected != "all") print(selected)
  updateSelectizeInput(
    inputId = "tx",
    choices = isoforms,
    selected = selected,
    server = TRUE
  )
}

tx_from_gene_list <- function(gene_name_list, gene = NULL, selected = NULL,
                              additionals = NULL) {

  if (is.null(gene)) {
    gene <- gene_name_list[value == selected,][1]$label
    if (length(gene) == 0 | is.na(gene)) stop("Isoform does not exist in species!")
  } else if (gene == "all") {
    return(c(gene, additionals))
  }
  print(paste("Gene set:", gene))
  isoforms <- gene_name_list[label == gene, 1][[1]]
  isoforms <- c(additionals, isoforms)
  if (length(isoforms) == 0) stop("Gene does not exist in this species")
  return(isoforms)
}

frame_type_update_select <- function(selected) {
  updateSelectizeInput(
    inputId = "frames_type",
    label = "Select frames display type",
    choices = c("lines", "columns", "stacks", "area", "heatmap"),
    selected = selected
  )
}

library_update_select <- function(libs, selected = isolate(libs()[1])) {
  updateSelectizeInput(
    inputId = "library",
    choices = libs(),
    selected = selected,
    server = TRUE
  )
}

condition_update_select <- function(cond) {
  updateSelectizeInput(
    inputId = "condition",
    choices = cond(),
    selected = cond()[1]
  )
}

kmer_update_select <- function(select) {
  updateSliderInput(inputId = "kmer", value = select)
}
m-swirski/RiboCrypt documentation built on Jan. 15, 2025, 11:57 p.m.