mirror of
				https://github.com/johrpan/ubigen.git
				synced 2025-10-26 19:57:24 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			336 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			R
		
	
	
	
	
	
			
		
		
	
	
			336 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			R
		
	
	
	
	
	
| #' Function for creating the main user interface.
 | |
| #' @noRd
 | |
| ui <- function(custom_dataset = NULL, show_api_docs = FALSE) {
 | |
|   title <- "Ubigen"
 | |
|   commit_text <- ""
 | |
| 
 | |
|   commit_file <- system.file("misc", "commit.txt", package = "ubigen")
 | |
|   if (file.exists(commit_file)) {
 | |
|     title <- "Ubigen (Staging)"
 | |
|     long_hash <- readLines(commit_file, warn = FALSE)[1]
 | |
|     short_hash <- substr(long_hash, 1, 7)
 | |
|     commit_text <- glue::glue(
 | |
|       ", commit <a href=\"https://gitlab.uni-rostock.de/ep135/ubigen/-/commit/",
 | |
|       "{long_hash}\" target=\"_blank\"><code>{short_hash}</code></a>"
 | |
|     )
 | |
|   }
 | |
| 
 | |
|   div(
 | |
|     custom_css(),
 | |
|     rclipboard::rclipboardSetup(),
 | |
|     navbarPage(
 | |
|       theme = bslib::bs_theme(
 | |
|         version = 5,
 | |
|         bootswatch = "united",
 | |
|         primary = "#7d19bf"
 | |
|       ),
 | |
|       title = title,
 | |
|       tabPanel(
 | |
|         "Explore",
 | |
|         sidebarLayout(
 | |
|           sidebarPanel(
 | |
|             width = 3,
 | |
|             h5("Your genes"),
 | |
|             gene_selector_ui("custom_genes"),
 | |
|             h5("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",
 | |
|                   "CMap" = "cmap"
 | |
|                 )
 | |
| 
 | |
|                 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
 | |
|             ),
 | |
|             div(
 | |
|               class = "footer",
 | |
|               HTML(glue::glue(
 | |
|                 "Ubigen version {packageVersion(\"ubigen\")}{commit_text}<br>",
 | |
|                 "Source code: ",
 | |
|                 "<a href=\"https://gitlab.uni-rostock.de/ep135/ubigen/\" ",
 | |
|                 "target=\"blank\">available online</a> (GNU AGPL v3)<br>",
 | |
|                 "Citation: Manuscript in preparation"
 | |
|               ))
 | |
|             )
 | |
|           ),
 | |
|           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. ",
 | |
|                   "Double-click removes the selection."
 | |
|                 )),
 | |
|                 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_top_genes")
 | |
|               ),
 | |
|               tabPanel(
 | |
|                 "Compare rankings",
 | |
|                 value = "rankings",
 | |
|                 div(
 | |
|                   class = "flow-layout",
 | |
|                   selectInput(
 | |
|                     "ranking_y",
 | |
|                     label = NULL,
 | |
|                     list(
 | |
|                       "Custom" = "custom",
 | |
|                       "GTEx (across tissues and conditions)" = "gtex_all",
 | |
|                       "GTEx (across tissues)" = "gtex_tissues",
 | |
|                       "Human Protein Atlas (across tissues)" = "hpa_tissues",
 | |
|                       "CMap" = "cmap"
 | |
|                     ),
 | |
|                     selected = "cmap"
 | |
|                   ),
 | |
|                   span(
 | |
|                     style = paste0(
 | |
|                       "display: inline-block;",
 | |
|                       "margin-right: 12px;",
 | |
|                       "padding: 0.375rem 0.75rem;"
 | |
|                     ),
 | |
|                     "~"
 | |
|                   ),
 | |
|                   selectInput(
 | |
|                     "ranking_x",
 | |
|                     label = NULL,
 | |
|                     list(
 | |
|                       "Custom" = "custom",
 | |
|                       "GTEx (across tissues and conditions)" = "gtex_all",
 | |
|                       "GTEx (across tissues)" = "gtex_tissues",
 | |
|                       "Human Protein Atlas (across tissues)" = "hpa_tissues",
 | |
|                       "CMap" = "cmap"
 | |
|                     )
 | |
|                   ),
 | |
|                   selectInput(
 | |
|                     "rankings_comparison_mode",
 | |
|                     label = NULL,
 | |
|                     list(
 | |
|                       "Compare scores" = "scores",
 | |
|                       "Compare percentiles" = "percentiles"
 | |
|                     )
 | |
|                   )
 | |
|                 ),
 | |
|                 div(class = "p-1"),
 | |
|                 div(paste0(
 | |
|                   "Hover over the markers to see the HGNC symbols for the ",
 | |
|                   "genes. Click or draw within the figure to select genes of ",
 | |
|                   "interest. Double-click removes the selection."
 | |
|                 )),
 | |
|                 div(class = "p-1"),
 | |
|                 plotly::plotlyOutput(
 | |
|                   "rankings_plot",
 | |
|                   width = "800px",
 | |
|                   height = "800px"
 | |
|                 ),
 | |
|                 div(class = "p-1"),
 | |
|                 genes_table_ui("selected_comparison_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("Drug effects"),
 | |
|           p(HTML(paste0(
 | |
|             "Scores for drugs based on the genes that are significantly ",
 | |
|             "influenced by them. To compute a score for each drug, the scores ",
 | |
|             "of all influenced genes based on “GTEx (all)” (X-axis) and ",
 | |
|             "“CMap” (Y-axis) are averaged with weights based on the fold ",
 | |
|             "change of the interactions. The position of each drug in this ",
 | |
|             "plot is therefore a result of how ubiquitous the genes that it ",
 | |
|             "influences are."
 | |
|           ))),
 | |
|           p(HTML(paste0(
 | |
|             "Note: Hover over the markers to see drug names."
 | |
|           ))),
 | |
|           plotly::plotlyOutput("fig_drug_scores", height = "1200px"),
 | |
|           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 = "Help",
 | |
|         div(
 | |
|           class = "container",
 | |
|           includeMarkdown(system.file("content", "help.md", package = "ubigen"))
 | |
|         )
 | |
|       ),
 | |
|       if (show_api_docs) {
 | |
|         tabPanel(
 | |
|           title = "API access",
 | |
|           div(
 | |
|             class = "container",
 | |
|             includeMarkdown(
 | |
|               system.file("content", "api.md", package = "ubigen")
 | |
|             )
 | |
|           )
 | |
|         )
 | |
|       }
 | |
|     )
 | |
|   )
 | |
| }
 |