R/ui.R

Defines functions ui_crispr_app

ui_crispr_app <- function(request){
  
  # get modes and themes for the ace editor
  modes <- shinyAce::getAceModes()
  themes <- shinyAce::getAceThemes()
  
  tagList(dashboardPage(skin = "green",
    dashboardHeader(title = "Cookie CRISPR"#,
    ),  # End of Header
    dashboardSidebar(
      sidebarUserPanel("Institut Curie",
                       subtitle = "Bioinformatic Platform",
                       #image = "https://upload.wikimedia.org/wikipedia/commons/7/77/Logo_Institut_Curie.jpg"
                       image = ""
      ),
      sidebarMenu(id ="sidebarmenu",
        menuItem("Data Input", tabName = "DataInput"),
        menuItem("Descriptive analysis", tabName = "Descriptive_data_analysis",
                 menuSubItem("Raw distributions","Rawdist"),
                 menuSubItem("Temporal evolution","Tev"),
                 menuSubItem("ROC Curves","Roc")#,
                 #menuSubItem("Clustering","Clustering"),
                 #menuSubItem('Compare conditions','CompCond')
                 ),
        menuItem("Statistical analysis",tabName = "Statistical_analysis"),
        menuItem("Clustering", tabName = "Clustering"),
        menuItem("Report", tabName = "Report")
      )
    ),
    dashboardBody(
      tags$head(
        tags$style(
          HTML(".shiny-notification {
              height: 100px;
              width: 800px;
              position:fixed;
              opacity:0.91;
              top: calc(50% - 50px);;
              left: calc(50% - 400px);;
            }
           "
          )
        )),
      fluidPage(
        use_cicerone(),
      tabItems(
        tabItem(tabName = "DataInput",
                useShinyjs(),
                #useShinyalert(),
                infoBoxOutput("Totguidenumber",width = 6),
                valueBoxOutput("Depth",width = 6),
                br(),
                fluidRow(
                    box(title = p('Inputs',actionButton("startCicerone0",label=NULL,icon = icon("info-circle")),
                                  actionButton("exampledatasetbut",label=NULL,icon = icon("teeth"))),
                    width = 12,
                    status = "success",solidHeader = TRUE,
                    #title="Inputs",
                        tabsetPanel(type = "tabs",
                                tabPanel("Uploads",
                                         #fluidPage(
                                         #fluidRow(
                                           column(width=6,div(id = "sample_plandiv",fileInput("sample_plan","Sample infos"))),
                                           column(width=6,
                                                  div(id = "orderUIdiv",uiOutput("orderUI"))),
                                           fluidRow(),
                                           #div(id = 'genelistdiv',
                                               column(width=6,
                                                      div(id = "essentialdiv",fileInput("essential","Essential genes"))),
                                               column(width=6,
                                                      div(id = "nonessentialdiv",fileInput("nonessential","Other genes"))),
                                               #),
                                           #fluidRow(
                                          column(width = 6,
                                                 div(id = "countsdiv",fileInput("counts","Global counts"))),
                                          column(width = 6,
                                                 radioButtons("screentype","Screening type :", choices = c("negative","positive"),
                                                              selected = "negative")),
                                           # column(width = 12,fileInput(inputId = "restore", accept = ".rda", label = "Restore Previous analysis",
                                           #                            buttonLabel=list(icon("angle-double-up"))))
                                           ),
                                tabPanel("Help",
                                         uiOutput("Datahelptext"),
                                         fluidRow(
                                           column(width = 4,
                                                  downloadButton("DlTestSplan","DL sample plan example",style = "width:100%;"),#, class = "butt"),
                                                  tags$head(tags$style(".butt{background-color:#add8e6;} .butt{color: #337ab7;}"))
                                                  ),
                                           column(width = 4,downloadButton("DlTestCounts","DL counts matrix example",style = "width:100%;")),#, class = "butt")),
                                           column(width = 4,downloadButton("DlTesGuideList","DL Genes list example",style = "width:100%;"))#, class = "butt"))
                                           )#,
                                         #downloadButton("state_save_sc","Save State as .rda",style = "visibility: hidden;"),
                                         #downloadButton("exit_and_save","Save State as .rda",style = "visibility: hidden;")
                                )
                    )# end of tabset
                    
                    )# end of box
                    #) # end of div
                    ), 
                fluidRow(
                  box(
                    width = 12, status = "success", solidHeader = TRUE, collapsible = TRUE,collapsed = FALSE,
                    title = "Counts table", id ='countstablebox',
                    column(width = 12,
                           div(id = "removegenesdiv",pickerInput("removegenes", "Remove genes for further analysis",
                                       choices = NULL,
                                       selected = NULL,
                                       multiple = TRUE,
                                       choicesOpt = NULL,
                                       inline = FALSE,
                                       options = pickerOptions(
                                         actionsBox = TRUE,
                                         title = "Select genes you want to remove",
                                         liveSearch = TRUE,
                                         liveSearchStyle = "contains"
                                       )))),
                    tabsetPanel(id="countstabset",
                      tabPanel("Rawcounts",br(),DT::dataTableOutput("counts_table")),
                      tabPanel("log10(cpm)",br(),DT::dataTableOutput("normalized_counts_table"))
                    )
                  )),
                fluidRow(
                  box(
                    width = 12, status = "success", solideHeader = TRUE, collapsed = FALSE,collapsible = TRUE,
                    title = "Sample plan", id = "sampleplanbox",
                    column(width = 12,
                           div(id = "removesamplesdiv",pickerInput("removesamples", "Remove samples for further analysis",
                                choices = NULL,
                                selected = NULL,
                                multiple = TRUE,
                                choicesOpt = NULL,
                                inline = FALSE,
                                options = pickerOptions(
                                  actionsBox = TRUE,
                                  title = "Select samples you want to remove",
                                  liveSearch = TRUE,
                                  liveSearchStyle = "contains"
                                )))),
                    column(width = 12,div(style = 'overflow-x: scroll',DT::dataTableOutput("sample_plan_table"))),
                  ),
                  column(width = 12,
                         div(id = 'correlationsAnnotdiv',pickerInput(inputId = "correlationsAnnot","Choose variables to construct annotations",width = '100%',
                                     choices = NULL,
                                     selected = NULL,
                                     multiple = TRUE,
                                     choicesOpt = NULL,
                                     inline = FALSE,
                                     options = pickerOptions(
                                       actionsBox = TRUE,
                                       title = "Select multiple conditions here",
                                       liveSearch = TRUE,
                                       liveSearchStyle = "contains",
                                     ))),
                         plotOutput("correlation_heatmap")),
                  br(),br(),
                  column(width = 6,
                         br(),
                         downloadButton("dlcorrelation_heatmap","Download correlations heatmaps",
                                        style = "width:100%;")),
                  column(width = 6,
                         br(),
                         downloadButton("dlcorrelation_coefficients","Download correlations coefficients",style = "width:100%;")),
                )),
        tabItem(tabName = "Rawdist",
                fluidRow(
                  box(collapsible = TRUE, collapsed = FALSE,
                      width = 12,status = "success",solidHeader = TRUE,
                      title="Read counts",
                      column(width=12,
                             plotOutput("read_number"),
                             downloadButton("dlreadnumber","Download read numbers plot",style = "width:100%;"),
                             br(),br()
                      ))),
                fluidRow(
                   box(collapsible = TRUE, collapsed = FALSE,
                       width = 12, status = "success", solidHeader = TRUE,
                       title = "Normalized log_cpm distributions",
                       column(width = 12,
                       plotOutput("boxplot_all", width = "100%", height = 600),
                       ),
                       column(width = 6,plotOutput("boxplot_noness"),
                              ),
                       column(width = 6,plotOutput("boxplot_ess"),
                              ),
                       br(),
                       column(width = 12,downloadButton("dlbox_all","Download Boxplots ",style = "width:100%;"),br(),br()),
                       # br()
                )),
                fluidRow(
                  box(collapsible = TRUE, collapsed = FALSE,
                      width = 12, status = "success", solidHeader = TRUE,
                      title = "Counts distributions for essential and non essential gene",
                      column(width=6,plotOutput("essential_distribs", width = "100%", height = 600)),
                      column(width=6,plotOutput("nonessential_distribs", width = "100%", height = 600)),
                      downloadButton("splited_distribs","Download distributions per gene categories",style = "width:100%;"),br(),br()
                  ))
        ),
        tabItem("Tev",
                fluidRow(
                      column(width=6,plotOutput("diff_box_all", width = "100%", height = 600),br()),
                      column(width=6,plotOutput("diff_box_ess", width = "100%", height = 600),br()),
                      downloadButton("dldiffboxes","Download difference to zero boxes",style = "width:100%;"),
                      br()
                )
            ),
            tabItem("Roc",
                    fluidRow(
                      column(width = 12,
                         checkboxInput("labels","Print AUC labels on plots",value = FALSE),
                         div(style = 'overflow-x: scroll',plotOutput("roc")),
                         br(),
                         downloadButton("dlROC","Download ROC plots",style = "width:100%;"),#class = "butt"
                         br(),br(),
                         DT::dataTableOutput('auc'),
                         br(),
                         downloadButton("dlauc","Download AUCs table",style = "width:100%;")#, class = "butt"
                  )
                )
            ),
            tabItem("Clustering",
                  fluidRow(
                    column(width = 12,infoBoxOutput("InfoCompHeatmap", width = 12)),
                    br(),
                      column(width = 12,ClusteringUIMod(id = "heatmapID"))
                  )
        ),
        tabItem("CompCond",
                fluidRow(
                column(width=8,pickerInput(inputId = "conditionreference1","Choose conditions to compare",width = '100%',
                                                     choices = NULL,
                                                     selected = NULL,
                                                     multiple = TRUE,
                                                     choicesOpt = NULL,
                                                     inline = FALSE,
                                                     options = pickerOptions(
                                                       actionsBox = TRUE,
                                                       title = "Select multiple conditions here",
                                                       liveSearch = TRUE,
                                                       liveSearchStyle = "contains",
                                                     ))),
                column(width=4,checkboxInput("splitcelline","Split boxplots by cell line ?"))),
                fluidRow(
                  column(width=8,
                         pickerInput(inputId = "selectguidescomp","Annotate guide on boxplots",width = '100%',
                                                    choices = NULL,
                                                    selected = NULL,
                                                    multiple = FALSE,
                                                    choicesOpt = NULL,
                                                    inline = FALSE,
                                                    options = pickerOptions(
                                                      actionsBox = TRUE,
                                                      title = "Select guides here",
                                                      liveSearch = TRUE,
                                                      liveSearchStyle = "contains",
                                                    ))),
                                column(width=4,pickerInput(inputId = "selecttimepointscomp","Remove timepoints from boxplots data",width = '100%',
                                                            choices = NULL,
                                                            selected = NULL,
                                                            multiple = TRUE,
                                                            choicesOpt = NULL,
                                                            inline = FALSE,
                                                            options = pickerOptions(
                                                              actionsBox = TRUE,
                                                              title = "Select timepoints conditions here",
                                                              liveSearch = TRUE,
                                                              liveSearchStyle = "contains",
                                                            )))),# end of fluidRow
                br(),
                fluidRow(column(width =12,girafeOutput("positive_boxplots", width = "90%", height = "90%")))
        ),
        tabItem(tabName = "Statistical_analysis",
                CRISPRDeaModUI(id = "DEA")),
        tabItem(tabName = "Report",
                          h2("About this report"),
                          h4("This content has been loaded from the template report `.Rmd` file. Please edit it at your best convenience!"),
                          h4("Some <!–html_preserve–> text may appear on this preview. Do not worry it will disappear when generating and saving the report."),            icon = icon("pencil"),
                          h1("Report Editor"),
                          fluidRow(
                             column(width = 12,
                                box(width = '100%',
                                title = "markdown options", status = "primary", solidHeader = TRUE, collapsible = TRUE, collapsed = FALSE,
                                column(width = 6,radioButtons("rmd_dl_format", label = "Choose Format:", c("HTML" = "html", "R Markdown" = "rmd"), inline = TRUE),
                                textInput("report_title", "Title: "),
                                textInput("report_author", "Author: "),
                                radioButtons("report_toc", "Table of Contents", choices = list("Yes" = "true", "No" = "false"))
                                ),
                                column(width = 6,
                                       fluidRow(
                                              checkboxGroupInput("include",label = "Add/remove sections in the report",
                                                                 choices = c("Data Overview" = "DataOverview","read_numbers",
                                                                             "density_ridges","temporal_evolution",
                                                                             "Volcano plots","SessionInfo")),
                                       br(),
                                       br(),
                                       br(),
                                       radioButtons("report_ns", "Number sections", choices = list("Yes" = "true", "No" = "false")),
                                       pickerInput("report_theme", "Theme",
                                                   choices = list("Default" = "default", "Cerulean" = "cerulean",
                                                                  "Journal" = "journal", "Flatly" = "flatly",
                                                                  "Readable" = "readable", "Spacelab" = "spacelab",
                                                                  "United" = "united", "Cosmo" = "cosmo"),multiple = FALSE,
                                                   choicesOpt = NULL,
                                                   inline = FALSE,
                                                   options = pickerOptions(
                                                     actionsBox = TRUE,
                                                     liveSearch = TRUE,
                                                     liveSearchStyle = "contains"
                                                   )))
                                       )
                                    )
                                )
                          ),
                          fluidRow(
                            column(3,
                                   actionButton("updatepreview_button", "Update report",class = "btn btn-primary"),p()
                            ),
                            column(3, downloadButton("saveRmd", "Generate & Save",class = "btn btn-success"))
                          ),
                          tabBox(
                            width = NULL,
                            id="report_tabbox",
                            tabPanel("Report preview",
                                     icon = icon("file-text"),
                                     htmlOutput("knitDoc"),
                                     aceEditor("acereport_rmd", mode="markdown",theme = "solarized_light",autoComplete = "live",
                                               value="_Initialization of the_ `CRISPRApp` _report generation..._",
                                               placeholder = "You can enter some code and text in R Markdown format",
                                               height="800px"),
                                     #box(
                                     #   title = "editor_options", status = "primary", solidHeader = TRUE, collapsible = TRUE, collapsed = TRUE,
                                     #   column(width = 12,
                                              checkboxInput("enableAutocomplete", "Enable AutoComplete", TRUE),
                                              #conditionalPanel(
                                               # "input.enableAutocomplete",
                                                #wellPanel(
                                                  checkboxInput("enableLiveCompletion", "Live auto completion", TRUE),
                                                  checkboxInput("enableRCompletion", "R code completion", TRUE),
                                               # )
                                    #          ),
                                              pickerInput("mode", "Mode: ", choices=modes, selected="markdown",
                                                          multiple = FALSE,
                                                          choicesOpt = NULL,
                                                          inline = FALSE,
                                                          options = pickerOptions(
                                                            actionsBox = TRUE,
                                                            liveSearch = TRUE,
                                                            liveSearchStyle = "contains"
                                                          )),
                                              pickerInput("theme", "Theme: ", choices=themes, selected="solarized_light",
                                                          multiple = FALSE,
                                                          choicesOpt = NULL,
                                                          inline = FALSE,
                                                          options = pickerOptions(
                                                            actionsBox = TRUE,
                                                            liveSearch = TRUE,
                                                            liveSearchStyle = "contains"
                                                          ))
                                              
                                     #  ))
                                     ),
                            tabPanel(
                              "About the app", icon = icon("institution"),
                              includeMarkdown(system.file("extdata", "about.md",package = "CRISPRApp")),
                              hr(),
                            )
                          )
                ) # end of tabBox
                ))
      )
  ),
  tags$footer(
    wellPanel(
      HTML(
        '
      <style>
      .footer {
        background: #0ea743;
        font-family: "serif", cursive;
        font-weight: 500;
        line-height: 1.1;
        color: #ffffff;
        height : 150px;
      }
      </style>

      <div class="footer">
      </br>
      <p align="center" width="4">Documentation available on the <a href="https://gitlab.curie.fr/r-shiny/bioshiny/blob/Master/Applications_tutorials/Per_App_Documentation/COOKIE_CRISPR/COOKIE_CRISP-R_DOC.html" style="color:#041518;"> bioshiny git page </a></p>
	<br/>
      <p align="center" width="4">Developped by: <a href="mailto: benoitclement.sand@gmail.com" style="color:#041518;">Clément BENOIT</a> & <a href="mailto: pierre.gestraud@curie.fr" style="color:#041518;">Pierre Gestraud</a></p>
      <p align="center" width="4"> For the <a href ="https://science.curie.fr/plateformes/criblage-genetique-crispr-crisprit/" style="color:#041518;">CRISPR IT Platform of the Institut Curie</a></p>
      </div>  
      '
      )
    )),
    tags$script(src = "imgModal.js")
  )
}
bioinfo-pf-curie/cookieCrispR documentation built on Dec. 19, 2021, 9:45 a.m.