geposanui/R/preset_editor.R

97 lines
2.8 KiB
R

#' Create the UI for a preset editor.
#'
#' @param id ID for namespacing.
#' @return The UI elements.
#'
#' @noRd
preset_editor_ui <- function(id) {
verticalLayout(
h3("Inputs"),
selectInput(
NS(id, "species"),
"Species to include",
choices = list(
"All species" = "all",
"Known replicatively aging species" = "replicative",
"Customize" = "custom"
)
),
conditionalPanel(
condition = sprintf("input['%s'] == 'custom'", NS(id, "species")),
selectizeInput(
inputId = NS(id, "custom_species"),
label = "Select input species",
choices = NULL,
multiple = TRUE
),
),
selectInput(
NS(id, "reference_genes"),
"Reference genes",
choices = list(
"Verified or suggested TPE-OLD genes" = "tpeold",
"Only verified TPE-OLD genes" = "verified",
"Customize" = "custom"
)
),
conditionalPanel(
condition = sprintf(
"input['%s'] == 'custom'",
NS(id, "reference_genes")
),
gene_selector_ui(
NS(id, "custom_genes"),
genes[suggested | verified == TRUE, id]
)
)
)
}
#' Application logic for the preset editor.
#'
#' @param id ID for namespacing the inputs and outputs.
#' @return A reactive containing the preset or `NULL`, if the input data doesn't
#' result in a valid one.
#'
#' @noRd
preset_editor_server <- function(id) {
moduleServer(id, function(input, output, session) {
species_choices <- geposan::species$id
names(species_choices) <- geposan::species$name
updateSelectizeInput(
session,
"custom_species",
choices = species_choices,
server = TRUE
)
custom_gene_ids <- gene_selector_server("custom_genes")
reactive({
reference_gene_ids <- if (input$reference_genes == "tpeold") {
genes[verified | suggested == TRUE, id]
} else if (input$reference_genes == "verified") {
genes[verified == TRUE, id]
} else {
custom_gene_ids()
}
species_ids <- if (input$species == "replicative") {
species_ids_replicative
} else if (input$species == "all") {
geposan::species$id
} else {
input$custom_species
}
tryCatch(
geposan::preset(
reference_gene_ids,
species_ids = species_ids
),
error = function(err) NULL
)
})
})
}