我正在構建一個flex dashboard
/shiny
應用程序datatable
並嘗試構建兩個輸入作爲此datatable
的選擇,每個選擇都有一個「全部」選項。第一個問題是我如何通過選擇第一個選項"team"
來限制第二個選擇"user"
?如何使用更新和多重選擇在我的閃亮應用中創建多個輸入?
然後,使用這些輸入,我想將我的數據分爲任意兩個選擇組合。管理團隊,用戶「達爾文d」將返回單行數據表以他的名字,團隊和其他指標要添加等
低於柔性降價文件中的所有代碼:
---
title: "example"
output:
flexdashboard::flex_dashboard:
orientation: columns
vertical_layout: fill
runtime: shiny
---
```{r setup, include=FALSE}
library(shiny)
library(shinydashboard)
library(flexdashboard)
library(magrittr)
library(feather)
library(anytime)
library(data.table)
library(DT)
library(datasets)
Name <- c("Allan A","Barbara B","Charles C","Darwin D","Evelyn E","Frank F","Greg G","Hans H")
Team <- c(1,2,3,3,2,1,2,2)
users <- data.frame(Name,Team)
remove(Name,Team)
```
Inputs {.sidebar}
=======================================================================
### Input Variables
```{r global_input}
# input variable to call selection, name of field, selections/options variable
dateRangeInput('dateRange',
label = 'Date range input: yyyy-mm-dd',
start = Sys.Date() - 8,
end = Sys.Date() - 1,
min = "2013-01-01",
max = Sys.Date() -1
)
selectInput("teaminput","Team", c("All",unique(users$Team)))
observe({
if(input$teaminput == "All") {
subDT <- copy(users)
} else {
subDT <- users[ users$Team == input$teaminput, ]
}
updateSelectInput(
"userinput",
label = "User Name",
choices = c("All", unique(subDT$Name))
)
})
```
### Intake Coordinator KPIs
```{r daily_table}
# reactive data object based on inputs above
daily_dt <- reactive({
if(input$teaminput == "All"){
subDT
} else{
subset(subDT$Team == input$teaminput)
}
})
# render DT datatable object with sorts/search
renderDataTable(daily_dt())
```
增加了一個完整的代碼示例。 – gscott