inst/shiny-GUI/SANTA-App/data/chooser.R

# Title: Custom input control
# Author: Joe Cheng <joe@rstudio.com>
# AuthorUrl: http://www.rstudio.com/
# License: MIT
# Type: Shiny
# Tags: javascript custom-input
# DisplayMode: Normal
# https://github.com/rstudio/shiny-examples/tree/master/036-custom-input-control

chooserInput <- function(inputId, leftLabel, rightLabel, leftChoices, rightChoices,
  size = 5, multiple = FALSE) {
  
  leftChoices <- lapply(leftChoices, tags$option)
  rightChoices <- lapply(rightChoices, tags$option)
  
  if (multiple)
    multiple <- "multiple"
  else
    multiple <- NULL
  
  tagList(
    singleton(tags$head(
      tags$script(src="chooser-binding.js"),
      tags$style(type="text/css",
        HTML(".chooser-container { display: inline-block; }")
      )
    )),
    div(id=inputId, class="chooser",
      div(class="chooser-container chooser-left-container",
       h4(leftLabel),
        tags$select(class="left", size=size, multiple=multiple, leftChoices)
      ),
      div(class="chooser-container chooser-center-container",
        icon("arrow-alt-circle-right", "right-arrow fa-3x"),
        tags$br(),
        icon("arrow-alt-circle-left", "left-arrow fa-3x")
      ),
      div(class="chooser-container chooser-right-container",
        h4(rightLabel),
        tags$select(class="right", size=size, multiple=multiple, rightChoices)
      )
    )
  )
}

registerInputHandler("shinyjsexamples.chooser", function(data, ...) {
  if (is.null(data))
    NULL
  else
    list(left=as.character(data$left), right=as.character(data$right))
}, force = TRUE)
adwolfer/santaR documentation built on March 10, 2024, 5:28 p.m.