Как создать возможность для каждой вкладки со своим собственным диапазоном ввода даты в shinydashboard

#r #shinydashboard #reactive #dt

#r #shinydashboard #реактивный #dt

Вопрос:

У меня есть пять вкладок в моей shinydashboard. Четыре из этих пяти вкладок имеют свои собственные таблицы. Каждая из этих таблиц отличается друг от друга и имеет разные диапазоны дат. Я хочу иметь возможность, чтобы, когда пользователь вводит дату на одной из вкладок, это не влияло на другие таблицы и их диапазоны ввода. Однако с моим кодом ниже это не так. Если я выберу диапазон дат на моей первой вкладке, это повлияет на то, какие даты отображаются на других вкладках. Вот мой код ниже

 #ui.R
#----


# Header -----------------------------------------------------------------------|
header<-dashboardHeader( title = "Marketing Dashboard"
  
)


# Sidebar ----------------------------------------------------------------------|

sidebar<-dashboardSidebar(
  sidebarMenu(
    menuItem("Overview", tabName ="overview", icon = icon("dashboard")),
    menuItem("User", tabName ="user", icon = icon("user")),
    menuItem("Behavior", tabName ="behavior", icon = icon("people-carry")),
    menuItem("Finance", tabName ="finance", icon = icon("piggy-bank")),
    menuItem("Weather", tabName ="weather", icon = icon("bolt"))
  )
)

# Body -------------------------------------------------------------------------|
  
body<-dashboardBody(theme = "solar.css",
  tabItems(
    tabItem(tabName = "overview",
      fluidRow(
        dateRangeInput("date",
                       label = 'Date range input',
                       start =  range(tib1$start_time)[2] - 7, end =  range(tib1$start_time)[2],
                       min = range(tib1$start_time)[1], max =  range(tib1$start_time)[2]
        )
      ),      
      fluidRow(
        DT::dataTableOutput("overviewtable")
      )
    ),
    tabItem(tabName = 'user',
            fluidRow(
              dateRangeInput("date",
                             label = 'Date range input',
                             start =  range(tib2$end_time)[2] - 7, end =  range(tib2$end_time)[2],
                             min = range(tib2$end_time)[1], max =  range(tib2$end_time)[2]
              )
            ),
            fluidRow(
              DT::dataTableOutput("usertable")
            )

    ),
    tabItem(tabName = 'behavior',
            fluidRow(
              dateRangeInput("date",
                             label = 'Date range input',
                             start =  range(tib3$start_time)[2] - 7, end =  range(tib3$start_time)[2],
                             min = range(tib3$start_time)[1], max =  range(tib3$start_time)[2]
              )
            ),
            fluidRow(
              DT::dataTableOutput("behaviortable")
            )
    ),
    tabItem(tabName = 'finance',
            fluidRow(
              dateRangeInput("date",
                             label = 'Date range input',
                             start =  range(tib4$start_time)[2] - 7, end =  range(tib4$start_time)[2],
                             min = range(tib4$start_time)[1], max =  range(tib4$start_time)[2]
              )
            ),
            fluidRow(
              DT::dataTableOutput("financetable")
            )
    ),
    tabItem(tabName = 'weather',
      fluidRow(
        tags$iframe(
          seamless = "seamless",
          src = "personal",
          height = 800,
          width = 1400
        )
      )
    )
  )
)



# UI ---------------------------------------------------------------------------|

ui = dashboardPage(
  header,
  sidebar,
  body
)

  
 # server.R
#---------


server <- function(input,output){
  #Reactive for dateRangeInput in overview
  
  overviewdata<- reactive({
    filter(tib1, between(start_time, input$date[1], input$date[2]))
  })
  
  #Table for overview
  output$overviewtable<- DT::renderDataTable({
    DT::datatable(data =overviewdata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  #User Section -----------------------------------------------------------------|
  userdata<- reactive({
    filter(tib2, between(end_time, input$date[1], input$date[2]))
  })
  
  #Table for user
  output$usertable<- DT::renderDataTable({
    DT::datatable(data =userdata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  
  #Behavior section -------------------------------------------------------------|
  
  behaviordata<- reactive({
    filter(tib3, between(start_time, input$date[1], input$date[2]))
  })
  
  #Table for overview
  output$behaviortable<- DT::renderDataTable({
    DT::datatable(data = behaviordata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  
  #Finance section -------------------------------------------------------------|
  financedata<- reactive({
    filter(tib4, between(start_time, input$date[1], input$date[2]))
  })
  
  #Table for overview
  output$financetable<- DT::renderDataTable({
    DT::datatable(data = financedata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  
}
  

Я искал онлайн и буду продолжать искать ответ в Интернете, но я не вижу ничего, что точно относится к этому вопросу. Есть ли способ указать идентификатор в dateInputeRange, чтобы reactive({}) функция на стороне сервера знала, что диапазон dateinpute находится на вкладке 1, 2 и т.д.

Комментарии:

1. ваш dateRangeInput принимает inputId в качестве аргумента. вы можете назначить разные идентификаторы, например, date_user, date_finance и т.д. Вместо просто ‘date’. Затем вы ссылаетесь на каждый отдельный date_id при фильтрации на этой вкладке. В качестве альтернативы, вы можете создать один модуль, который вы вызываете несколько раз.

2. Это действительно решило проблему. Если вы хотите сделать это ответом, я выберу его в качестве решения проблемы.

Ответ №1:

ваш dateRangeInput принимает inputId в качестве аргумента. вы можете назначить разные идентификаторы, например, date_user, date_finance и т.д. Вместо просто ‘date’. Затем вы ссылаетесь на каждый отдельный date_id при фильтрации на этой вкладке. В качестве альтернативы, вы можете создать один модуль, который вы вызываете несколько раз, используя ns функцию:

 #ui.R
#----


# Header -----------------------------------------------------------------------|
header<-dashboardHeader( title = "Marketing Dashboard"
                         
)


# Sidebar ----------------------------------------------------------------------|

sidebar<-dashboardSidebar(
  sidebarMenu(
    menuItem("Overview", tabName ="overview", icon = icon("dashboard")),
    menuItem("User", tabName ="user", icon = icon("user")),
    menuItem("Behavior", tabName ="behavior", icon = icon("people-carry")),
    menuItem("Finance", tabName ="finance", icon = icon("piggy-bank")),
    menuItem("Weather", tabName ="weather", icon = icon("bolt"))
  )
)

# Body -------------------------------------------------------------------------|

body<-dashboardBody(theme = "solar.css",
                    tabItems(
                      tabItem(tabName = "overview",
                              fluidRow(
                                dateRangeInput("date_overview",
                                               label = 'Date range input',
                                               start =  range(tib1$start_time)[2] - 7, end =  range(tib1$start_time)[2],
                                               min = range(tib1$start_time)[1], max =  range(tib1$start_time)[2]
                                )
                              ),      
                              fluidRow(
                                DT::dataTableOutput("overviewtable")
                              )
                      ),
                      tabItem(tabName = 'user',
                              fluidRow(
                                dateRangeInput("date_user",
                                               label = 'Date range input',
                                               start =  range(tib2$end_time)[2] - 7, end =  range(tib2$end_time)[2],
                                               min = range(tib2$end_time)[1], max =  range(tib2$end_time)[2]
                                )
                              ),
                              fluidRow(
                                DT::dataTableOutput("usertable")
                              )
                              
                      ),
                      tabItem(tabName = 'behavior',
                              fluidRow(
                                dateRangeInput("date_behaviour",
                                               label = 'Date range input',
                                               start =  range(tib3$start_time)[2] - 7, end =  range(tib3$start_time)[2],
                                               min = range(tib3$start_time)[1], max =  range(tib3$start_time)[2]
                                )
                              ),
                              fluidRow(
                                DT::dataTableOutput("behaviortable")
                              )
                      ),
                      tabItem(tabName = 'finance',
                              fluidRow(
                                dateRangeInput("date_finance",
                                               label = 'Date range input',
                                               start =  range(tib4$start_time)[2] - 7, end =  range(tib4$start_time)[2],
                                               min = range(tib4$start_time)[1], max =  range(tib4$start_time)[2]
                                )
                              ),
                              fluidRow(
                                DT::dataTableOutput("financetable")
                              )
                      ),
                      tabItem(tabName = 'weather',
                              fluidRow(
                                tags$iframe(
                                  seamless = "seamless",
                                  src = "personal",
                                  height = 800,
                                  width = 1400
                                )
                              )
                      )
                    )
)



# UI ---------------------------------------------------------------------------|

ui = dashboardPage(
  header,
  sidebar,
  body
)

  
 # server.R
#---------


server <- function(input,output){
  #Reactive for dateRangeInput in overview
  
  overviewdata<- reactive({
    filter(tib1, between(start_time, input$date_overview[1], input$date_overview[2]))
  })
  
  #Table for overview
  output$overviewtable<- DT::renderDataTable({
    DT::datatable(data =overviewdata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  #User Section -----------------------------------------------------------------|
  userdata<- reactive({
    filter(tib2, between(end_time, input$date_user[1], input$date_user[2]))
  })
  
  #Table for user
  output$usertable<- DT::renderDataTable({
    DT::datatable(data =userdata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  
  #Behavior section -------------------------------------------------------------|
  
  behaviordata<- reactive({
    filter(tib3, between(start_time, input$date_behaviour[1], input$date_behaviour[2]))
  })
  
  #Table for overview
  output$behaviortable<- DT::renderDataTable({
    DT::datatable(data = behaviordata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  
  #Finance section -------------------------------------------------------------|
  financedata<- reactive({
    filter(tib4, between(start_time, input$date_finance[1], input$date_finance[2]))
  })
  
  #Table for overview
  output$financetable<- DT::renderDataTable({
    DT::datatable(data = financedata(),
                  extensions = 'Buttons',
                  options = list(
                    dom = "Blfrtip",
                    buttons =
                      list("copy", list(
                        extend = "collection",
                        buttons = c("csv","excel","pdf"),
                        text ="Download"
                      ))#End of button customization
                  ))
  })
  
}