vignettes/downloadableTable-module.Rmd
downloadableTable-module.Rmd
This Shiny Module provides a consistent and easy-to-use table including a downloadFileButton that is automatically created, linked and managed.
downloadableTable
parameter downloaddatafxn
or
downloadableTableUI
parameter downloadtypes
is
emptyShiny modules consist of a pair of functions that modularize, or package, a small piece of reusable functionality. The UI function is called directly by the user to place the UI in the correct location (as with other shiny UI objects). The module server function that is called only once to set it up using the module name as a function inside the server function (i.e. user-local session scope. The first function argument is a string that represents the module id (the same id used in module UI function). Additional arguments can be supplied by the user based on the specific shiny module that is called. There can be additional helper functions that are a part of a shiny module.
The downloadableTable Shiny Module is a part of the periscope2 package and consists of the following functions:
The downloadableTableUI function is called from the ui.R (or equivalent) file in the location where the table should be placed. This is similar to other UI element placement in shiny.
The downloadableTableUI looks like:
The downloadableTableUI function takes the unique object ID for the UI object.
The next two arguments (downloadtypes and hovertext) are passed to the downloadFileButton and set the file types the button will allow the user to request and the downloadFileButton’s tooltip text.
The contentHeight argument is optional but important - it sets the viewable height of the table content which can be any css-recognizable size value.
The downloadableTables are multi-select by default, however if you need a table to only allow single row selections you can set the singleSelect argument to TRUE.
# Inside ui_body.R or ui_sidebar.R
downloadableTableUI(id = "object_id1",
downloadtypes = c("csv", "tsv"),
hovertext = "Download the data here!",
contentHeight = "300px",
singleSelect = FALSE)
The downloadableTable function is called directly. The call consists of the following:
Data Function or Reactive Expression Requirements
Reactive Return Value
The server function returns a reactive expression containing the selected rows. Note that this is the data, not references, rownumbers, etc from the table – it is the actual, visible, table row data. This allows the developer to use this more easily to update another table, chart, etc. as desired.
It is acceptable to ignore the return value as well if this functionality is not needed. Simply do not assign the result to a variable.
Customization Options
downloadableTable module can be customized using DT
arguments, options or format functions (see
?DT::datatable
). These options can be sent as a named
options via the server function, see example below.
Caveats on DT usage:
selection
parameter in the server function has
different usage than DT::datatable
selection
option as it should be a function or reactive expression providing the
row_ids of the rows that should be selected. Its default value is
NULL
editable
, width
, height
options in DT::datatable
are not supportedThe following is an example of a customized downloadableTable:
It was generated using the following code:
# Inside server_local.R
sketch <- htmltools::withTags(
table(
class = "display",
thead(
tr(
th(rowspan = 2, "Location"),
th(colspan = 2, "Statistics")
),
tr(
th("Change"),
th("Increase")
)
)
)
)
selectedrows <- downloadableTable(
id = "exampleDT1",
logger = ss_userAction.Log,
filenameroot = "exampletable",
downloaddatafxns = list(csv = load_data3, tsv = load_data3),
tabledata = load_data3,
colnames = c("Area", "Delta", "Increase"),
filter = "bottom",
callback = htmlwidgets::JS("table.order([1, 'asc']).draw();"),
container = sketch,
formatStyle = list(columns = c("Total.Population.Change"),
color = DT::styleInterval(0, c("red", "green"))),
formatStyle = list(columns = c("Natural.Increase"),
backgroundColor = DT::styleInterval(
c(7614, 15914, 34152),
c("blue", "lightblue", "#FF7F7F", "red")))
)
# NOTE: selectedrows is the reactive return value, captured for later use
For a complete running shiny example application using the downloadableTable module you can create and run a periscope2 sample application using:
library(periscope2)
app_dir = tempdir()
create_new_application(name = 'mysampleapp', location = app_dir, sample_app = TRUE)
runApp(paste(app_dir, 'mysampleapp', sep = .Platform$file.sep))