Search code examples
rshinyshinydashboard

R ShinyDashBoard layout column layout


I have the following code in my R Shiny dashboard body:

dashboardBody(
    tabBox(width = 12,
           tabPanel("US County Detail",
                fluidRow(width=12,
                         column(width=6, tableOutput("County_tbl")),
                         column(width=3, uiOutput("States_List")),
                         column(width=3, sliderInput("slider", "Threshold:", 0, 100, post = " %", 50))),
                fluidRow(width=12,
                         column(width=7, ''),
                         column(width=4, plotlyOutput("County_Map"))),
                fluidRow(width=12,
                         column(width=6, ''),
                         column(width=6, plotlyOutput("County_Chart")))
              )
            )
          )

Essentially with the code above I'm trying to produce a long data table in the first column with a drop down box and slider next to it in columns 2 and 3. Then next to the data table I want to show a map with a bar chart underneath.

However the map and the bar chart are currently being positioned right at the bottom of my long data table. Meaning you can't see them unless you scroll down. Any ideas how I can force the map and the chart underneath the drop down box and slider?

Thanks

Currently doing this:

enter image description here

When in fact I'm trying to get it up here:

enter image description here


Solution

  • HI Please provide a minimal reproducible code so it will help to replicate the issue. It is the issue of how you arrange your UI means fluidrow and column. I tried with the same and build a sample code on that.

    [![library(shiny)
    library(shinydashboard)
    library(plotly)
    
    ui <- dashboardPage(
      dashboardHeader(
        title = "Dashboard"),
    
    
      #sidebar content
      dashboardSidebar(
        sidebarMenu(
          menuItem("Dashboard", tabName = "dashboard", icon = icon("dashboard"))
        )
      ),
    
    
    
    dashboardBody(
      tabItems(
        tabItem(tabName='dashboard',
                tabBox(width = 12,
                       tabPanel("US County Detail",
                                fluidRow(
                                  column(5,
                                         fluidRow(
                                           tableOutput("County_tbl")
                                         )
                                         ),
                                  column(7,
                                         fluidRow(
                                           column(6,
                                                  uiOutput("States_List")
                                                  ),
                                           column(6,
                                                  sliderInput("slider", "Threshold:", 0, 100, post = " %", 50)
                                                  )
                                                  ),
                                         fluidRow(
                                           column(12,
                                                  plotlyOutput("County_Map")
                                                  )
                                                ),
                                         fluidRow(
                                           column(12,
                                                  plotlyOutput("County_Chart")
                                                  )
    
                                         )
    
                                         )
                                )
                       )
                )    
    
        )
    
      )
    
    )
    )
    
    
    
    server <- function(input, output,session) {
    
      output$County_tbl<-renderTable({
        head(mtcars)
      })
    
      output$States_List<-renderUI({
        list_data<-unique(names(mtcars))
        selectInput("cars","Select Car",choices = list_data)
      })
    
      output$County_Map<-renderPlotly({
        plot_ly(
          x = c("giraffes", "orangutans", "monkeys"),
          y = c(20, 14, 23),
          name = "SF Zoo",
          type = "bar"
        )
      })
    
      output$County_Chart<-renderPlotly({
        Animals <- c("giraffes", "orangutans", "monkeys")
        SF_Zoo <- c(20, 14, 23)
        LA_Zoo <- c(12, 18, 29)
        data <- data.frame(Animals, SF_Zoo, LA_Zoo)
    
      plot_ly(data, x = ~Animals, y = ~SF_Zoo, type = 'bar', name = 'SF Zoo') %>%
          add_trace(y = ~LA_Zoo, name = 'LA Zoo') %>%
          layout(yaxis = list(title = 'Count'), barmode = 'group')
    
      })
    
    
    }  
    shinyApp(ui = ui, server = server)
    

    enter image description here