I'm trying to use the reactable
package to hop to a specific row index after a user modifies the data underlying the reactable
.
library(shiny)
library(reactable)
library(dplyr)
ui <- fluidPage(
selectInput("index", "Index", choices = seq_len(nrow(iris))),
selectInput("species", "Species", choices = unique(iris$Species)),
actionButton("go", "Modify"),
reactableOutput("table")
)
server <- function(input, output, session) {
# Reactive data
data <- reactiveValues(
data = iris |> mutate(Index = row_number())
)
# Render reactable
output$table <- renderReactable({
reactable(data$data)
})
# Update data on button click
observeEvent(
input$go,
{
# modify the one record
x <- data$data |>
filter(Index == input$index) |>
mutate(Species = input$species)
# rm from all data
data$data <- data$data |>
filter(Index != input$index) |>
bind_rows(x) |>
arrange(Index)
# get index of change
index <- x |> pull(Index)
# hop to that approximate page
updateReactable("table", page = ceiling(index / 10))
}
)
}
shinyApp(ui, server)
The observeEvent()
successfully updates the data but does not hop to the page of the modified index. I.e., if a user is on page 1 but modifies the record with Index == 44
from setosa
to versicolor
, I'd like to use reactable::updateReactable()
to jump to that page. When running this code, it looks like it tries to jump to the page before the reactable
output renders the new data, which is what I'm assuming the issue is.