| 
									
										
										
										
											2022-08-18 10:00:05 +02:00
										 |  |  | #' Create a GSEA page. | 
					
						
							|  |  |  | #' @noRd | 
					
						
							|  |  |  | gsea_ui <- function(id) { | 
					
						
							|  |  |  |   verticalLayout( | 
					
						
							| 
									
										
										
										
											2022-08-18 11:09:22 +02:00
										 |  |  |     filters_ui(NS(id, "filters")), | 
					
						
							| 
									
										
										
										
											2022-08-22 15:48:25 +02:00
										 |  |  |     div( | 
					
						
							|  |  |  |       class = "flow-layout", | 
					
						
							|  |  |  |       actionButton( | 
					
						
							|  |  |  |         NS(id, "gsea_run"), | 
					
						
							|  |  |  |         "Update analysis", | 
					
						
							|  |  |  |         class = "btn-primary" | 
					
						
							|  |  |  |       ), | 
					
						
							|  |  |  |       a( | 
					
						
							|  |  |  |         "Powered by g:Profiler", | 
					
						
							|  |  |  |         href = "https://biit.cs.ut.ee/gprofiler/gost", | 
					
						
							|  |  |  |         target = "_blank", | 
					
						
							|  |  |  |         style = "margin-left: 16px" | 
					
						
							|  |  |  |       ) | 
					
						
							| 
									
										
										
										
											2022-08-18 11:09:22 +02:00
										 |  |  |     ), | 
					
						
							| 
									
										
										
										
											2022-08-18 10:00:05 +02:00
										 |  |  |     div( | 
					
						
							|  |  |  |       style = "margin-top: 16px", | 
					
						
							|  |  |  |       plotly::plotlyOutput(NS(id, "plot")), | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     div( | 
					
						
							|  |  |  |       style = "margin-top: 16px", | 
					
						
							|  |  |  |       DT::DTOutput(NS(id, "details")) | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #' Create a server for the comparison editor. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @param id ID for namespacing the inputs and outputs. | 
					
						
							|  |  |  | #' @param ranking The ranking to be analyzed. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @noRd | 
					
						
							|  |  |  | gsea_server <- function(id, ranking) { | 
					
						
							|  |  |  |   moduleServer(id, function(input, output, session) { | 
					
						
							| 
									
										
										
										
											2022-08-18 11:09:22 +02:00
										 |  |  |     ranking_filtered <- filters_server("filters", ranking) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-18 10:00:05 +02:00
										 |  |  |     gsea_analysis <- reactive({ | 
					
						
							|  |  |  |       withProgress( | 
					
						
							|  |  |  |         message = "Querying g:Profiler", | 
					
						
							|  |  |  |         value = 0.0, | 
					
						
							|  |  |  |         { # nolint | 
					
						
							|  |  |  |           setProgress(0.2) | 
					
						
							|  |  |  |           gprofiler2::gost( | 
					
						
							| 
									
										
										
										
											2022-08-18 11:09:22 +02:00
										 |  |  |             ranking_filtered()$gene, | 
					
						
							|  |  |  |             custom_bg = ranking()$gene, | 
					
						
							| 
									
										
										
										
											2022-08-18 10:00:05 +02:00
										 |  |  |             domain_scope = "custom_annotated" | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ) | 
					
						
							| 
									
										
										
										
											2022-08-18 11:09:22 +02:00
										 |  |  |     }) |> | 
					
						
							|  |  |  |       bindCache(ranking_filtered()) |> | 
					
						
							|  |  |  |       bindEvent(input$gsea_run, ignoreNULL = FALSE) | 
					
						
							| 
									
										
										
										
											2022-08-18 10:00:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     output$plot <- plotly::renderPlotly({ | 
					
						
							|  |  |  |       gprofiler2::gostplot( | 
					
						
							|  |  |  |         gsea_analysis(), | 
					
						
							|  |  |  |         capped = FALSE, | 
					
						
							|  |  |  |         interactive = TRUE | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     output$details <- DT::renderDT({ | 
					
						
							|  |  |  |       data <- data.table(gsea_analysis()$result) | 
					
						
							|  |  |  |       setorder(data, p_value) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       data[, total_ratio := term_size / effective_domain_size] | 
					
						
							|  |  |  |       data[, query_ratio := intersection_size / query_size] | 
					
						
							|  |  |  |       data[, increase := (query_ratio - total_ratio) / total_ratio] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       data <- data[, .( | 
					
						
							|  |  |  |         source, | 
					
						
							|  |  |  |         term_name, | 
					
						
							|  |  |  |         total_ratio, | 
					
						
							|  |  |  |         query_ratio, | 
					
						
							|  |  |  |         increase, | 
					
						
							|  |  |  |         p_value | 
					
						
							|  |  |  |       )] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       DT::datatable( | 
					
						
							|  |  |  |         data, | 
					
						
							|  |  |  |         rownames = FALSE, | 
					
						
							|  |  |  |         colnames = c( | 
					
						
							|  |  |  |           "Source", | 
					
						
							|  |  |  |           "Term", | 
					
						
							|  |  |  |           "Total ratio", | 
					
						
							|  |  |  |           "Query ratio", | 
					
						
							|  |  |  |           "Increase", | 
					
						
							|  |  |  |           "p-value" | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |         options = list( | 
					
						
							|  |  |  |           pageLength = 25 | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       ) |> | 
					
						
							|  |  |  |         DT::formatRound("p_value", digits = 4) |> | 
					
						
							|  |  |  |         DT::formatPercentage( | 
					
						
							|  |  |  |           c("total_ratio", "query_ratio", "increase"), | 
					
						
							|  |  |  |           digits = 2 | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | } |