| 
									
										
										
										
											2022-05-07 17:54:23 +02:00
										 |  |  | #' Function for creating the main user interface. | 
					
						
							|  |  |  | #' @noRd | 
					
						
							|  |  |  | ui <- function() { | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |   navbarPage( | 
					
						
							|  |  |  |     theme = bslib::bs_theme( | 
					
						
							|  |  |  |       version = 5, | 
					
						
							|  |  |  |       bootswatch = "united", | 
					
						
							|  |  |  |       primary = "#7d19bf" | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     title = "Ubigen", | 
					
						
							| 
									
										
										
										
											2022-05-30 21:27:18 +02:00
										 |  |  |     header = custom_css(), | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |     tabPanel( | 
					
						
							|  |  |  |       "Explore", | 
					
						
							|  |  |  |       sidebarLayout( | 
					
						
							|  |  |  |         sidebarPanel( | 
					
						
							|  |  |  |           width = 3, | 
					
						
							| 
									
										
										
										
											2022-05-30 21:27:18 +02:00
										 |  |  |           h3("My genes"), | 
					
						
							|  |  |  |           gene_selector_ui("custom_genes"), | 
					
						
							|  |  |  |           h3("Scoring"), | 
					
						
							| 
									
										
										
										
											2022-05-30 20:22:42 +02:00
										 |  |  |           selectInput( | 
					
						
							|  |  |  |             "cross_sample_metric", | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |             verticalLayout( | 
					
						
							| 
									
										
										
										
											2022-05-30 21:59:40 +02:00
										 |  |  |               strong("Expression across samples"), | 
					
						
							|  |  |  |               paste0( | 
					
						
							|  |  |  |                 "Proportion samples in which the gene is expressed above the ", | 
					
						
							|  |  |  |                 "selected threshold. Select a method and a weight for the ", | 
					
						
							|  |  |  |                 "final score." | 
					
						
							|  |  |  |               ) | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |             ), | 
					
						
							| 
									
										
										
										
											2022-05-30 20:22:42 +02:00
										 |  |  |             list( | 
					
						
							|  |  |  |               "Above 95th percentile" = "above_95", | 
					
						
							|  |  |  |               "Above median" = "above_median", | 
					
						
							|  |  |  |               "Above zero" = "above_zero" | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |           ), | 
					
						
							|  |  |  |           sliderInput( | 
					
						
							| 
									
										
										
										
											2022-05-30 20:22:42 +02:00
										 |  |  |             "cross_sample_weight", | 
					
						
							|  |  |  |             label = NULL, | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |             min = -1.0, | 
					
						
							|  |  |  |             max = 1.0, | 
					
						
							|  |  |  |             step = 0.01, | 
					
						
							| 
									
										
										
										
											2022-05-30 20:25:50 +02:00
										 |  |  |             value = 0.5 | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |           ), | 
					
						
							| 
									
										
										
										
											2022-06-06 15:56:34 +02:00
										 |  |  |           sliderInput( | 
					
						
							|  |  |  |             "mean_expression", | 
					
						
							|  |  |  |             verticalLayout( | 
					
						
							|  |  |  |               strong("Mean Expression"), | 
					
						
							|  |  |  |               "Mean expression of the gene across all samples." | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             min = -1.0, | 
					
						
							|  |  |  |             max = 1.0, | 
					
						
							|  |  |  |             step = 0.01, | 
					
						
							|  |  |  |             value = 0.25 | 
					
						
							|  |  |  |           ), | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |           sliderInput( | 
					
						
							|  |  |  |             "sd_expression", | 
					
						
							|  |  |  |             verticalLayout( | 
					
						
							|  |  |  |               strong("Standard deviation"), | 
					
						
							| 
									
										
										
										
											2022-05-30 20:25:50 +02:00
										 |  |  |               "Standard deviation of the gene's expression across all samples." | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |             ), | 
					
						
							|  |  |  |             min = -1.0, | 
					
						
							|  |  |  |             max = 1.0, | 
					
						
							|  |  |  |             step = 0.01, | 
					
						
							| 
									
										
										
										
											2022-06-06 15:56:34 +02:00
										 |  |  |             value = -0.25 | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |           ) | 
					
						
							| 
									
										
										
										
											2022-05-07 17:54:23 +02:00
										 |  |  |         ), | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |         mainPanel( | 
					
						
							|  |  |  |           width = 9, | 
					
						
							| 
									
										
										
										
											2022-05-30 20:08:54 +02:00
										 |  |  |           plotly::plotlyOutput("overview_plot", height = "200px"), | 
					
						
							| 
									
										
										
										
											2022-05-30 21:59:40 +02:00
										 |  |  |           tabsetPanel( | 
					
						
							| 
									
										
										
										
											2022-06-02 09:14:34 +02:00
										 |  |  |             id = "results_panel", | 
					
						
							|  |  |  |             selected = "top_genes", | 
					
						
							|  |  |  |             header = div(class = "p-2"), | 
					
						
							|  |  |  |             tabPanel( | 
					
						
							|  |  |  |               "Your genes", | 
					
						
							|  |  |  |               value = "custom_genes", | 
					
						
							| 
									
										
										
										
											2022-05-30 21:59:40 +02:00
										 |  |  |               htmlOutput("custom_genes_synopsis"), | 
					
						
							| 
									
										
										
										
											2022-06-22 12:39:26 +02:00
										 |  |  |               plotly::plotlyOutput("custom_genes_boxplot"), | 
					
						
							|  |  |  |               div(class = "p-1"), | 
					
						
							|  |  |  |               DT::dataTableOutput("custom_genes_details") | 
					
						
							| 
									
										
										
										
											2022-06-02 09:14:34 +02:00
										 |  |  |             ), | 
					
						
							|  |  |  |             tabPanel( | 
					
						
							|  |  |  |               "Top genes", | 
					
						
							|  |  |  |               value = "top_genes", | 
					
						
							|  |  |  |               div(paste0( | 
					
						
							|  |  |  |                 "Hover over the markers to see details on each gene. Click or ", | 
					
						
							|  |  |  |                 "drag within the figure to select genes of interest." | 
					
						
							|  |  |  |               )), | 
					
						
							|  |  |  |               plotly::plotlyOutput("scores_plot"), | 
					
						
							|  |  |  |               div(paste0( | 
					
						
							| 
									
										
										
										
											2022-06-02 09:23:01 +02:00
										 |  |  |                 "Click on gene names to view them using the GTEx website. ", | 
					
						
							|  |  |  |                 "There, you can see the tissue specific expression behavior ", | 
					
						
							|  |  |  |                 "derived from the samples that this analysis is also based on." | 
					
						
							| 
									
										
										
										
											2022-06-02 09:14:34 +02:00
										 |  |  |               )), | 
					
						
							|  |  |  |               div(class = "p-1"), | 
					
						
							|  |  |  |               DT::dataTableOutput("selected_genes") | 
					
						
							| 
									
										
										
										
											2022-06-02 10:17:49 +02:00
										 |  |  |             ), | 
					
						
							|  |  |  |             tabPanel( | 
					
						
							|  |  |  |               "GSEA", | 
					
						
							|  |  |  |               value = "gsea", | 
					
						
							|  |  |  |               div( | 
					
						
							|  |  |  |                 class = "flow-layout", | 
					
						
							|  |  |  |                 selectInput( | 
					
						
							|  |  |  |                   "gsea_set", | 
					
						
							|  |  |  |                   label = NULL, | 
					
						
							|  |  |  |                   list( | 
					
						
							|  |  |  |                     "Top genes" = "top", | 
					
						
							|  |  |  |                     "Selected genes" = "selected", | 
					
						
							|  |  |  |                     "Your genes" = "custom" | 
					
						
							|  |  |  |                   ) | 
					
						
							|  |  |  |                 ), | 
					
						
							|  |  |  |                 conditionalPanel( | 
					
						
							|  |  |  |                   "input.gsea_set == 'top'", | 
					
						
							|  |  |  |                   sliderInput( | 
					
						
							|  |  |  |                     "gsea_ranks", | 
					
						
							|  |  |  |                     label = NULL, | 
					
						
							|  |  |  |                     min = 10, | 
					
						
							|  |  |  |                     max = 1000, | 
					
						
							|  |  |  |                     value = 100, | 
					
						
							|  |  |  |                     step = 10, | 
					
						
							|  |  |  |                     ticks = FALSE | 
					
						
							|  |  |  |                   ) | 
					
						
							|  |  |  |                 ), | 
					
						
							|  |  |  |                 actionButton( | 
					
						
							|  |  |  |                   "gsea_run", | 
					
						
							|  |  |  |                   "Update analysis", | 
					
						
							|  |  |  |                   class = "btn-primary" | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |               ), | 
					
						
							|  |  |  |               plotly::plotlyOutput("gsea_plot"), | 
					
						
							|  |  |  |               div(class = "p-2"), | 
					
						
							|  |  |  |               DT::dataTableOutput("gsea_details") | 
					
						
							| 
									
										
										
										
											2022-05-30 21:59:40 +02:00
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-06-02 09:14:34 +02:00
										 |  |  |           ) | 
					
						
							| 
									
										
										
										
											2022-05-07 17:54:23 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |       ) | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     tabPanel( | 
					
						
							|  |  |  |       title = "Help" | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     tabPanel( | 
					
						
							|  |  |  |       title = "Publication" | 
					
						
							| 
									
										
										
										
											2022-05-07 17:54:23 +02:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2022-05-30 19:32:19 +02:00
										 |  |  |   ) | 
					
						
							| 
									
										
										
										
											2022-05-07 17:54:23 +02:00
										 |  |  | } |