Building Dashboards with shinydashboard
Png Kee Seng
Researcher
For each output, a pair of functions need to be called
<type>output(<identifying label>, ...)
The second code required is defined within the server function
output$<identifying label> <- render<type>(...)
library(tidyverse)
sleep <- read_csv("../data/Time Americans Spend Sleeping.csv")
$ index : num [1:945] 0 1 2 3 4 ...
$ Year : num [1:945] 2003 2004 2005 2006 2007 ...
$ Period : chr [1:945] "Annual" "Annual" "Annual" "Annual" ...
$ Avg hrs per day sleeping: num [1:945] 8.57 8.55 8.62 8.63 ...
$ Standard Error : num [1:945] 0.018 0.026 0.023 0.024 ...
$ Type of Days : chr [1:945] "All days" "All days" "All days" ...
$ Age Group : chr [1:945] "15 years and over" "15 years and over" ...
$ Activity : chr [1:945] "Sleeping" "Sleeping" "Sleeping" ...
$ Sex : chr [1:945] "Both" "Both" "Both" ...
textOutput
in the UIui <- fluidPage(
titlePanel("Sleeping habits in America"),
textOutput("textlabel"))
server <- function(input, output) {
}
shinyApp(ui, server)
renderText
in the serveroutput$
notationui <- fluidPage( titlePanel("Sleeping habits in America"), textOutput("textlabel"))
server <- function(input, output) { output$textlabel <- renderText("Sleep deprivation is a serious health issue in many major cities around the world.") }
shinyApp(ui, server)
input$
input$<type>
ui <- fluidPage( titlePanel("Sleeping habits in America"),
textInput("textlabel", "Tell me your name", value = "", placeholder = "Don"),
textOutput("textoutlabel")) server <- function(input, output) { output$textoutlabel <- renderText(paste0("Hello ",
input$textlabel,
"Sleep deprivation is a serious health issue in many major cities around the world.")) } shinyApp(ui, server)
plotOutput()
in the UIui <- fluidPage( titlePanel("Sleeping habits in America"),
plotOutput("plotlabel"))
server <- function(input, output) { } shinyApp(ui, server)
renderPlot()
in server()
ui <- fluidPage( titlePanel("Sleeping habits in America"), plotOutput("plotlabel")) server <- function(input, output) {
output$plotlabel <- renderPlot({ ggplot(sleep) + geom_histogram(aes(x = `Avg hrs per day sleeping`)) })
} shinyApp(ui, server)
ui <- fluidPage(
titlePanel("Sleeping habits in America"),
selectInput("selectlabel",
"Select an option",
choices = c("Histogram", "Boxplot")),
plotOutput("plotlabel"))
server <- function(input, output) { output$plotlabel <- renderPlot({ if (input$selectlabel == "Histogram"){
ggplot(sleep) + geom_histogram(aes(x = `Avg hrs per day sleeping`))
} else if (input$selectlabel == "Boxplot"){
ggplot(sleep) + geom_boxplot(aes(x = `Avg hrs per day sleeping`))
} }) } shinyApp(ui, server)
sliderInput
ui <- fluidPage( titlePanel("Sleeping habits in America"),
sliderInput("sliderlabel", "Average hours of sleep", min = 7.5, max = 11, value = c(7.5, 11), step = 0.02),
plotOutput("plotlabel")) server <- function(input, output) {
output$plotlabel <- renderPlot({ filter(sleep, `Avg hrs per day sleeping` >= input$sliderlabel[1], `Avg hrs per day sleeping` <= input$sliderlabel[2]) %>% ggplot() + geom_boxplot(aes(x=`Avg hrs per day sleeping`)) })
} shinyApp(ui, server)
shiny
also contains icons that can be used in a shinyAppicon("...")
icon("bed")
ui <- fluidPage( titlePanel("Sleeping habits in America"), sliderInput("sliderlabel",
list(icon("bed"),
"Select an option:"), min = 7.5, max = 11, value = c(7.5, 11), step = 0.02), plotOutput("plotlabel")) server <- function(input, output) { output$plotlabel <- renderPlot({ filter(sleep, `Avg hrs per day sleeping` >= input$sliderlabel[1], `Avg hrs per day sleeping` <= input$sliderlabel[2]) %>% ggplot() + geom_boxplot(aes(x=`Avg hrs per day sleeping`)) }) } shinyApp(ui, server)
Building Dashboards with shinydashboard