| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  | #' Construct UI for the detailed results panel. | 
					
						
							|  |  |  | #' @noRd | 
					
						
							| 
									
										
										
										
											2022-08-17 16:46:39 +02:00
										 |  |  | details_ui <- function(id) { | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   verticalLayout( | 
					
						
							|  |  |  |     div( | 
					
						
							|  |  |  |       style = "margin-top: 16px", | 
					
						
							|  |  |  |       splitLayout( | 
					
						
							|  |  |  |         cellWidths = "auto", | 
					
						
							|  |  |  |         uiOutput(NS(id, "copy")), | 
					
						
							|  |  |  |         downloadButton(NS(id, "download"), "Download CSV") | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     div( | 
					
						
							|  |  |  |       style = "margin-top: 16px", | 
					
						
							|  |  |  |       DT::DTOutput(NS(id, "genes")) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   ) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #' Server for the detailed results panel. | 
					
						
							|  |  |  | #' | 
					
						
							| 
									
										
										
										
											2022-08-18 09:21:48 +02:00
										 |  |  | #' @param options Global options for the application. | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  | #' @param filtered_results A reactive containing the prefiltered results to be | 
					
						
							|  |  |  | #'   displayed. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @noRd | 
					
						
							| 
									
										
										
										
											2022-08-18 09:21:48 +02:00
										 |  |  | details_server <- function(id, options, filtered_results) { | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   moduleServer(id, function(input, output, session) { | 
					
						
							|  |  |  |     output$copy <- renderUI({ | 
					
						
							|  |  |  |       results <- filtered_results() | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       gene_ids <- results[, gene] | 
					
						
							|  |  |  |       names <- results[name != "", name] | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       genes_text <- paste(gene_ids, collapse = "\n") | 
					
						
							|  |  |  |       names_text <- paste(names, collapse = "\n") | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       splitLayout( | 
					
						
							|  |  |  |         cellWidths = "auto", | 
					
						
							|  |  |  |         rclipboard::rclipButton( | 
					
						
							|  |  |  |           "copy_ids_button", | 
					
						
							|  |  |  |           "Copy gene IDs", | 
					
						
							|  |  |  |           genes_text, | 
					
						
							|  |  |  |           icon = icon("clipboard") | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |         rclipboard::rclipButton( | 
					
						
							|  |  |  |           "copy_names_button", | 
					
						
							|  |  |  |           "Copy gene names", | 
					
						
							|  |  |  |           names_text, | 
					
						
							|  |  |  |           icon = icon("clipboard") | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       ) | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-18 09:21:48 +02:00
										 |  |  |     methods <- options$methods | 
					
						
							| 
									
										
										
										
											2022-05-26 17:55:40 +02:00
										 |  |  |     method_ids <- sapply(methods, function(method) method$id) | 
					
						
							|  |  |  |     method_names <- sapply(methods, function(method) method$name) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     columns <- c( | 
					
						
							|  |  |  |       "rank", | 
					
						
							|  |  |  |       "gene", | 
					
						
							|  |  |  |       "name", | 
					
						
							|  |  |  |       "chromosome", | 
					
						
							|  |  |  |       "distance", | 
					
						
							|  |  |  |       method_ids, | 
					
						
							|  |  |  |       "score", | 
					
						
							|  |  |  |       "percentile" | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     column_names <- c( | 
					
						
							|  |  |  |       "", | 
					
						
							|  |  |  |       "Gene", | 
					
						
							|  |  |  |       "", | 
					
						
							| 
									
										
										
										
											2022-08-18 09:54:59 +02:00
										 |  |  |       "Chr.", | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       "Distance", | 
					
						
							|  |  |  |       method_names, | 
					
						
							|  |  |  |       "Score", | 
					
						
							|  |  |  |       "Percentile" | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     output_data <- reactive({ | 
					
						
							|  |  |  |       filtered_results()[, ..columns][ | 
					
						
							|  |  |  |         , | 
					
						
							|  |  |  |         distance := paste0( | 
					
						
							|  |  |  |           format( | 
					
						
							|  |  |  |             round(distance / 1000000, digits = 2), | 
					
						
							|  |  |  |             nsmall = 2, | 
					
						
							|  |  |  |           ), | 
					
						
							|  |  |  |           " Mbp" | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       ] | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:29:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     output$download <- downloadHandler( | 
					
						
							|  |  |  |       filename = "geposan_filtered_results.csv", | 
					
						
							| 
									
										
										
										
											2022-08-18 09:54:59 +02:00
										 |  |  |       content = \(file) fwrite(filtered_results()[, ..columns], file = file), | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |       contentType = "text/csv" | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     output$genes <- DT::renderDT({ | 
					
						
							| 
									
										
										
										
											2022-08-18 09:54:59 +02:00
										 |  |  |       data <- filtered_results()[, ..columns] | 
					
						
							|  |  |  |       data[, distance := glue::glue( | 
					
						
							|  |  |  |         "{format(round(distance / 1000000, digits = 2), nsmall = 2)} Mbp" | 
					
						
							|  |  |  |       )] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       DT::datatable( | 
					
						
							|  |  |  |         data, | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |         rownames = FALSE, | 
					
						
							|  |  |  |         colnames = column_names, | 
					
						
							|  |  |  |         options = list( | 
					
						
							| 
									
										
										
										
											2022-08-17 17:09:38 +02:00
										 |  |  |           rowCallback = js_link(), | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |           columnDefs = list(list(visible = FALSE, targets = 2)), | 
					
						
							|  |  |  |           pageLength = 25 | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-08-18 09:54:59 +02:00
										 |  |  |       ) |> | 
					
						
							|  |  |  |         DT::formatRound(c(method_ids, "score"), digits = 4) |> | 
					
						
							|  |  |  |         DT::formatPercentage("percentile", digits = 2) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  |     }) | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   }) | 
					
						
							| 
									
										
										
										
											2021-12-30 12:19:00 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2022-08-17 17:09:38 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #' Generate a JavaScript function to replace gene IDs with Ensembl gene links. | 
					
						
							|  |  |  | #' @noRd | 
					
						
							|  |  |  | js_link <- function() { | 
					
						
							|  |  |  |   DT::JS("function(row, data) { | 
					
						
							|  |  |  |     let id = data[1]; | 
					
						
							|  |  |  |     var name = data[2]; | 
					
						
							|  |  |  |     if (!name) name = 'Unknown'; | 
					
						
							|  |  |  |     let url = `https://www.ensembl.org/Homo_sapiens/Gene/Summary?g=${id}`; | 
					
						
							|  |  |  |     $('td:eq(1)', row).html(`<a href=\"${url}\" target=\"_blank\">${name}</a>`); | 
					
						
							|  |  |  |   }") | 
					
						
							|  |  |  | } |