Shiny: переключение реактивных наборов данных с Rhandsontable и внешними параметрами
По сути, я пытаюсь переключаться между Rhandsontables, которые также имеют внешние виджеты, которые управляют ими. Кроме того, в этих таблицах есть основные формулы. Эти таблицы по сути одинаковы, а виджеты и формулы работают одинаково в обоих случаях, я просто хотел бы иметь возможность переключаться между ними. Пример ниже может быть для информативности...
library(shiny)
library(rhandsontable)
RepData1 <- data.frame(col1 = c(1:10)
,col2 = "C1"
,col3 = runif(10,0,0.023)
,col4 = runif(10,0,1))
RepData2 <- data.frame(col1 = c(1:10)
,col2 = "C2"
,col3 = runif(10,0,0.023)
,col4 = runif(10,0,1))
ui=fluidPage(
sliderInput("mySlider",label="Slider", min = 0, max = 100, post = " %", value = 50)
,numericInput("Total", "Total:", 500000)
,verbatimTextOutput("value")
,fluidRow(
column(3, radioButtons("Buttn10", label="col", choices= c("C1","C2"), selected = "C1", inline = TRUE))
,column(6,rHandsontableOutput("hotable1"))
)
)
server <- shinyServer(function(input, output, session) {
selData <- ""
previous <- reactive({
if(input$Buttn10 == "C1") {
if(selData == "" | selData == "C2") {
selData <<- "C1"
return(RepData1)
}
} else {
if(selData == "C1") {
selData <<- "C2"
return(RepData2)
}
}
})
MyChanges <- reactive({
if(is.null(input$hotable1)){
return(previous())
} else if(!identical(previous(),input$hotable1)){
mytable <- as.data.frame(hot_to_r(input$hotable1))
x <- input$Total*(input$mySlider/100)
mytable$QTY <- x*mytable$col4
mytable
}
})
output$hotable1 <- renderRHandsontable({
if(is.null(MyChanges())) return()
df_ <- MyChanges()
rhandsontable(df_, readOnly = FALSE, rowHeaders= NULL, useTypes= TRUE) %>%
hot_table(highlightCol = TRUE, highlightRow = TRUE)
})
})
shinyApp(ui,server)
В этом случае виджеты и формулы работают, но не переключение...
1 ответ
Попробуй это:
server <- shinyServer(function(input, output, session) {
previous <- reactive({
if(input$Buttn10 == "C1") {
return(RepData1)
}
if(input$Buttn10 == "C2"){
return(RepData2)
}
})
MyChanges <- reactive({
mytable <- previous()
x <- input$Total*(input$mySlider/100)
mytable$QTY <- x*mytable$col4
mytable
})
output$hotable1 <- renderRHandsontable({
df_ <- MyChanges()
rhandsontable(df_, readOnly = FALSE, rowHeaders= NULL, useTypes=TRUE) %>%
hot_table(highlightCol = TRUE, highlightRow = TRUE)
})
})