-
-
Notifications
You must be signed in to change notification settings - Fork 41
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
# Pull Request Fixes #nnn ### Changes description - Adds `within` and `eval_code` to `teal_data_module` - Adds tests for new functions (100% coverage) - Updates `data-as-shiny-module` vignette - 🟠 Moves `{teal.code}` from `Suggests` to `Imports` --------- Signed-off-by: André Veríssimo <[email protected]> Co-authored-by: Marcin <[email protected]> Co-authored-by: Aleksander Chlebowski <[email protected]> Co-authored-by: 27856297+dependabot-preview[bot]@users.noreply.github.com <27856297+dependabot-preview[bot]@users.noreply.github.com>
- Loading branch information
1 parent
8ab7492
commit 32bfe75
Showing
13 changed files
with
506 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,104 @@ | ||
setOldClass("teal_data_module") | ||
|
||
#' Evaluate the code in the qenv environment | ||
#' @name eval_code | ||
#' @description | ||
#' Given code is evaluated in the `qenv` environment of `teal_data` reactive defined in `teal_data_module`. | ||
#' @param object (`teal_data_module`) | ||
#' @inheritParams teal.code::eval_code | ||
#' @return Returns a `teal_data_module` object. | ||
#' @importMethodsFrom teal.code eval_code | ||
#' @importFrom methods setMethod | ||
NULL | ||
|
||
#' @rdname eval_code | ||
#' @export | ||
#' | ||
#' @examples | ||
#' tdm <- teal_data_module( | ||
#' ui = function(id) div(id = shiny::NS(id)("div_id")), | ||
#' server = function(id) { | ||
#' shiny::moduleServer(id, function(input, output, session) { | ||
#' shiny::reactive(teal_data(IRIS = iris)) | ||
#' }) | ||
#' } | ||
#' ) | ||
#' eval_code(tdm, "IRIS <- subset(IRIS, Species == 'virginica')") | ||
setMethod("eval_code", signature = c("teal_data_module", "character"), function(object, code) { | ||
teal_data_module( | ||
ui = function(id) { | ||
ns <- NS(id) | ||
object$ui(ns("mutate_inner")) | ||
}, | ||
server = function(id) { | ||
moduleServer(id, function(input, output, session) { | ||
teal_data_rv <- object$server("mutate_inner") | ||
|
||
if (!is.reactive(teal_data_rv)) { | ||
stop("The `teal_data_module` must return a reactive expression.", call. = FALSE) | ||
} | ||
|
||
td <- eventReactive(teal_data_rv(), | ||
{ | ||
if (inherits(teal_data_rv(), c("teal_data", "qenv.error"))) { | ||
eval_code(teal_data_rv(), code) | ||
} else { | ||
teal_data_rv() | ||
} | ||
}, | ||
ignoreNULL = FALSE | ||
) | ||
td | ||
}) | ||
} | ||
) | ||
}) | ||
|
||
#' @rdname eval_code | ||
#' @export | ||
setMethod("eval_code", signature = c("teal_data_module", "language"), function(object, code) { | ||
eval_code(object, code = paste(lang2calls(code), collapse = "\n")) | ||
}) | ||
|
||
#' @rdname eval_code | ||
#' @export | ||
setMethod("eval_code", signature = c("teal_data_module", "expression"), function(object, code) { | ||
eval_code(object, code = paste(lang2calls(code), collapse = "\n")) | ||
}) | ||
|
||
#' @inherit teal.code::within.qenv params title details | ||
#' @description | ||
#' Convenience function for evaluating inline code inside the environment of a | ||
#' `teal_data_module` | ||
#' | ||
#' @param data (`teal_data_module`) object | ||
#' @return Returns a `teal_data_module` object with a delayed evaluation of `expr` | ||
#' when module. | ||
#' @export | ||
#' @seealso [base::within()], [teal_data_module()] | ||
#' @examples | ||
#' tdm <- teal_data_module( | ||
#' ui = function(id) div(id = shiny::NS(id)("div_id")), | ||
#' server = function(id) { | ||
#' shiny::moduleServer(id, function(input, output, session) { | ||
#' shiny::reactive(teal_data(IRIS = iris)) | ||
#' }) | ||
#' } | ||
#' ) | ||
#' within(tdm, IRIS <- subset(IRIS, Species == "virginica")) | ||
within.teal_data_module <- function(data, expr, ...) { | ||
expr <- substitute(expr) | ||
extras <- list(...) | ||
|
||
# Add braces for consistency. | ||
if (!identical(as.list(expr)[[1L]], as.symbol("{"))) { | ||
expr <- call("{", expr) | ||
} | ||
|
||
calls <- as.list(expr)[-1] | ||
|
||
# Inject extra values into expressions. | ||
calls <- lapply(calls, function(x) do.call(substitute, list(x, env = extras))) | ||
|
||
eval_code(object = data, code = as.expression(calls)) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.