-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathjstree-shiny.R
88 lines (84 loc) · 3.65 KB
/
jstree-shiny.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#' @title Shiny bindings for jstree
#'
#' @description Output and render functions for using \code{jstree} within
#' Shiny applications and interactive Rmd documents. See examples with
#' \code{\link{jstreeExample}}.
#'
#' @param outputId output variable to read from
#' @param width,height must be a valid CSS unit (like \code{'100\%'},
#' \code{'400px'}, \code{'auto'}) or a number, which will be coerced to a
#' string and have \code{'px'} appended
#' @param expr an expression that generates a \code{\link{jstree}}
#' @param env the environment in which to evaluate \code{expr}
#' @param quoted logical, whether \code{expr} is a quoted expression
#' (with \code{quote()}); this is useful if you want to save an expression
#' in a variable
#'
#' @return \code{jstreeOutput} returns an output element that can be included
#' in a Shiny UI definition, and \code{renderJstree} returns a
#' \code{shiny.render.function} object that can be included in a Shiny server
#' definition.
#'
#' @section Shiny values:
#' If the \code{outputId} is called \code{"ID"} for example, you have four
#' or seven available Shiny \code{input} values in the server:
#' \code{input[["ID"]]} contains the tree with the node fields \code{text}
#' and \code{data} only, \code{input[["ID_full"]]} contains the full tree,
#' \code{input[["ID_selected"]]} contains the selected nodes,
#' \code{input[["ID_selected_paths"]]} is like \code{input[["ID_selected"]]}
#' except that it provides the paths to the selected nodes instead of only
#' the values of their text field. This makes four Shiny values always
#' present. There are three additional Shiny values if you have set
#' \code{checkboxes=TRUE} in the \code{\link{jstree}} command:
#' \code{input[["ID_checked"]]} contains the checked nodes,
#' \code{input[["ID_checked_paths"]]} provides the paths to the checked
#' nodes. If you have set \code{checkboxes=TRUE} and
#' \code{checkWithText=TRUE} (the default), then these two additional
#' Shiny values are useless because 'checked' is the same as 'selected' in
#' this situation. Try \code{jstreeExample("checkWithText")}. Finally, the
#' seventh Shiny value that is provided when \code{checkboxes=TRUE} is
#' \code{input[["ID_checked_tree"]]}. It is like \code{input[["ID_checked"]]}
#' except that it returns the hierarchy, in other words it provides the
#' checked nodes with their parent(s).
#'
#' @name jstree-shiny
#'
#' @importFrom htmlwidgets shinyWidgetOutput shinyRenderWidget
#' @export
jstreeOutput <- function(outputId, width = "100%", height = "auto"){
shinyWidgetOutput(
outputId, 'jstreer', width, height, package = 'jsTreeR'
)
}
#' @rdname jstree-shiny
#' @export
renderJstree <- function(expr, env = parent.frame(), quoted = FALSE) {
if(!quoted) expr <- substitute(expr) # force quoted
shinyRenderWidget(expr, jstreeOutput, env, quoted = TRUE)
}
#' @title Destroy jstree
#' @description Destroy a `jstree` instance in a Shiny app.
#'
#' @param session the Shiny \code{session} object
#' @param id the id of the tree to be destroyed
#'
#' @return No value, just called to destroy a tree.
#' @export
jstreeDestroy <- function(session, id){
session$sendCustomMessage(paste0(id, "_destroy"), TRUE)
}
#' @title Update jstree
#' @description Update a `jstree` instance in a Shiny app.
#'
#' @param session the Shiny \code{session} object
#' @param id the id of the tree to be updated
#' @param nodes the new \code{nodes} list
#'
#' @return No value, just called to update a tree.
#' @export
jstreeUpdate <- function(session, id, nodes){
if(!isNodesList(nodes)) {
stop("Invalid `nodes` argument.")
}
session$sendCustomMessage(paste0(id, "_update"), nodes)
}