Skip to content

wleepang/shiny-directory-input

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

74 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

directoryInput

A widget for interactive selection of directories for R Shiny Applications

directory widget

Application

Provides an input for users to select directories via an interactive, and os native dialog, rather than having to type in paths in a textInput().

NOTE: This is intended to only be used with locally run shiny applications. It will not work on server deployed applications because it uses OS shell calls to present a directory choosing dialog. There is currently no way (that I'm aware) of securely presenting a client side directory selection dialog from a hosted web application.

Install the package

First install the shiny R-package from CRAN as it is required:

install.packages('shiny')

Then install this package from github:

devtools::install_github('wleepang/shiny-directory-input')

Special Requirements

  • Windows:
    • PowerShell 3 or higher

Run the demo

Simply run the code to see the widget in action:

library(shinyDirectoryInput)
shinyDirectoryInput::runDirinputExample()

Use the widget

In global.R in your own app (create it if it doesn't already exist) add the line:

library('shinyDirectoryInput')

In ui.R:

  • Add the widget
directoryInput('directory', label = 'select a directory')
  • Add the widget with a default value
directoryInput('directory', label = 'select a directory', value = '~')

In server.R:

  • Important: Pass session into the server, it is used to communicate with the client-side widget
shinyServer(function(input, output, session) {
  # ...
}
  • Invoke the dialog
path = readDirectoryInput(session, 'directory')
  • Update the widget value
path = 'path/to/directory'
updateDirectoryInput(session, 'directory', value = path)
  • Example: Observe when a user clicks the ... button to select a new directory
observeEvent(
  ignoreNULL = TRUE,
  eventExpr = {
    input$directory
  },
  handlerExpr = {
    if (input$directory > 0) {
      # condition prevents handler execution on initial app launch
      
      # launch the directory selection dialog with initial path read from the widget
      path = choose.dir(default = readDirectoryInput(session, 'directory'))
      
      # update the widget value
      updateDirectoryInput(session, 'directory', value = path)
    }
  }
)