У меня есть решение с модулями и с функцией render_dq_box_group
, я думаю, это то, что вы пытаетесь сделать:
library(shiny)
library(dqshiny)
selectorUI <- function(id){
ns = NS(id)
tags$div(
fluidRow(
column(6, uiOutput(ns('new_ui')))
),
id = paste0('ui', id)
)
}
selectorServer <- function(input, output, session){
ns = session$ns
output$new_ui <- render_dq_box_group({
dq_accordion(ns("foo"),
titles = ns("input"),
contents = list(textInput(inputId = ns("txt"),
label = "")),
bg_color = NULL,
options = list(animate = 200, collapsible = TRUE),
icons = c(open = "hand-point-down", closed = "hand-point-right")
)
})
}
shinyApp(
ui = fluidPage(
fluidRow(
actionButton("add", "+"),
selectorUI(1),
selectorUI(2),
selectorUI(3),
tags$div(id = 'placeholder'),
actionButton("delete", "-")
)
),
server = function(input, output) {
callModule(selectorServer, 1)
callModule(selectorServer, 2)
callModule(selectorServer, 3)
counter <- reactiveValues(value = 3) # number of inputs already present
observeEvent(input$add, {
counter$value <- counter$value + 1
insertUI(
selector = "#placeholder",
ui = selectorUI(counter$value)
)
callModule(selectorServer, counter$value)
})
observeEvent(input$delete, {
removeUI(
selector = paste0("#ui", counter$value)
)
counter$value <- counter$value - 1
})
}
)
Я использовал этот ответ , чтобы сделать это решение.