在闪亮中使用 insertUI 时未返回 jqui_sortable 的订单

order for jqui_sortable not returned when using insertUI in shiny

我发现了这个相关问题:dragUI not draggable when created with insertUI shiny

我想在 jqui_sortable() 中插入任意数量的 ui 元素,并在服务器函数中设置可用元素的顺序。

如果我事先知道需要多少元素,我可以在 insertUI 中调用 jqui_sortable() 函数,然后访问服务器中元素的顺序:

library(shiny)

ui <- fluidPage(
  actionButton("add", "Add"),
  div(id = "foo")
)

server <- function(input, output, session) {
  observeEvent(input$add, {
    insertUI(selector = "#foo",
             where = "beforeEnd",
             ui = jqui_sortable(tags$ul(
               id = paste0('lst', input$add),
               tags$li('A'),
               tags$li('B'),
               tags$li('C')
             )))
  })

  observe({
    cat(str(input$lst_order1))
    cat(str(input$lst_order2))
  })
}

shinyApp(ui, server)

如果您 运行 上面的应用程序,您将看到插入的前两个列表的顺序打印到控制台。更改元素的顺序也会打印到控制台。

但是,如果我尝试将 jqui_sortable() 放入 UI 并仅插入元素,则不会打印顺序。这是一个可重现的例子:

library(shiny)
library(shinyjqui)

ui <- fluidPage(
  actionButton("add", "add"),
  jqui_sortable(tags$ul(id = "lst")),
)

server <- function(input, output, session) {
  
  observeEvent(input$add, {
    insertUI(
      selector = "#lst",
      where = "beforeEnd",
      ui = tags$li(paste0("test", input$add))
    )
  })
  
  observe({
    cat(str(input$lst_order))
  })
}

shinyApp(ui, server)

如何创建可排序元素并在任何给定时间检索页面上元素的顺序?解决方案不必使用 {shinyjqui}.

我在 {shinyjqui} GitHub 页面上交叉发布了这个,但我不确定这是一个错误。

更新:

{sortable} 包让我更接近一点。但是,插入新元素时不会更新元素的顺序,只有通过移动元素来更新顺序。



library(shiny)
library(sortable)

ui <- fluidPage(
  actionButton("add", "add"),
  tags$ul(id = "lst"),
  verbatimTextOutput("text"),
  sortable_js(css_id = "lst",  options = sortable_options(
    onSort = sortable_js_capture_input(input_id = "selected"),
    onLoad = sortable_js_capture_input(input_id = "selected")
  ))
)

server <- function(input, output, session) {
  
  observeEvent(input$add, {
    insertUI(
      selector = "#lst",
      where = "beforeEnd",
      ui = tags$li(paste0("test", input$add))
    )
  })
  
  output$text <- renderText({
    req(input$selected)
    input$selected
  })
  
}

shinyApp(ui, server)

似乎是这样工作的。这个想法是销毁可分类的东西并重新启用它。

library(shiny)
library(shinyjqui)

ui <- fluidPage(
  actionButton("add", "add"),
  tags$ul(id = "lst"),
)

server <- function(input, output, session) {
  
  observeEvent(input$add, {
    insertUI(
      selector = "#lst",
      where = "beforeEnd",
      ui = tags$li(paste0("test", input$add))
    )
    jqui_sortable("#lst", operation = "enable")
  }, priority = 1)
  
  observeEvent(input$add, {
    jqui_sortable("#lst", operation = "destroy")
  }, priority = 2)
  
  observe({
    cat(str(input$lst_order))
  })
}

shinyApp(ui, server)