Manipulate an existing DataTables instance in a Shiny app
The function dataTableProxy()
creates a proxy object that can be used
to manipulate an existing DataTables instance in a Shiny app, e.g. select
rows/columns, or add rows.
dataTableProxy( outputId, session = shiny::getDefaultReactiveDomain(), deferUntilFlush = TRUE ) selectRows(proxy, selected, ignore.selectable = FALSE) selectColumns(proxy, selected, ignore.selectable = FALSE) selectCells(proxy, selected, ignore.selectable = FALSE) addRow(proxy, data, resetPaging = TRUE) clearSearch(proxy) selectPage(proxy, page) updateCaption(proxy, caption) updateSearch(proxy, keywords = list(global = NULL, columns = NULL)) showCols(proxy, show, reset = FALSE) hideCols(proxy, hide, reset = FALSE) colReorder(proxy, order, origOrder = FALSE) reloadData( proxy, resetPaging = TRUE, clearSelection = c("all", "none", "row", "column", "cell") )
outputId |
the id of the table to be manipulated (the same id as the one
you used in |
session |
the Shiny session object (from the server function of the Shiny app) |
deferUntilFlush |
whether an action should be carried out right away, or should be held until after the next time all of the outputs are updated |
proxy |
a proxy object returned by |
selected |
an integer vector of row/column indices, or a matrix of two
columns (row and column indices, respectively) for cell indices; you may
use |
ignore.selectable |
when |
data |
a single row of data to be added to the table; it can be a matrix
or data frame of one row, or a vector or list of row data (in the latter
case, please be cautious about the row name: if your table contains row
names, here |
resetPaging |
whether to reset the paging position |
page |
a number indicating the page to select |
caption |
a new table caption (see the |
keywords |
a list of two components: |
show |
a vector of column positions to show (the indexing starts at 0, but if row.names are visible, they are the first column). |
reset |
if |
hide |
a vector of column positions to hide |
order |
A numeric vector of column positions, starting from 0, and including the row.names as a column, if they are include. Must contain a value for all columns, regardless of whether they are visible or not. Also for column reordering to work, the datatable must have extension 'ColReorder' set as well as option 'colReordoer' set to TRUE). |
origOrder |
Whether column reordering should be relative to the original order (the default is to compare to current order) |
clearSelection |
which existing selections to clear: it can be any
combinations of |
addRow()
only works for client-side tables. If you want to use
it in a Shiny app, make sure to use renderDataTable(..., server =
FALSE)
. Also note that the column filters (if used) of the table will not
be automatically updated when a new row is added, e.g., the range of the
slider of a column will stay the same even if you have added a value
outside the range of the original data column.
reloadData()
only works for tables in the server-side processing
mode, e.g. tables rendered with renderDataTable(server = TRUE)
. The
data to be reloaded (i.e. the one you pass to dataTableAjax()
) must
have exactly the same number of columns as the previous data object in the
table.
Please choose more modern alternatives, such as Google Chrome or Mozilla Firefox.