mirror of
				https://github.com/johrpan/ubigen.git
				synced 2025-10-26 19:57:24 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			225 lines
		
	
	
	
		
			7.9 KiB
		
	
	
	
		
			R
		
	
	
	
	
	
			
		
		
	
	
			225 lines
		
	
	
	
		
			7.9 KiB
		
	
	
	
		
			R
		
	
	
	
	
	
| #' Function for creating the main user interface.
 | |
| #' @noRd
 | |
| ui <- function(custom_dataset = NULL) {
 | |
|   div(
 | |
|     custom_css(),
 | |
|     rclipboard::rclipboardSetup(),
 | |
|     navbarPage(
 | |
|       theme = bslib::bs_theme(
 | |
|         version = 5,
 | |
|         bootswatch = "united",
 | |
|         primary = "#7d19bf"
 | |
|       ),
 | |
|       title = "Ubigen",
 | |
|       tabPanel(
 | |
|         "Explore",
 | |
|         sidebarLayout(
 | |
|           sidebarPanel(
 | |
|             width = 3,
 | |
|             h3("Your genes"),
 | |
|             gene_selector_ui("custom_genes"),
 | |
|             h3("Method"),
 | |
|             selectInput(
 | |
|               "dataset",
 | |
|               label = strong("Expression dataset"),
 | |
|               {
 | |
|                 choices <- list(
 | |
|                   "GTEx (across tissues and conditions)" = "gtex_all",
 | |
|                   "GTEx (across tissues)" = "gtex_tissues",
 | |
|                   "Human Protein Atlas (across tissues)" = "hpa_tissues"
 | |
|                 )
 | |
| 
 | |
|                 if (!is.null(custom_dataset)) {
 | |
|                   c(list("Custom dataset" = "custom"), choices)
 | |
|                 } else {
 | |
|                   choices
 | |
|                 }
 | |
|               }
 | |
|             ),
 | |
|             selectInput(
 | |
|               "cross_sample_metric",
 | |
|               verticalLayout(
 | |
|                 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."
 | |
|                 )
 | |
|               ),
 | |
|               list(
 | |
|                 "Above 95th percentile" = "above_95",
 | |
|                 "Above median" = "above_median",
 | |
|                 "Above zero" = "above_zero"
 | |
|               )
 | |
|             ),
 | |
|             sliderInput(
 | |
|               "cross_sample_weight",
 | |
|               label = NULL,
 | |
|               min = -1.0,
 | |
|               max = 1.0,
 | |
|               step = 0.01,
 | |
|               value = 0.5
 | |
|             ),
 | |
|             selectInput(
 | |
|               "level_metric",
 | |
|               verticalLayout(
 | |
|                 strong("Expression level"),
 | |
|                 "Typical expression level of the gene across all samples."
 | |
|               ),
 | |
|               list(
 | |
|                 "Median expression" = "median_expression_normalized",
 | |
|                 "Mean expression" = "mean_expression_normalized"
 | |
|               )
 | |
|             ),
 | |
|             sliderInput(
 | |
|               "level_weight",
 | |
|               label = NULL,
 | |
|               min = -1.0,
 | |
|               max = 1.0,
 | |
|               step = 0.01,
 | |
|               value = 0.25
 | |
|             ),
 | |
|             selectInput(
 | |
|               "variation_metric",
 | |
|               verticalLayout(
 | |
|                 strong("Expression variation"),
 | |
|                 paste0(
 | |
|                   "Measure of the variation of the gene's expression between ",
 | |
|                   "samples."
 | |
|                 )
 | |
|               ),
 | |
|               list(
 | |
|                 "Quantile based coefficient of variation" =
 | |
|                   "qcv_expression_normalized",
 | |
|                 "Interquartile range" = "iqr_expression_normalized",
 | |
|                 "Coefficient of variation" = "cv_expression_normalized",
 | |
|                 "Standard deviation" = "sd_expression_normalized"
 | |
|               )
 | |
|             ),
 | |
|             sliderInput(
 | |
|               "variation_weight",
 | |
|               label = NULL,
 | |
|               min = -1.0,
 | |
|               max = 1.0,
 | |
|               step = 0.01,
 | |
|               value = -0.25
 | |
|             )
 | |
|           ),
 | |
|           mainPanel(
 | |
|             width = 9,
 | |
|             plotly::plotlyOutput("overview_plot", height = "200px"),
 | |
|             tabsetPanel(
 | |
|               id = "results_panel",
 | |
|               selected = "top_genes",
 | |
|               header = div(class = "p-2"),
 | |
|               tabPanel(
 | |
|                 "Your genes",
 | |
|                 value = "custom_genes",
 | |
|                 htmlOutput("custom_genes_synopsis"),
 | |
|                 plotly::plotlyOutput("custom_genes_boxplot"),
 | |
|                 div(class = "p-1"),
 | |
|                 genes_table_ui("custom_genes")
 | |
|               ),
 | |
|               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(class = "p-1"),
 | |
|                 div(paste0(
 | |
|                   "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."
 | |
|                 )),
 | |
|                 div(class = "p-1"),
 | |
|                 genes_table_ui("selected_genes")
 | |
|               ),
 | |
|               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"
 | |
|                   ),
 | |
|                   a(
 | |
|                     "Powered by g:Profiler",
 | |
|                     href = "https://biit.cs.ut.ee/gprofiler/gost",
 | |
|                     target = "_blank",
 | |
|                     style = "margin-left: 16px"
 | |
|                   )
 | |
|                 ),
 | |
|                 plotly::plotlyOutput("gsea_plot"),
 | |
|                 div(class = "p-2"),
 | |
|                 DT::dataTableOutput("gsea_details")
 | |
|               )
 | |
|             )
 | |
|           )
 | |
|         )
 | |
|       ),
 | |
|       tabPanel(
 | |
|         title = "Additional information",
 | |
|         div(
 | |
|           class = "container",
 | |
|           h2("Number of interesting genes along the ranking"),
 | |
|           p(HTML(paste0(
 | |
|             "The notion of ubiquitous genes or housekeeping genes implies ",
 | |
|             "some kind of enrichment of important genes. Within groups of ",
 | |
|             "genes with certain biological associations, these genes should ",
 | |
|             "be overrepresented. We use GeneOntology terms as well as some ",
 | |
|             "other gene set sources to represent this concept. The following ",
 | |
|             "plot shows the number of associated terms for a non-overlapping ",
 | |
|             "sliding window of 500 genes along the ranking of ubiquity using ",
 | |
|             "our default parameters. The terms have been obtained using a ",
 | |
|             "gene set enrichment analysis with the tool ",
 | |
|             "<a href=\"https://biit.cs.ut.ee/gprofiler/gost\" ",
 | |
|             "target=\"_blank\">g:Profiler</a>. We observe that the most ",
 | |
|             "ubiquitous genes have many more known biological implications ",
 | |
|             "than any other bucket of genes. The genes of average ubiquity ",
 | |
|             "have almost no associations with GeneOntology terms. The number ",
 | |
|             "of associations rises again for the least ubiquitous genes."
 | |
|           ))),
 | |
|           p(HTML(paste0(
 | |
|             "Note: Click on the legend items to toggle single sources. A ",
 | |
|             "double-click will isolate a single source of interest."
 | |
|           ))),
 | |
|           plotly::plotlyOutput("gsea_plot_ranking", height = "600px")
 | |
|         )
 | |
|       ),
 | |
|       tabPanel(
 | |
|         title = "API access",
 | |
|         div(
 | |
|           class = "container",
 | |
|           includeMarkdown(system.file("content", "api.md", package = "ubigen"))
 | |
|         )
 | |
|       )
 | |
|     )
 | |
|   )
 | |
| }
 |