#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
))
})
}