geposanui/R/preset_editor.R

149 lines
4.5 KiB
R
Raw Normal View History

2021-10-21 14:56:19 +02:00
# Create a preset editor.
preset_editor_ui <- function(id) {
verticalLayout(
h3("Inputs"),
2021-10-21 14:56:19 +02:00
selectInput(
NS(id, "species"),
"Species to include",
2021-10-21 14:56:19 +02:00
choices = list(
"All species" = "all",
"Known replicatively aging species" = "replicative",
2021-10-21 14:56:19 +02:00
"Customize" = "custom"
)
),
2021-12-08 13:46:59 +01:00
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"
)
),
2021-12-08 13:46:59 +01:00
conditionalPanel(
condition = sprintf(
"input['%s'] == 'custom'",
NS(id, "reference_genes")
),
2021-12-15 12:41:35 +01:00
selectInput(
NS(id, "identifier_type"),
"Gene identifiers",
choices = list(
"HGNC symbols" = "hgnc",
"Ensembl gene IDs" = "ensembl"
)
),
textAreaInput(
2021-12-08 13:46:59 +01:00
inputId = NS(id, "custom_reference_genes"),
2021-12-15 12:41:35 +01:00
label = "Enter reference genes",
height = "250px"
)
),
tabsetPanel(
id = NS(id, "apply_panel"),
type = "hidden",
tabPanelBody(value = "hide"),
tabPanelBody(
value = "show",
2021-11-02 14:42:52 +01:00
actionButton(
NS(id, "apply_button"),
"Perform analysis",
class = "btn-primary",
style = "margin-top: 16px; margin-bottom: 16px"
)
2021-10-21 14:56:19 +02:00
)
)
)
}
# Create a server for the preset editor.
#
# @param id ID for namespacing the inputs and outputs.
#
# @return A reactive containing the preset.
preset_editor_server <- function(id) {
moduleServer(id, function(input, output, session) {
2022-01-17 20:42:27 +01:00
species_choices <- geposan::species$id
names(species_choices) <- geposan::species$name
2021-12-08 13:46:59 +01:00
updateSelectizeInput(
session,
"custom_species",
choices = species_choices,
server = TRUE
)
current_preset <- reactiveVal(geposan::preset(
2022-01-17 20:42:27 +01:00
genes[suggested | verified == TRUE, id]
))
2021-10-21 14:56:19 +02:00
new_preset <- reactive({
2021-11-18 14:10:06 +01:00
species_ids <- if (input$species == "replicative") {
2022-01-17 20:42:27 +01:00
species_ids_replicative
2021-11-18 14:10:06 +01:00
} else if (input$species == "all") {
2022-01-17 20:42:27 +01:00
geposan::species$id
2021-11-18 14:10:06 +01:00
} else {
input$custom_species
}
reference_gene_ids <- if (input$reference_genes == "tpeold") {
genes[verified | suggested == TRUE, id]
} else if (input$reference_genes == "verified") {
genes[verified == TRUE, id]
} else {
2021-12-15 12:41:35 +01:00
inputs <- strsplit(input$custom_reference_genes, "\\s+")[[1]]
if (input$identifier_type == "hgnc") {
geposan::genes[name %chin% inputs, id]
} else {
geposan::genes[id %chin% inputs, id]
}
}
geposan::preset(
2022-01-17 20:36:34 +01:00
reference_gene_ids,
2021-12-16 13:52:14 +01:00
methods = methods,
2021-11-18 14:10:06 +01:00
species_ids = species_ids,
2022-01-17 20:36:34 +01:00
gene_ids = genes$id
)
})
observeEvent(
{ # nolint
current_preset()
new_preset()
},
{ # nolint
if (rlang::hash(new_preset()) !=
rlang::hash(current_preset())) {
updateTabsetPanel(
session,
"apply_panel",
selected = "show"
)
} else {
updateTabsetPanel(
session,
"apply_panel",
selected = "hide"
)
}
}
)
observeEvent(input$apply_button, {
current_preset(new_preset())
2021-10-21 14:56:19 +02:00
})
current_preset
2021-10-21 14:56:19 +02:00
})
}