gpt4 book ai didi

Using shinyjs, insertUI() and removeUI() with Shiny modules(使用shinyjs,对闪亮的模块插入ui()和移除ui())

转载 作者:bug小助手 更新时间:2023-10-25 19:07:05 28 4
gpt4 key购买 nike



EDIT: I just needed to change the namespace of the insertUI selector!! Will leave up for others.

编辑:我只需要更改intertUI选择器的命名空间!!会留给其他人。


insertUI(
selector = paste0("#",ns(add)),
where = "afterEnd",
ui = tags$div(
id = ui_id,
box(
textInput(paste0("txt", added_ui_count()), "Insert some text")
)
)
)

I'm attempting to use shinyjs to control the number of fileInputs, which then eventually displays a plot once the user uploads a file to all inputs. I have not been able to get it working as a part of a larger app, so I have focused on smaller cases.

我正在尝试使用shinyjs来控制文件输入的数量,一旦用户将文件上传到所有输入,它最终会显示一个曲线图。我一直无法让它作为更大的应用程序的一部分运行,所以我专注于较小的案例。


I am able to get this working in a regular Shiny app, but when I try to modularise the code, I cannot even get the add and remove buttons to work, so I think my usage of shinyjs and namespaces aren't quite right here but I'm not quite sure what I'm doing wrong. Reprexes:

我可以在一个普通的闪亮的应用程序中实现这一点,但当我试图模块化代码时,我甚至无法使用Add和Remove按钮,所以我认为我在这里使用shinyjs和命名空间不太正确,但我不太确定我做错了什么。前缀:


Working regular Shiny app:

工作正常的闪亮应用程序:


library(shiny)
library(shinydashboardPlus)
library(shinyjs)

# Define UI
ui <- fluidPage(
useShinyjs(), # Initialize shinyjs

# Disable the Remove UI button initially
fluidRow(div(id = "box1", box(
fileInput("plotFile1", "Upload 1")
))),
fluidRow(div(id = "box2", box(
fileInput("plotFile2", "Upload 2")
))),
actionButton("add", "Add"),
actionButton("remove", "Remove last input"),
plotOutput("seeplot")
)

# Server logic
server <- function(input, output, session) {

added <- reactive({
print(added_ui_count())
added_ui_count()
})
# Reactive value to track the added UI elements
added_ui_count <- reactiveVal(2) # Initialize with 2

# Create a condition for enabling/disabling the "Add UI" button
enable_add_button <- reactive({
added_ui_count() < 4 # Adjust the number as needed
})

enable_remove_button <- reactive({
added_ui_count() > 2 # Adjust the number as needed
})

observeEvent(enable_add_button(), {
# Enable or disable the "Add UI" button based on the condition
if (enable_add_button()) {
enable("add") # Enable the button
} else {
disable("add") # Disable the button
}
})

observeEvent(enable_remove_button(), {
# Enable or disable the "Remove UI" button based on the condition
if (enable_remove_button()) {
enable("remove") # Enable the button
} else {
disable("remove") # Disable the button
}
})

observeEvent(input$add, {
if (enable_add_button()) {
# Increment the count of added UI elements
added_ui_count(added_ui_count() + 1)

# Generate a unique ID for the new UI element
ui_id <- paste0("box", added_ui_count())

insertUI(
selector = "#add",
where = "beforeBegin",
ui = tags$div(
id = ui_id,
fluidRow(
box(fileInput(paste0("plotFile", added_ui_count()), paste0("Upload ", added_ui_count())))
)
)
)
}
})

observeEvent(input$remove, {
if (enable_remove_button()) {
current_count <- added_ui_count()

# Remove the UI element with the corresponding ID
removeUI(
selector = paste0("#box", current_count)
)

# Decrement the count of added UI elements
added_ui_count(current_count - 1)
}
})

loadData <- function(number){
#should be reactive to the download buttons

n <- number
for(i in 1:n){
eval(parse(text=paste0("req(input$plotFile",i,")")))
}
}

seePlot <- reactive({
loadData(added())
plot(1:10)
})

output$seeplot <- renderPlot({
seePlot()
})

}

# Complete app with UI and server components
shinyApp(ui, server)

Problematic modularised code:

有问题的模块化代码:


library(shiny)
library(shinydashboardPlus)
library(shinyjs)


# Define UI
inputUI <- function(id){
ns <- NS(id) # Initialize shinyjs


# Disable the Remove UI button initially
tagList(
fluidRow(div(id = ns("box1"), box(
fileInput(ns("plotFile1"), "Upload 1")
))),
fluidRow(div(id = ns("box2"), box(
fileInput(ns("plotFile2"), "Upload 2")
))),
actionButton(ns("add"), "Add"),
actionButton(ns("remove"), "Remove last input")
)
}

# Server logic
inputServer <- function(id) {
library(shinyjs)
moduleServer(id, function(input, output, session) {
ns <- session$ns


added <- reactive({
print(added_ui_count())
added_ui_count()
})

# Reactive value to track the added UI elements
added_ui_count <- reactiveVal(2) # Initialize with 2

# Create a condition for enabling/disabling the "Add UI" button
enable_add_button <- reactive({
added_ui_count() < 4 # Adjust the number as needed
})

enable_remove_button <- reactive({
added_ui_count() > 2 # Adjust the number as needed
})

observeEvent(enable_add_button(), {
# Enable or disable the "Add UI" button based on the condition
if (enable_add_button()) {
enable("add") # Enable the button
} else {
disable("add") # Disable the button
}
})

observeEvent(enable_remove_button(), {
# Enable or disable the "Remove UI" button based on the condition
if (enable_remove_button()) {
enable("remove") # Enable the button
} else {
disable("remove") # Disable the button
}
})

observeEvent(input$add, {
if (enable_add_button()) {
# Increment the count of added UI elements
added_ui_count(added_ui_count() + 1)

# Generate a unique ID for the new UI element
ui_id <- paste0("box", added_ui_count())

insertUI(
selector = "#add",
where = "beforeBegin",
ui = tags$div(
id = ui_id,
fluidRow(
box(fileInput(ns(paste0("plotFile", added_ui_count())), paste0("Upload ", added_ui_count())))
)
)
)
}
})

observeEvent(input$remove, {
if (enable_remove_button()) {
current_count <- added_ui_count()

# Remove the UI element with the corresponding ID
removeUI(
selector = paste0("#box", current_count)
)

# Decrement the count of added UI elements
added_ui_count(current_count - 1)
}
})
})
}

ui <- fluidPage(
useShinyjs(), # Initialize ShinyJS
inputUI("module1"),
# Other UI components
)

server <- function(input, output, session) {
inputServer("module1")
# Other server logic
}

# Complete app with UI and server components
shinyApp(ui, server)

TIA :)

TIA:)


更多回答

Hi, if you have found answer to your question please add it below in the answer section. Thanks.

嗨,如果你找到了你的问题的答案,请把它添加到下面的答案部分。谢谢。

@RonakShah Apologies didn't know I could do that, thanks :)

@RonakShah抱歉,我不知道我可以这样做,谢谢:)

优秀答案推荐

I just needed to change the namespace of the insertUI selector!! Will leave up for others.

我只需要更改intertUI选择器的名称空间!!会留给其他人。


insertUI(
selector = paste0("#",ns(add)),
where = "afterEnd",
ui = tags$div(
id = ui_id,
box(
textInput(paste0("txt", added_ui_count()), "Insert some text")
)
)
)

更多回答

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com