Mam kilka danych poniżej, które używam do stworzenia wykresu pączka w błyszczącym R, gdzie date
jest postacią. Chcę móc wybrać adres e-mail, którego wynik chcę wyświetlić, ale w drugim menu wybierz tylko daty, dla których ta wiadomość e-mail ma aktywność.R Błyszczący selectInput, który jest zależny od innego selectInput
Na przykład, jeśli wybiorę email = xxxx na pierwszym liście, chcę zobaczyć tylko "brak aktywności" w polu wyboru daty. Dla adresu e-mail = rrrr, chcę wybrać tylko 6/17/14, 6/18/14, 6/19/14 jako opcje.
Próbowałem rodzaju zagnieżdżonego podzbioru w ui. Przykład:
> ui <- shinyUI(fluidPage(
+ sidebarLayout(
+ sidebarPanel(
+ selectInput('Select', 'Customer:', choices = unique(as.character(dat5$email))),
+ selectInput("User", "Date:", choices = dat5[dat5$email==input$Select,date])
+ ),
+ mainPanel(plotOutput("distPlot"))
+ )
+))
Ale to nadal pokazuje wszystkie możliwe pozycje date
DANE
email date variable value ymin ymax
xxxx no activity e_score 0 0 0
xxxx no activity diff 1 0 1
yyyy 6/17/14 e_score 0.7472 0 0.7472
yyyy 6/17/14 diff 0.2528 0.7472 1
yyyy 6/18/14 e_score 0.373 0 0.373
yyyy 6/18/14 diff 0.627 0.373 1
yyyy 6/19/14 e_score 0.533 0 0.533
yyyy 6/19/14 diff 0.467 0.533 1
Mój kod do tej pory:
app.R
library(shiny)
library(shinydashboard)
ui <- shinyUI(fluidPage(
sidebarLayout(
sidebarPanel(
selectInput('Select', 'Customer:', choices = unique(as.character(dat5$email))),
selectInput("User", "Date:", choices = unique(dat5$date))
),
mainPanel(plotOutput("distPlot"))
)
))
server <- function(input, output) {
output$distPlot <- renderPlot({
ggplot(data = subset(dat5, (email %in% input$Select & date %in% input$User)), aes(fill=variable, ymax = ymax, ymin = ymin, xmax = 4, xmin = 3)) +
geom_rect(colour = "grey30", show_guide = F) +
coord_polar(theta = "y") +
geom_text(aes(x = 0, y = 0,label = round(value[1]*100))) +
xlim(c(0, 4)) +
theme_bw() +
theme(panel.grid=element_blank()) +
theme(axis.text=element_blank()) +
theme(axis.ticks=element_blank()) +
xlab("") +
ylab("") +
scale_fill_manual(values=c('#33FF00','#CCCCCC'))
})
}
shinyApp(ui = ui, server = server)
że szkoda !! Z jakiegoś powodu musiałem użyć opcji 'choose = as.character (dat5 [dat5 $ email == input $ Select," date "])) bez cudzysłowu wokół daty. W przeciwnym razie działało świetnie! – Hillary
Jestem zdezorientowany stwierdzeniem "nie można uzyskać dostępu do danych wejściowych w części aplikacji". Podczas korzystania z panelu warunkowego definiujesz warunek na podstawie input.panel. Czy to nie zależy od danych wejściowych interfejsu użytkownika? –