| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  | #' 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) { | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   named_genes <- geposan::genes[name != ""] | 
					
						
							|  |  |  |   named_genes <- unique(named_genes, by = "name") | 
					
						
							|  |  |  |   gene_choices <- named_genes$id | 
					
						
							|  |  |  |   names(gene_choices) <- named_genes$name | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   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 | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  |         ), | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       ), | 
					
						
							|  |  |  |       tabPanelBody( | 
					
						
							|  |  |  |         "hgnc", | 
					
						
							|  |  |  |         textAreaInput( | 
					
						
							|  |  |  |           NS(id, "hgnc_names_raw"), | 
					
						
							|  |  |  |           "Enter HGNC symbols", | 
					
						
							|  |  |  |           value = paste( | 
					
						
							|  |  |  |             geposan::genes[ | 
					
						
							|  |  |  |               id %chin% default_gene_ids & name != "", | 
					
						
							|  |  |  |               name | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             collapse = "\n" | 
					
						
							|  |  |  |           ), | 
					
						
							|  |  |  |           height = "250px" | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       ), | 
					
						
							|  |  |  |       tabPanelBody( | 
					
						
							|  |  |  |         "ensembl", | 
					
						
							|  |  |  |         textAreaInput( | 
					
						
							|  |  |  |           NS(id, "gene_ids_raw"), | 
					
						
							|  |  |  |           "Enter Ensembl gene IDs", | 
					
						
							|  |  |  |           value = paste(default_gene_ids, collapse = "\n"), | 
					
						
							|  |  |  |           height = "250px" | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       ) | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   ) | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #' 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) { | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   moduleServer(id, function(input, output, session) { | 
					
						
							|  |  |  |     observe({ | 
					
						
							|  |  |  |       updateTabsetPanel( | 
					
						
							|  |  |  |         session, | 
					
						
							|  |  |  |         "custom_input", | 
					
						
							|  |  |  |         selected = input$identifier_type | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     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] | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       if (length(gene_ids > 100)) { | 
					
						
							|  |  |  |         gene_ids[seq_len(100)] | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         gene_ids | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  |     }) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   }) | 
					
						
							| 
									
										
										
										
											2022-01-26 14:48:29 +01:00
										 |  |  | } |