Как передать значения светлого дерева в раскрывающийся список в блестящем - PullRequest
0 голосов
/ 19 февраля 2020

Я пытаюсь создать раскрывающийся ввод в виде блеска, который имеет иерархический раскрывающийся список в R блестящем, как показано ниже:

иерархический раскрывающийся список в R блестящем

На данный момент я могу создать блестящее дерево, в котором мы можем отобразить весь список, но я хочу отобразить список в раскрывающемся списке вместо блестящего дерева.

Ниже приведен мой код:

библиотека (блестящий)

библиотека (Блестящее дерево)

Определить пользовательский интерфейс для приложения:

ui <- {

fluidPage(

sidebarLayout(

sidebarPanel(width = 3,
             div(shinyTree("Tree",checkbox = TRUE)),
             verbatimTextOutput("selected")
), 
mainPanel(width = 9)
)
)}

Определить логи сервера c требуется:

server <- function(input, output, session){

observe({
df <- data.frame(child = c('a','b','c','d','e','f','g','h'),parent = c('f','f','f','g','h','i','i','i'))

tree <- FromDataFrameNetwork(df)

filtered_value <- as.list(tree)

filtered_value <- filtered_value[-1]

output$Tree <- renderTree({ 
  filtered_value
})
})
}

Запустите приложение

shinyApp(ui = ui, server = server)

Я ищу ввод следующим образом: Custom-Dropdown

1 Ответ

0 голосов
/ 20 февраля 2020

Вчера я сделал привязку Shiny для библиотеки ComboTree . Это работает, но это не фантастика c.

Файл comboTreeBinding. js для помещения в подпапку www*1008*:

var comboTreeBinding = new Shiny.InputBinding();

$.extend(comboTreeBinding, {
  find: function (scope) {
    return $(scope).find(".comboTree");
  },
  getValue: function (el) {
    var value = el.value.split(", ");
    var empty = value.length === 1 && value[0] === "";
    return empty ? null : value;
  },
  setValue: function(el, value) {
    $(el).setSelection(value);
  },
  subscribe: function (el, callback) {
    $(el).on("change.comboTreeBinding", function (e) {
      callback();
    });
  },
  unsubscribe: function (el) {
    $(el).off(".comboTreeBinding");
  },
  initialize: function(el) {
        var $el = $(el);
        $el.comboTree({
      source: $el.data("choices"),
      isMultiple: $el.data("multiple"),
      cascadeSelect: $el.data("cascaded"),
      collapse: true
    });
  }
});

Shiny.inputBindings.register(comboTreeBinding);

Блестящее приложение (поместите файлы в стиле . css и comboTreePlugin. js в подпапку www*1018*):

library(shiny)
library(jsonlite)

comboTreeInput <- function(inputId, width = "30%", height = "100px", 
                           choices, multiple = TRUE, cascaded = TRUE){
  tags$div(style = sprintf("width: %s; height: %s;", width, height),
           tags$input(id = inputId, class = "comboTree", type = "text", 
                      placeholder = "Select",
                      `data-choices` = as.character(toJSON(choices, auto_unbox = TRUE)),
                      `data-multiple` = ifelse(multiple, "true", "false"), 
                      `data-cascaded` = ifelse(cascaded, "true", "false")
           )
  )
}

choices <- list(
  list(id = 1, title = "item1"),
  list(id = 2, title = "item2", 
       subs = list(
         list(id = 21, title = "item2-1"), 
         list(id = 22, title = "item2-2")
       )
  ), 
  list(id = 3, title = "item3",
       subs = list(
         list(id = 31, title = "item3-1", isSelectable = FALSE,
              subs = list(
                list(id = 311, title = "item3-1-1"),
                list(id = 312, title = "item3-1-2")
              )
         ),
         list(id = 32, title = "item3-2")
       )
  )
)

ui <- fluidPage(
  tags$head(
    tags$link(rel = "stylesheet", href = "style.css"),
    tags$script(src = "comboTreePlugin.js"),
    tags$script(src = "comboTreeBinding.js")
  ),
  br(),
  h3("You selected:"),
  verbatimTextOutput("selections"),
  br(),
  comboTreeInput("mycombotree", choices = choices)
)

server <- function(input, output, session){

  output[["selections"]] <- renderPrint({
    input[["mycombotree"]]
  })

}

shinyApp(ui, server)

enter image description here

...