render dropdown for single column in DT shiny
Asked Answered
C

1

8

I'm not proficient in Javascript and would like to replicate a dropdown function as is available in the rhandsontable package but for the DT package.

How could this be achieved in the most efficient way?

Example


library(DT)

i <- 1:5

datatable(iris[1:20, ],
          editable = T,
          options = list(
                    columnDefs = list(
                                      list(
                                           targets = 5,
                                           render = JS(
                     # can't get my head around what should be in the renderer...
         )
      ))
    ))

The goal is to have the i variable act as validator for the allowed input in the DT object.

Any help is much appreciated!

Coincidental answered 26/7, 2019 at 7:58 Comment(0)
P
23

I blatantly stole the idea from Yihui's app for including radioButtons in DT.

Code:

library(shiny)
library(DT)

ui <- fluidPage(
  title = 'Selectinput column in a table',
  h3("Source:", tags$a("Yihui Xie", href = "https://yihui.shinyapps.io/DT-radio/")),
  DT::dataTableOutput('foo'),
  verbatimTextOutput('sel')
)

server <- function(input, output, session) {
  data <- head(iris, 5)

  for (i in 1:nrow(data)) {
    data$species_selector[i] <- as.character(selectInput(paste0("sel", i), "", choices = unique(iris$Species), width = "100px"))
  }

  output$foo = DT::renderDataTable(
    data, escape = FALSE, selection = 'none', server = FALSE,
    options = list(dom = 't', paging = FALSE, ordering = FALSE),
    callback = JS("table.rows().every(function(i, tab, row) {
        var $this = $(this.node());
        $this.attr('id', this.data()[0]);
        $this.addClass('shiny-input-container');
      });
      Shiny.unbindAll(table.table().node());
      Shiny.bindAll(table.table().node());")
  )
  output$sel = renderPrint({
    str(sapply(1:nrow(data), function(i) input[[paste0("sel", i)]]))
  })
}

shinyApp(ui, server)

Output:

Output

Pettifog answered 26/7, 2019 at 10:41 Comment(3)
a question à bit similar there please :) render dropdown for single column in DT shiny BUT loaded only on cell click and with replaceData()Mahala
and it's bounted :)Mahala
Hi @GyD. Could you show how it would be possible to update the values of the the Species column to the value of the species_selector SelectInput values? I can't seem to change it even while using reactive and observe. IVidar

© 2022 - 2024 — McMap. All rights reserved.