Shiny-Modul-Namespace außerhalb der Benutzeroberfläche für JavaScript-Links
Ich versuche, glänzende Module zu verwenden, um die Benutzeroberfläche und den Servercode für die Darstellung von drei verschiedenen Datensätzen mit derselben Präsentation wiederzuverwenden.
Bei der Verwendung der JavaScript-basierten modalen Erstellung von Popup-Links außerhalb der Benutzeroberfläche / des Server-Codes eine Herausforderung im Umgang mit dem Namespace.
Hier ist mein nicht funktionierender App-Code:
library(shiny)
library(shinyBS)
library(DT)
df <- data.frame(id = c('a', 'b', 'c'), value = c(1, 2, 3))
on_click_js = "
Shiny.onInputChange('myLinkName', '%s');
$('#myModal').modal('show')
"
convert_to_link = function(x) {
as.character(tags$a(href = "#", onclick = sprintf(on_click_js, x), x))
}
df$id_linked <- sapply(df$id, convert_to_link)
df <- df[, c('id_linked', 'value')]
mySampleUI <- function(id) {
ns <- NS(id)
fluidPage(
mainPanel(
dataTableOutput(ns('myDT')),
bsModal(id = 'myModal',
title = 'My Modal Title',
trigger = '',
size = 'large',
textOutput(ns('modalDescription'))
),
width = 12
)
)
}
ui <- fluidPage(mySampleUI('myUI'))
myServerFunc <- function(input, output, session, df) {
output$myDT <- DT::renderDataTable({
datatable(df, escape = FALSE, selection='none')
})
output$modalDescription <- renderText({
sprintf('My beautiful %s', input$myLinkName)
})
}
server <- function(input, output) {
callModule(myServerFunc, 'myUI', df)
}
shinyApp(ui = ui, server = server)
Eine funktionierende Version würde erfolgreich @ anzeigemyLinkName
im Beschreibungsteil des modalen Popups. Der Grund, warum dieser Code nicht funktioniert, liegt darin, dass der Wert der Benutzeroberflächenkomponenten-ID außerhalb des Benutzeroberflächencodes ohne die Namespace-Einschließung erstellt wird. Ich verstehe das. Aber ich kann nicht herausfinden, wie ich es überarbeiten soll, damit der Namensraum übereinstimmt.
Irgendwelche Ideen / Optionen?