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

})
Другие вопросы по тегам