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")
)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.