光沢のあるダッシュボードのサイドバーでサブメニューを手動で展開しようとしています。updateTabItems 関数を使用すると、タブに移動できますが、メニューは展開されません。
ここでの質問に対する再現可能な回答を探しています。光沢のあるダッシュボードのサイドバーでサブメニューを手動で展開する方法 。これには、実装されていない素晴らしい例と回答が含まれています。
光沢のあるダッシュボードのサイドバーでサブメニューを手動で展開しようとしています。updateTabItems 関数を使用すると、タブに移動できますが、メニューは展開されません。
ここでの質問に対する再現可能な回答を探しています。光沢のあるダッシュボードのサイドバーでサブメニューを手動で展開する方法 。これには、実装されていない素晴らしい例と回答が含まれています。
これは、参照された回答に基づく作業コードです。tabName
この場合、JavaScript はをセレクターとして使用してactive
クラスをツリー メニューに追加することに注意してください。
library(shiny)
library(shinydashboard)
library(shinyjs)
ui <- dashboardPage(
dashboardHeader(title = "Simple tabs"),
dashboardSidebar(
sidebarMenu(
id = "tabs",
actionButton('switchtab', 'Switch tab'),
menuItem("Widgets", tabName = "widgets", icon = icon("th")),
menuItem("Dashboard", tabName = "dashboard", icon = icon("dashboard"),
menuSubItem("Sub Menu 1",icon = icon("folder-open"), tabName = "subMenu1")
)
)
),
dashboardBody(
useShinyjs(),
extendShinyjs(text = "shinyjs.activateTab = function(name){
setTimeout(function(){
$('a[href$=' + '\"#shiny-tab-' + name + '\"' + ']').closest('li').addClass('active')
}, 200);
}"
),
tabItems(
tabItem(tabName = "subMenu1",
h2("Dashboard tab / Sub menu 1 content")
),
tabItem(tabName = "widgets",
h2("Widgets tab content")
)
)
)
)
server <- function(input, output, session) {
observeEvent(input$switchtab, {
newtab <- switch(input$tabs,
"subMenu1" = "widgets",
"widgets" = "subMenu1"
)
updateTabItems(session, "tabs", newtab)
if (newtab == "subMenu1")
js$activateTab("dashboard")
})
}
shinyApp(ui, server)