| 
									
										
										
										
											2021-10-20 15:34:52 +02:00
										 |  |  | #' Run the application server. | 
					
						
							|  |  |  | #' | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  | #' @param reference_gene_sets A list of predefined gene sets to be used as | 
					
						
							|  |  |  | #'   reference genes. This should be a named list containing vectors of gene IDs | 
					
						
							|  |  |  | #'   for each set. You have to provide *at least one gene set* which will be | 
					
						
							|  |  |  | #'   selected as the initial reference gene set. | 
					
						
							| 
									
										
										
										
											2022-05-19 16:24:23 +02:00
										 |  |  | #' @param species_sets A list of predefined species sets. This should be a named | 
					
						
							|  |  |  | #'   list containing vectors of species IDs for each set. The names will be used | 
					
						
							|  |  |  | #'   to present the species set throughout the user interface. | 
					
						
							| 
									
										
										
										
											2022-08-18 09:21:48 +02:00
										 |  |  | #' @param methods A list of [`geposan::method`] objects to be used for all | 
					
						
							|  |  |  | #'   presets. By default, all available methods will be used. | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  | #' @param comparison_gene_sets A named list of predefined gene sets to be used | 
					
						
							|  |  |  | #'   as comparison genes. | 
					
						
							| 
									
										
										
										
											2022-05-19 16:24:23 +02:00
										 |  |  | #' @param locked Whether the application should be locked and prohibit | 
					
						
							|  |  |  | #'   performing custom analyses. If this is set to `TRUE`, only the predefined | 
					
						
							|  |  |  | #'   gene and species sets are available for customizing the analysis. This may | 
					
						
							|  |  |  | #'   be useful to limit resource usage on a publicly available instance. | 
					
						
							| 
									
										
										
										
											2022-05-19 16:28:59 +02:00
										 |  |  | #' @param title Set the title of the application. | 
					
						
							| 
									
										
										
										
											2021-10-20 15:34:52 +02:00
										 |  |  | #' @param port The port to serve the application on. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @export | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  | run_app <- function(reference_gene_sets, | 
					
						
							| 
									
										
										
										
											2022-05-19 16:24:23 +02:00
										 |  |  |                     species_sets = NULL, | 
					
						
							| 
									
										
										
										
											2022-08-18 09:21:48 +02:00
										 |  |  |                     methods = geposan::all_methods(), | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  |                     comparison_gene_sets = NULL, | 
					
						
							| 
									
										
										
										
											2022-05-19 16:24:23 +02:00
										 |  |  |                     locked = FALSE, | 
					
						
							| 
									
										
										
										
											2022-05-19 16:28:59 +02:00
										 |  |  |                     title = "Gene Position Analysis", | 
					
						
							| 
									
										
										
										
											2022-05-19 16:24:23 +02:00
										 |  |  |                     port = 3464) { | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  |   stopifnot(!is.null(reference_gene_sets) & !is.null(reference_gene_sets[[1]])) | 
					
						
							| 
									
										
										
										
											2021-10-21 15:57:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   # These function calls make the required java scripts available. | 
					
						
							|  |  |  |   shinyjs::useShinyjs() | 
					
						
							|  |  |  |   rclipboard::rclipboardSetup() | 
					
						
							| 
									
										
										
										
											2021-10-21 15:57:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   # Bundle of global options to redue broilerplate. | 
					
						
							|  |  |  |   options <- list( | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  |     reference_gene_sets = reference_gene_sets, | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     species_sets = species_sets, | 
					
						
							| 
									
										
										
										
											2022-08-18 09:21:48 +02:00
										 |  |  |     methods = methods, | 
					
						
							| 
									
										
										
										
											2022-08-18 09:02:53 +02:00
										 |  |  |     comparison_gene_sets = comparison_gene_sets, | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |     locked = locked, | 
					
						
							|  |  |  |     title = title | 
					
						
							|  |  |  |   ) | 
					
						
							| 
									
										
										
										
											2021-10-21 15:57:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-26 12:44:09 +02:00
										 |  |  |   # Actually run the app. | 
					
						
							|  |  |  |   shiny::runApp( | 
					
						
							|  |  |  |     shiny::shinyApp(ui(options), server(options)), | 
					
						
							|  |  |  |     port = port | 
					
						
							|  |  |  |   ) | 
					
						
							| 
									
										
										
										
											2021-10-20 15:34:52 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2022-08-17 17:09:38 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #' Generate the main UI for the application. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @param options Global options for the application. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @noRd | 
					
						
							|  |  |  | ui <- function(options) { | 
					
						
							|  |  |  |   div( | 
					
						
							|  |  |  |     custom_css(), | 
					
						
							|  |  |  |     shinyjs::useShinyjs(), | 
					
						
							|  |  |  |     rclipboard::rclipboardSetup(), | 
					
						
							|  |  |  |     navbarPage( | 
					
						
							|  |  |  |       id = "main_page", | 
					
						
							|  |  |  |       theme = bslib::bs_theme( | 
					
						
							|  |  |  |         version = 5, | 
					
						
							|  |  |  |         bootswatch = "united", | 
					
						
							|  |  |  |         primary = "#1964bf" | 
					
						
							|  |  |  |       ), | 
					
						
							|  |  |  |       title = options$title, | 
					
						
							|  |  |  |       selected = "Results", | 
					
						
							|  |  |  |       tabPanel( | 
					
						
							|  |  |  |         "Input data", | 
					
						
							|  |  |  |         input_page_ui("input_page", options) | 
					
						
							|  |  |  |       ), | 
					
						
							|  |  |  |       tabPanel( | 
					
						
							|  |  |  |         "Results", | 
					
						
							|  |  |  |         results_ui("results", options) | 
					
						
							| 
									
										
										
										
											2024-02-18 18:03:55 +01:00
										 |  |  |       ), | 
					
						
							|  |  |  |       tabPanel( | 
					
						
							|  |  |  |         "Help", | 
					
						
							|  |  |  |         div( | 
					
						
							|  |  |  |           class = "container", | 
					
						
							|  |  |  |           htmltools::includeMarkdown( | 
					
						
							|  |  |  |             system.file("content", "manual.md", package = "geposanui") | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-08-17 17:09:38 +02:00
										 |  |  |       ) | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #' Create a server function for the application. | 
					
						
							|  |  |  | #' | 
					
						
							|  |  |  | #' @param options Global application options. | 
					
						
							|  |  |  | #' @noRd | 
					
						
							|  |  |  | server <- function(options) { | 
					
						
							|  |  |  |   function(input, output, session) { | 
					
						
							|  |  |  |     preset <- input_page_server("input_page", options) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     observe({ | 
					
						
							|  |  |  |       updateNavbarPage( | 
					
						
							|  |  |  |         session, | 
					
						
							|  |  |  |         "main_page", | 
					
						
							|  |  |  |         selected = "Results" | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     }) |> bindEvent(preset(), ignoreInit = TRUE) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Compute the results according to the preset. | 
					
						
							|  |  |  |     analysis <- reactive({ | 
					
						
							|  |  |  |       withProgress( | 
					
						
							|  |  |  |         message = "Analyzing genes", | 
					
						
							|  |  |  |         value = 0.0, | 
					
						
							|  |  |  |         { # nolint | 
					
						
							|  |  |  |           geposan::analyze( | 
					
						
							|  |  |  |             preset(), | 
					
						
							|  |  |  |             progress = function(progress) { | 
					
						
							|  |  |  |               setProgress(progress) | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             include_results = FALSE | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     }) |> bindCache(preset()) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results_server("results", options, analysis) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |