inst/examples/10-node-ids/server.R

library(shiny)
library(shinyTree)

#' Define server logic required to generate a simple tree
#' @author Mike Schaffer \email{mschaff@gmail.com}
shinyServer(function(input, output, session) {
  log <- c(paste0(Sys.time(), ": Interact with the tree to see the logs here..."))
  
  output$tree <- renderTree({
    structure(
      list(
        'Project A' = structure(
          list(
            'Study A-A'=structure('',stid=1,stclass='study'), 
            'Study A-B'=structure('',stid=2,stclass='study')
          ),
          stid=1,
          stopened=TRUE,
          stclass='project'
        ), 
        'Project B' = structure(
          list(
            'Study B-A'=structure('',stid=3,stclass='study'), 
            'Study B-B'=structure('',stid=4,stclass='study')
          ),
          stid=2,
          stopened=TRUE,
          stclass='project'
        )
      ),
      stopened=TRUE
    )
  })
  
  output$selTxt <- renderPrint({
    tree <- input$tree
    if (is.null(tree)){
      "None"
    } else{
      #cat( attr(get_selected(input$tree, format="slices"),"id" ) )
      # names(as.data.frame(get_selected(input$tree, format = "slices")))
      
      str(get_selected(input$tree, format = "classid"))
    }
  })
  
  output$treeTxt <- renderPrint({
    tree <- input$tree
    if (is.null(tree)){
      "None"
    } else{
      str(input$tree)
    }
  })
  
  
})

Try the shinyTree package in your browser

Any scripts or data that you put into this service are public.

shinyTree documentation built on Aug. 8, 2023, 1:08 a.m.