mirror of
				https://github.com/johrpan/geposanui.git
				synced 2025-10-26 19:27:24 +01:00 
			
		
		
		
	
		
			
	
	
		
			102 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			R
		
	
	
	
	
	
		
		
			
		
	
	
			102 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			R
		
	
	
	
	
	
|  | #' Create the UI for a gene selector. | ||
|  | #' | ||
|  | #' @param id ID for namespacing. | ||
|  | #' @param default_gene_ids Gene IDs of initially selected genes. | ||
|  | #' | ||
|  | #' @return The user interface | ||
|  | #' | ||
|  | #' @noRd | ||
|  | gene_selector_ui <- function(id, default_gene_ids = NULL) { | ||
|  |     named_genes <- genes[name != ""] | ||
|  |     named_genes <- unique(named_genes, by = "name") | ||
|  |     gene_choices <- named_genes$id | ||
|  |     names(gene_choices) <- named_genes$name | ||
|  | 
 | ||
|  |     verticalLayout( | ||
|  |         selectInput( | ||
|  |             NS(id, "identifier_type"), | ||
|  |             "Gene identifiers", | ||
|  |             choices = list( | ||
|  |                 "Select from list" = "list", | ||
|  |                 "HGNC symbols" = "hgnc", | ||
|  |                 "Ensembl gene IDs" = "ensembl" | ||
|  |             ) | ||
|  |         ), | ||
|  |         tabsetPanel( | ||
|  |             id = NS(id, "custom_input"), | ||
|  |             type = "hidden", | ||
|  |             tabPanelBody( | ||
|  |                 "list", | ||
|  |                 shinyvs::virtualSelectInput( | ||
|  |                     NS(id, "selected_genes"), | ||
|  |                     label = "Select genes", | ||
|  |                     choices = gene_choices, | ||
|  |                     multiple = TRUE, | ||
|  |                     search = TRUE, | ||
|  |                     selectAllOnlyVisible = TRUE | ||
|  |                 ), | ||
|  |             ), | ||
|  |             tabPanelBody( | ||
|  |                 "hgnc", | ||
|  |                 textAreaInput( | ||
|  |                     NS(id, "hgnc_names_raw"), | ||
|  |                     "Enter HGNC symbols", | ||
|  |                     value = paste( | ||
|  |                         genes[id %chin% default_gene_ids & name != "", name], | ||
|  |                         collapse = "\n" | ||
|  |                     ), | ||
|  |                     height = "250px" | ||
|  |                 ) | ||
|  |             ), | ||
|  |             tabPanelBody( | ||
|  |                 "ensembl", | ||
|  |                 textAreaInput( | ||
|  |                     NS(id, "gene_ids_raw"), | ||
|  |                     "Enter Ensembl gene IDs", | ||
|  |                     value = paste(default_gene_ids, collapse = "\n"), | ||
|  |                     height = "250px" | ||
|  |                 ) | ||
|  |             ) | ||
|  |         ) | ||
|  |     ) | ||
|  | } | ||
|  | 
 | ||
|  | #' Application logic for the gene selector. | ||
|  | #' | ||
|  | #' @param id ID for namespacing. | ||
|  | #' | ||
|  | #' @return A reactive containing the selected gene IDs. | ||
|  | #' | ||
|  | #' @noRd | ||
|  | gene_selector_server <- function(id) { | ||
|  |     moduleServer(id, function(input, output, session) { | ||
|  |         observe({ | ||
|  |             updateTabsetPanel( | ||
|  |                 session, | ||
|  |                 "custom_input", | ||
|  |                 selected = input$identifier_type | ||
|  |             ) | ||
|  |         }) | ||
|  | 
 | ||
|  |         reactive({ | ||
|  |             gene_ids <- if (input$identifier_type == "list") { | ||
|  |                 input$selected_genes | ||
|  |             } else if (input$identifier_type == "hgnc") { | ||
|  |                 inputs <- unique(strsplit(input$hgnc_names_raw, "\\s+")[[1]]) | ||
|  |                 inputs <- inputs[inputs != ""] | ||
|  |                 geposan::genes[name %chin% inputs, id] | ||
|  |             } else { | ||
|  |                 inputs <- unique(strsplit(input$gene_ids_raw, "\\s+")[[1]]) | ||
|  |                 inputs <- inputs[inputs != ""] | ||
|  |                 geposan::genes[id %chin% inputs, id] | ||
|  |             } | ||
|  | 
 | ||
|  |             if (length(gene_ids > 100)) { | ||
|  |                 gene_ids[seq_len(100)] | ||
|  |             } else { | ||
|  |                 gene_ids | ||
|  |             } | ||
|  |         }) | ||
|  |     }) | ||
|  | } |