From 509705809831014cbdca68f4548b50da6039d27c Mon Sep 17 00:00:00 2001 From: walkowif <59475134+walkowif@users.noreply.github.com> Date: Mon, 19 Aug 2024 09:06:39 +0200 Subject: [PATCH 01/42] Workflow propagations (#767) Signed-off-by: walkowif <59475134+walkowif@users.noreply.github.com> Co-authored-by: 27856297+dependabot-preview[bot]@users.noreply.github.com <27856297+dependabot-preview[bot]@users.noreply.github.com> Co-authored-by: Pawel Rucki <12943682+pawelru@users.noreply.github.com> --- .github/workflows/check.yaml | 6 ++---- .github/workflows/docs.yaml | 1 + .github/workflows/on-demand.yaml | 12 ------------ .github/workflows/release.yaml | 4 ++++ .github/workflows/scheduled.yaml | 16 ++++++++++++++++ _pkgdown.yml | 2 ++ 6 files changed, 25 insertions(+), 16 deletions(-) delete mode 100644 .github/workflows/on-demand.yaml diff --git a/.github/workflows/check.yaml b/.github/workflows/check.yaml index 4bce0c86d..a3dc3dfed 100644 --- a/.github/workflows/check.yaml +++ b/.github/workflows/check.yaml @@ -51,12 +51,10 @@ jobs: additional-env-vars: | _R_CHECK_EXAMPLE_TIMING_THRESHOLD_=11 TESTING_DEPTH=5 + NOT_CRAN=true enforce-note-blocklist: true - publish-unit-test-report-gh-pages: false - junit-xml-comparison: false concurrency-group: non-cran - disable-unit-test-reports: true - skip-r-cmd-install: true + unit-test-report-directory: unit-test-report-non-cran note-blocklist: | checking dependencies in R code .* NOTE checking R code for possible problems .* NOTE diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml index 9b7a7e54e..57ae80042 100644 --- a/.github/workflows/docs.yaml +++ b/.github/workflows/docs.yaml @@ -41,3 +41,4 @@ jobs: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} with: default-landing-page: latest-tag + additional-unit-test-report-directories: unit-test-report-non-cran diff --git a/.github/workflows/on-demand.yaml b/.github/workflows/on-demand.yaml deleted file mode 100644 index 02843bb32..000000000 --- a/.github/workflows/on-demand.yaml +++ /dev/null @@ -1,12 +0,0 @@ ---- -name: On-demand 🧑‍🔬 - -on: - schedule: - - cron: '45 3 * * 0' - workflow_dispatch: - -jobs: - revdepcheck: - name: revdepcheck ↩️ - uses: insightsengineering/r.pkg.template/.github/workflows/revdepcheck.yaml@main diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 226473ce9..e56418bb8 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -52,3 +52,7 @@ jobs: uses: insightsengineering/r.pkg.template/.github/workflows/test-coverage.yaml@main secrets: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} + wasm: + name: Build WASM packages 🧑‍🏭 + needs: release + uses: insightsengineering/r.pkg.template/.github/workflows/wasm.yaml@main diff --git a/.github/workflows/scheduled.yaml b/.github/workflows/scheduled.yaml index f2ddf6862..73e3ce868 100644 --- a/.github/workflows/scheduled.yaml +++ b/.github/workflows/scheduled.yaml @@ -26,3 +26,19 @@ jobs: uses: insightsengineering/r.pkg.template/.github/workflows/branch-cleanup.yaml@main secrets: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} + revdepcheck: + name: revdepcheck ↩️ + uses: insightsengineering/r.pkg.template/.github/workflows/revdepcheck.yaml@main + rhub: + name: R-hub 🌐 + uses: insightsengineering/r.pkg.template/.github/workflows/rhub.yaml@main + with: + lookup-refs: | + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/tern + insightsengineering/rtables diff --git a/_pkgdown.yml b/_pkgdown.yml index ec36b1c74..d8d697150 100644 --- a/_pkgdown.yml +++ b/_pkgdown.yml @@ -15,6 +15,8 @@ navbar: href: coverage-report/ - text: Unit test report href: unit-test-report/ + - text: Non-CRAN unit test report + href: unit-test-report-non-cran/ github: icon: fa-github href: https://github.com/insightsengineering/teal.modules.general From 45eaf8f9cd04b1c420f08eac8789b5bd6c8d50db Mon Sep 17 00:00:00 2001 From: walkowif Date: Mon, 19 Aug 2024 07:07:34 +0000 Subject: [PATCH 02/42] [skip actions] Bump version to 0.3.0.9041 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 241ddf308..c8ee22835 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9040 -Date: 2024-08-14 +Version: 0.3.0.9041 +Date: 2024-08-19 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index d5620160f..a19867933 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9040 +# teal.modules.general 0.3.0.9041 * Removed `Show Warnings` modals from modules. From ee0c6dbfcd8af88215120a219546ebfcd00dc19c Mon Sep 17 00:00:00 2001 From: Pawel Rucki <12943682+pawelru@users.noreply.github.com> Date: Wed, 28 Aug 2024 15:54:01 +0200 Subject: [PATCH 03/42] update readme (#777) - remove r-universe from install instructions for simplicity - remove r-universe link - this fixes url-checker - add reference to the introduction article --- README.md | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index ef66a1ece..56a13a866 100644 --- a/README.md +++ b/README.md @@ -41,26 +41,19 @@ Please see [`teal` gallery](https://github.com/insightsengineering/teal.gallery) ## Installation ```r -# stable versions install.packages('teal.modules.general') - -# install.packages("pak") -pak::pak("insightsengineering/teal.modules.general@*release") ``` -Alternatively, you might want to use the development version available on [r-universe](https://r-universe.dev/). +Alternatively, you might want to use the development version. ```r -# beta versions -install.packages('teal.modules.general', repos = c('https://pharmaverse.r-universe.dev', getOption('repos'))) - # install.packages("pak") pak::pak("insightsengineering/teal.modules.general") ``` ## Usage -See package vignettes `browseVignettes(package = "teal.modules.general")` for usage of this package or visit [Package Website](https://insightsengineering.github.io/teal.modules.general/latest-tag/). +To understand how to use this package, please refer to the [Getting Started](https://insightsengineering.github.io/teal.modules.general/latest-tag/articles/teal-modules-general.html) article, which provides multiple examples of code implementation. ## Getting help From 7026ce272feac76ab34a752918ed356e8f73e624 Mon Sep 17 00:00:00 2001 From: pawelru Date: Wed, 28 Aug 2024 13:55:03 +0000 Subject: [PATCH 04/42] [skip actions] Bump version to 0.3.0.9042 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index c8ee22835..6eb16af8a 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9041 -Date: 2024-08-19 +Version: 0.3.0.9042 +Date: 2024-08-28 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index a19867933..b8e7a20f5 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9041 +# teal.modules.general 0.3.0.9042 * Removed `Show Warnings` modals from modules. From 1f93830493eb8f160c4a1b5a481bb625b1841609 Mon Sep 17 00:00:00 2001 From: Pawel Rucki <12943682+pawelru@users.noreply.github.com> Date: Tue, 10 Sep 2024 18:45:57 +0200 Subject: [PATCH 05/42] Update DESCRIPTION (#776) - be in line with whats in suggests - cran type of reference is redundant Signed-off-by: Pawel Rucki <12943682+pawelru@users.noreply.github.com> --- DESCRIPTION | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 6eb16af8a..b7026f534 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -90,10 +90,10 @@ Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, insightsengineering/tern, tidyverse/tibble, tidyverse/tidyr, tidymodels/broom, daattali/colourpicker, daattali/ggExtra, aphalo/ggpmisc, aphalo/ggpp, slowkow/ggrepel, baddstats/goftest, - gridExtra, ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, - daroczig/logger, deepayan/lattice, MASS, - insightsengineering/nestcolor, r-lib/rlang, rstudio/rmarkdown, - insightsengineering/rtables, tidyverse/rvest, sparkline, + ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, + daroczig/logger, deepayan/lattice, + insightsengineering/nestcolor, r-lib/pkgload, r-lib/rlang, rstudio/rmarkdown, + insightsengineering/rtables, tidyverse/rvest, htmlwidgets/sparkline, rstudio/shinytest2, r-lib/testthat, r-lib/withr Config/Needs/website: insightsengineering/nesttemplate Encoding: UTF-8 From c3ca9622bde42b79b025d1840f36fcf3199d4fb5 Mon Sep 17 00:00:00 2001 From: pawelru Date: Tue, 10 Sep 2024 16:46:54 +0000 Subject: [PATCH 06/42] [skip actions] Bump version to 0.3.0.9043 --- DESCRIPTION | 14 +++++++------- NEWS.md | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index b7026f534..35bcb17ff 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9042 -Date: 2024-08-28 +Version: 0.3.0.9043 +Date: 2024-09-10 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), @@ -90,11 +90,11 @@ Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, insightsengineering/tern, tidyverse/tibble, tidyverse/tidyr, tidymodels/broom, daattali/colourpicker, daattali/ggExtra, aphalo/ggpmisc, aphalo/ggpp, slowkow/ggrepel, baddstats/goftest, - ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, - daroczig/logger, deepayan/lattice, - insightsengineering/nestcolor, r-lib/pkgload, r-lib/rlang, rstudio/rmarkdown, - insightsengineering/rtables, tidyverse/rvest, htmlwidgets/sparkline, - rstudio/shinytest2, r-lib/testthat, r-lib/withr + ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, daroczig/logger, + deepayan/lattice, insightsengineering/nestcolor, r-lib/pkgload, + r-lib/rlang, rstudio/rmarkdown, insightsengineering/rtables, + tidyverse/rvest, htmlwidgets/sparkline, rstudio/shinytest2, + r-lib/testthat, r-lib/withr Config/Needs/website: insightsengineering/nesttemplate Encoding: UTF-8 Language: en-US diff --git a/NEWS.md b/NEWS.md index b8e7a20f5..d2edfb2f9 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9042 +# teal.modules.general 0.3.0.9043 * Removed `Show Warnings` modals from modules. From 022a92ad71b5c3f2fe2f8a00936a4e6bd7d8dcf8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dawid=20Ka=C5=82=C4=99dkowski?= <6959016+gogonzo@users.noreply.github.com> Date: Wed, 11 Sep 2024 22:58:38 +0200 Subject: [PATCH 07/42] @datanames ignored (#782) Fix after https://github.com/insightsengineering/teal/pull/1334 --- tests/testthat/test-shinytest2-tm_variable_browser.R | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/testthat/test-shinytest2-tm_variable_browser.R b/tests/testthat/test-shinytest2-tm_variable_browser.R index 854f1352d..abf5680f8 100644 --- a/tests/testthat/test-shinytest2-tm_variable_browser.R +++ b/tests/testthat/test-shinytest2-tm_variable_browser.R @@ -10,18 +10,18 @@ app_driver_tm_variable_browser <- function() { CO2 <- CO2 # nolint: object_name. } ) - teal.data::datanames(data) <- c("iris", "mtcars", "women", "faithful", "CO2") init_teal_app_driver( data = data, modules = tm_variable_browser( label = "Variable browser (e2e)", + datasets_selected = c("iris", "mtcars", "women", "faithful", "CO2"), parent_dataname = "CO2", ggplot2_args = teal.widgets::ggplot2_args( labs = list(subtitle = "Plot generated by Variable Browser Module") ), pre_output = shiny::tags$div("A pre-output message for tm_variable_browser"), - post_output = shiny::tags$div("A post-output message for tm_variable_browser"), + post_output = shiny::tags$div("A post-output message for tm_variable_browser") ) ) } From b2336e4b54202ca85e361906551ada3e40d2f338 Mon Sep 17 00:00:00 2001 From: donyunardi Date: Wed, 11 Sep 2024 20:59:31 +0000 Subject: [PATCH 08/42] [skip actions] Bump version to 0.3.0.9044 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 35bcb17ff..d6041f6d1 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9043 -Date: 2024-09-10 +Version: 0.3.0.9044 +Date: 2024-09-11 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index d2edfb2f9..5db3ac959 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9043 +# teal.modules.general 0.3.0.9044 * Removed `Show Warnings` modals from modules. From c7f8ab9855b53479f1176e5dc1105f224befd6ca Mon Sep 17 00:00:00 2001 From: Pawel Rucki <12943682+pawelru@users.noreply.github.com> Date: Thu, 12 Sep 2024 01:45:28 +0200 Subject: [PATCH 09/42] Update scheduled.yaml (#781) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Part of https://github.com/insightsengineering/teal.modules.general/issues/771 https://github.com/insightsengineering/teal.modules.general/actions/runs/10650763277/job/29522527240 ``` ✖ Package teal not found in the `insightsengineering/teal.transform`, `insightsengineering/teal.code`, `insightsengineering/teal.data`, `insightsengineering/teal.logger`, `insightsengineering/teal.reporter`, `insightsengineering/teal.widgets`, `insightsengineering/tern`, and `insightsengineering/rtables` list. Exiting. ``` Signed-off-by: Pawel Rucki <12943682+pawelru@users.noreply.github.com> --- .github/workflows/scheduled.yaml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/scheduled.yaml b/.github/workflows/scheduled.yaml index 73e3ce868..86b8582d9 100644 --- a/.github/workflows/scheduled.yaml +++ b/.github/workflows/scheduled.yaml @@ -34,6 +34,7 @@ jobs: uses: insightsengineering/r.pkg.template/.github/workflows/rhub.yaml@main with: lookup-refs: | + insightsengineering/teal insightsengineering/teal.transform insightsengineering/teal.code insightsengineering/teal.data From f940d8e856ecaa013a755ef6681c459241ddc483 Mon Sep 17 00:00:00 2001 From: pawelru Date: Wed, 11 Sep 2024 23:46:24 +0000 Subject: [PATCH 10/42] [skip actions] Bump version to 0.3.0.9045 --- DESCRIPTION | 2 +- NEWS.md | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index d6041f6d1..f9a0819ae 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,7 +1,7 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9044 +Version: 0.3.0.9045 Date: 2024-09-11 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), diff --git a/NEWS.md b/NEWS.md index 5db3ac959..3cf1ded85 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9044 +# teal.modules.general 0.3.0.9045 * Removed `Show Warnings` modals from modules. From de466acc0d7919cf65bf95ec14572f0fe3a6df03 Mon Sep 17 00:00:00 2001 From: saerobson <86623301+saerobson@users.noreply.github.com> Date: Thu, 12 Sep 2024 16:11:09 +0100 Subject: [PATCH 11/42] Update tm_g_distribution.R (#766) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: saerobson <86623301+saerobson@users.noreply.github.com> Co-authored-by: Dony Unardi Co-authored-by: Dawid Kałędkowski <6959016+gogonzo@users.noreply.github.com> --- R/tm_g_distribution.R | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/R/tm_g_distribution.R b/R/tm_g_distribution.R index 390ab4c88..1361e3504 100644 --- a/R/tm_g_distribution.R +++ b/R/tm_g_distribution.R @@ -510,11 +510,8 @@ srv_distribution <- function(id, selector_list()$dist_i()$select ), handlerExpr = { - req(input$params_reset) params <- if (length(input$t_dist) != 0) { - dist_var2 <- as.vector(merged$anl_input_r()$columns_source$dist_i) - get_dist_params <- function(x, dist) { if (dist == "unif") { return(stats::setNames(range(x, na.rm = TRUE), c("min", "max"))) @@ -525,8 +522,8 @@ srv_distribution <- function(id, ) } - ANL <- merged$anl_q_r()[[as.character(dist_var[[1]]$dataname)]] - round(get_dist_params(as.numeric(stats::na.omit(ANL[[dist_var2]])), input$t_dist), 2) + ANL <- merged$anl_q_r()[["ANL"]] + round(get_dist_params(as.numeric(stats::na.omit(ANL[[merge_vars()$dist_var]])), input$t_dist), 2) } else { c("param1" = NA_real_, "param2" = NA_real_) } From 652712875109376b05dfd2709c06c3508aa675c8 Mon Sep 17 00:00:00 2001 From: gogonzo Date: Thu, 12 Sep 2024 15:12:07 +0000 Subject: [PATCH 12/42] [skip actions] Bump version to 0.3.0.9046 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index f9a0819ae..c41a9720c 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9045 -Date: 2024-09-11 +Version: 0.3.0.9046 +Date: 2024-09-12 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 3cf1ded85..25855828a 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9045 +# teal.modules.general 0.3.0.9046 * Removed `Show Warnings` modals from modules. From 2327679278558a2edc6525f5186e9b91978861d3 Mon Sep 17 00:00:00 2001 From: Shunya <109354956+PritDash@users.noreply.github.com> Date: Thu, 12 Sep 2024 20:28:37 -0600 Subject: [PATCH 13/42] added checks to resolve issue with the outlier function (#778) Fixes #768 --- R/tm_outliers.R | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/R/tm_outliers.R b/R/tm_outliers.R index 7f30b897a..db3ce782d 100644 --- a/R/tm_outliers.R +++ b/R/tm_outliers.R @@ -964,7 +964,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, substitute( expr = { columns_index <- union( - setdiff(names(ANL_OUTLIER), "is_outlier_selected"), + setdiff(names(ANL_OUTLIER), c("is_outlier_selected", "order")), table_columns ) ANL_OUTLIER_EXTENDED[ANL_OUTLIER_EXTENDED$is_outlier_selected, columns_index] From 18e6655a795e9b78bdb9307c96dca33897047b66 Mon Sep 17 00:00:00 2001 From: donyunardi Date: Fri, 13 Sep 2024 02:29:30 +0000 Subject: [PATCH 14/42] [skip actions] Bump version to 0.3.0.9047 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index c41a9720c..cda7b0fc7 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9046 -Date: 2024-09-12 +Version: 0.3.0.9047 +Date: 2024-09-13 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 25855828a..514310dbe 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9046 +# teal.modules.general 0.3.0.9047 * Removed `Show Warnings` modals from modules. From 020440401275ab95c9320bb3b4fcbfbe3804715c Mon Sep 17 00:00:00 2001 From: walkowif <59475134+walkowif@users.noreply.github.com> Date: Mon, 16 Sep 2024 16:29:18 +0200 Subject: [PATCH 15/42] Workflow propagations (#780) --- .github/workflows/check.yaml | 3 +++ .github/workflows/release.yaml | 3 +++ .github/workflows/scheduled.yaml | 32 ++++++++++++++++++++++++++++++++ 3 files changed, 38 insertions(+) diff --git a/.github/workflows/check.yaml b/.github/workflows/check.yaml index a3dc3dfed..e7b7ebc6b 100644 --- a/.github/workflows/check.yaml +++ b/.github/workflows/check.yaml @@ -69,6 +69,9 @@ jobs: uses: insightsengineering/r.pkg.template/.github/workflows/test-coverage.yaml@main secrets: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} + with: + additional-env-vars: | + NOT_CRAN=true linter: if: github.event_name != 'push' name: SuperLinter 🦸‍♀️ diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index e56418bb8..aa3e7bb45 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -52,6 +52,9 @@ jobs: uses: insightsengineering/r.pkg.template/.github/workflows/test-coverage.yaml@main secrets: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} + with: + additional-env-vars: | + NOT_CRAN=true wasm: name: Build WASM packages 🧑‍🏭 needs: release diff --git a/.github/workflows/scheduled.yaml b/.github/workflows/scheduled.yaml index 86b8582d9..a73b25644 100644 --- a/.github/workflows/scheduled.yaml +++ b/.github/workflows/scheduled.yaml @@ -5,9 +5,26 @@ on: schedule: - cron: '45 3 * * 0' workflow_dispatch: + inputs: + chosen-workflow: + description: | + Select which workflow you'd like to run + required: true + type: choice + default: rhub + options: + - rhub + - dependency-test + - branch-cleanup + - revdepcheck jobs: dependency-test: + if: > + github.event_name == 'schedule' || ( + github.event_name == 'workflow_dispatch' && + inputs.chosen-workflow == 'dependency-test' + ) strategy: fail-fast: false matrix: @@ -22,14 +39,29 @@ jobs: additional-env-vars: | PKG_SYSREQS_DRY_RUN=true branch-cleanup: + if: > + github.event_name == 'schedule' || ( + github.event_name == 'workflow_dispatch' && + inputs.chosen-workflow == 'branch-cleanup' + ) name: Branch Cleanup 🧹 uses: insightsengineering/r.pkg.template/.github/workflows/branch-cleanup.yaml@main secrets: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} revdepcheck: + if: > + github.event_name == 'schedule' || ( + github.event_name == 'workflow_dispatch' && + inputs.chosen-workflow == 'revdepcheck' + ) name: revdepcheck ↩️ uses: insightsengineering/r.pkg.template/.github/workflows/revdepcheck.yaml@main rhub: + if: > + github.event_name == 'schedule' || ( + github.event_name == 'workflow_dispatch' && + inputs.chosen-workflow == 'rhub' + ) name: R-hub 🌐 uses: insightsengineering/r.pkg.template/.github/workflows/rhub.yaml@main with: From 2d73acd4e0dc7af0f5dd206970575febbf5c217e Mon Sep 17 00:00:00 2001 From: walkowif Date: Mon, 16 Sep 2024 14:30:14 +0000 Subject: [PATCH 16/42] [skip actions] Bump version to 0.3.0.9048 --- .pre-commit-config.yaml | 2 +- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 347dffa0a..7dd8e86f4 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -6,7 +6,7 @@ default_language_version: python: python3 repos: - repo: https://github.com/lorenzwalthert/precommit - rev: v0.4.3 + rev: v0.4.3.9001 hooks: - id: style-files name: Style code with `styler` diff --git a/DESCRIPTION b/DESCRIPTION index cda7b0fc7..bf40fcb9f 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9047 -Date: 2024-09-13 +Version: 0.3.0.9048 +Date: 2024-09-16 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 514310dbe..b424fe8b4 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9047 +# teal.modules.general 0.3.0.9048 * Removed `Show Warnings` modals from modules. From b61d9442975c3d3446785c3f36ff0a8fb8b88ded Mon Sep 17 00:00:00 2001 From: Alvaro Sanchez <71273913+svalvaro@users.noreply.github.com> Date: Tue, 17 Sep 2024 13:49:37 +0200 Subject: [PATCH 17/42] Fixes missing imports (#784) # Pull Request Fixes #783 There were a few missing imports that made the package unusable if we want to load functions with `box`. --- R/tm_variable_browser.R | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/R/tm_variable_browser.R b/R/tm_variable_browser.R index 626822d3d..c4b7ae6c8 100644 --- a/R/tm_variable_browser.R +++ b/R/tm_variable_browser.R @@ -907,9 +907,9 @@ render_tab_header <- function(dataset_name, output, data) { dataset_ui_id <- paste0("dataset_summary_", dataset_name) output[[dataset_ui_id]] <- renderText({ df <- data()[[dataset_name]] - join_keys <- join_keys(data()) + join_keys <- teal.data::join_keys(data()) if (!is.null(join_keys)) { - key <- join_keys(data())[dataset_name, dataset_name] + key <- teal.data::join_keys(data())[dataset_name, dataset_name] } else { key <- NULL } @@ -979,7 +979,7 @@ render_tab_table <- function(dataset_name, parent_dataname, output, data, input, # get icons proper for the data types icons <- vapply(df, function(x) class(x)[1L], character(1L)) - join_keys <- join_keys(data()) + join_keys <- teal.data::join_keys(data()) if (!is.null(join_keys)) { icons[intersect(join_keys[dataset_name, dataset_name], colnames(df))] <- "primary_key" } From 56dc3d600defd86ccea456ec349d9fee0aa73693 Mon Sep 17 00:00:00 2001 From: vedhav Date: Tue, 17 Sep 2024 11:50:35 +0000 Subject: [PATCH 18/42] [skip actions] Bump version to 0.3.0.9049 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index bf40fcb9f..aff6d9374 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9048 -Date: 2024-09-16 +Version: 0.3.0.9049 +Date: 2024-09-17 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index b424fe8b4..cdefc78f4 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9048 +# teal.modules.general 0.3.0.9049 * Removed `Show Warnings` modals from modules. From 05aeb65d00f86a3b78b77afab0296e50e83ae575 Mon Sep 17 00:00:00 2001 From: Pawel Rucki <12943682+pawelru@users.noreply.github.com> Date: Tue, 1 Oct 2024 10:31:18 +0200 Subject: [PATCH 19/42] use roxy.shinylive (#775) test with https://github.com/insightsengineering/roxy.shinylive/pull/1 Implementation of `roxy.shinylive`. Please run `pkgdown::build_site()` to see the difference. ![image](https://github.com/user-attachments/assets/96283a55-5c2a-493f-a855-5ef17425ac34) Extra: - for a few examples: remove dependency on `teal.widgets` so that the example code is simpler - for a few examples: replace `@examples` with `@examplesIf`. This is for our incorrect implementation of soft dependencies - add a new "Playground" section in the README with links to the shinylive - include shinylive iframe in the vignettes --------- Signed-off-by: Pawel Rucki <12943682+pawelru@users.noreply.github.com> Co-authored-by: 27856297+dependabot-preview[bot]@users.noreply.github.com <27856297+dependabot-preview[bot]@users.noreply.github.com> --- .gitignore | 2 ++ DESCRIPTION | 5 +-- R/tm_a_pca.R | 17 +++++----- R/tm_a_regression.R | 19 ++++++----- R/tm_data_table.R | 9 ++++++ R/tm_file_viewer.R | 4 +++ R/tm_front_page.R | 4 +++ R/tm_g_association.R | 17 +++++----- R/tm_g_bivariate.R | 18 +++++------ R/tm_g_distribution.R | 23 ++++++++------ R/tm_g_response.R | 19 ++++++----- R/tm_g_scatterplot.R | 23 ++++++++------ R/tm_g_scatterplotmatrix.R | 11 ++++++- R/tm_missing_data.R | 31 +++++++++--------- R/tm_outliers.R | 21 ++++++------ R/tm_t_crosstable.R | 21 ++++++------ R/tm_variable_browser.R | 38 ++++++++++++++-------- README.md | 7 ++++ inst/WORDLIST | 1 + man/tm_a_pca.Rd | 23 +++++++++----- man/tm_a_regression.Rd | 25 +++++++++------ man/tm_data_table.Rd | 15 +++++++++ man/tm_file_viewer.Rd | 10 ++++++ man/tm_front_page.Rd | 10 ++++++ man/tm_g_association.Rd | 23 +++++++++----- man/tm_g_bivariate.Rd | 24 ++++++++------ man/tm_g_distribution.Rd | 29 +++++++++++------ man/tm_g_response.Rd | 25 +++++++++------ man/tm_g_scatterplot.Rd | 29 +++++++++++------ man/tm_g_scatterplotmatrix.Rd | 21 ++++++++++-- man/tm_missing_data.Rd | 41 ++++++++++++++---------- man/tm_outliers.Rd | 27 +++++++++------- man/tm_t_crosstable.Rd | 31 +++++++++++------- man/tm_variable_browser.Rd | 44 ++++++++++++++++++-------- staged_dependencies.yaml | 3 ++ vignettes/teal-modules-general.Rmd | 31 ++++++++++++++---- vignettes/using-association-plot.Rmd | 26 ++++++++++++--- vignettes/using-bivariate-plot.Rmd | 26 ++++++++++++--- vignettes/using-cross-table.Rmd | 27 +++++++++++++--- vignettes/using-data-table.Rmd | 30 ++++++++++++++---- vignettes/using-outliers-module.Rmd | 30 ++++++++++++++---- vignettes/using-regression-plots.Rmd | 26 ++++++++++++--- vignettes/using-response-plot.Rmd | 26 ++++++++++++--- vignettes/using-scatterplot-matrix.Rmd | 27 +++++++++++++--- vignettes/using-scatterplot.Rmd | 35 ++++++++++++++------ 45 files changed, 663 insertions(+), 291 deletions(-) diff --git a/.gitignore b/.gitignore index fb00dbe32..1657ceda4 100644 --- a/.gitignore +++ b/.gitignore @@ -29,3 +29,5 @@ vignettes/*.R coverage.* tests/testthat/_snaps/**/*.new.md tests/testthat/_snaps/**/*.new.svg +/doc/ +/Meta/ diff --git a/DESCRIPTION b/DESCRIPTION index aff6d9374..8b91d2565 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -71,6 +71,7 @@ Suggests: pkgload, rlang (>= 1.0.0), rmarkdown (>= 2.23), + roxy.shinylive, rtables (>= 0.6.8), rvest, shinytest2, @@ -92,12 +93,12 @@ Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, aphalo/ggpmisc, aphalo/ggpp, slowkow/ggrepel, baddstats/goftest, ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, daroczig/logger, deepayan/lattice, insightsengineering/nestcolor, r-lib/pkgload, - r-lib/rlang, rstudio/rmarkdown, insightsengineering/rtables, + r-lib/rlang, rstudio/rmarkdown, insightsengineering/roxy.shinylive, insightsengineering/rtables, tidyverse/rvest, htmlwidgets/sparkline, rstudio/shinytest2, r-lib/testthat, r-lib/withr Config/Needs/website: insightsengineering/nesttemplate Encoding: UTF-8 Language: en-US LazyData: true -Roxygen: list(markdown = TRUE) +Roxygen: list(markdown = TRUE, packages = c("roxy.shinylive")) RoxygenNote: 7.3.2 diff --git a/R/tm_a_pca.R b/R/tm_a_pca.R index b2c0a1a2e..53996ebb7 100644 --- a/R/tm_a_pca.R +++ b/R/tm_a_pca.R @@ -18,9 +18,11 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples -#' library(teal.widgets) -#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -45,9 +47,6 @@ #' multiple = TRUE #' ), #' filter = NULL -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by PCA Module") #' ) #' ) #' ) @@ -56,6 +55,11 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -80,9 +84,6 @@ #' multiple = TRUE #' ), #' filter = NULL -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by PCA Module") #' ) #' ) #' ) diff --git a/R/tm_a_regression.R b/R/tm_a_regression.R index a941e5e20..89406f5e5 100644 --- a/R/tm_a_regression.R +++ b/R/tm_a_regression.R @@ -42,10 +42,12 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples #' # general data example -#' library(teal.widgets) -#' #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) @@ -77,9 +79,6 @@ #' multiple = TRUE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Regression Module") #' ) #' ) #' ) @@ -88,9 +87,12 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example -#' library(teal.widgets) -#' #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) @@ -123,9 +125,6 @@ #' multiple = TRUE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Regression Module") #' ) #' ) #' ) diff --git a/R/tm_data_table.R b/R/tm_data_table.R index 2d215f8c9..4a2be49d4 100644 --- a/R/tm_data_table.R +++ b/R/tm_data_table.R @@ -29,6 +29,10 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples #' # general data example #' data <- teal_data() @@ -53,6 +57,11 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example #' data <- teal_data() #' data <- within(data, { diff --git a/R/tm_file_viewer.R b/R/tm_file_viewer.R index 3b96185bb..772dfdac3 100644 --- a/R/tm_file_viewer.R +++ b/R/tm_file_viewer.R @@ -13,6 +13,10 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples #' data <- teal_data() #' data <- within(data, { diff --git a/R/tm_front_page.R b/R/tm_front_page.R index fbffb8769..7304eb90c 100644 --- a/R/tm_front_page.R +++ b/R/tm_front_page.R @@ -17,6 +17,10 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples #' data <- teal_data() #' data <- within(data, { diff --git a/R/tm_g_association.R b/R/tm_g_association.R index b0611490c..c3698f5d8 100644 --- a/R/tm_g_association.R +++ b/R/tm_g_association.R @@ -25,9 +25,11 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples -#' library(teal.widgets) -#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -60,9 +62,6 @@ #' multiple = TRUE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Association Module") #' ) #' ) #' ) @@ -71,6 +70,11 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -108,9 +112,6 @@ #' multiple = TRUE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Association Module") #' ) #' ) #' ) diff --git a/R/tm_g_bivariate.R b/R/tm_g_bivariate.R index 807b4f23b..bf9358476 100644 --- a/R/tm_g_bivariate.R +++ b/R/tm_g_bivariate.R @@ -46,9 +46,11 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples -#' library(teal.widgets) -#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -96,9 +98,6 @@ #' selected = "Treatment", #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Bivariate Module") #' ) #' ) #' ) @@ -106,7 +105,11 @@ #' shinyApp(app$ui, app$server) #' } #' -#' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -155,9 +158,6 @@ #' selected = "COUNTRY", #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Bivariate Module") #' ) #' ) #' ) diff --git a/R/tm_g_distribution.R b/R/tm_g_distribution.R index 1361e3504..6b6192678 100644 --- a/R/tm_g_distribution.R +++ b/R/tm_g_distribution.R @@ -27,9 +27,13 @@ #' #' @inherit shared_params return #' -#' @examples -#' library(teal.widgets) -#' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +# nolint start: line_length_linter. +#' @examplesIf require("ggpmisc", quietly = TRUE) && require("ggpp", quietly = TRUE) && require("goftest", quietly = TRUE) && require("MASS", quietly = TRUE) && require("broom", quietly = TRUE) +# nolint end: line_length_linter. #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -44,9 +48,6 @@ #' dist_var = data_extract_spec( #' dataname = "iris", #' select = select_spec(variable_choices("iris"), "Petal.Length") -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Distribution Module") #' ) #' ) #' ) @@ -55,6 +56,13 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +# nolint start: line_length_linter. +#' @examplesIf require("ggpmisc", quietly = TRUE) && require("ggpp", quietly = TRUE) && require("goftest", quietly = TRUE) && require("MASS", quietly = TRUE) && require("broom", quietly = TRUE) +# nolint end: line_length_linter. #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -94,9 +102,6 @@ #' vars = vars1, #' multiple = TRUE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Distribution Module") #' ) #' ) #' ) diff --git a/R/tm_g_response.R b/R/tm_g_response.R index 44daa300d..35ee6d36a 100644 --- a/R/tm_g_response.R +++ b/R/tm_g_response.R @@ -39,10 +39,12 @@ #' @note For more examples, please see the vignette "Using response plot" via #' `vignette("using-response-plot", package = "teal.modules.general")`. #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples #' # general data example -#' library(teal.widgets) -#' #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) @@ -77,9 +79,6 @@ #' multiple = FALSE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Response Module") #' ) #' ) #' ) @@ -88,9 +87,12 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example -#' library(teal.widgets) -#' #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) @@ -123,9 +125,6 @@ #' multiple = FALSE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Response Module") #' ) #' ) #' ) diff --git a/R/tm_g_scatterplot.R b/R/tm_g_scatterplot.R index 066ee5506..d093a4fad 100644 --- a/R/tm_g_scatterplot.R +++ b/R/tm_g_scatterplot.R @@ -30,9 +30,13 @@ #' #' @inherit shared_params return #' -#' @examples -#' library(teal.widgets) -#' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +# nolint start: line_length_linter. +#' @examplesIf require("ggpmisc", quietly = TRUE) && require("ggExtra", quietly = TRUE) && require("colourpicker", quietly = TRUE) +# nolint end: line_length_linter. #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -108,9 +112,6 @@ #' multiple = FALSE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Scatterplot Module") #' ) #' ) #' ) @@ -119,6 +120,13 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +# nolint start: line_length_linter. +#' @examplesIf require("ggpmisc", quietly = TRUE) && require("ggExtra", quietly = TRUE) && require("colourpicker", quietly = TRUE) +# nolint end: line_length_linter. #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -195,9 +203,6 @@ #' multiple = FALSE, #' fixed = FALSE #' ) -#' ), -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Scatterplot Module") #' ) #' ) #' ) diff --git a/R/tm_g_scatterplotmatrix.R b/R/tm_g_scatterplotmatrix.R index e8c7ce3b9..a570bf6bb 100644 --- a/R/tm_g_scatterplotmatrix.R +++ b/R/tm_g_scatterplotmatrix.R @@ -18,7 +18,11 @@ #' #' @inherit shared_params return #' -#' @examples +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examplesIf require("lattice", quietly = TRUE) #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -102,6 +106,11 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examplesIf require("lattice", quietly = TRUE) #' # CDISC data example #' data <- teal_data() #' data <- within(data, { diff --git a/R/tm_missing_data.R b/R/tm_missing_data.R index 7af029e74..7f026cb49 100644 --- a/R/tm_missing_data.R +++ b/R/tm_missing_data.R @@ -17,19 +17,11 @@ #' #' @inherit shared_params return #' -#' @examples -#' library(teal.widgets) -#' -#' # module specification used in apps below -#' tm_missing_data_module <- tm_missing_data( -#' ggplot2_args = list( -#' "Combinations Hist" = ggplot2_args( -#' labs = list(subtitle = "Plot produced by Missing Data Module", caption = NULL) -#' ), -#' "Combinations Main" = ggplot2_args(labs = list(title = NULL)) -#' ) -#' ) -#' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examplesIf require("gridExtra", quietly = TRUE) && require("rlang", quietly = TRUE) #' # general example data #' data <- teal_data() #' data <- within(data, { @@ -52,12 +44,19 @@ #' #' app <- init( #' data = data, -#' modules = modules(tm_missing_data_module) +#' modules = modules( +#' tm_missing_data() +#' ) #' ) #' if (interactive()) { #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examplesIf require("gridExtra", quietly = TRUE) && require("rlang", quietly = TRUE) #' # CDISC example data #' data <- teal_data() #' data <- within(data, { @@ -70,7 +69,9 @@ #' #' app <- init( #' data = data, -#' modules = modules(tm_missing_data_module) +#' modules = modules( +#' tm_missing_data() +#' ) #' ) #' if (interactive()) { #' shinyApp(app$ui, app$server) diff --git a/R/tm_outliers.R b/R/tm_outliers.R index db3ce782d..03a43b18e 100644 --- a/R/tm_outliers.R +++ b/R/tm_outliers.R @@ -17,9 +17,11 @@ #' #' @inherit shared_params return #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} #' @examples -#' library(teal.widgets) -#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -57,11 +59,6 @@ #' multiple = TRUE #' ) #' ) -#' ), -#' ggplot2_args = list( -#' ggplot2_args( -#' labs = list(subtitle = "Plot generated by Outliers Module") -#' ) #' ) #' ) #' ) @@ -70,6 +67,11 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examples #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -107,11 +109,6 @@ #' multiple = TRUE #' ) #' ) -#' ), -#' ggplot2_args = list( -#' ggplot2_args( -#' labs = list(subtitle = "Plot generated by Outliers Module") -#' ) #' ) #' ) #' ) diff --git a/R/tm_t_crosstable.R b/R/tm_t_crosstable.R index d4e3b4700..9e4e8e62c 100644 --- a/R/tm_t_crosstable.R +++ b/R/tm_t_crosstable.R @@ -25,10 +25,12 @@ #' #' @inherit shared_params return #' -#' @examples +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examplesIf require("rtables", quietly = TRUE) #' # general data example -#' library(teal.widgets) -#' #' data <- teal_data() #' data <- within(data, { #' mtcars <- mtcars @@ -65,9 +67,6 @@ #' multiple = FALSE, #' fixed = FALSE #' ) -#' ), -#' basic_table_args = basic_table_args( -#' subtitles = "Table generated by Crosstable Module" #' ) #' ) #' ) @@ -76,9 +75,12 @@ #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +#' @examplesIf require("rtables", quietly = TRUE) #' # CDISC data example -#' library(teal.widgets) -#' #' data <- teal_data() #' data <- within(data, { #' ADSL <- rADSL @@ -117,9 +119,6 @@ #' multiple = FALSE, #' fixed = FALSE #' ) -#' ), -#' basic_table_args = basic_table_args( -#' subtitles = "Table generated by Crosstable Module" #' ) #' ) #' ) diff --git a/R/tm_variable_browser.R b/R/tm_variable_browser.R index c4b7ae6c8..28e0c11d1 100644 --- a/R/tm_variable_browser.R +++ b/R/tm_variable_browser.R @@ -21,17 +21,13 @@ #' #' @inherit shared_params return #' -#' @examples -#' library(teal.widgets) -#' -#' # Module specification used in apps below -#' tm_variable_browser_module <- tm_variable_browser( -#' label = "Variable browser", -#' ggplot2_args = ggplot2_args( -#' labs = list(subtitle = "Plot generated by Variable Browser Module") -#' ) -#' ) -#' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +# nolint start: line_length_linter. +#' @examplesIf require("sparkline", quietly = TRUE) && require("htmlwidgets", quietly = TRUE) && require("jsonlite", quietly = TRUE) +# nolint end: line_length_linter. #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -45,13 +41,25 @@ #' #' app <- init( #' data = data, -#' modules = modules(tm_variable_browser_module) +#' modules = modules( +#' tm_variable_browser( +#' label = "Variable browser" +#' ) +#' ) #' ) #' if (interactive()) { #' shinyApp(app$ui, app$server) #' } #' +#' @examplesShinylive +#' library(teal.modules.general) +#' interactive <- function() TRUE +#' {{ next_example }} +# nolint start: line_length_linter. +#' @examplesIf require("sparkline", quietly = TRUE) && require("htmlwidgets", quietly = TRUE) && require("jsonlite", quietly = TRUE) +# nolint end: line_length_linter. #' # CDISC example data +#' library(sparkline) #' data <- teal_data() #' data <- within(data, { #' ADSL <- rADSL @@ -62,7 +70,11 @@ #' #' app <- init( #' data = data, -#' modules = modules(tm_variable_browser_module) +#' modules = modules( +#' tm_variable_browser( +#' label = "Variable browser" +#' ) +#' ) #' ) #' if (interactive()) { #' shinyApp(app$ui, app$server) diff --git a/README.md b/README.md index 56a13a866..b60732686 100644 --- a/README.md +++ b/README.md @@ -55,6 +55,13 @@ pak::pak("insightsengineering/teal.modules.general") To understand how to use this package, please refer to the [Getting Started](https://insightsengineering.github.io/teal.modules.general/latest-tag/articles/teal-modules-general.html) article, which provides multiple examples of code implementation. +## Playground + +You can try out the package without installing it in the Shinylive: + +* [stable](https://shinylive.io/r/editor/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCGAC+AXSA) +* [development](https://shinylive.io/r/editor/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMI1UgSxIGcAKAdzgCMAnAfVQGsA5jy5xURRgAIAvJILMAOmC4BaAK4Q6ANzhdGcJTMlKAFqVKpGiAPTXUJqFxhQdeuBlUbtu-RgAmcFpKuJKCcKQA8rQMEIpg7Nx8QiJiEkoAlJkKEAA2dNyOAJ7M5FA5GDBEfmo5cIwYYRC6ZenZYAC+ALpAA) + ## Getting help If you encounter a bug or have a feature request, please file an issue. For questions, discussions, and staying up to date, please use the `teal` channel in the [`pharmaverse` slack workspace](https://pharmaverse.slack.com). diff --git a/inst/WORDLIST b/inst/WORDLIST index e77494d7b..d00a0162f 100644 --- a/inst/WORDLIST +++ b/inst/WORDLIST @@ -1,6 +1,7 @@ Forkers Hoffmann Prebuilt +Shinylive TLG UI customizable diff --git a/man/tm_a_pca.Rd b/man/tm_a_pca.Rd index a4fa1e679..0c3613ac4 100644 --- a/man/tm_a_pca.Rd +++ b/man/tm_a_pca.Rd @@ -83,8 +83,6 @@ Additionally, it enables dynamic customization of plot aesthetics, such as opaci font size, through UI inputs. } \examples{ -library(teal.widgets) - # general data example data <- teal_data() data <- within(data, { @@ -109,9 +107,6 @@ app <- init( multiple = TRUE ), filter = NULL - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by PCA Module") ) ) ) @@ -144,9 +139,6 @@ app <- init( multiple = TRUE ), filter = NULL - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by PCA Module") ) ) ) @@ -156,3 +148,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlY4AygCCjNUtonG6fYPDpKJKAL5d6UHQ8KLFGbZZCmATQ2LTW27Q6GMqeewV-hm6ALyXQbgXfEIio7dPwmLn3ZW6pDCJUESqAIqQuP10WwACgBhfpbB7fcExG53QFhUjMDSJUSoOAEL7gpEZZZ6W5bHZTGZ4MGE0RwEQaFF0hmkbG4-E0wm6Aj5Ii0AhiFFaFi0KD0ESJHl8gWrTlc1EolLAYDkga7EZbAC6mtKHLAAFlBIx+DJ4RCwP1RKIoMJSGbyYx6FAIJCiKh7WAsGg4FsuvKfnIEf7Ksy8eR+Ci9Ybjaa8ObLdbbb6g8GYLbaJFSfYnK5EYTA3LKiZaNRyIwUQA5RwAGWrcr9AYuXS6tBMunYKjL6k0OhstnK31EhQgrH66HYaFQABJ6qVJ1O6YwdJ05kowLNNUA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwNJQNKoAhZfF1XQbAAKXkGGxRAypdUSWMyaWipGYGjSolQcAI0OZLNZuUWekRGy2jMpLNEcBEGixCqVD35guFotFBBKBwIYixWhYtCg9BEjz1tANyzl2qREURmWAwGlI22YCBQKqQo2ACEALJYADSWAAjIzqZsAOKuPBR5wAeQCPgAmht+vaqXImVm6qrBeR+FjfWBAyHw5HpbGM7m8zB7rQ4pL7E5XCLRTm7XUTLRqORGFiAHKOUbbDt1TPZmH9fq0Ey6dgqAfqTQ6Gy2GrM0RlCCsQbodhoVAAEhaVWPJ4VjB0fVmSjAMyBQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_a_regression.Rd b/man/tm_a_regression.Rd index dc4f458f3..40a1679c0 100644 --- a/man/tm_a_regression.Rd +++ b/man/tm_a_regression.Rd @@ -112,8 +112,6 @@ For more examples, please see the vignette "Using regression plots" via } \examples{ # general data example -library(teal.widgets) - data <- teal_data() data <- within(data, { require(nestcolor) @@ -145,9 +143,6 @@ app <- init( multiple = TRUE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Regression Module") ) ) ) @@ -157,8 +152,6 @@ if (interactive()) { } # CDISC data example -library(teal.widgets) - data <- teal_data() data <- within(data, { require(nestcolor) @@ -191,9 +184,6 @@ app <- init( multiple = TRUE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Regression Module") ) ) ) @@ -203,3 +193,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QNKAL5dKdDwosUZtlkE7Apgo6tdSmiowyp5K93+GboAvEdBuBW6fEIioqfXAsJiB5WVpDCJUInVEtWioisEFeb0q1Cg9DgfjOqywcD+YkBJFWl0OoP+qBIoj0ZxSiTCpGYGkSolQcGWV1BlWmsBxulW6zwlKp2JEGgerPJpBJZIpaKpYIhUIeqwAylCubotCxaBCRIgUcyBQR8kRaAQxCKwIJUEEANZwRX8gWcjRwfhanX6w1M41UmDCTSROkAMQAggAZUXOVEC0EmWihc0PBwuJVvLoCuS+qm-f6iDoPPEEonc0nkkECmnwLWMmMmiXss6mtO8zN+8GQ6H0sDitmkKUyuViBW2v1vFVqjX3M7Sxiy+giRKd9UvFLAYAMwarAC6M9KFMIJAIKJrdmqgXgZA20fDoJLwZhS4sRvblQd1CdIhDTh9e7eAaDFrO7q9rjtlUjVK-n6uXS6tAmLo7AqOQqbaHANi2OUhyiIUECsG66DsNsAAk9SlGh2KMDonQTEoYDjDOQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwNJQNINCQNUSiKwQaEDOr06hQehwahYjZYODksRUkgbFF0+n1MSoEiiPSIzJpaKkZgaNKiVBwAi0wWC37wNmbEbbPD41VikQaLEGpUPBVKlWqwWM5msxEbAIs026LQsWhMkSIPl6q0EEoHAhiTUAIQAslgANJYACM3oFVt0Jo0cH4IfDUdjuvjVpg91ocXFugAYoNRgFnPyE-STLQoimsQ4XD76f0rXJK6qyRTRL0sZLpbKzYrlc26urCxstnGq0nSManXLzSPs6qbSzNY7DXPXYx3fQMV6s1W6n6A0HETu9yJHv7aIHzrlgMBJ9qNkCgVUR5sAOKuPC6B1nAADT5ACwCwQYvD-OR21HelZ3re0fz-Dsq1zahNALBsnArOC6hrOtU0REsy1cFc6lbVVKIomF+n6WgTF0dgVHIQdtDgGxbBqOlRDKCBWEGdB2DQVAABIWiqETRLFRgdD6WYlDAGYgSAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_data_table.Rd b/man/tm_data_table.Rd index 1d24f04b1..8f0f9ff07 100644 --- a/man/tm_data_table.Rd +++ b/man/tm_data_table.Rd @@ -108,3 +108,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQ20onG6vaJKAL5dKdDwosUZtlkE7ApgQ0tdSmioAyp5i93+GboAvPtBuBW6fEIi-ceXwmK7lZWkMMkZiUH0Io9PlVostCgXzEiVEcBEGjg-COujoLR+vx6jD6MIWSwAynBUNwMAAZCgSApLUoYrE4gDqtH4RLwuiWAAU4EEePiIIT8sS6WBGcyMJTqRzaRjUHACLQxKtzr85Gc9r9qYkWBIbrC+qR2AQ0JoSDClgBJLB69H2IEiXQAYS1Vggkrlui6lS6XVoJl07BU5GYlh0Nls5T2okKEFYAEF0OwNgASeqlKNgxg6TqjJRgEYAXSAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwDK5NLhegiaEDOrUrQsWhQcliNKiOAiDRwfhYuiiUjsLZYgjQsABOyOHwATT8Pg2VQ2jgCjgAQgApKUy3QbBUqtV4DXCvx2Zw62WbADirl1mucAA0NnI5CiqdSQg8WBJMYjubyCGhNCQsRt+XYGSJvL6rBA7fjdP06v1+rQTLp2CpyMxLDobLYalTRGUIKxBuh2GhUAASFpVUtllmMHR9WZKMAzIFAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_file_viewer.Rd b/man/tm_file_viewer.Rd index c04f73a2e..668b3cb4c 100644 --- a/man/tm_file_viewer.Rd +++ b/man/tm_file_viewer.Rd @@ -51,3 +51,13 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXSSfTLCME2Z4dgBGRQgAX1Kk6HhRRLDbCIJ2BTAkltKlNFRslRjmiAysgF4cr1x03T4hEVFdEanhMX6MjNIYfxNaEX8tWjhImWWVjJVUQVJ-VE9Yud06UVIj44yTImp+GVvRVge4GDytnBmmBRLBUNtNjMWikrgQANZQKS3Fp+XgCRbiKQQNTUdrjAbPDKoCASL4-cj-SFAlqgmDguAbQGiAD0tPpjJEGGJEmhulhCKRIxRcG4aOmYkk0lkeImhNIAA9SGTfpTAcC2RCmaywZrOQrSLz+Yi9EKwKiFjNJdjpWA5PjCRlBIxqMiwLFSKRUKJEMzmSYPJIiFo-Vr+IxBBIWWd6PdYnB+MyAApERheGNwQwAESIBEE8DIhgAYimYJ5DABlVBwAi0TYETxWCDiVD8EwtWUrUrHLu6UqlWu6dgqcjMSw6Gy2NIE0TxCCsACC6HYXQAJIJaClV6IZDpGKUykowGUALpAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_front_page.Rd b/man/tm_front_page.Rd index 801bbd00e..78e725ddc 100644 --- a/man/tm_front_page.Rd +++ b/man/tm_front_page.Rd @@ -82,3 +82,13 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXUY4AEdBWiz2CDFSYmoiRkUIDIBBABEAZQAZH0y6pvTdT1JGdjbGlIUweC8kwdsIulFSdkHqwTjywd0AXl1BgDlnertdLhhBgbAk-1EiQUYCOCXVwdFWMli4TQJdUbBKgF9KpOh4UUSwuNjLMGo1BkoAFZEFT+ADWcFY-ySQNecBMUGEpH8BH4tFEBH8UJh8MRwB+sDEAK8cgAum4yFB6CJ-ABGFpJDAmZjwdgASQgJiIK10BBmYGqBzWYAAQmMUnY4AAPUjC0WzSWDWXvSpeJlwfwAJnZYU53Lg7AABgBhIjUQQwKosi2qsVWjVgWpy3TW232qoG52rUUAVgwwZSADYMBG5CkfXaHboAMyBkViiV4KVauQ6xnMpPGrymil8gVCoNi1yZwYAMS9CuVLsGAHF3QAJMaVJS65kqVDzFqTaYdQZ2PN6FnXXbj1m4EdgMd63QGqc9-UGudVKWLkTJ1czpNKLvQdAtFQxGZbpLCpKbjJ8IQiUTCh-CSkdDKkGD+LkkLGoKApEvDIQN0R4oH4GR-HIRsKw-UCpV5GBUHKLwyF0FRBUYGBPCsCAp0GXkVQIKAqgkIVHiyDADng0DBgAeTiGQMLLbDcJIAiwCtUjdHIsCZDgaiwFo3RYxEtdn1WNd-D7eY7wQiDcU0EhuGgwDJN0Ns7AAWUadN+CUvDuE0nTmnKXRRHiCBWGnCRnz4yi9H0JgAD45REwUiFICAvLEJswAADU4vFdkeUx8imUwiC8nzyHdABNDDnyYiy4GICB+CimLfPcrdQMsohIn8YYILCYUHBceDKgyMSt3AyDGGFLw7IAEliFkxXqWBUF3ap0DoEjlPw955M88hGqk9SWtQdN+toQa8Ky8bcuPWgTF0dgVHG9RNB0GxbDSLdLJUVg+pmtBUBavIUgulrRBkHQKiUD4lDAD4aSAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_g_association.Rd b/man/tm_g_association.Rd index ef47169a7..9ffd8ac9d 100644 --- a/man/tm_g_association.Rd +++ b/man/tm_g_association.Rd @@ -71,8 +71,6 @@ For more examples, please see the vignette "Using association plot" via \code{vignette("using-association-plot", package = "teal.modules.general")}. } \examples{ -library(teal.widgets) - # general data example data <- teal_data() data <- within(data, { @@ -105,9 +103,6 @@ app <- init( multiple = TRUE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Association Module") ) ) ) @@ -153,9 +148,6 @@ app <- init( multiple = TRUE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Association Module") ) ) ) @@ -165,3 +157,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QMVpuqkHaLD0PCi7ABitNTkjOy0og4upVpokRyjpZsYJpMdpe0StATc7ACMADJyL129g8BnGtMAusPU+2ohw+XymjFEP1KUHEBHyLEmMi6AF8uik5mJihlbFkCOwFGBRviukp9sMVHk8d1-BldABealBXDjPhCEQzeks4QY8aVUgwRISRLQ0REAi0QJWCCUyoyqpwEx0hlQRJhUjMDSJUSoOC4nmypXoxX4wl4PWy0RwEQaRUWq2kTXa3VU-UygH0S1GsAAZUtOtIuj2jHF9BEiHxTOdLt0sKINzEisDwZEiRjcYWKWAwGNg3xP0h0bxYAACgCyOHdPi7KxteXK9VAvAy2AXhGozLbX64PxPSWoE3W23TLRQl3FYsAIKPL2uSOyt76uQD2WB9lKlWhNWTB066VRtGwPT07NjU2z9u+630jsarU7s36t0eo-ei-+xNQENiMOnwfR-Kxgh43pd9PxTf800xIJM2PXN811YtS1IWswCrGs8ArFD6z5CgkObRd73NV9R2fOwsMbXClyjGBhE0SJD3sJxnEol0TGHYjdAnKcZzbec5z1ecui6WgFQ2VR1U0HQbFscoqVEQoIFYcd0HYfYABJ6ihdBVItRgdE6JQkSUMAkR+IA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwNISNJQUSiIgEWhhKwQaEDOqMhomLGZNLRUjMDRpUSoOAEemMoVIqCLPSIjZbDYohnC3SiOAiDRYhVKh68-mCuWM6hQeiKrEbAKK-mkXRaFjU+giRDS-HagglA4EMRYi2MK0iR5O2gu5b27Ui4DASUjbZgIFAmWBoUCo3OAAa0t0Gywgy8rjwKbAXgA8o4AHIOACayclWAAsmWwAEHIM7IMAIzV2tphsAJmrfjsdgAYuGqhsAEIVrAAaSwnbA-Rjujk0ZjqtNcH4hrAaYzdtl2pMtCiK6xvcGowCrm3QpnwvnAfNLExiLZHK56r5cfPjN+8DXUrwN7qS+VREAJfTU-x1PUDQlGsTWVd1PTEW1f3fWMfT9N1LT1L1HWdPFkOFTJg1DaYIyjMDY2hGtE2rDdM0HHN8yLLBSyzcsqxYms6wbZt2NbetBinOjuz7AdsxHcdJw2S9A2vPD-xg8hVygsSJwEsjsXuWg4nFewnGcBdA13fdFN0I8TzPaSbykucYX6fpaBZdgVHIZ9tDgGxbBqBlRDKCBWEGdB2DQVAABIWiqILgoVRgdD6WYlDAGYgSAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_g_bivariate.Rd b/man/tm_g_bivariate.Rd index fc0675ee3..070d9f8b1 100644 --- a/man/tm_g_bivariate.Rd +++ b/man/tm_g_bivariate.Rd @@ -116,8 +116,6 @@ For more examples, please see the vignette "Using bivariate plot" via \code{vignette("using-bivariate-plot", package = "teal.modules.general")}. } \examples{ -library(teal.widgets) - # general data example data <- teal_data() data <- within(data, { @@ -165,9 +163,6 @@ app <- init( selected = "Treatment", fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Bivariate Module") ) ) ) @@ -175,7 +170,6 @@ if (interactive()) { shinyApp(app$ui, app$server) } - # CDISC data example data <- teal_data() data <- within(data, { @@ -224,9 +218,6 @@ app <- init( selected = "COUNTRY", fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Bivariate Module") ) ) ) @@ -235,3 +226,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHH+GRgmzPDs-QNdAL5dKdDwosUZtlkE7Apg09tdSmiowyp5W90jsQC8F1C4Fbp8QiKiutekMIkSifTaLLSBcDOlUqoVeN0SYVIzA0iVEqDgm3uwJuSz0122uzwSOBojgIg0YNx+NIsPhiPOyMq1Cg9DxYO2AGU8QjSLotH8aSJENs7hTKQR8kRaAQxGD2Yx-vQRIkBUKRSsUsBgBjBtsALpquS8yk45kaOD8emEEgEHnY5EmWihA1ggBiAEEADIM1x8ypdZFa7GsMEpCGhKHqElwhFAymLWBo3QqgZmt26Ikswl64NksM66m0vzosBM4lsjlSuDcrHxyqy4Wi67iyXSivy1ZBJUx9Wa7U6hMpm05wSoIIAazgcY7D2EmkiUYdzuc7Z1luthuuU5d5t0HuBXr5jCI2USJnUcFZ1z9kOhqdDq4j8CNmNnuvz10TMJD5JHmbpObzSZrnOLw479ZVgWEq-jKgqVgqGTNjsqpgBqm4jk+5CLtGYB2Kw8L-nOVrdroy6ujq67unebR7geR7gqeQakhe8ZXlGLaljqSHJsSNGvh277ZqhX4Ej+RYlneyKAS81aFnW4ENoqyowbGcFtqulRIbh2x2NUgTwGQWGUvOuH4auRFrvcXRdLQJi6OwKjkGe2iAnItjlOcoiFBArD2ug7CHAAJPUpTebijA6J0SizEoYCzGqQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yCdgUwKdGt-oArIhU0gGs4VmXMteN+OBMoYVI0gn5aUQI0w+Ozi+AF2DEK3CcgAum5oOgJipipsBiFcroALzw8K4Wq6PhCESiJG6UgwNISNL0bQsWhhOCwup1KK4zJpaKkZgaNKiVBwDbo6koqCLPTIrY7LZouHc0RwEQaXHiyVPNkcqnc6nUKD0CW4rYBCUc0i6LRk1UiRDCrlKgglI4EMS4-WMcn0ETPC20K2XXLAYCCka7MAgkFyEVK6kynVwfga7YAcVceFN3JMtCiYdxADFBqMAq5RdT+tyA6bWHTcgyokz1HL2Zzs3V-vAI0LY9XdCGpciWxWFXHlar1QKwFrZXqDQ64MbG0G6ubLdbkbb7Y6py7AZkPV7pr7-YGJ+3k33MwANE1NuowR60OL83RpjPOLdBhNJ8PI6+Zru5nN3+pEAppe5W3XIvSjLMh2VZBrWl5rj6n51O20raiy8pgROKpqtQEYDjqQ52oao5HhOuiLq6NrDguzqukCUCrts3pbH6+bHs2CHkE+uiClgACy+ETg+u5Xumr5Nu+dQMdy3S-uocAATyJZlohlaKtyEH1rR45KnBbbMayCldnUqG9mx-bMdh854WpQZETOJm4U605uuE1ENvRMHBsxfFbF4ADyjgAHIOAAmtx96JnxL5ZkGwm6O+-T9LQJi6OwKjkCB2iUnItg1HCohlBArCDOg7BoKgAAkLRVEVxXiowOh9LMShgDMIJAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_g_distribution.Rd b/man/tm_g_distribution.Rd index 033161a0c..1b67c42c2 100644 --- a/man/tm_g_distribution.Rd +++ b/man/tm_g_distribution.Rd @@ -74,8 +74,7 @@ It offers several tools, such as histograms, Q-Q plots, and various statistical visually and statistically analyze the variable's distribution. } \examples{ -library(teal.widgets) - +\dontshow{if (require("ggpmisc", quietly = TRUE) && require("ggpp", quietly = TRUE) && require("goftest", quietly = TRUE) && require("MASS", quietly = TRUE) && require("broom", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example data <- teal_data() data <- within(data, { @@ -90,9 +89,6 @@ app <- init( dist_var = data_extract_spec( dataname = "iris", select = select_spec(variable_choices("iris"), "Petal.Length") - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Distribution Module") ) ) ) @@ -100,7 +96,8 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +\dontshow{if (require("ggpmisc", quietly = TRUE) && require("ggpp", quietly = TRUE) && require("goftest", quietly = TRUE) && require("MASS", quietly = TRUE) && require("broom", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # CDISC data example data <- teal_data() data <- within(data, { @@ -140,9 +137,6 @@ app <- init( vars = vars1, multiple = TRUE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Distribution Module") ) ) ) @@ -150,5 +144,20 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +} +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLpSEGrUuvxQpFC6cAAesKgiSlc3BsZc1AD6b1A2r2utyMugA7rRSAALFTsP6REBKXS6HyhD7IxihJQAX0UED+0HgolhQNsIP8KNE-iUSjQqDRKghfggSL+5ThiN0fCEIlE5TozSZSKRpBg3wkv1CpAx9EEmmsHKFl0l3y0LDZQO+Dyl6lI31EqDgBEFiqF+NgemS5IxlLwCpNojgIg05QdTt1+sN7FVGKg9BE3wIkKItAIYiGFP8cki-gACrFuBgADIUCRQyN2pG4xVZ3S43G0Ey6dgqcjMSw6Gy2BHM3SiaEQVijdDsWkAEm8kTbDsYOkYuKxSjAWIAukA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLoAwgAiAJLjJ7r8UKRQunAAHrCoIkp3DwbGXNQA+l8oDZPvdHkZdAB3WikAAWKnYQMiICUul0ozO4wAMj9shjsUoAL6KCBA6DwUSIsG2CEEIb4rH+EkAKyIKn+AGs4KxKUCacZ+HATFBhKR-gR+KECP9WeyuTzgGTYGIqQ85ABdJRKLQsUQARlxBFhbIIYn+ojgIg0cH4fggaJ1jFoUHoInFxtopt5YOAwH8DP86vVkTp-qwwyK-hOAHlHAA5BwATUjYHGzgAGky5LhUboLVbyPxynHHFjGRASUo0KhcSoYXa0UDykjc3whCJROU28IVbm0aQYP8JIDQqQnfRBJprH20bdR-9Hc2wf8XmP1GLRKg4KH7bO90r4OV-ZjGXgZ3v89vSOVLxpzVud3un7ojSaxOVHc7XXB3W-vQ9fWPAkwCDEN6QAcVcPBdH8AAhYYsAAaSwPUsxzXdnzRW9CyPMB4KQlCInPJ8YFFWh3j0ZIADFRixNN0Mw2cTFoZ4bXKGi6NcDCnxJZ9s2I5pmAeBcWCXYTV2YO9N23BtMIPSiYLAAMz24vdmOochGHKdTNPvGTiL3R1O2SIy9QYxjdFIjTyJEPZUgM3ReJ48y9wkRgiEEVARK05IgRXZ41ykh9ZOfeTcOUlynx0mRtNoDSZD0x8LKMj9dTMhy0SszQKLslwHKcvcCsc3MSRJWgTF0dgVE09dtEGORbBRXdRHhCBWFGdB2GrAASbxIh6i1GB0RgSUJJQwEJdUgA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } } +} + diff --git a/man/tm_g_response.Rd b/man/tm_g_response.Rd index 6e9e1e93c..0f9ae470c 100644 --- a/man/tm_g_response.Rd +++ b/man/tm_g_response.Rd @@ -98,8 +98,6 @@ For more examples, please see the vignette "Using response plot" via } \examples{ # general data example -library(teal.widgets) - data <- teal_data() data <- within(data, { require(nestcolor) @@ -134,9 +132,6 @@ app <- init( multiple = FALSE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Response Module") ) ) ) @@ -146,8 +141,6 @@ if (interactive()) { } # CDISC data example -library(teal.widgets) - data <- teal_data() data <- within(data, { require(nestcolor) @@ -180,9 +173,6 @@ app <- init( multiple = FALSE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Response Module") ) ) ) @@ -192,3 +182,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlTCtLKJxur0E-RWmHbrsWroqugTsCoSs1Iuli1qiq7qLsFuLUiyLcrbl3ZVDfYyiwMBaALp3g1DiJuqkHezD-Tf3d12VAF8lACuiloPBRMUMrYsosvldFm5oOhBio8gszildABefwZXBjPhCEQDXFE4RiDHnXSkGCJCSJaqiVAkURwKnU3TUKD0OB+XGLLBiFkQNm6AAK7VImzwY2pTJFYtxKUSYVIzA0iWZcHmcs5YNgegFYHhMoJZ05ujZIg0OKtfJ1pC1qB1HMtlW5vP52zAAGUHbatCxaDyRIhVnrLQR8kRaAQxHag4wQ-QRIlo7H45CUjc4ZcZQ9Srqlis8D6DowjnJze7ztbHXB+HbFgRlhGLe6YMJNJEjboAGIAQQAMr7nDXa6ZaKFG3ah6PXB3qf9OdXI7pQnaVWqNU7tbql+cDfBmyb8+3a-Xbbir3uXQfJ1yeXzT-6baRdEmU2GL5OM3GE1xL9QzgdMYwA7MMlzM8RgRMBCzmBYwA2PYUBgKsJ0vANyCbY0UNlQ9qS7agexEOcRzHTD3RMadZ1xecx3XSoV2XPUVy6LpaBMSYVHIXdtHZY4yjGURCggVhB3Qdg0FQAASepShk2S2UYHROmBJQwABO4gA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yCdgUwKdGt-oArIhU0gGs4VmXMteN+OBMoYVI0gn5aUQI0w+Ozi+AF2DEK3CcgAum5oOgJipipsBiFcroALzw8K4Wq6PhCESiJEYgTCQHouqkGBpCRpBqiVAkURwWF1Bm6ahQehwai4rZYMTUiC03QABR6pFEWzRcMZlJ5fORmTS0VIzA0aSpcA2RMZKKgiz0yK2O1F6sZtJEGlxxtVTxVavFGrqzNZ7N1YACbItui0LFoLJEiANNttBBKRwIYlxHsYXvoImeQdoIcuuWAwD1I12YBBIKqarAACEALJYADSWAATKLdFsvAB5RwAOQcAE09nIxbaja6NHB+BzcwXi2W8IaNTBHrQ4jrdAAxQajALOVttuomWhRLu46ez1z+hn9W0todRXGy+WKy2oVX0tv-eA9-WD7d1c2m5FPs8XoeM+1snsuk2kd2et6cC+vei51IGwahsi4aRtGEFxoCmRJim0zppmujZnOAAa5acoMXiuGAcj7g+DKvmuTpYPhhELouI7UJo47rjOc60W2y6rt2yIbnOH66LuGoCXUAn9P0tAmLo7AqOQp7aHSxHVOiohlBArCDOg7BoKgAAkLRVFp2m0owOh9LMShgDMIJAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_g_scatterplot.Rd b/man/tm_g_scatterplot.Rd index 466294031..c8b39bbe1 100644 --- a/man/tm_g_scatterplot.Rd +++ b/man/tm_g_scatterplot.Rd @@ -108,8 +108,7 @@ For more examples, please see the vignette "Using scatterplot" via \code{vignette("using-scatterplot", package = "teal.modules.general")}. } \examples{ -library(teal.widgets) - +\dontshow{if (require("ggpmisc", quietly = TRUE) && require("ggExtra", quietly = TRUE) && require("colourpicker", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example data <- teal_data() data <- within(data, { @@ -185,9 +184,6 @@ app <- init( multiple = FALSE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Scatterplot Module") ) ) ) @@ -195,7 +191,8 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +\dontshow{if (require("ggpmisc", quietly = TRUE) && require("ggExtra", quietly = TRUE) && require("colourpicker", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # CDISC data example data <- teal_data() data <- within(data, { @@ -272,9 +269,6 @@ app <- init( multiple = FALSE, fixed = FALSE ) - ), - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Scatterplot Module") ) ) ) @@ -282,5 +276,20 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +} +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLpSEGrUuvxQpFC6cIWwqCJK84sGxlzUAPpbUDabC0tGugDutKQAFirsR5EgSrrZno1w7NOipMStjEUEDeAGEAPIAJh2unBEKUAF8gUdoPBRI8zrYLv5Yf4lEo0KhoSobn5gXMztUnq9dHwhCJRNVacIxKS3m9SDB9hJ9mEFuQOq1SKy2W9qFB6HBZsl-ABlAh8mTrIikGG3IhdMQRakiwqUs77FYldSkHmoOAEYUit7I2B6aVgHF4bVW0SS80q5KukQaU3my1W0XiyXVWVujS6LQsWjikSILVkgNvAhqjUM5KRxjR+gifbJ9UEFlHYDAbGQ-wAXXLkQt-mIFjK-kEqEWvX8cjkuGdAa97rg-BDzXrToTiZgwk06ztugAYgBBAAyMucnZHAZMtEKfeqc8XrlXbKBAY7Xd0Q3JiwNxWYPtEZpr++tZxRU9LcOHid0PfDnrDJtvfpPEUxQlKVdFDb0VQzLNY3jD8kxTAs0wjKMYzgXMEMLM5i1fCsq10GtB3CPAwLAJsWzgNtjwfNkv3Ift7TIqBW3fOCx2oCcRG3BclxXODTA3Ldkh3JdAN0Q8rSogN-iIRh9noM8jkvI0bzvf0RRteAB0dXjE1o6paN9e8+OA4N7RlX9kMzVC4xYj881TaooNQ9D8xZUT1KwksHTLMBKx0viCIABTFMgGzAOxWDNMK7HcBZ4FC4jaxIIjIkbZsmIosBxI-SS4NowTdAAOUced5380dx1oScuN3cq1wE+iZ24vccpPXKRVEWgAC80PkvUL0Na8-1U0SNJfby3zqmiLJ-CDDLUq0TNA8D3Us6C4BsqaRXsxDHJQ7M0J2zDFmwibcOrPxCLCxjmPbLbpoggq0vI2DWMq6qhOa+63nXTdGuElrE2yg8psYIhLn2Ex1FifqoCUob5tGp9bS0nz7r02b3UR6jAxAgdzIgtbrNeuyMKQpyDpc1N0ROrzHT8-DLuCqAEtS8LIsytmYrgOKKFISjvs-X8CuK0rBbYjipwBwXfoKgHROBt52rZf5Iehj1zzhwbjWxj8xtRybRIxoW5v-Iy4KW-GLIpmDbMTI7yf2nMHZpqBTvpvCgpC-nEvZqLfe53mEru9yTd7RrRbK0OJaqzjPtq0PZf+5qFba51xKBIFaBMXR2BUfljW0L5210F4yVEe4IFYWd0HYAkABJvEiBvXUYHRAQRJQwHhcsgA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLoAwgAiAJIAypO6-FCkULpwhbCoIkorawbGXNQA+vtQNnur60a6AO60pAAWKuznkSBKutmejXDsEDEpGIrUYigg3wAgtN5gAZQ7ZaFwpQAX3B52g8FEb2utluBD8YCRsP84IAVkQVCdeqxsec8cZ+HATFBhKQTgR+KECCcKVSaaJgBjYGIcWs5ABdJRKNCoBEqR5+CHLa7Vd5fXR8IQiUTVLXCUUa76kGAnCQnMKrcgdVqkJXfB26ahQehwajVfzzAhWmQ7IikKZPSkEMQRI0Owpq64nTYldTs0SoOAE8OO4XwD1EmEkvCph2iN3JgPJAsiDQWpMp5WOx3O13u5KewsaXRaFi0F0iRBh6s174EINdMTVNuMDv0EQcwchunXYDAfzE-wSiWRFNEgDirjwun8ACEALJYADSWAAjGV90fTwAmUlyXB5x2lotwfiZyFbnt9x0wNm0HY9GSAAxSFYXmZxH17PsTFoQo32qUDwNcaCHXBPsHzzIYVTWGNimYctE2Te0f3TIDdyzZFc1Q74XxbEtmwTSsSJ-J0XTdTN5kY1t207OBu2o1j+2nYdklHcdJwHYNRXOedF2zZdV10ddP23SIrxPc9LzAQ9NLvMA5Ewmj80YhDGx068tMEoS-2oTRAMQsCIKgoTTDgszdCQiCn10dCayMvsQSIRgTnobDzjwuNCOYnyyI-BTrL7Oji10ZKK2InzvjrDjzK4ssA3EviBJcoSpKHXUxN4ic4CnaTsUyh1ZIXSicxXErXJUr8dw008L26iy9O0rBIUmNSKKwZwN1mAB5AA5Pq-NYgKhOSjzZscWFYXan9bPskRHOQ7aYPc98QKclClrzZbn1oAAvGqwqjXDYwIpiMuMuLzKXRKa2S6o0qIqtXOyhsKLyoseLHIrv1KkSKshiSarKmcxSgOSWsUtdCVU7TdN6+8jt+0zToonGfr7XaAP2s7Doa2D4JJryLp-Ra0MJxgiDuE4WRDFKIpe+N0qB0jrkxcj5KownaO4hj8qFlifxBzjuMK6rioa5HRIRvjavK1H0e+trlMJPGsH09SwGG0ahsmmb5oJhrVpJ9bNqlh1KYcmnnLpk6Du84zWe+a6HRBbn1FiJ6oEi175di0WRXiyWfL+2Wi1j4ysvY0Gm3y7W1Zh1jNfh1XJLh-XmsNpT11N83xpGsb-Amqa5oW4OkuJ6oXa2hqPepzzzrd756Y8pmfMD3zwz88FwVoExdHYFRrXjbR-kM3RPmVUQXggVhIXQdhZQAEm8SIj4LRgdDBVElDAFEJSAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } } +} + diff --git a/man/tm_g_scatterplotmatrix.Rd b/man/tm_g_scatterplotmatrix.Rd index 65672cb11..294eae5ab 100644 --- a/man/tm_g_scatterplotmatrix.Rd +++ b/man/tm_g_scatterplotmatrix.Rd @@ -48,6 +48,7 @@ For more examples, please see the vignette "Using scatterplot matrix" via \code{vignette("using-scatterplot-matrix", package = "teal.modules.general")}. } \examples{ +\dontshow{if (require("lattice", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example data <- teal_data() data <- within(data, { @@ -130,7 +131,8 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +\dontshow{if (require("lattice", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # CDISC data example data <- teal_data() data <- within(data, { @@ -182,5 +184,20 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +} +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLpSEGrUuvyBULpwAB6wqCJK+aSFRrpc1AD6VVA2lQUGxgDutKQAFirszeEgSrq6xOakjFGiHXkFGCbM8H4QY2O0-AnjfmAAIq54uv4AYlhhx2AAknYX-s4AyndgAAq3R-4A4ucfYAByABlngAhQ7hfwAxzPACC7zkuFG6wkRB0jAg8DI2xM6lIREYq3W6wI7AATOEyboKQBGcm03Q0+nhBkk+GIwnUKD0ODUWaJYn+ACyJBYBF6rGeWDgqEE9DoBH8qUJrLW6w5EAkgigUga2JgtFiWJxeIJhJ2DIAzOFLbprdbqUyrUzlabdByuTztvywJ8ZDAoMp5b8ABLckQBiVEP0WUJgRXrZ3rVBEaUczQkT3sAAc1oAbAB2cI5gAM4QALAX6SX6QyqRWqQyixgc+EAJwJsYsOCFPnsc0AVgrfb7FqLDL7Rb7rep5oppZH5Kb4Wz7cy-FQGfNGFLC4rJIwNa34Ub1sbFMbFcbk90jYbW5X-Dg9FIGb3zIwdsPlMXX4-25-C7-PdfzjONRG4MQ5maRZljgE0Ni2RIqUQccERVMYJjINgGk2bYwJgcpYLZIldgOZ4zmeG5nkeZ43meb5nkBEEwUuSEYThVCXVEWgAC89ESFCiLGdxynUPikhcIiV1YLtGFwvFSHYPCCNJUci0QEkiw08IUN0YSORCbYHBcOQVx0CBBDEpSRHYL1RD9ahqGeeB+FoQQYGeDlGCkZ4SDobIFW0qs9NEwzkhXAh-RCBy4AQ3QrNg4kjOccITmhAEHhSQLwmCgzEiSlcvH9TRSDiRI0TxGB2B0qkiyrDTwqIURSF5XSIAqqqq0zOqixXVBGCIEwem2crGEqnStMrEClAAX1SZpoHgURBgKWxai9DCphmZ4wJEUQFSUAArIgVAaABrOBWCW5pVuMI6TvOy6TTuiAzou3YNumMRng+rbfk2ALEWe16OH8Havt+MG9r+-gAZVIGHveohJk+qHwTASGLi9f6wG2fwPtYbCYdjVJUiUNB11qFQehNZptiGRE+CEXbtkZ4QxDguoYAaCQGlECKghkcoiFIP1NuKDmxjdblcbAB5+fIRghefUXpmKMJBN0LQWFoTlmcSOgmol9ZmgaEophxXnUDgfk0JdeZqgWsS8aRzDfo4u2xlEblrefRIvZEDRLeto2XSl3JEn8B5vY0TXtd1sREHV22PdFY6QharXpnjhpU9odPluqYBgGd5HfoAXTLlcPf9n2YozfxOygZ4JDXZ4HyfWGPcJGBhE0AjQpcd2u90PEH3cWKkqHrvBuKOvElS9LXGT004xdKvjYKU3inNwPRCtm3h-m2AnfR8DUY1wlBuoBWsX1BWg4P4fXU5aWI9l6Pn0znXZTgRO8Av00mcWol0wgTbGU8U69DThBRIWtqAWRzlAvO7NmhF1BmffwFc0b40Jp3J+NcNBzx2P4UivxyK-Eor8aivxaK-Hor8RivxQTPFYr8WEeDh492vrQfueVkgALGOvQkBDfZxQ-g-EOpow4yyjgHT+ccf6iD-hAu2ud07bC-tnNRKCChoNPrtTBZdwhekKmQHo4pfjECaqjS4fUBo9AVEI00IiiEmM1GYkq31GrNWeHYwapAOFdy4X3EQA9koCPWKPGQRDJ4RLGDPIhC8MoRNXivDWqSpoQFSLQEwuh2AqAVjibQsETK6BGCqUQ-QICsGhOgdg5MAAk3hwiNK9owVEqRppKDANNMuQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLoAwgAiAJIAypm6-IFQunAAHrCoIkolpGVGulzUAPr1UDZ1pQbGAO60pAAWKuwd4SBKuroAgtn5ADK9uoxzi1Oz2Vj5y6tb+UoAvqkd0PCiY6W2TQR+YGsLYbr+c9v+qQBWRCqtANZwrAuHWuxn4cBMUGEpFaBH4tFEBFaXx+-0BwFOsDElwacgAukolGhUMsVIM-BBph0EsVSrgNnwhCJRNSGcIsRtpqQYK0JK0EYFyIwakQuYFGLQKuTptLdNQoPQ4NRqf58gQBTJhaRdDAxRKwhzpVoWLR5UzqXRRKQpTLpR1WpVSMwNHzUHBbgabTSGmc9IkXvNHngPTbRIq3VrEqGRM7RK73RTPTa5QqlX6wPkwxpdEbxaaxIh9QnE9KCENviFmYkcyb6CIYWXaBXsVBgMB-eswLjcXI6UXi7oo+G4Pxqe77gBxVx4Z5gLAzTJT8Iq5wADXevf70pgUNoNV9SRcG83uiIjDB7hHiQch+DnpMEuH1IAYjMFvlXH3Paliz3b16oPaFSOuo0Kxm61rFhi8DKvc+yFpu97UIK1KIYKLrgX+MrJoqMEZtGWoUPwqDfGQogFkGn6Jjmla6GOAAKMxzgAsjkTwvAAagUuR2OumElg2FbUka1CCHA9blliHStv6bydri4T0YxMwsdkbH3Jx+TceutF3AxzFqTMGlaWAci-pRnqDhoj5prkABy7HOHYujGM4tnZLoADyT66HZ2SOJkdi5B5tnwce25IbuIjUteH6bmZm6WRGA6ZqBcYQf22GpjOeHhtmxp5mRoWbqWEk0dWebiY2kmlNJsGyV28XHol1k6S8k4Gexr4GdkACavHmTa4WaHu0XJEem6nueLUxeN-b3hULUvm+sX9t+iZrTKG26GtqSpLQJi6OwKiCiB2hwDYtiTAmogjBArAzOg7BEgAJN44QvaGjA6IwqSHEoYCHLiQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } } +} + diff --git a/man/tm_missing_data.Rd b/man/tm_missing_data.Rd index 878adeb14..505a3747a 100644 --- a/man/tm_missing_data.Rd +++ b/man/tm_missing_data.Rd @@ -58,18 +58,7 @@ It is useful for clinical data analysis within the context of \code{CDISC} stand adaptable for general data analysis purposes. } \examples{ -library(teal.widgets) - -# module specification used in apps below -tm_missing_data_module <- tm_missing_data( - ggplot2_args = list( - "Combinations Hist" = ggplot2_args( - labs = list(subtitle = "Plot produced by Missing Data Module", caption = NULL) - ), - "Combinations Main" = ggplot2_args(labs = list(title = NULL)) - ) -) - +\dontshow{if (require("gridExtra", quietly = TRUE) && require("rlang", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general example data data <- teal_data() data <- within(data, { @@ -92,12 +81,15 @@ datanames(data) <- c("iris", "mtcars") app <- init( data = data, - modules = modules(tm_missing_data_module) + modules = modules( + tm_missing_data() + ) ) if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +\dontshow{if (require("gridExtra", quietly = TRUE) && require("rlang", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # CDISC example data data <- teal_data() data <- within(data, { @@ -110,10 +102,27 @@ join_keys(data) <- default_cdisc_join_keys[datanames(data)] app <- init( data = data, - modules = modules(tm_missing_data_module) + modules = modules( + tm_missing_data() + ) ) if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +} +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEulIQatS6cKGwqCK6-FCkUEr9gwbGXNQA+iNQNsMDUGO6AO60pAAWKuwz0SBKurme3r6toqTE1ESM9fu6UPz8k9CiS2YWmtahtnsQBwehwFE3RE7FEnkm3BIEnYX2iJkuV3YIlKGxhtgAVLlzLQTOwAIzRDAABgArIS8QB2OTUgC6SwAcgBBW7-W4AXyUtx8tBeRl03NEtxg5xYvOMwoIos5v35QVEwDpfOK6ES7AF0Xuj2e9QOEtFCqWyp6HD1jFEGoeTygoh1ulN8uA-gIrGo-hpiuM1owJnUpER9uAjsILrdNNtAaDUhYoaWXp9Gn9IrNgf8UcYofqbPqM2g8FE2wWtj5BD8YAF5X89v8N2g6CWKjWfhlMxqOyFAmEYhqfCEInzLN0pBgkxgPNEKgk0wWcxl9XqON0atUzEsOhs31uok2EFYjPQ7DQqAAJN4Negj2DGDprkoORAwGyaUA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEugDCACIAkgDKzbpwobCoIrr8UKRQSiNjBsZc1AD6k1A2E6NQ07oA7rSkABYq7IvRIEq6uZ7evhBipMTURIz1pwCCrZ0AMuuML+8nui9YnU+-06SgAvvVFtB4KIDqtbEZdAQ-GBvm9yv5gf56gArIgqOYAazgrBhi3hxn4cBMUGEpDmBH4tFEBDmuPxRJJwEhsDEsLGcgAukolGhUOsVNs-BBTosaodfnwhCJRDVFcJeb9TqQYHMYEzRCoJAtVstpbp6vVaCZdOwVORmJYdDZbMczaI9hBWE90OxRQASbzRf2iGQ6B5gpRgUECoA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} } + diff --git a/man/tm_outliers.Rd b/man/tm_outliers.Rd index 4ca23deeb..3d76bf5b7 100644 --- a/man/tm_outliers.Rd +++ b/man/tm_outliers.Rd @@ -58,8 +58,6 @@ such as IQR, Z-score, and Percentiles, and offers visualizations including box plots, density plots, and cumulative distribution plots to help interpret the outliers. } \examples{ -library(teal.widgets) - # general data example data <- teal_data() data <- within(data, { @@ -97,11 +95,6 @@ app <- init( multiple = TRUE ) ) - ), - ggplot2_args = list( - ggplot2_args( - labs = list(subtitle = "Plot generated by Outliers Module") - ) ) ) ) @@ -147,11 +140,6 @@ app <- init( multiple = TRUE ) ) - ), - ggplot2_args = list( - ggplot2_args( - labs = list(subtitle = "Plot generated by Outliers Module") - ) ) ) ) @@ -161,3 +149,18 @@ if (interactive()) { } } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6ugDCAPIATHHV9RVNdcDACmCojLQwLKyJANZwrJ0AumONonAAjokiEOwQjETZ7LV1cooQAL7bKdDwosUZtlmdG51KAFZEKkMjxylnxrf3w6zHbxAPHBfNeF0-zqnVKnW6vX6v06WzcEC0LFEjQI+TuBDEiWmIg0cH47ARPSg9BEiRRaLEJyC7WB4zGpQI7E6AAVqFAyKCgWA7KxUHAOZ07Iw4IF4OywFttko0KhGio8oyIJUUroALz+DK4Fp8IQiJFq7XCCktSqkGCJIiCUh0GTHY2VXQWq20GSJAmq3R0USkBX233qoKJMKkZgaTG8hl2v3+tmwPRqml4SN+rFwDTulOh0Thn1Rv2s+hwPzxsAAZULqdIugJtCJIkQoKTUbJtHReqrLBrxLgpNRLYpKWpYEuYAm9MZhBIBH5YEEqCCwxhck1itzvoz5H47s6s-nfMTK9XlRgwk0kTjugAYgBBAAyJecy8P9pMtFCuPd17vrgPue2q7-fpLkmBCBHAEhED0IFJG6aqet6jbRoGoTBuopBhqmOargcsZbkOAKPoeL7UOQjDukRJHoRGP6rgSba0QRT7Nq27oItQgjdkx-YZIOw6ju2jCiAAJOuuJAdRuYiZuaqsexPbkk83EdHhIIjnS-FCZJYlPkeJ60Ge7oOC4CGVABUamfa5kAds2y0CYujsCoJGodocA2LY5QrqIhQQKwV7oOw0qCYItClIF0yMDojDbDsShgDsYxAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXQBBHwCAGWTdRkaWpQBfRQhM6HhRCtzbfIUwTuaJpQArIhU0gGs4VmHMseN+OBMoYVI0gn5aUQI0+cWVteAB2DER8LkAXTcIXY00rRZRNKh+UWobUG9wAYrRqORGOwTg4XFVRGg4hxMsBgBMphMnk8qicMO9SERGHJiUovoxRG0CCUFgQxGlRHARBo4Px2GTaFB6CJDtTaLT1rlUeimtMwFiqvjPt9fv95H0lIi2ipiuxaiFcroALzq8K4NV8IQiCnag3Ce5quqkGBpIiCUh0GTDC11XS2+20GRSxha3R0USkVUQF3BnVQNLRUjMD6iVBwAiBkMh27wH3Crp4Z2JhlM0g+7Nxg4xuMJxMh6icxmpsABRkF3TszkiRATPVB0vBqk0sQ+htcuA8rsC8JCyYizHY3Tx9EAcVceF0EwAQgBZLAAaSwAEYJsTW+3g-nmfwq-VZy3M6WYPtaHE9NqQfVmgFnHv93UTLQoiyfQ+n642+2fSARecivh2YRwBIhJ8twXo+n6AYXnUmThlEkbqIWsZTgBpbJneC6jumYGlh+EIyD6pGQvSWElm+ZLGvW3zEe2nZ8t22pfNQgj9qx-IPFAI4YmKE70QAJIe5D8KBSEhhJ34cdw3EDmxQ4CWihGiuKjHkuJtZHtJOHtleEI3iIPqwv+b5AaW1nBrZujWX0fS0CYujQqoUaaDoNi2DUbaiGUECsPU6DsIiomCLQVThQyjA6ESPRKGA3RPEAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_t_crosstable.Rd b/man/tm_t_crosstable.Rd index 54b96b06e..3cc5c5cb4 100644 --- a/man/tm_t_crosstable.Rd +++ b/man/tm_t_crosstable.Rd @@ -62,9 +62,8 @@ For more examples, please see the vignette "Using cross table" via \code{vignette("using-cross-table", package = "teal.modules.general")}. } \examples{ +\dontshow{if (require("rtables", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example -library(teal.widgets) - data <- teal_data() data <- within(data, { mtcars <- mtcars @@ -101,9 +100,6 @@ app <- init( multiple = FALSE, fixed = FALSE ) - ), - basic_table_args = basic_table_args( - subtitles = "Table generated by Crosstable Module" ) ) ) @@ -111,10 +107,9 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +\dontshow{if (require("rtables", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # CDISC data example -library(teal.widgets) - data <- teal_data() data <- within(data, { ADSL <- rADSL @@ -153,9 +148,6 @@ app <- init( multiple = FALSE, fixed = FALSE ) - ), - basic_table_args = basic_table_args( - subtitles = "Table generated by Crosstable Module" ) ) ) @@ -163,5 +155,20 @@ app <- init( if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} } +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6UhBq1Lr8UEG6cAAesKgiSgVFRrpc1AD61VA2VYVQBsYA7rSkABYq7M0RIEq6ujCkBCyinRNTM2OmRIy67Fq6KroEfoSs1OG6-lpheEcoMIf+Uiz+crajEOPjk9OMosDAWgC633NQ4hM6lIK3Yrxmnx+3zS4wAvktwe9Pv5UIxaDAWKwGgBrOCsfy-OaiTwNEQQdgQRhELpghbve5KWFpZrQeCiIbtWy1fyI05KABWRBUOLx7OaXOMguFuNY7KlEBFHB5dNOEWVb1V51R6MxiruaSUaFQcxUvT8T3y7USlqCuARAmEYmtfCEoXNzzqMAapAaBCpolEQRCcHdHt01GCcDySX8AGF-bM7MFKnglh6Stbmg1SqRmBoGqJUHAdmmwyzYHoY2BeeFSx7iSINNaG8WfYXi6Gw88I-Qo9b-ABlKOt3RaFi0ZNwRC1i1d8YEPpCghOpJjtGT32L2jLsXtZHVlUE74REt7A5nY6a-ywK5gG6MfV22dzlsaOD8a2ngj7W-3u5PudnhgYRNAqStkhcADAN0FZ+Bkd9rQcSC6zDExaBKBCkgAMQAQQAGQHVxnw9GEwzkKCPXiJIsxzPM2yLEtiOect4H7A8NRnQDX1IZth3zdtGOg8NI2jc4h0bHi1wnYNp1TJiPQXJcV1HccN0U7cxA5IJ9xrMBfhPXZv3PNUwBOW8bwvO84FuMB7gol8+PID8qzMuShOA6hQJEa1cII5x7K7NCMOc3RfMIlDxlIkjS1ItI0loEw1hUcg6O0EN7l0R5xlEAYIFYHD0HYI0ABJvAiEriUYHRGDSeEIDAWFviAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6AMIAIgCSAMpZuvxQQbpwAB6wqCJKpeVGulzUAPoNUDb1ZVAGxgDutKQAFirsHREgSrq6AII5BQAyfbqM80tKAL5pHdDwouM9tk3+64v+SgBWRCqtANZwrAcdx8b8cCZQwqStBPy0ogIrWutweT2Au1gYkOQTkAF0lEo0KgViohn4IDMOokSj1cNNdHwhKEcUThNCCTNSDBWj8CIwiKJREEQnAMTMObpqME4NQcf4sgymfZgnU8JSOZUcR1WlVSMwNK1RKg4AR2ZyOZD4PywGdwhLOaJearSDijSJFcrVeqNRzufReTqCsaNLotCxaKK4Ih9ZjbRyCMMbgQxDj3YxPazfkHaCHnj1gMBTgtzmA4XCIqJBPQjaakmYLJprC9dFM-f6ObR+FKmgBCd3oOIwqARFTDGRDUQRahECSx7jsACMcgiav8OTKcHCun8AAUAPIFPIADQ007ni5X1FI-jkaQrnPcpEEjAg7D20JewCrlTh+4P23x5f95pNcH4Oqy88cADkHABNX0D0Jb5aFqPQkgcFwn2AohGHedwP0glIYIPExaEqd8cQAMVmRYClcZ9OXvYjUM5eIkhlOUFR+K0xyIzUegvHU9XFBiZlfV0kk42iVXo4D7UdJJ-GdC1TXDSMRB9NjgMDYNQySCSvWjeT4yCRNkw2NMM10LMcxiHEC0sYsjlLA1-RvFYG1qDgJl0AEME+DQ4O7Xt+2oIc93M20jxPM8LzUqA5Gvas728jlH3CjiXXIJCZzAAjlyAg8YFA8CcLwgiyP9dDMLi3D8MIisSI5Er7zSNJaBMXR2BUcgaO0Nk9zMv1RFGCBWFmdB2GRAASbwIj6o1GB0Rg0k2JQwE2OEgA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } +} +} + diff --git a/man/tm_variable_browser.Rd b/man/tm_variable_browser.Rd index 00d3548b7..9c4c3f119 100644 --- a/man/tm_variable_browser.Rd +++ b/man/tm_variable_browser.Rd @@ -54,16 +54,7 @@ or continuous with a checkbox allowing users to switch how they are treated(if < then the default is discrete, otherwise it is continuous). } \examples{ -library(teal.widgets) - -# Module specification used in apps below -tm_variable_browser_module <- tm_variable_browser( - label = "Variable browser", - ggplot2_args = ggplot2_args( - labs = list(subtitle = "Plot generated by Variable Browser Module") - ) -) - +\dontshow{if (require("sparkline", quietly = TRUE) && require("htmlwidgets", quietly = TRUE) && require("jsonlite", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example data <- teal_data() data <- within(data, { @@ -77,13 +68,19 @@ datanames(data) <- c("iris", "mtcars", "women", "faithful", "CO2") app <- init( data = data, - modules = modules(tm_variable_browser_module) + modules = modules( + tm_variable_browser( + label = "Variable browser" + ) + ) ) if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +\dontshow{if (require("sparkline", quietly = TRUE) && require("htmlwidgets", quietly = TRUE) && require("jsonlite", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # CDISC example data +library(sparkline) data <- teal_data() data <- within(data, { ADSL <- rADSL @@ -94,10 +91,29 @@ join_keys(data) <- default_cdisc_join_keys[datanames(data)] app <- init( data = data, - modules = modules(tm_variable_browser_module) + modules = modules( + tm_variable_browser( + label = "Variable browser" + ) + ) ) if (interactive()) { shinyApp(app$ui, app$server) } - +\dontshow{\}) # examplesIf} +} +\section{Examples in Shinylive}{ +\describe{ + \item{example-1}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEulLhsrr8UKRQunAAHrCoIkoLSwbGXNQA+jtQNtuLy0a65aQFKuwnUSBKuro+tKJ7b4wfL7owpAILE+VwBQMYNQgr1KRHgUKuMLhfxMUFotzM1C+KLRBQxfwAwgB5ABMXyJxKUAF9FBATtB4KIHhdbFcCH4wO8anhdP4wcDav5ERQBWBsejhCLyf4aUo0Kgvio0X4ofMLk1Hn8+EIRJ8UlrhGJla9XsVDloWLQoPQRIcmERSqIZEbja9qFa4JiUv4AGoWq0iXR2h0yfx-V408NKGm0Ey6dgqcjMSw6Gy2Z4q0R3CCsACC6HYcoAJN4okXHYwdIwaZSlGBKQBdIA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } + \item{example-2}{ + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEugDCACIAkgDK07pwAB6wqCK6-FCkUEp0TCwcgSFhcIoQu-sGxlzUAPo3UDZKL3e65aQFKuwvURASl0ugAgrNFgAZT6McFQ4Fg2Z2OzOGHg5GuCAAXyuL2g8FE-z2UFsRl0BD8YDhkNq-nRKP8Vy6RBUj2CcFYhJepOM-DgJigwlIjwI-FoogIj2ZrPZnOAeNgYiJ+zkAF0lEo0KhPipaKQ-BAQR8UgCEXwhCJRE1zcIlQiQcVHloWLQoPQRI8mERSqIZAaQQHdNQ3XBqE1-AA1F1u7Zen0yfz23RXEFXK60Ey6dgqcjMSw6Gy2IGG3SiX4QVig9DsLUAEm8UTrvsYOkYVyxSjAWNVQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} + } } +} + diff --git a/staged_dependencies.yaml b/staged_dependencies.yaml index 16fdd83d9..d484dfe68 100644 --- a/staged_dependencies.yaml +++ b/staged_dependencies.yaml @@ -5,6 +5,9 @@ upstream_repos: insightsengineering/nestcolor: repo: insightsengineering/nestcolor host: https://github.com + insightsengineering/roxy.shinylive: + repo: insightsengineering/roxy.shinylive + host: https://github.com insightsengineering/teal.logger: repo: insightsengineering/teal.logger host: https://github.com diff --git a/vignettes/teal-modules-general.Rmd b/vignettes/teal-modules-general.Rmd index 4ccb9a329..6969a0695 100644 --- a/vignettes/teal-modules-general.Rmd +++ b/vignettes/teal-modules-general.Rmd @@ -10,16 +10,16 @@ vignette: > ### Introduction -`teal` extends the `shiny` framework, enabling the creation of interactive GUI applications using the `R`. -`shiny`, and `teal`facilitate the development of extensive applications through combining small, decoupled modules. -The `teal.modules.general` package consist of collection of modules essential for developing `teal` applications. -It is "general" in the sense that the intended functions of these modules are more fundamental. This contrasts with the more specialized focus on clinical data found in the `teal.modules.clinical` package. +`teal` extends the `shiny` framework, enabling the creation of interactive GUI applications using the `R`. +`shiny`, and `teal`facilitate the development of extensive applications through combining small, decoupled modules. +The `teal.modules.general` package consist of collection of modules essential for developing `teal` applications. +It is "general" in the sense that the intended functions of these modules are more fundamental. This contrasts with the more specialized focus on clinical data found in the `teal.modules.clinical` package. The modules from `teal.modules.general` can be used in conjunction with modules from `teal.modules.clinical` and / or other `shiny` modules to build a large `teal` / `shiny` app. The concepts presented here require knowledge about the core features of `teal`, specifically on how to launch a `teal` -application and how to pass data into it. Therefore, it is highly recommended to refer to the [`README`](https://insightsengineering.github.io/teal/index.html) file and +application and how to pass data into it. Therefore, it is highly recommended to refer to the [`README`](https://insightsengineering.github.io/teal/index.html) file and the introductory [vignette](https://insightsengineering.github.io/teal/latest-tag/articles/getting-started-with-teal.html) of the `teal` package. See also `teal.modules.clinical`'s [`README`](https://insightsengineering.github.io/teal.modules.clinical/latest-tag/index.html). @@ -39,10 +39,11 @@ See [package functions / modules](https://insightsengineering.github.io/teal.mod ### Example application A simple application featuring the `tm_variable_browser()` module: -```{r, message = FALSE, results = "hide"} +```{r app, message = FALSE, results = "hide"} # load libraries library(teal.modules.general) library(teal.widgets) +library(sparkline) # teal_data object data <- teal_data() @@ -69,12 +70,28 @@ app <- init( ) ``` -```{r, eval = FALSE} +```{r shinyapp, eval = FALSE} shinyApp(app$ui, app$server) ``` +### Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` + Let's break the above app into pieces: 1: Load the necessary libraries and data. diff --git a/vignettes/using-association-plot.Rmd b/vignettes/using-association-plot.Rmd index dc4660cb8..b303ff9b7 100644 --- a/vignettes/using-association-plot.Rmd +++ b/vignettes/using-association-plot.Rmd @@ -19,7 +19,7 @@ This vignette will guide you through the four parts to create a `teal` applicati ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets ``` @@ -33,7 +33,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -56,7 +56,7 @@ join_keys(data) <- default_cdisc_join_keys[datanames] This is the most important section. We will use the `teal::init()` function to create an app. The data will be handed over using `teal.data::teal_data()`. The app itself will be constructed by multiple calls of `tm_g_association()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for a single wide dataset mod1 <- tm_g_association( label = "Single wide dataset", @@ -296,8 +296,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-bivariate-plot.Rmd b/vignettes/using-bivariate-plot.Rmd index 518692b38..a13de8866 100644 --- a/vignettes/using-bivariate-plot.Rmd +++ b/vignettes/using-bivariate-plot.Rmd @@ -20,7 +20,7 @@ various types of datasets using the bivariate plot module `tm_g_bivariate()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets ``` @@ -35,7 +35,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -61,7 +61,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_g_bivariate()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide dataset mod1 <- tm_g_bivariate( label = "Single wide dataset", @@ -622,8 +622,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-cross-table.Rmd b/vignettes/using-cross-table.Rmd index fd0c98b6d..73c823003 100644 --- a/vignettes/using-cross-table.Rmd +++ b/vignettes/using-cross-table.Rmd @@ -20,9 +20,10 @@ various types of datasets using the cross table module `tm_t_crosstable()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets +library(rtables) ``` ## 2 - Create data sets @@ -32,7 +33,7 @@ Inside this app 2 datasets will be used 1. `ADSL` A wide data set with subject data 2. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide", echo=2:6} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide", echo=2:6} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL @@ -55,7 +56,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_t_crosstable()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide dataset mod1 <- tm_t_crosstable( label = "Single wide dataset", @@ -138,8 +139,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-data-table.Rmd b/vignettes/using-data-table.Rmd index c1a34f450..686f61b14 100644 --- a/vignettes/using-data-table.Rmd +++ b/vignettes/using-data-table.Rmd @@ -20,7 +20,7 @@ various types of datasets using the data table module `tm_data_table()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app ``` @@ -32,7 +32,7 @@ Inside this app 3 datasets will be used 2. `ADTTE` A long data set with time to event data 3. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL @@ -51,7 +51,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The app itself will be constructed by multiple calls of `tm_data_table()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the two-datasets example mod1 <- tm_data_table( label = "Two datasets", @@ -106,11 +106,29 @@ app <- init( ## 4 - Run the app -A simple `shiny::shinyApp()` call will let you run the app. -Note that app is only displayed when running this code inside an `R` session. +A simple `shiny::shinyApp()` call will let you run the app. +Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-outliers-module.Rmd b/vignettes/using-outliers-module.Rmd index 9ed56f0ad..1d6ca8536 100644 --- a/vignettes/using-outliers-module.Rmd +++ b/vignettes/using-outliers-module.Rmd @@ -20,7 +20,7 @@ various types of datasets using the outliers module `tm_outliers()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets ``` @@ -33,7 +33,7 @@ Inside this app 3 datasets will be used 2. `ADRS` A long data set with response data for subjects at different time points of the study 3. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL @@ -52,7 +52,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_outliers()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide dataset mod1 <- tm_outliers( label = "Single wide dataset", @@ -187,11 +187,29 @@ app <- init( ``` ## 4 - Run the app -A simple `shiny::shinyApp()` call will let you run the app. -Note that app is only displayed when running this code inside an `R` session. +A simple `shiny::shinyApp()` call will let you run the app. +Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-regression-plots.Rmd b/vignettes/using-regression-plots.Rmd index 93d901012..94c8aac14 100644 --- a/vignettes/using-regression-plots.Rmd +++ b/vignettes/using-regression-plots.Rmd @@ -21,7 +21,7 @@ various types of datasets using the regression plot module `tm_a_regression()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets ``` @@ -35,7 +35,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -61,7 +61,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_a_regression()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide dataset mod1 <- tm_a_regression( label = "Single wide dataset", @@ -269,8 +269,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-response-plot.Rmd b/vignettes/using-response-plot.Rmd index 415f095f7..f8054e4c8 100644 --- a/vignettes/using-response-plot.Rmd +++ b/vignettes/using-response-plot.Rmd @@ -20,7 +20,7 @@ various types of datasets using the response plot module `tm_g_response()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets ``` @@ -34,7 +34,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -60,7 +60,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_g_response()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide dataset mod1 <- tm_g_response( label = "Single wide dataset", @@ -378,8 +378,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-scatterplot-matrix.Rmd b/vignettes/using-scatterplot-matrix.Rmd index befb643fb..c89490ad4 100644 --- a/vignettes/using-scatterplot-matrix.Rmd +++ b/vignettes/using-scatterplot-matrix.Rmd @@ -21,9 +21,10 @@ various types of datasets using the scatter plot matrix module `tm_g_scatterplot ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets +library(lattice) ``` ## 2 - Create data sets @@ -35,7 +36,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -61,7 +62,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_g_scatterplotmatrix()` using different combinations of data sets. -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide dataset mod1 <- tm_g_scatterplotmatrix( label = "Single wide dataset", @@ -156,8 +157,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` diff --git a/vignettes/using-scatterplot.Rmd b/vignettes/using-scatterplot.Rmd index 58e42ef92..bd28df325 100644 --- a/vignettes/using-scatterplot.Rmd +++ b/vignettes/using-scatterplot.Rmd @@ -21,9 +21,12 @@ various types of datasets using the scatter plot module `tm_g_scatterplot()`: ## 1 - Load libraries -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets +library(ggpmisc) +library(ggExtra) +library(colourpicker) ``` ## 2 - Create data sets @@ -35,7 +38,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -61,13 +64,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_g_scatterplot()` using different combinations of data sets. -```{r ggExtra, include = FALSE} -ggextra_available <- requireNamespace("ggExtra", quietly = TRUE) -``` -```{r, include = !ggextra_available} -# NOTE: The code will not be run as package ggExtra is not installed. -``` -```{r, eval = ggextra_available, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} # configuration for the single wide datasets mod1 <- tm_g_scatterplot( label = "Single wide dataset", @@ -376,8 +373,26 @@ app <- init( A simple `shiny::shinyApp()` call will let you run the app. Note that app is only displayed when running this code inside an `R` session. -```{r, echo=TRUE, results="hide", eval=base::interactive()} +```{r shinyapp, echo=TRUE, results="hide", eval=base::interactive()} shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ``` + +## 5 - Try it out in Shinylive + +```{r shinylive_url, echo = FALSE, results = 'asis'} +code <- paste0(c( + knitr::knit_code$get("library"), + knitr::knit_code$get("data"), + knitr::knit_code$get("app"), + knitr::knit_code$get("shinyapp") +), collapse = "\n") + +url <- roxy.shinylive::create_shinylive_url(code) +cat(sprintf("[Open in Shinylive](%s)\n\n", url)) +``` + +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +knitr::include_url(url, height = "800px") +``` From ae01110ea4c35ff586ffaeebf7f9455b8a38d57c Mon Sep 17 00:00:00 2001 From: pawelru Date: Tue, 1 Oct 2024 08:32:11 +0000 Subject: [PATCH 20/42] [skip actions] Bump version to 0.3.0.9050 --- DESCRIPTION | 10 +++++----- NEWS.md | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 8b91d2565..a19237bbc 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9049 -Date: 2024-09-17 +Version: 0.3.0.9050 +Date: 2024-10-01 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), @@ -93,9 +93,9 @@ Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, aphalo/ggpmisc, aphalo/ggpp, slowkow/ggrepel, baddstats/goftest, ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, daroczig/logger, deepayan/lattice, insightsengineering/nestcolor, r-lib/pkgload, - r-lib/rlang, rstudio/rmarkdown, insightsengineering/roxy.shinylive, insightsengineering/rtables, - tidyverse/rvest, htmlwidgets/sparkline, rstudio/shinytest2, - r-lib/testthat, r-lib/withr + r-lib/rlang, rstudio/rmarkdown, insightsengineering/roxy.shinylive, + insightsengineering/rtables, tidyverse/rvest, htmlwidgets/sparkline, + rstudio/shinytest2, r-lib/testthat, r-lib/withr Config/Needs/website: insightsengineering/nesttemplate Encoding: UTF-8 Language: en-US diff --git a/NEWS.md b/NEWS.md index cdefc78f4..8c896e68b 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9049 +# teal.modules.general 0.3.0.9050 * Removed `Show Warnings` modals from modules. From d9fd08ba2e53c54c549333c65f4f63cb51fd32bb Mon Sep 17 00:00:00 2001 From: Marcin <133694481+m7pr@users.noreply.github.com> Date: Mon, 7 Oct 2024 23:46:37 +0200 Subject: [PATCH 21/42] WIP 771 fix failed pipelines (#789) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Fixes #771 - revdepcheck 🆗 https://github.com/insightsengineering/teal.modules.general/actions/runs/11162906687 - rhub 🌮 WIP https://github.com/insightsengineering/teal.modules.general/actions/runs/11211837075/job/31161572229 This fixes R-hub and revdepcheck checks --- .github/workflows/scheduled.yaml | 15 +++++++++++++++ DESCRIPTION | 2 +- vignettes/teal-modules-general.Rmd | 8 ++++---- vignettes/using-association-plot.Rmd | 4 ++-- vignettes/using-bivariate-plot.Rmd | 4 ++-- vignettes/using-cross-table.Rmd | 4 ++-- vignettes/using-data-table.Rmd | 4 ++-- vignettes/using-outliers-module.Rmd | 4 ++-- vignettes/using-regression-plots.Rmd | 4 ++-- vignettes/using-response-plot.Rmd | 4 ++-- vignettes/using-scatterplot-matrix.Rmd | 4 ++-- vignettes/using-scatterplot.Rmd | 10 +++++----- 12 files changed, 41 insertions(+), 26 deletions(-) diff --git a/.github/workflows/scheduled.yaml b/.github/workflows/scheduled.yaml index a73b25644..2aace5e2b 100644 --- a/.github/workflows/scheduled.yaml +++ b/.github/workflows/scheduled.yaml @@ -56,6 +56,19 @@ jobs: ) name: revdepcheck ↩️ uses: insightsengineering/r.pkg.template/.github/workflows/revdepcheck.yaml@main + with: + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.slice + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/tern + insightsengineering/rtables rhub: if: > github.event_name == 'schedule' || ( @@ -66,10 +79,12 @@ jobs: uses: insightsengineering/r.pkg.template/.github/workflows/rhub.yaml@main with: lookup-refs: | + insightsengineering/roxy.shinylive insightsengineering/teal insightsengineering/teal.transform insightsengineering/teal.code insightsengineering/teal.data + insightsengineering/teal.slice insightsengineering/teal.logger insightsengineering/teal.reporter insightsengineering/teal.widgets diff --git a/DESCRIPTION b/DESCRIPTION index a19237bbc..42b807f01 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -81,7 +81,7 @@ Suggests: VignetteBuilder: knitr Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, - rstudio/shiny, insightsengineering/teal, + rstudio/shiny, insightsengineering/teal, insightsengineering/teal.transform, mllg/checkmate, tidyverse/dplyr, rstudio/DT, tidyverse/forcats, r-lib/scales, daattali/shinyjs, shinyTree/shinyTree, rstudio/shinyvalidate, dreamRs/shinyWidgets, diff --git a/vignettes/teal-modules-general.Rmd b/vignettes/teal-modules-general.Rmd index 6969a0695..0980da151 100644 --- a/vignettes/teal-modules-general.Rmd +++ b/vignettes/teal-modules-general.Rmd @@ -39,7 +39,7 @@ See [package functions / modules](https://insightsengineering.github.io/teal.mod ### Example application A simple application featuring the `tm_variable_browser()` module: -```{r app, message = FALSE, results = "hide"} +```{r app, message = FALSE, results = "hide", eval = requireNamespace("sparkline", quietly = TRUE)} # load libraries library(teal.modules.general) library(teal.widgets) @@ -78,7 +78,7 @@ shinyApp(app$ui, app$server) ### Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("app"), knitr::knit_code$get("shinyapp") @@ -88,7 +88,7 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` @@ -146,7 +146,7 @@ In a `teal` app, data and modules are decoupled. In the app above: - The app developer specified the module and assigned it to the `modules` argument. - The `init` function took these arguments and returned a list containing `ui` and `server` object, which can be demonstrated by running: -```{r, indent = " "} +```{r, indent = " ", eval = requireNamespace("sparkline", quietly = TRUE)} class(app) names(app) ``` diff --git a/vignettes/using-association-plot.Rmd b/vignettes/using-association-plot.Rmd index b303ff9b7..b7f8aff42 100644 --- a/vignettes/using-association-plot.Rmd +++ b/vignettes/using-association-plot.Rmd @@ -304,7 +304,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -316,6 +316,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-bivariate-plot.Rmd b/vignettes/using-bivariate-plot.Rmd index a13de8866..431c87929 100644 --- a/vignettes/using-bivariate-plot.Rmd +++ b/vignettes/using-bivariate-plot.Rmd @@ -630,7 +630,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -642,6 +642,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-cross-table.Rmd b/vignettes/using-cross-table.Rmd index 73c823003..0a9ad3011 100644 --- a/vignettes/using-cross-table.Rmd +++ b/vignettes/using-cross-table.Rmd @@ -147,7 +147,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -159,6 +159,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-data-table.Rmd b/vignettes/using-data-table.Rmd index 686f61b14..27fd1ea3c 100644 --- a/vignettes/using-data-table.Rmd +++ b/vignettes/using-data-table.Rmd @@ -117,7 +117,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -129,6 +129,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-outliers-module.Rmd b/vignettes/using-outliers-module.Rmd index 1d6ca8536..507cf4716 100644 --- a/vignettes/using-outliers-module.Rmd +++ b/vignettes/using-outliers-module.Rmd @@ -198,7 +198,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -210,6 +210,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-regression-plots.Rmd b/vignettes/using-regression-plots.Rmd index 94c8aac14..fe10bce4f 100644 --- a/vignettes/using-regression-plots.Rmd +++ b/vignettes/using-regression-plots.Rmd @@ -277,7 +277,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -289,6 +289,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-response-plot.Rmd b/vignettes/using-response-plot.Rmd index f8054e4c8..59dae80f3 100644 --- a/vignettes/using-response-plot.Rmd +++ b/vignettes/using-response-plot.Rmd @@ -386,7 +386,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -398,6 +398,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-scatterplot-matrix.Rmd b/vignettes/using-scatterplot-matrix.Rmd index c89490ad4..28d09f70e 100644 --- a/vignettes/using-scatterplot-matrix.Rmd +++ b/vignettes/using-scatterplot-matrix.Rmd @@ -165,7 +165,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -177,6 +177,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` diff --git a/vignettes/using-scatterplot.Rmd b/vignettes/using-scatterplot.Rmd index bd28df325..ec40e2e8d 100644 --- a/vignettes/using-scatterplot.Rmd +++ b/vignettes/using-scatterplot.Rmd @@ -21,7 +21,7 @@ various types of datasets using the scatter plot module `tm_g_scatterplot()`: ## 1 - Load libraries -```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r library, echo=TRUE, message=FALSE, warning=FALSE, results="hide", eval = requireNamespace("ggpmics") && requireNamespace("ggExtra") && requireNamespace("colourpicker")} library(teal.modules.general) # used to create the app library(dplyr) # used to modify data sets library(ggpmisc) @@ -38,7 +38,7 @@ Inside this app 4 datasets will be used 3. `ADTTE` A long data set with time to event data 4. `ADLB` A long data set with lab measurements for each subject -```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r data, echo=TRUE, message=FALSE, warning=FALSE, results="hide", eval = requireNamespace("ggpmics") && requireNamespace("ggExtra") && requireNamespace("colourpicker")} data <- teal_data() data <- within(data, { ADSL <- teal.modules.general::rADSL %>% @@ -64,7 +64,7 @@ create an app. The data will be handed over using `teal.data::teal_data()`. The itself will be constructed by multiple calls of `tm_g_scatterplot()` using different combinations of data sets. -```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide"} +```{r app, echo=TRUE, message=FALSE, warning=FALSE, results="hide", eval = requireNamespace("ggpmics") && requireNamespace("ggExtra") && requireNamespace("colourpicker")} # configuration for the single wide datasets mod1 <- tm_g_scatterplot( label = "Single wide dataset", @@ -381,7 +381,7 @@ shinyApp(app$ui, app$server, options = list(height = 1024, width = 1024)) ## 5 - Try it out in Shinylive -```{r shinylive_url, echo = FALSE, results = 'asis'} +```{r shinylive_url, echo = FALSE, results = 'asis', eval = requireNamespace("roxy.shinylive", quietly = TRUE)} code <- paste0(c( knitr::knit_code$get("library"), knitr::knit_code$get("data"), @@ -393,6 +393,6 @@ url <- roxy.shinylive::create_shinylive_url(code) cat(sprintf("[Open in Shinylive](%s)\n\n", url)) ``` -```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} +```{r shinylive_iframe, echo = FALSE, out.width = '150%', out.extra = 'style = "position: relative; z-index:1"', eval = requireNamespace("roxy.shinylive", quietly = TRUE) && knitr::is_html_output() && identical(Sys.getenv("IN_PKGDOWN"), "true")} knitr::include_url(url, height = "800px") ``` From 643644eb0d839c755cc796f6074b6f8c4b9b59ea Mon Sep 17 00:00:00 2001 From: donyunardi Date: Mon, 7 Oct 2024 21:47:30 +0000 Subject: [PATCH 22/42] [skip actions] Bump version to 0.3.0.9051 --- .pre-commit-config.yaml | 2 +- DESCRIPTION | 6 +++--- NEWS.md | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 7dd8e86f4..469b6771c 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,7 +1,7 @@ --- # All available hooks: https://pre-commit.com/hooks.html # R specific hooks: https://github.com/lorenzwalthert/precommit -default_stages: [commit] +default_stages: [pre-commit] default_language_version: python: python3 repos: diff --git a/DESCRIPTION b/DESCRIPTION index 42b807f01..fd23a917a 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9050 -Date: 2024-10-01 +Version: 0.3.0.9051 +Date: 2024-10-07 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), @@ -81,7 +81,7 @@ Suggests: VignetteBuilder: knitr Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, - rstudio/shiny, insightsengineering/teal, + rstudio/shiny, insightsengineering/teal, insightsengineering/teal.transform, mllg/checkmate, tidyverse/dplyr, rstudio/DT, tidyverse/forcats, r-lib/scales, daattali/shinyjs, shinyTree/shinyTree, rstudio/shinyvalidate, dreamRs/shinyWidgets, diff --git a/NEWS.md b/NEWS.md index 8c896e68b..62b8e77e5 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9050 +# teal.modules.general 0.3.0.9051 * Removed `Show Warnings` modals from modules. From dfd33c43afb41417a6f4852304dfec31170065de Mon Sep 17 00:00:00 2001 From: Pawel Rucki <12943682+pawelru@users.noreply.github.com> Date: Fri, 25 Oct 2024 12:20:30 +0200 Subject: [PATCH 23/42] add rmarkdown to VignetteBuilder (#792) fix nosuggest ci --- DESCRIPTION | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/DESCRIPTION b/DESCRIPTION index fd23a917a..a04a431f4 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -79,7 +79,8 @@ Suggests: testthat (>= 3.1.9), withr (>= 2.0.0) VignetteBuilder: - knitr + knitr, + rmarkdown Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, rstudio/shiny, insightsengineering/teal, insightsengineering/teal.transform, mllg/checkmate, tidyverse/dplyr, From 0ea551b583ec739c7a4b01b70b7e8bce9b5133e7 Mon Sep 17 00:00:00 2001 From: pawelru Date: Fri, 25 Oct 2024 10:21:26 +0000 Subject: [PATCH 24/42] [skip actions] Bump version to 0.3.0.9052 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index a04a431f4..b371e0f7c 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9051 -Date: 2024-10-07 +Version: 0.3.0.9052 +Date: 2024-10-25 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 62b8e77e5..6b98d9689 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9051 +# teal.modules.general 0.3.0.9052 * Removed `Show Warnings` modals from modules. From b0d1863735f5a29b1ac2459c1683906e52528d3e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20Ver=C3=ADssimo?= <211358+averissimo@users.noreply.github.com> Date: Mon, 4 Nov 2024 12:53:41 +0000 Subject: [PATCH 25/42] Adds `roxy.shinylive` to pre-commit configuration (#793) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit # Pull Request Fixes https://github.com/insightsengineering/nestdevs-tasks/issues/85 ### Changes description - Add dependency to pre-commit configuration --------- Signed-off-by: André Veríssimo <211358+averissimo@users.noreply.github.com> --- .pre-commit-config.yaml | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 469b6771c..b154dbae6 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -6,7 +6,7 @@ default_language_version: python: python3 repos: - repo: https://github.com/lorenzwalthert/precommit - rev: v0.4.3.9001 + rev: v0.4.3.9003 hooks: - id: style-files name: Style code with `styler` @@ -18,8 +18,6 @@ repos: - ggmosaic - ggplot2 - shiny - - teal - - teal.transform - checkmate - dplyr - DT @@ -33,6 +31,9 @@ repos: - shinyWidgets - stats - stringr + - insightsengineering/roxy.shinylive + - insightsengineering/teal + - insightsengineering/teal.transform - insightsengineering/teal.code - insightsengineering/teal.data - insightsengineering/teal.logger From e67d7f2b46f302ccd2ac41d942f30bf6f68609d3 Mon Sep 17 00:00:00 2001 From: averissimo Date: Mon, 4 Nov 2024 12:54:34 +0000 Subject: [PATCH 26/42] [skip actions] Bump version to 0.3.0.9053 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index b371e0f7c..c91bff840 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9052 -Date: 2024-10-25 +Version: 0.3.0.9053 +Date: 2024-11-04 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 6b98d9689..b50d8ce9a 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9052 +# teal.modules.general 0.3.0.9053 * Removed `Show Warnings` modals from modules. From 3c9bcb4461302e5cfdaae06ac9d7f9f6c3795781 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20Ver=C3=ADssimo?= <211358+averissimo@users.noreply.github.com> Date: Fri, 8 Nov 2024 14:02:16 +0000 Subject: [PATCH 27/42] `teal.data::datanames()` is deprecated in favor of dot-prefix and `names()` (#794) # Pull Request Part of https://github.com/insightsengineering/teal.data/issues/333 Blocked by: - https://github.com/insightsengineering/teal.code/pull/218 - https://github.com/insightsengineering/teal.data/pull/347 - https://github.com/insightsengineering/teal/pull/1402 --- DESCRIPTION | 8 ++++---- R/tm_a_pca.R | 5 +---- R/tm_a_regression.R | 4 +--- R/tm_data_table.R | 6 ++---- R/tm_file_viewer.R | 1 - R/tm_front_page.R | 5 ++--- R/tm_g_association.R | 4 +--- R/tm_g_bivariate.R | 4 +--- R/tm_g_distribution.R | 10 ++++------ R/tm_g_response.R | 4 +--- R/tm_g_scatterplot.R | 4 +--- R/tm_g_scatterplotmatrix.R | 4 +--- R/tm_missing_data.R | 15 +++++++-------- R/tm_outliers.R | 6 ++---- R/tm_t_crosstable.R | 4 +--- R/tm_variable_browser.R | 6 ++---- man/tm_a_pca.Rd | 13 +++++-------- man/tm_a_regression.Rd | 12 +++++------- man/tm_data_table.Rd | 12 +++++------- man/tm_file_viewer.Rd | 5 ++--- man/tm_front_page.Rd | 7 +++---- man/tm_g_association.Rd | 12 +++++------- man/tm_g_bivariate.Rd | 12 +++++------- man/tm_g_distribution.Rd | 12 +++++------- man/tm_g_response.Rd | 12 +++++------- man/tm_g_scatterplot.Rd | 12 +++++------- man/tm_g_scatterplotmatrix.Rd | 12 +++++------- man/tm_missing_data.Rd | 12 +++++------- man/tm_outliers.Rd | 12 +++++------- man/tm_t_crosstable.Rd | 12 +++++------- man/tm_variable_browser.Rd | 12 +++++------- tests/testthat/helper-TealAppDriver.R | 16 ++++++---------- tests/testthat/test-shinytest2-tm_a_pca.R | 2 -- tests/testthat/test-shinytest2-tm_a_regression.R | 1 - .../testthat/test-shinytest2-tm_g_association.R | 5 ++--- tests/testthat/test-shinytest2-tm_g_bivariate.R | 1 - .../testthat/test-shinytest2-tm_g_distribution.R | 7 ++----- tests/testthat/test-shinytest2-tm_g_response.R | 3 +-- .../testthat/test-shinytest2-tm_g_scatterplot.R | 3 +-- tests/testthat/test-shinytest2-tm_outliers.R | 1 - vignettes/teal-modules-general.Rmd | 8 ++------ vignettes/using-association-plot.Rmd | 4 +--- vignettes/using-bivariate-plot.Rmd | 4 +--- vignettes/using-cross-table.Rmd | 4 +--- vignettes/using-data-table.Rmd | 4 +--- vignettes/using-outliers-module.Rmd | 4 +--- vignettes/using-regression-plots.Rmd | 4 +--- vignettes/using-response-plot.Rmd | 4 +--- vignettes/using-scatterplot-matrix.Rmd | 4 +--- vignettes/using-scatterplot.Rmd | 4 +--- 50 files changed, 124 insertions(+), 218 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index c91bff840..580816261 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -27,8 +27,8 @@ Depends: ggplot2 (>= 3.4.0), R (>= 3.6), shiny (>= 1.6.0), - teal (>= 0.15.2.9052), - teal.transform (>= 0.5.0) + teal (>= 0.15.2.9079), + teal.transform (>= 0.5.0.9015) Imports: checkmate (>= 2.1.0), dplyr (>= 1.0.5), @@ -42,8 +42,8 @@ Imports: shinyWidgets (>= 0.5.1), stats, stringr (>= 1.4.1), - teal.code (>= 0.5.0), - teal.data (>= 0.5.0), + teal.code (>= 0.5.0.9012), + teal.data (>= 0.6.0.9015), teal.logger (>= 0.2.0.9004), teal.reporter (>= 0.3.0), teal.widgets (>= 0.4.0), diff --git a/R/tm_a_pca.R b/R/tm_a_pca.R index 53996ebb7..7753c3101 100644 --- a/R/tm_a_pca.R +++ b/R/tm_a_pca.R @@ -30,8 +30,6 @@ #' USArrests <- USArrests #' }) #' -#' datanames(data) <- "USArrests" -#' #' app <- init( #' data = data, #' modules = modules( @@ -66,8 +64,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_a_regression.R b/R/tm_a_regression.R index 89406f5e5..4e28de543 100644 --- a/R/tm_a_regression.R +++ b/R/tm_a_regression.R @@ -53,7 +53,6 @@ #' require(nestcolor) #' CO2 <- CO2 #' }) -#' datanames(data) <- c("CO2") #' #' app <- init( #' data = data, @@ -98,8 +97,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_data_table.R b/R/tm_data_table.R index 4a2be49d4..2a688f7d7 100644 --- a/R/tm_data_table.R +++ b/R/tm_data_table.R @@ -40,7 +40,6 @@ #' require(nestcolor) #' iris <- iris #' }) -#' datanames(data) <- c("iris") #' #' app <- init( #' data = data, @@ -68,8 +67,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, @@ -196,7 +194,7 @@ srv_page_data_table <- function(id, if_filtered <- reactive(as.logical(input$if_filtered)) if_distinct <- reactive(as.logical(input$if_distinct)) - datanames <- isolate(teal.data::datanames(data())) + datanames <- isolate(names(data())) datanames <- Filter(function(name) { is.data.frame(isolate(data())[[name]]) }, datanames) diff --git a/R/tm_file_viewer.R b/R/tm_file_viewer.R index 772dfdac3..ee2d50acb 100644 --- a/R/tm_file_viewer.R +++ b/R/tm_file_viewer.R @@ -22,7 +22,6 @@ #' data <- within(data, { #' data <- data.frame(1) #' }) -#' datanames(data) <- c("data") #' #' app <- init( #' data = data, diff --git a/R/tm_front_page.R b/R/tm_front_page.R index 7304eb90c..6cdbb0ce8 100644 --- a/R/tm_front_page.R +++ b/R/tm_front_page.R @@ -28,8 +28,7 @@ #' ADSL <- rADSL #' attr(ADSL, "metadata") <- list("Author" = "NEST team", "data_source" = "synthetic data") #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' table_1 <- data.frame(Info = c("A", "B"), Text = c("A", "B")) #' table_2 <- data.frame(`Column 1` = c("C", "D"), `Column 2` = c(5.5, 6.6), `Column 3` = c("A", "B")) @@ -169,7 +168,7 @@ srv_front_page <- function(id, data, tables, show_metadata) { ) metadata_data_frame <- reactive({ - datanames <- teal.data::datanames(data()) + datanames <- names(data()) convert_metadata_to_dataframe( lapply(datanames, function(dataname) attr(data()[[dataname]], "metadata")), datanames diff --git a/R/tm_g_association.R b/R/tm_g_association.R index c3698f5d8..3611df804 100644 --- a/R/tm_g_association.R +++ b/R/tm_g_association.R @@ -38,7 +38,6 @@ #' factors <- names(Filter(isTRUE, vapply(CO2, is.factor, logical(1L)))) #' CO2[factors] <- lapply(CO2[factors], as.character) #' }) -#' datanames(data) <- c("CO2") #' #' app <- init( #' data = data, @@ -81,8 +80,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_g_bivariate.R b/R/tm_g_bivariate.R index bf9358476..4e93151b9 100644 --- a/R/tm_g_bivariate.R +++ b/R/tm_g_bivariate.R @@ -57,7 +57,6 @@ #' require(nestcolor) #' CO2 <- data.frame(CO2) #' }) -#' datanames(data) <- c("CO2") #' #' app <- init( #' data = data, @@ -116,8 +115,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- c("ADSL") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_g_distribution.R b/R/tm_g_distribution.R index 6b6192678..22d5fec89 100644 --- a/R/tm_g_distribution.R +++ b/R/tm_g_distribution.R @@ -39,7 +39,6 @@ #' data <- within(data, { #' iris <- iris #' }) -#' datanames(data) <- "iris" #' #' app <- init( #' data = data, @@ -68,8 +67,7 @@ #' data <- within(data, { #' ADSL <- rADSL #' }) -#' datanames(data) <- c("ADSL") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' vars1 <- choices_selected( #' variable_choices(data[["ADSL"]], c("ARM", "COUNTRY", "SEX")), @@ -1216,15 +1214,15 @@ srv_distribution <- function(id, # wrapped in if since could lead into validate error - we do want to continue test_r_qenv_out <- try(test_q(), silent = TRUE) if (!inherits(test_r_qenv_out, c("try-error", "error"))) { - qenv_final <- teal.code::join(qenv_final, test_q()) + qenv_final <- c(qenv_final, test_q()) } qenv_final <- if (tab == "Histogram") { req(dist_q()) - teal.code::join(qenv_final, dist_q()) + c(qenv_final, dist_q()) } else if (tab == "QQplot") { req(qq_q()) - teal.code::join(qenv_final, qq_q()) + c(qenv_final, qq_q()) } qenv_final }) diff --git a/R/tm_g_response.R b/R/tm_g_response.R index 35ee6d36a..a593c46a4 100644 --- a/R/tm_g_response.R +++ b/R/tm_g_response.R @@ -53,7 +53,6 @@ #' mtcars[[v]] <- as.factor(mtcars[[v]]) #' } #' }) -#' datanames(data) <- "mtcars" #' #' app <- init( #' data = data, @@ -98,8 +97,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- c("ADSL") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_g_scatterplot.R b/R/tm_g_scatterplot.R index d093a4fad..1f2d9d58a 100644 --- a/R/tm_g_scatterplot.R +++ b/R/tm_g_scatterplot.R @@ -43,7 +43,6 @@ #' require(nestcolor) #' CO2 <- CO2 #' }) -#' datanames(data) <- "CO2" #' #' app <- init( #' data = data, @@ -133,8 +132,7 @@ #' require(nestcolor) #' ADSL <- rADSL #' }) -#' datanames(data) <- c("ADSL") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_g_scatterplotmatrix.R b/R/tm_g_scatterplotmatrix.R index a570bf6bb..70f5d4b7e 100644 --- a/R/tm_g_scatterplotmatrix.R +++ b/R/tm_g_scatterplotmatrix.R @@ -56,7 +56,6 @@ #' profit = rnorm(50, 20, 10) #' ) #' }) -#' datanames(data) <- c("countries", "sales") #' join_keys(data) <- join_keys( #' join_key("countries", "countries", "id"), #' join_key("sales", "sales", "id"), @@ -117,8 +116,7 @@ #' ADSL <- rADSL #' ADRS <- rADRS #' }) -#' datanames(data) <- c("ADSL", "ADRS") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_missing_data.R b/R/tm_missing_data.R index 7f026cb49..d57c616bd 100644 --- a/R/tm_missing_data.R +++ b/R/tm_missing_data.R @@ -40,7 +40,6 @@ #' mtcars[["cyl"]] <- as.factor(mtcars[["cyl"]]) #' mtcars[["gear"]] <- as.factor(mtcars[["gear"]]) #' }) -#' datanames(data) <- c("iris", "mtcars") #' #' app <- init( #' data = data, @@ -64,8 +63,7 @@ #' ADSL <- rADSL #' ADRS <- rADRS #' }) -#' datanames(data) <- c("ADSL", "ADRS") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, @@ -173,10 +171,11 @@ srv_page_missing_data <- function(id, data, reporter, filter_panel_api, parent_d moduleServer(id, function(input, output, session) { teal.logger::log_shiny_input_changes(input, namespace = "teal.modules.general") - datanames <- isolate(teal.data::datanames(data())) - datanames <- Filter(function(name) { - is.data.frame(isolate(data())[[name]]) - }, datanames) + datanames <- isolate(names(data())) + datanames <- Filter( + function(name) is.data.frame(isolate(data())[[name]]), + datanames + ) if_subject_plot <- length(parent_dataname) > 0 && parent_dataname %in% datanames ns <- session$ns @@ -465,7 +464,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par data_parent_keys <- reactive({ - if (length(parent_dataname) > 0 && parent_dataname %in% teal.data::datanames(data())) { + if (length(parent_dataname) > 0 && parent_dataname %in% names(data())) { keys <- teal.data::join_keys(data())[[dataname]] if (parent_dataname %in% names(keys)) { keys[[parent_dataname]] diff --git a/R/tm_outliers.R b/R/tm_outliers.R index 03a43b18e..dab983f2d 100644 --- a/R/tm_outliers.R +++ b/R/tm_outliers.R @@ -28,7 +28,6 @@ #' CO2 <- CO2 #' CO2[["primary_key"]] <- seq_len(nrow(CO2)) #' }) -#' datanames(data) <- "CO2" #' join_keys(data) <- join_keys(join_key("CO2", "CO2", "primary_key")) #' #' vars <- choices_selected(variable_choices(data[["CO2"]], c("Plant", "Type", "Treatment"))) @@ -77,8 +76,7 @@ #' data <- within(data, { #' ADSL <- rADSL #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' fact_vars_adsl <- names(Filter(isTRUE, sapply(data[["ADSL"]], is.factor))) #' vars <- choices_selected(variable_choices(data[["ADSL"]], fact_vars_adsl)) @@ -396,7 +394,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, }) # Used to create outlier table and the dropdown with additional columns - dataname_first <- isolate(teal.data::datanames(data())[[1]]) + dataname_first <- isolate(names(data())[[1]]) common_code_q <- reactive({ req(iv_r()$is_valid()) diff --git a/R/tm_t_crosstable.R b/R/tm_t_crosstable.R index 9e4e8e62c..47d84bcfd 100644 --- a/R/tm_t_crosstable.R +++ b/R/tm_t_crosstable.R @@ -39,7 +39,6 @@ #' } #' mtcars[["primary_key"]] <- seq_len(nrow(mtcars)) #' }) -#' datanames(data) <- "mtcars" #' join_keys(data) <- join_keys(join_key("mtcars", "mtcars", "primary_key")) #' #' app <- init( @@ -85,8 +84,7 @@ #' data <- within(data, { #' ADSL <- rADSL #' }) -#' datanames(data) <- "ADSL" -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, diff --git a/R/tm_variable_browser.R b/R/tm_variable_browser.R index 28e0c11d1..708c835e7 100644 --- a/R/tm_variable_browser.R +++ b/R/tm_variable_browser.R @@ -37,7 +37,6 @@ #' faithful <- faithful #' CO2 <- CO2 #' }) -#' datanames(data) <- c("iris", "mtcars", "women", "faithful", "CO2") #' #' app <- init( #' data = data, @@ -65,8 +64,7 @@ #' ADSL <- rADSL #' ADTTE <- rADTTE #' }) -#' datanames(data) <- c("ADSL", "ADTTE") -#' join_keys(data) <- default_cdisc_join_keys[datanames(data)] +#' join_keys(data) <- default_cdisc_join_keys[names(data)] #' #' app <- init( #' data = data, @@ -225,7 +223,7 @@ srv_variable_browser <- function(id, varname_numeric_as_factor <- reactiveValues() - datanames <- isolate(teal.data::datanames(data())) + datanames <- isolate(names(data())) datanames <- Filter(function(name) { is.data.frame(isolate(data())[[name]]) }, datanames) diff --git a/man/tm_a_pca.Rd b/man/tm_a_pca.Rd index 0c3613ac4..ac4f506ba 100644 --- a/man/tm_a_pca.Rd +++ b/man/tm_a_pca.Rd @@ -90,8 +90,6 @@ data <- within(data, { USArrests <- USArrests }) -datanames(data) <- "USArrests" - app <- init( data = data, modules = modules( @@ -121,8 +119,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -151,14 +148,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlY4AygCCjNUtonG6fYPDpKJKAL5d6UHQ8KLFGbZZCmATQ2LTW27Q6GMqeewV-hm6ALyXQbgXfEIio7dPwmLn3ZW6pDCJUESqAIqQuP10WwACgBhfpbB7fcExG53QFhUjMDSJUSoOAEL7gpEZZZ6W5bHZTGZ4MGE0RwEQaFF0hmkbG4-E0wm6Aj5Ii0AhiFFaFi0KD0ESJHl8gWrTlc1EolLAYDkga7EZbAC6mtKHLAAFlBIx+DJ4RCwP1RKIoMJSGbyYx6FAIJCiKh7WAsGg4FsuvKfnIEf7Ksy8eR+Ci9Ybjaa8ObLdbbb6g8GYLbaJFSfYnK5EYTA3LKiZaNRyIwUQA5RwAGWrcr9AYuXS6tBMunYKjL6k0OhstnK31EhQgrH66HYaFQABJ6qVJ1O6YwdJ05kowLNNUA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlY4AygCCjNUtonG6fYPDpKJKAL5dSmioYyp57BX+GboAvJtBuBt8QiKju0fCYuvdlbqkMIlQiagEqRs3ugpgAAoAwv2fB2u7xiOz2jzCpGYGkSolQcAIV3ewIy0HgoM+EyGYmmALeSNEcBEGlBBKJpBhcIReKRugI+SItAIYlBWhYtCg9BEiTpDKZokRNKRKVBKWAwAxAyxI0+AF0ZaUqWAALKCRj8GQAj5gfqiURQYSkTUYxj0KAQL5EVBGsBYNBwT5dQU3OSAp2VUnw8j8UGKlVqjV4LU6vUGh2ut0wA20SJ6XYOFzU53hmkmWjUciMUEAOUcABlc4nHc6Nl0urQTLp2CoM+pNDobLZytdRIUIKx+uh2EsACT1Uo9gmMHSdOZKMCzGVAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwNJQNKoAhZfF1XQbAAKXkGGxRAypdUSWMyaWipGYGjSolQcAI0OZLNZuUWekRGy2jMpLNEcBEGixCqVD35guFotFBBKBwIYixWhYtCg9BEjz1tANyzl2qREURmWAwGlI22YCBQKqQo2ACEALJYADSWAAjIzqZsAOKuPBR5wAeQCPgAmht+vaqXImVm6qrBeR+FjfWBAyHw5HpbGM7m8zB7rQ4pL7E5XCLRTm7XUTLRqORGFiAHKOUbbDt1TPZmH9fq0Ey6dgqAfqTQ6Gy2GrM0RlCCsQbodhoVAAEhaVWPJ4VjB0fVmSjAMyBQA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkoGlUAQsn9kboFGAAApeQYEsFIvGJGGZNLRUjMDRpUSoOAERF4ym5B56YEEqajMm4jmiOAiDQwkVi47M1nsjl4gglJYEMQwrQsWhQegiE5K2gqzZC+V1TLU3LAYB8kYCsAvF5VNkEgBCAFksABpLAARjJ+LAgwA4q48H7nAB5AI+ACaBP6xuRcnJ8bqktZ5H4MMdYFdHu9vr5QdjSeTMCOtDiPPsTlcFI5iaNyJMtGo5EYMIAco5RgLa3U4wm-v1+rQTLp2CpW+pNDobLYakjRGUIKxBuh2GhUAASFpVDebkWMHR9WZKMAzF5AA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_a_regression.Rd b/man/tm_a_regression.Rd index 40a1679c0..85b3c578d 100644 --- a/man/tm_a_regression.Rd +++ b/man/tm_a_regression.Rd @@ -117,7 +117,6 @@ data <- within(data, { require(nestcolor) CO2 <- CO2 }) -datanames(data) <- c("CO2") app <- init( data = data, @@ -157,8 +156,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -196,14 +194,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QNKAL5dKdDwosUZtlkE7Apgo6tdSmiowyp5K93+GboAvEdBuBW6fEIioqfXAsJiB5WVpDCJUInVEtWioisEFeb0q1Cg9DgfjOqywcD+YkBJFWl0OoP+qBIoj0ZxSiTCpGYGkSolQcGWV1BlWmsBxulW6zwlKp2JEGgerPJpBJZIpaKpYIhUIeqwAylCubotCxaBCRIgUcyBQR8kRaAQxCKwIJUEEANZwRX8gWcjRwfhanX6w1M41UmDCTSROkAMQAggAZUXOVEC0EmWihc0PBwuJVvLoCuS+qm-f6iDoPPEEonc0nkkECmnwLWMmMmiXss6mtO8zN+8GQ6H0sDitmkKUyuViBW2v1vFVqjX3M7Sxiy+giRKd9UvFLAYAMwarAC6M9KFMIJAIKJrdmqgXgZA20fDoJLwZhS4sRvblQd1CdIhDTh9e7eAaDFrO7q9rjtlUjVK-n6uXS6tAmLo7AqOQqbaHANi2OUhyiIUECsG66DsNsAAk9SlGh2KMDonQTEoYDjDOQA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QNKAL5dSmiowyp57BX+GboAvMtBuEt8QiKia7o7wmKL3ZW6pDCJUInVEtWiolYQp+fn1FD0cH7rCmBYcHuYieJD+WzObweqBIoj06xSiTCpGYGkSolQcAIrze5xS0HgBz+ozBSxxulhIg0BwpmNIaIxWNJZN0Hy+P10fwAyt9abotCxaJ8RIgSRDmQR8kRaAQxISwIJUEEANZwUXM840jRwfhyhXK1V4JlkmDCTSROG6ABiAEEADKc5zg9WVEy0ULag4OFxG85dMlyJ04u4PUQdA4IpEounozHYsl42AWomDNXMzWkak81Exxlisms75y7mUjP8xiC+h7EWGvM4iVSmX7dZlisiRL16UnFLAYDJsZgAC6A9KjMIJAIYI5YDs1UC8DIfzkAZ9b3THt+Y4sqfVJuoZpEnqcjpX51d7p16xt9tctcqfpx97vSy6XVoJl07BU5Cj2jgNls5RnKIhQQKw1roOwMwACT1KU0GwowOidBMShgOMA5AA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwNJQNINCQNUSiKwQaEDOr06hQehwahYjZYODksRUkgbFF0+n1MSoEiiPSIzJpaKkZgaNKiVBwAi0wWC37wNmbEbbPD41VikQaLEGpUPBVKlWqwWM5msxEbAIs026LQsWhMkSIPl6q0EEoHAhiTUAIQAslgANJYACM3oFVt0Jo0cH4IfDUdjuvjVpg91ocXFugAYoNRgFnPyE-STLQoimsQ4XD76f0rXJK6qyRTRL0sZLpbKzYrlc26urCxstnGq0nSManXLzSPs6qbSzNY7DXPXYx3fQMV6s1W6n6A0HETu9yJHv7aIHzrlgMBJ9qNkCgVUR5sAOKuPC6B1nAADT5ACwCwQYvD-OR21HelZ3re0fz-Dsq1zahNALBsnArOC6hrOtU0REsy1cFc6lbVVKIomF+n6WgTF0dgVHIQdtDgGxbBqOlRDKCBWEGdB2DQVAABIWiqETRLFRgdD6WYlDAGYgSAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkoGkGhIGqJRFYIIjkcjqFB6HBqDCFGAsHBsWI8SQqWCkUScagSKI9MDMmloqRmBo0qJUHACISicjMg8uboqVNRky-hLdJyRBoYarRcdhaLxcq6iSyRTgVSAuStbotCxaKSRIhFSz9QQSksCGJKWAAEIAWSwAGksABGB365GajRwfgen3+oMh0Owo60OIygBig1GAWczITploUUjMIcLiVEv6yrkOYlWJxol6MJ5fIF2pFYtLRKlsBlcpGCrw7bD5vVwPDLd1A6JhvJHrNatIluttrE9v7juVztd7uBVsYNvoIhOLtobqeuWAwB70zALxeVTbYEGAHFXHhZWAswANJlvrCDLwvuRKwnQc50LE0H2feNQxgJMUyLJxs2AuoTHzMDdHTTNXDXZFyzLUtcP6fpaBMXR2BUchm20OAbFsGokVEMoIFYQZ0HYNBUAAEhaKp2I4zlGB0PpZiUMAZheIA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_data_table.Rd b/man/tm_data_table.Rd index 8f0f9ff07..3d105c6c0 100644 --- a/man/tm_data_table.Rd +++ b/man/tm_data_table.Rd @@ -68,7 +68,6 @@ data <- within(data, { require(nestcolor) iris <- iris }) -datanames(data) <- c("iris") app <- init( data = data, @@ -91,8 +90,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -111,14 +109,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQ20onG6vaJKAL5dKdDwosUZtlkE7ApgQ0tdSmioAyp5i93+GboAvPtBuBW6fEIi-ceXwmK7lZWkMMkZiUH0Io9PlVostCgXzEiVEcBEGjg-COujoLR+vx6jD6MIWSwAynBUNwMAAZCgSApLUoYrE4gDqtH4RLwuiWAAU4EEePiIIT8sS6WBGcyMJTqRzaRjUHACLQxKtzr85Gc9r9qYkWBIbrC+qR2AQ0JoSDClgBJLB69H2IEiXQAYS1Vggkrlui6lS6XVoJl07BU5GYlh0Nls5T2okKEFYAEF0OwNgASeqlKNgxg6TqjJRgEYAXSAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQ20onG6vaJKAL5dSmioAyp57BX+GboAvAtBuPN8QiL9K5vCYnPdlbqkMMkZiUH0IofHx1ostFDXYomicCIacPzLunQttzuxyGvwIczAAGU4KhuBgADIUCQFBR4XQoqEwngAdVo-GRqJRAAU4EEeAiIEj8ijSkSSbCcXiqQTIag4ARaGIUV0gbo5Osjnc8YkWBIdn8+qR2AQ0JoSL8UQBJLAKiH2Z4iXQAYRlVggXPmlW5vKUXVoJl07BU5GYlh0Nls5SOokKEFYAEF0OxJgASeqlH3vRg6TqjJRgEYAXSAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwDK5NLhegiaEDOrUrQsWhQcliNKiOAiDRwfhYuiiUjsLZYgjQsABOyOHwATT8Pg2VQ2jgCjgAQgApKUy3QbBUqtV4DXCvx2Zw62WbADirl1mucAA0NnI5CiqdSQg8WBJMYjubyCGhNCQsRt+XYGSJvL6rBA7fjdP06v1+rQTLp2CpyMxLDobLYalTRGUIKxBuh2GhUAASFpVUtllmMHR9WZKMAzIFAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYBlcmlwvQRIjkcitCxaFBsWI0qI4CINHB+DC6KJSOwpuNgQRfmAAnZHD4AJp+HwKPC6AWOAKOABCACk+QKqgLRZLpYK5X47M5FbKwIMAOKuJXs5wADQFcjkYKReP4xxYEmhwLpDIIaE0JBhAqZ9mJIm8TqsEGNfzq-UDSn6tBMunYKnIzEsOhsthqSNEZQgrEG6HYaFQABIWlUs9nyYwdH1ZkowDMXkA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_file_viewer.Rd b/man/tm_file_viewer.Rd index 668b3cb4c..cf3b5cdd3 100644 --- a/man/tm_file_viewer.Rd +++ b/man/tm_file_viewer.Rd @@ -31,7 +31,6 @@ data <- teal_data() data <- within(data, { data <- data.frame(1) }) -datanames(data) <- c("data") app <- init( data = data, @@ -54,9 +53,9 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXSSfTLCME2Z4dgBGRQgAX1Kk6HhRRLDbCIJ2BTAkltKlNFRslRjmiAysgF4cr1x03T4hEVFdEanhMX6MjNIYfxNaEX8tWjhImWWVjJVUQVJ-VE9Yud06UVIj44yTImp+GVvRVge4GDytnBmmBRLBUNtNjMWikrgQANZQKS3Fp+XgCRbiKQQNTUdrjAbPDKoCASL4-cj-SFAlqgmDguAbQGiAD0tPpjJEGGJEmhulhCKRIxRcG4aOmYkk0lkeImhNIAA9SGTfpTAcC2RCmaywZrOQrSLz+Yi9EKwKiFjNJdjpWA5PjCRlBIxqMiwLFSKRUKJEMzmSYPJIiFo-Vr+IxBBIWWd6PdYnB+MyAApERheGNwQwAESIBEE8DIhgAYimYJ5DABlVBwAi0TYETxWCDiVD8EwtWUrUrHLu6UqlWu6dgqcjMSw6Gy2NIE0TxCCsACC6HYXQAJIJaClV6IZDpGKUykowGUALpAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXSSfTLCME2Z4dgBGRQgAX1KlNFRslRj2dJyvXQBeJuTGviERUVbdLuExBogMjNIYfxNaEX8tWjhImWHR0ZVUQVJ-VE9YvrpRUmWV0ZMian4ZPtFWA7gYPOm4BrBRWFQZqZ6FPF1tggBrKBSPrfPy8ASDcRSCBqajfOS4RrHX4QCRXG7ke6fJ7fV4wd5wSaPUQAejxBKJIgwqFR3xSf0BwLaoLg3HB3TEkmksnhiJGyN0pAAHqR0bcsY9nuSPsSyW8ZVThaQ6b91Iy9MywGCBj0uTCeWAEUjjoJGNQQWBYqRSKhRIgSSSTB5JEQtI7ZfxGIIJKT1vR9rE4PwSQAFIiMLz+uCGAAiRAIgngZEMADFwzBPIYAMqoOAEWhTAieKwQcSofgmb7GjKlFa13SlUoF3TsFTkZiWHQ2WxpfmieIQVgAQXQ7GqABJBLQUhPRDIdIxSmUlGAygBdIA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_front_page.Rd b/man/tm_front_page.Rd index 78e725ddc..35b1c3e9d 100644 --- a/man/tm_front_page.Rd +++ b/man/tm_front_page.Rd @@ -46,8 +46,7 @@ data <- within(data, { ADSL <- rADSL attr(ADSL, "metadata") <- list("Author" = "NEST team", "data_source" = "synthetic data") }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] table_1 <- data.frame(Info = c("A", "B"), Text = c("A", "B")) table_2 <- data.frame(`Column 1` = c("C", "D"), `Column 2` = c(5.5, 6.6), `Column 3` = c("A", "B")) @@ -85,9 +84,9 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXUY4AEdBWiz2CDFSYmoiRkUIDIBBABEAZQAZH0y6pvTdT1JGdjbGlIUweC8kwdsIulFSdkHqwTjywd0AXl1BgDlnertdLhhBgbAk-1EiQUYCOCXVwdFWMli4TQJdUbBKgF9KpOh4UUSwuNjLMGo1BkoAFZEFT+ADWcFY-ySQNecBMUGEpH8BH4tFEBH8UJh8MRwB+sDEAK8cgAum4yFB6CJ-ABGFpJDAmZjwdgASQgJiIK10BBmYGqBzWYAAQmMUnY4AAPUjC0WzSWDWXvSpeJlwfwAJnZYU53Lg7AABgBhIjUQQwKosi2qsVWjVgWpy3TW232qoG52rUUAVgwwZSADYMBG5CkfXaHboAMyBkViiV4KVauQ6xnMpPGrymil8gVCoNi1yZwYAMS9CuVLsGAHF3QAJMaVJS65kqVDzFqTaYdQZ2PN6FnXXbj1m4EdgMd63QGqc9-UGudVKWLkTJ1czpNKLvQdAtFQxGZbpLCpKbjJ8IQiUTCh-CSkdDKkGD+LkkLGoKApEvDIQN0R4oH4GR-HIRsKw-UCpV5GBUHKLwyF0FRBUYGBPCsCAp0GXkVQIKAqgkIVHiyDADng0DBgAeTiGQMLLbDcJIAiwCtUjdHIsCZDgaiwFo3RYxEtdn1WNd-D7eY7wQiDcU0EhuGgwDJN0Ns7AAWUadN+CUvDuE0nTmnKXRRHiCBWGnCRnz4yi9H0JgAD45REwUiFICAvLEJswAADU4vFdkeUx8imUwiC8nzyHdABNDDnyYiy4GICB+CimLfPcrdQMsohIn8YYILCYUHBceDKgyMSt3AyDGGFLw7IAEliFkxXqWBUF3ap0DoEjlPw955M88hGqk9SWtQdN+toQa8Ky8bcuPWgTF0dgVHG9RNB0GxbDSLdLJUVg+pmtBUBavIUgulrRBkHQKiUD4lDAD4aSAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXUY4AEdBWiz2CDFSYmoiRkUIDIBBABEAZQAZH0y6pvTdT1JGdjbGlIUweC8kwdsIulFSdkHqwTjywd0AXl1BgDlnertdLhhBgbAk-1EiQUYCOCXVwdFWMli4TQJdUbBKgF9KgCsiFX8ANZwViiRJhcbGfhwExQYSkfwEfi0UQEfy-f5AkHAaDwUFJOQAXTcZCg9BE-gAjC0khgTMx4OwAJIQExEFa6AgzMDVA5rMAAITGKTscAAHqR2ZzZrzBoL3pUvGS4P4AEzUsK0+lwdgAAwAwkRqIIYFUKTrJVy9TKwLUhbp9YbjVUVebVpyAKwYd0pABsGB9chSDqNJt0AGZXRyuTy8Hy5XIFaTyWH1V5NbBtczWRbBq5Y4MAGJ2kXinNgADi1oAEmNKkpFeSVKh5i1JtMOoM7Em9BTrrtu5TcB2wF2lboVX2G8qVUOqnzRyJw5OB2GlHXoOgWioYjM50l2UlZxk+EIRKJ2SfhGJdxkMqQYP46SR4agoFIb7eMo8oFDGP5yKWbofp+GSDIyMCoOUXhkLoKisowMCeFYEB9mBEoEFAVQSGyjxZBgBwdCBfIAPJxDIsEsuUiGaCQqFgHqmG6Nhui4XA+FgIRt6Bpxd7dueqxTv4TbzEeIE-kiNHQAEXgSPxuhVnYACyjTRvwEnIdw8lKc05S6KI8QQKw-ayUxOEyHo+hMAAfEKPGmEQRCkBAjliGWAAadHIrsjymPkUz2Y5znkNaACasHnmRelwMQED8AFTkubZc6fvpRCRP4ww-mE7IOC4nGVBk3Fzt+v7sjJogACSxBSXL1LAqCLtU6B0BhklJRkrIuYwZVvpVqDRs1tCtch8UyEl660CYujsCo5DMJYOg2LYaRzvpKisE1-VoKgFV5Ck20VaIMg6BUSgfEoYAfASQA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_association.Rd b/man/tm_g_association.Rd index 9ffd8ac9d..c239f6051 100644 --- a/man/tm_g_association.Rd +++ b/man/tm_g_association.Rd @@ -79,7 +79,6 @@ data <- within(data, { factors <- names(Filter(isTRUE, vapply(CO2, is.factor, logical(1L)))) CO2[factors] <- lapply(CO2[factors], as.character) }) -datanames(data) <- c("CO2") app <- init( data = data, @@ -117,8 +116,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -160,14 +158,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QMVpuqkHaLD0PCi7ABitNTkjOy0og4upVpokRyjpZsYJpMdpe0StATc7ACMADJyL129g8BnGtMAusPU+2ohw+XymjFEP1KUHEBHyLEmMi6AF8uik5mJihlbFkCOwFGBRviukp9sMVHk8d1-BldABealBXDjPhCEQzeks4QY8aVUgwRISRLQ0REAi0QJWCCUyoyqpwEx0hlQRJhUjMDSJUSoOC4nmypXoxX4wl4PWy0RwEQaRUWq2kTXa3VU-UygH0S1GsAAZUtOtIuj2jHF9BEiHxTOdLt0sKINzEisDwZEiRjcYWKWAwGNg3xP0h0bxYAACgCyOHdPi7KxteXK9VAvAy2AXhGozLbX64PxPSWoE3W23TLRQl3FYsAIKPL2uSOyt76uQD2WB9lKlWhNWTB066VRtGwPT07NjU2z9u+630jsarU7s36t0eo-ei-+xNQENiMOnwfR-Kxgh43pd9PxTf800xIJM2PXN811YtS1IWswCrGs8ArFD6z5CgkObRd73NV9R2fOwsMbXClyjGBhE0SJD3sJxnEol0TGHYjdAnKcZzbec5z1ecui6WgFQ2VR1U0HQbFscoqVEQoIFYcd0HYfYABJ6ihdBVItRgdE6JQkSUMAkR+IA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QMVpuqkHaLD0PCi7ABitNTkjOy0og4upVpokRyjpZsYJpMdpe0StATc7ACMADJyL129g8BnGtMAusPU+2ohw+XymjFEP1KUHEBHyLEmMi6AF8ukp9sMVHl2OMUroALz+DK4cZ8IQiGYE0nCMTY7qVXSkGCJCSJaGiIgEWiBKwQWn0+nVEz4wlBRJhUjMDSJUSoOAEPn8+kpOZ6AkKMCjdXEumK3SiOAiDTC-WG0jS2Xy8a6yoA+gG4XqgDKBrlpF0e0YXPoIkQWqt1thRBuYmFHq9IkSgeDCxSwGA6s1YB+kN0lrAAAUAWQtbp1XZWLKc3nqoF4NmwC9tdb6SbXXB+A6M1nSH6ddaTLRQvXhYsAIKPR2uNv8t6KuRVxUeikiqBi0ISybmuUK3XK2Cq3Mawat6u1o0EvdmmXL-26232tVgZ2m90scNiX14U+KqMEEMEsNQb1wSP5INvmMMjjBNtyTFM00zKBy1KPMCzgIswDsEtGQoFsK3HZ9+UPbtLyQuBS1Qndq10GBhE0SIN22ZwJ2rDsuwbAk+wHIdq1HEd-VHLouloIUNlUSVNB0GxbHKOlREKCBWF7dB2H2AASeooXQOT9UYHROiUJElDAJEfiAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yFMCnRjaUAKyIVNIBrOFZlzLXjfjgTKGFSNIJ+WlECNP3Dk7PgBdgxFfCcgAum5oOgJipiuxaiFcroALyw8K4GF8IQiUQI3Ro4T-GF1UgwNISNJQUSiIgEWhhKwQaEDOqMhomLGZNLRUjMDRpUSoOAEemMoVIqCLPSIjZbDYohnC3SiOAiDRYhVKh68-mCuWM6hQeiKrEbAKK-mkXRaFjU+giRDS-HagglA4EMRYi2MK0iR5O2gu5b27Ui4DASUjbZgIFAmWBoUCo3OAAa0t0Gywgy8rjwKbAXgA8o4AHIOACayclWAAsmWwAEHIM7IMAIzV2tphsAJmrfjsdgAYuGqhsAEIVrAAaSwnbA-Rjujk0ZjqtNcH4hrAaYzdtl2pMtCiK6xvcGowCrm3QpnwvnAfNLExiLZHK56r5cfPjN+8DXUrwN7qS+VREAJfTU-x1PUDQlGsTWVd1PTEW1f3fWMfT9N1LT1L1HWdPFkOFTJg1DaYIyjMDY2hGtE2rDdM0HHN8yLLBSyzcsqxYms6wbZt2NbetBinOjuz7AdsxHcdJw2S9A2vPD-xg8hVygsSJwEsjsXuWg4nFewnGcBdA13fdFN0I8TzPaSbykucYX6fpaBZdgVHIZ9tDgGxbBqBlRDKCBWEGdB2DQVAABIWiqILgoVRgdD6WYlDAGYgSAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkJGkoKJREQCLQwlYIIjkciGiYYZk0tFSMwNGlRKg4ARiSTkZkHnpgQowFNRtywUjWbpRHARBoYSKxccGUyWUK6tQoPRRTDuQFRUzSLotCx8fQRIh+X95boCCUlgQxDCdYw9SITubaJbNsaTSCoMBgNzedyXi8BW7kcy1c4ABr83TcrCDLyuPCRsBeADyjgAcg4AJoR71YACy2bAAQcgzsgwAjAWi9HSwAmAt+Ox2ABifPj3IAQrmsABpLB1sD9QNyANuyWauD8VVgaOxo2C+UmWhRCcwpuDUYBVzzkmD1nD111G3Q4GU6m06WM4Pbtm5DlTn14A-Isfi4Evi+yp8kxXK6hT9VStqupKlChqPteJJmhaVrAjadpwA60EuhBrKZJ63ojK2fojoGwaFmGBYznGVTcsmaaZgWgx5pWxalhWbaFrRgz9iRYANs2rasZ2PZ9tyu4mvuKF1O+K5cmA3G9ixX7IjARy0HEnL2E4zg4QuS6iboa4bluAlPvxui7v0-S0OS7AqOQ57aHANi2DUSKiGUECsIM6DsGgqAACQtFU7keSKjA6H0sxKGAMwvEAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_bivariate.Rd b/man/tm_g_bivariate.Rd index 070d9f8b1..cce2711a0 100644 --- a/man/tm_g_bivariate.Rd +++ b/man/tm_g_bivariate.Rd @@ -122,7 +122,6 @@ data <- within(data, { require(nestcolor) CO2 <- data.frame(CO2) }) -datanames(data) <- c("CO2") app <- init( data = data, @@ -176,8 +175,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- c("ADSL") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -229,14 +227,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHH+GRgmzPDs-QNdAL5dKdDwosUZtlkE7Apg09tdSmiowyp5W90jsQC8F1C4Fbp8QiKiutekMIkSifTaLLSBcDOlUqoVeN0SYVIzA0iVEqDgm3uwJuSz0122uzwSOBojgIg0YNx+NIsPhiPOyMq1Cg9DxYO2AGU8QjSLotH8aSJENs7hTKQR8kRaAQxGD2Yx-vQRIkBUKRSsUsBgBjBtsALpquS8yk45kaOD8emEEgEHnY5EmWihA1ggBiAEEADIM1x8ypdZFa7GsMEpCGhKHqElwhFAymLWBo3QqgZmt26Ikswl64NksM66m0vzosBM4lsjlSuDcrHxyqy4Wi67iyXSivy1ZBJUx9Wa7U6hMpm05wSoIIAazgcY7D2EmkiUYdzuc7Z1luthuuU5d5t0HuBXr5jCI2USJnUcFZ1z9kOhqdDq4j8CNmNnuvz10TMJD5JHmbpObzSZrnOLw479ZVgWEq-jKgqVgqGTNjsqpgBqm4jk+5CLtGYB2Kw8L-nOVrdroy6ujq67unebR7geR7gqeQakhe8ZXlGLaljqSHJsSNGvh277ZqhX4Ej+RYlneyKAS81aFnW4ENoqyowbGcFtqulRIbh2x2NUgTwGQWGUvOuH4auRFrvcXRdLQJi6OwKjkGe2iAnItjlOcoiFBArD2ug7CHAAJPUpTebijA6J0SizEoYCzGqQA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHH+GRgmzPDs-QNdAL5dSmiowyp57BUjsQC8m1C4G3xCIqK6O6QwiRKJ9NostIFw692VuqGnu4lhpMwaiaKocAITxeLxS0Hg7wUYGmUP2zxBojgIg070RyNIfwBQI2IMq1Cg9CRkLAAGUkYDSLotHcCSJELCcbiCPkiLQCGJ3tTGPd6CJEszWezRMUMsBgFCYWAALpSuRw3EvNEUuD8YnECwM+G4ky0UIq94AMQAggAZEmuLWVLoguWM1jvFKfULfdQY-6A4G4sGwPQ7CWDTUKpUonbBt1Yz0K-GEvx+0nklFcnl0wMK3QCtkcnZJ2lwfkszPClJi-0DKEy22WxUJ8iquOCVBBADWcFTCpgwk0kV9umNZuc8rTOr1dd7pvNjKtjMrIMYRGyiRM6jglJ2jq+P3DHsnu3BPdLber6NRNcx26reIJRLjZOPOd5cHpeB3lQzQs5NIf+cFYhFQRL0IBtKsqDkGNb6nGdisACh4gsOEFjv2O7Wi8M4vG0i7LquHwbq6Z7YlW3oQnGkqgUeFInui+GRri0bXroUK3hR94ps+F7pgW77Zp+fJvr+xbioBZbAWhYHoghUJ2NUgTwGQsEvPBo59hOVYoVOzxdF0tAmLo7AqOQm7aI8ci2OUzyiIUECsEa6DsEsAAk9SlA5iKMDonRKLMShgLMUpAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yCdgUwKdGt-oArIhU0gGs4VmXMteN+OBMoYVI0gn5aUQI0w+Ozi+AF2DEK3CcgAum5oOgJipipsBiFcroALzw8K4Wq6PhCESiJG6UgwNISNL0bQsWhhOCwup1KK4zJpaKkZgaNKiVBwDbo6koqCLPTIrY7LZouHc0RwEQaXHiyVPNkcqnc6nUKD0CW4rYBCUc0i6LRk1UiRDCrlKgglI4EMS4-WMcn0ETPC20K2XXLAYCCka7MAgkFyEVK6kynVwfga7YAcVceFN3JMtCiYdxADFBqMAq5RdT+tyA6bWHTcgyokz1HL2Zzs3V-vAI0LY9XdCGpciWxWFXHlar1QKwFrZXqDQ64MbG0G6ubLdbkbb7Y6py7AZkPV7pr7-YGJ+3k33MwANE1NuowR60OL83RpjPOLdBhNJ8PI6+Zru5nN3+pEAppe5W3XIvSjLMh2VZBrWl5rj6n51O20raiy8pgROKpqtQEYDjqQ52oao5HhOuiLq6NrDguzqukCUCrts3pbH6+bHs2CHkE+uiClgACy+ETg+u5Xumr5Nu+dQMdy3S-uocAATyJZlohlaKtyEH1rR45KnBbbMayCldnUqG9mx-bMdh854WpQZETOJm4U605uuE1ENvRMHBsxfFbF4ADyjgAHIOAAmtx96JnxL5ZkGwm6O+-T9LQJi6OwKjkCB2iUnItg1HCohlBArCDOg7BoKgAAkLRVEVxXiowOh9LMShgDMIJAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgbpSDA0hI0vRtCxaGE4L8BnVdFEYZk0tFSMwNGlRKg4ARMdjsZkHnpgQowFNRoywVjqaI4CINDDOdzjmSKVTqdjqFB6FyYYyAlyKaRdFpUeKRIhWX8RboCCUlgQxDDFYw0fQRCdtbRdU9csBgIzmYyXi85GyNXU+XK4PwpUyAOKuPDqkUmWhRD0wgBig1GAVc7Ox-WpToDrDxuQJUSJ6gF5MpAbqtNg9N0tpGLP9sddsp5wLdJMFOfLovFkoZYBl-IVSuNcFVZZdmrNFv1nZNWp1Yi24WtxemYAdiYbFf5oZb0YAGmqF7oYEdaHFCxGo85nS6gyHPcCD9Hc7p43Hj3VGEQCmkDrr5cD8YTiVmhdf8-AvTtXsRRrd9dFA0ls2FDUxQlagvTbOUO0NZVuw3PtR3NPVgQNI0RwHcdMinJkS3tR17xAytyHPIsmSwABZdCT2DZddEvGMNVvOp52pboX3UOAwM-dNv0g38G3-Qtp1LCjFyQ6sqLE+s+1g5taMQnlcNQntZOxTDBxw4c4FNMdLUnG0SJnOddLkjRWMZLwAHlHAAOQcABNJiNVPVj2OvLibz+fp+loExdHYFRyG-bQMTkWwaixUQyggVhBnQdg0FQAASFoqkyrLOUYHQ+lmJQwBmF4gA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_distribution.Rd b/man/tm_g_distribution.Rd index 1b67c42c2..0b7cae9be 100644 --- a/man/tm_g_distribution.Rd +++ b/man/tm_g_distribution.Rd @@ -80,7 +80,6 @@ data <- teal_data() data <- within(data, { iris <- iris }) -datanames(data) <- "iris" app <- init( data = data, @@ -103,8 +102,7 @@ data <- teal_data() data <- within(data, { ADSL <- rADSL }) -datanames(data) <- c("ADSL") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] vars1 <- choices_selected( variable_choices(data[["ADSL"]], c("ARM", "COUNTRY", "SEX")), @@ -149,14 +147,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLpSEGrUuvxQpFC6cAAesKgiSlc3BsZc1AD6b1A2r2utyMugA7rRSAALFTsP6REBKXS6HyhD7IxihJQAX0UED+0HgolhQNsIP8KNE-iUSjQqDRKghfggSL+5ThiN0fCEIlE5TozSZSKRpBg3wkv1CpAx9EEmmsHKFl0l3y0LDZQO+Dyl6lI31EqDgBEFiqF+NgemS5IxlLwCpNojgIg05QdTt1+sN7FVGKg9BE3wIkKItAIYiGFP8cki-gACrFuBgADIUCRQyN2pG4xVZ3S43G0Ey6dgqcjMSw6Gy2BHM3SiaEQVijdDsWkAEm8kTbDsYOkYuKxSjAWIAukA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLpSEGrUuvxQpFC6cAAesKgiSlc3BsZc1AD6b1A2r2utyMugA7rRSAALFTsP6REBKXS6HyhD7IxihJQAX0UECUaFQaJUEL8ECRf3KcMRuj4QhEonKdGapKRSNIMG+El+oVIGPogk01mprMuPO+WhYlKB3wevPUpG+olQcAILJFrL+0Hg5X8KNEEWF6tEcBEGnKxtNCqVKvYEoxUHoIm+BEhRFoBDEQz1-jkkX8AAVYtwMAAZCgSKE+w1I3Ei2O6XG42gmXTsFTkZiWHQ2WwIsm6UTQiCsUbodgEgAk3kileNjB0jFxWKUYCxAF0gA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLoAwgAiAJLjJ7r8UKRQunAAHrCoIkp3DwbGXNQA+l8oDZPvdHkZdAB3WikAAWKnYQMiICUul0ozO4wAMj9shjsUoAL6KCBA6DwUSIsG2CEEIb4rH+EkAKyIKn+AGs4KxKUCacZ+HATFBhKR-gR+KECP9WeyuTzgGTYGIqQ85ABdJRKLQsUQARlxBFhbIIYn+ojgIg0cH4fggaJ1jFoUHoInFxtopt5YOAwH8DP86vVkTp-qwwyK-hOAHlHAA5BwATUjYHGzgAGky5LhUboLVbyPxynHHFjGRASUo0KhcSoYXa0UDykjc3whCJROU28IVbm0aQYP8JIDQqQnfRBJprH20bdR-9Hc2wf8XmP1GLRKg4KH7bO90r4OV-ZjGXgZ3v89vSOVLxpzVud3un7ojSaxOVHc7XXB3W-vQ9fWPAkwCDEN6QAcVcPBdH8AAhYYsAAaSwPUsxzXdnzRW9CyPMB4KQlCInPJ8YFFWh3j0ZIADFRixNN0Mw2cTFoZ4bXKGi6NcDCnxJZ9s2I5pmAeBcWCXYTV2YO9N23BtMIPSiYLAAMz24vdmOochGHKdTNPvGTiL3R1O2SIy9QYxjdFIjTyJEPZUgM3ReJ48y9wkRgiEEVARK05IgRXZ41ykh9ZOfeTcOUlynx0mRtNoDSZD0x8LKMj9dTMhy0SszQKLslwHKcvcCsc3MSRJWgTF0dgVE09dtEGORbBRXdRHhCBWFGdB2GrAASbxIh6i1GB0RgSUJJQwEJdUgA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLoAwgAiAJLjJ7r8UKRQunAAHrCoIkp3DwbGXNQA+l8oDZPvdHkZdAB3WikAAWKnYQMiICUul0ozO4wAMj9shjsUoAL6KCAAKyIKn+AGs4KxRIiwbYIfw4CYoMJSP8CPxQgR-uTKTS6cBoPB6UC5ABdJRKLQsUQARlxBFhFIIYn+ojgIg0cH4fggaLljFoUHoIi5qto6vFYOAwH8+Kx-klksiBCGoywwyK-hOAHlHAA5BwATV9YHGzgAGv45HJcKjdFqdeR+OUg44sc6ICSlGhULiVDCDWigeUkUm+EIRKJytXhGJS2jdKQYP8JIDQqQTfRBJprEmW7du-9jRWwf8Xj31JzRKg4B6h8PbmDRXpko7Mc68MvhynF6RygeNJqF0vDSvhyq1WJysbTea4Jbb7aHvatwSwK73Z6AOKuHguj+AAQsMWAANJYAqcYJnuK4nmm5SgeBUEwbul5XmiMAcrQ7wbroABioxYlGiaYVhJi0M8erlMRpGuBRw4klecFMcmM4PGOLATlx07MKe86Ls2V5AuuyFgE6ETwWiVHUOQjDlHJClnsJMktsadbJJpCrkVhLY4fJeEiHsqTqSxK5sVeEiMEQgioNxinJECU7PDOgnniJK5ibABGfjuemUbQ8kyEpwUqUJF76Ua8r3vKunqdhuH4aZLjmfBFlohZJIkrQJi6OwKgKbO2iDPGugopeojwhArCjOg7AFgAJN4kTNVqjA6IwJKEkoYCEpKQA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_response.Rd b/man/tm_g_response.Rd index 0f9ae470c..4c34a0f6f 100644 --- a/man/tm_g_response.Rd +++ b/man/tm_g_response.Rd @@ -106,7 +106,6 @@ data <- within(data, { mtcars[[v]] <- as.factor(mtcars[[v]]) } }) -datanames(data) <- "mtcars" app <- init( data = data, @@ -146,8 +145,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- c("ADSL") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -185,14 +183,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlTCtLKJxur0E-RWmHbrsWroqugTsCoSs1Iuli1qiq7qLsFuLUiyLcrbl3ZVDfYyiwMBaALp3g1DiJuqkHezD-Tf3d12VAF8lACuiloPBRMUMrYsosvldFm5oOhBio8gszildABefwZXBjPhCEQDXFE4RiDHnXSkGCJCSJaqiVAkURwKnU3TUKD0OB+XGLLBiFkQNm6AAK7VImzwY2pTJFYtxKUSYVIzA0iWZcHmcs5YNgegFYHhMoJZ05ujZIg0OKtfJ1pC1qB1HMtlW5vP52zAAGUHbatCxaDyRIhVnrLQR8kRaAQxHag4wQ-QRIlo7H45CUjc4ZcZQ9Srqlis8D6DowjnJze7ztbHXB+HbFgRlhGLe6YMJNJEjboAGIAQQAMr7nDXa6ZaKFG3ah6PXB3qf9OdXI7pQnaVWqNU7tbql+cDfBmyb8+3a-Xbbir3uXQfJ1yeXzT-6baRdEmU2GL5OM3GE1xL9QzgdMYwA7MMlzM8RgRMBCzmBYwA2PYUBgKsJ0vANyCbY0UNlQ9qS7agexEOcRzHTD3RMadZ1xecx3XSoV2XPUVy6LpaBMSYVHIXdtHZY4yjGURCggVhB3Qdg0FQAASepShk2S2UYHROmBJQwABO4gA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlTCtLKJxur0E-RWmHbrsWroqugTsCoSs1Iuli1qiq7qLsFuLUiyLcrbl3ZVDfYyiwMBaALp3g1DiJuqkHezD-Tf3d12VAF8lACuko0KhBio8gszildABefwZXBjPhCEQDRFo4RiGHnXSkGCJCSJaqiVAkURwPH43TUKD0OB+RGLLBiCkQKm6AAK7VImzwY3xZI5XMRKUSYVIzA0iXJcHmQtpKWg8AR2zAXyuqyV+KpIg06v1CtIctQCpptPO9MZzI1AGUmSbdFoWLQGSJEDqzlbKgR8kRaAQxOrXYx3fQRIl-YHg6JihkbostQKHqVFUsVngNQdGEc5Cifb7jRo4Px1YsCMtvb7zjBhJpInpEQAxACCABl7c5C7XKiZaKEy+r213XEX8f9aQXdbpQuqJVKZab5YqJ+cVbBmxqUzXi07DYiSyvzWu+3SGUyK2BHQbSC63R64F7Bev8TGgyHEWGI1GP3GEyCJNNUuVM7nTBYwA2PYUBgfNez7Y9hxZKCBQQ2t62oRsRBHTtu3Q30ByHctWzw8daynSclSnLouloExJhUchl20aljjKMZREKCBWDbdB2HBAASepSiEqlGB0TpgSUMAATuIA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+zOh4UQrc23yCdgUwKdGt-oArIhU0gGs4VmXMteN+OBMoYVI0gn5aUQI0w+Ozi+AF2DEK3CcgAum5oOgJipipsBiFcroALzw8K4Wq6PhCESiJEYgTCQHouqkGBpCRpBqiVAkURwWF1Bm6ahQehwai4rZYMTUiC03QABR6pFEWzRcMZlJ5fORmTS0VIzA0aSpcA2RMZKKgiz0yK2O1F6sZtJEGlxxtVTxVavFGrqzNZ7N1YACbItui0LFoLJEiANNttBBKRwIYlxHsYXvoImeQdoIcuuWAwD1I12YBBIKqarAACEALJYADSWAATKLdFsvAB5RwAOQcAE09nIxbaja6NHB+BzcwXi2W8IaNTBHrQ4jrdAAxQajALOVttuomWhRLu46ez1z+hn9W0todRXGy+WKy2oVX0tv-eA9-WD7d1c2m5FPs8XoeM+1snsuk2kd2et6cC+vei51IGwahsi4aRtGEFxoCmRJim0zppmujZnOAAa5acoMXiuGAcj7g+DKvmuTpYPhhELouI7UJo47rjOc60W2y6rt2yIbnOH66LuGoCXUAn9P0tAmLo7AqOQp7aHSxHVOiohlBArCDOg7BoKgAAkLRVFp2m0owOh9LMShgDMIJAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkJGkGqJUCRRHBEcjkdQoPQ4NQYQowFgxDiIHjdAAFHqkUSUsFIwlY2n04GZNLRUjMDRpbFwAgEwnIzIPPTAylTUZsv6S3R4kQaGFqsXHUXi5Uq3TE0nkuVgAJk7W6LQsWgkkSIJUcg0EEpLAhiGHWxi2+giE6u2jup65YDAeUjRVgF4vKp6sAAIQAslgANJYABMbN0lK8AHlHAA5BwATUpcjk7INyK1Gjg-ApCeTaczeH1KpgR1ocVlugAYoNRgFnJWq6ZaFE6zD+4PXE7Cf0VRW27oojC+QKhTrUGKJSrpbAe+Hpq259WLRrgTWtzvl4SjWSG+b1aQrTa7XAHSfR7oXW6PcCvR9P1f0DBFMlDI9I2jWNfjNZwAA0s0pLBBi8VwwHLEcqyvSdTRQtDHW-DtqE0bspwHIcsINExx1wvsKNnKsF0lZi6mY-p+loExdHYFRyE3bR8XLao-lEMoIFYQZ0HYNBUAAEhaKpZLkvFGB0PpZiUMAZheIA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_scatterplot.Rd b/man/tm_g_scatterplot.Rd index c8b39bbe1..5c1c306f7 100644 --- a/man/tm_g_scatterplot.Rd +++ b/man/tm_g_scatterplot.Rd @@ -115,7 +115,6 @@ data <- within(data, { require(nestcolor) CO2 <- CO2 }) -datanames(data) <- "CO2" app <- init( data = data, @@ -199,8 +198,7 @@ data <- within(data, { require(nestcolor) ADSL <- rADSL }) -datanames(data) <- c("ADSL") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -281,14 +279,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLpSEGrUuvxQpFC6cIWwqCJK84sGxlzUAPpbUDabC0tGugDutKQAFirsR5EgSrrZno1w7NOipMStjEUEDeAGEAPIAJh2unBEKUAF8gUdoPBRI8zrYLv5Yf4lEo0KhoSobn5gXMztUnq9dHwhCJRNVacIxKS3m9SDB9hJ9mEFuQOq1SKy2W9qFB6HBZsl-ABlAh8mTrIikGG3IhdMQRakiwqUs77FYldSkHmoOAEYUit7I2B6aVgHF4bVW0SS80q5KukQaU3my1W0XiyXVWVujS6LQsWjikSILVkgNvAhqjUM5KRxjR+gifbJ9UEFlHYDAbGQ-wAXXLkQt-mIFjK-kEqEWvX8cjkuGdAa97rg-BDzXrToTiZgwk06ztugAYgBBAAyMucnZHAZMtEKfeqc8XrlXbKBAY7Xd0Q3JiwNxWYPtEZpr++tZxRU9LcOHid0PfDnrDJtvfpPEUxQlKVdFDb0VQzLNY3jD8kxTAs0wjKMYzgXMEMLM5i1fCsq10GtB3CPAwLAJsWzgNtjwfNkv3Ift7TIqBW3fOCx2oCcRG3BclxXODTA3Ldkh3JdAN0Q8rSogN-iIRh9noM8jkvI0bzvf0RRteAB0dXjE1o6paN9e8+OA4N7RlX9kMzVC4xYj881TaooNQ9D8xZUT1KwksHTLMBKx0viCIABTFMgGzAOxWDNMK7HcBZ4FC4jaxIIjIkbZsmIosBxI-SS4NowTdAAOUced5380dx1oScuN3cq1wE+iZ24vccpPXKRVEWgAC80PkvUL0Na8-1U0SNJfby3zqmiLJ-CDDLUq0TNA8D3Us6C4BsqaRXsxDHJQ7M0J2zDFmwibcOrPxCLCxjmPbLbpoggq0vI2DWMq6qhOa+63nXTdGuElrE2yg8psYIhLn2Ex1FifqoCUob5tGp9bS0nz7r02b3UR6jAxAgdzIgtbrNeuyMKQpyDpc1N0ROrzHT8-DLuCqAEtS8LIsytmYrgOKKFISjvs-X8CuK0rBbYjipwBwXfoKgHROBt52rZf5Iehj1zzhwbjWxj8xtRybRIxoW5v-Iy4KW-GLIpmDbMTI7yf2nMHZpqBTvpvCgpC-nEvZqLfe53mEru9yTd7RrRbK0OJaqzjPtq0PZf+5qFba51xKBIFaBMXR2BUfljW0L5210F4yVEe4IFYWd0HYAkABJvEiBvXUYHRAQRJQwHhcsgA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLpSEGrUuvxQpFC6cIWwqCJK84sGxlzUAPpbUDabC0tGugDutKQAFirsR5EgSrrZno1w7NOipMStjEUEDeAGEAPIAJh2unBEKUAF8gUo0KhoSobn5gXMztUnq9dHwhCJRNVCcIxJi3m9SDB9hJ9mEFuQOq1SJSqW9qFB6HBZsl-ABlAhMmTrIikGG3IhdMQRfEcwq4s77FYldSkBmoOAEdkct5HaDwar+WFyrF63SiXnaiXJK0iDSa7W6i26Lk8vm6QXWjS6LQsWjckSIM2uqkEKUyknJf2MQP0ET7CPSggUo7AYAmyH+AC6OciOv8xAsZX8glQi16-jkclw8td9ptcH4xuaJbw9YtMGEmnWemSADEAIIAGQFzjr5tdJlohWb1WHY9cU45QIttc7uiG2MWKuKzEdoi1hZXVINsH7XrApo7p7ejd9dp9GqPzs3HPdvNbAuffoDQbgENbzDN5kyjapY3jRMwNTURHjODMszhMA8wLPw23CPAr3LSs4GrDc7ypB9yBbfkwBwqAq2AkDu2oXsRAXUdx0nEDTFnedByY5cwzXPUCItf4iEYfZ6G3I49zVQ9jxdDlzyNMibxYhtfyfB0X2k98qU-T1vTUv84wAoClLDGCxAg-8EzgJNI1gmTXXTTNr2zFD800jlCzAAAFLkyFLMA7FYLU-LsdwFngXysKLEhMMiMsK0ovCwF4njjOUtSON0AA5RwRxHVKux7Wg+0Ypd8r1Gc51I3RF3HTTkqpfi9VEWgAC8rNEpVd1VA91LfQi5MvJDQzSm1qmIp0T1Y7Tv1-SDDOGkybLMmMLOgpa4IcoaXLQqL21i8j4qomsyo5YiMri3CFtdWj6MvGqJzctjKpK2rCPqt5Go5RgiEufYTHUWJOqgCSeomuz9TOQ1Bqc5CTstFT4bUsHHumsifz0ubLKMx7TOjfSoKs3H4MWRCYdzfNdA87yoAi-aAqCyL-NCmkKFIfC4fvZ8Muy3KOYJQris40rHoqjL7rqzdPvDFo-oB20d2B7r1WR-rIYvVtFM04ixufFWpu5L80dm1bAKugT1vMgzLOslM0wQxyb1Qyn0Op2mr3pxK6eZ8K2aSqWLTOqqebyx6bqKhiheYkX2Kq8W3sl+teKBIFaBMXR2BUZl1W0L4a10F4sVEe4IFYId0HYFEABJvEiKurUYHRAQRJQwHhHMgA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLoAwgAiAJIAypO6-FCkULpwhbCoIkorawbGXNQA+vtQNnur60a6AO60pAAWKuznkSBKutmejXDsEDEpGIrUYigg3wAgtN5gAZQ7ZaFwpQAX3B52g8FEb2utluBD8YCRsP84IAVkQVCdeqxsec8cZ+HATFBhKQTgR+KECCcKVSaaJgBjYGIcWs5ABdJRKNCoBEqR5+CHLa7Vd5fXR8IQiUTVLXCUUa76kGAnCQnMKrcgdVqkJXfB26ahQehwajVfzzAhWmQ7IikKZPSkEMQRI0Owpq64nTYldTs0SoOAE8OO4XwD1EmEkvCph2iN3JgPJAsiDQWpMp5WOx3O13u5KewsaXRaFi0F0iRBh6s174EINdMTVNuMDv0EQcwchunXYDAfzE-wSiWRFNEgDirjwun8ACEALJYADSWAAjGV90fTwAmUlyXB5x2lotwfiZyFbnt9x0wNm0HY9GSAAxSFYXmZxH17PsTFoQo32qUDwNcaCHXBPsHzzIYVTWGNimYctE2Te0f3TIDdyzZFc1Q74XxbEtmwTSsSJ-J0XTdTN5kY1t207OBu2o1j+2nYdklHcdJwHYNRXOedF2zZdV10ddP23SIrxPc9LzAQ9NLvMA5Ewmj80YhDGx068tMEoS-2oTRAMQsCIKgoTTDgszdCQiCn10dCayMvsQSIRgTnobDzjwuNCOYnyyI-BTrL7Oji10ZKK2InzvjrDjzK4ssA3EviBJcoSpKHXUxN4ic4CnaTsUyh1ZIXSicxXErXJUr8dw008L26iy9O0rBIUmNSKKwZwN1mAB5AA5Pq-NYgKhOSjzZscWFYXan9bPskRHOQ7aYPc98QKclClrzZbn1oAAvGqwqjXDYwIpiMuMuLzKXRKa2S6o0qIqtXOyhsKLyoseLHIrv1KkSKshiSarKmcxSgOSWsUtdCVU7TdN6+8jt+0zToonGfr7XaAP2s7Doa2D4JJryLp-Ra0MJxgiDuE4WRDFKIpe+N0qB0jrkxcj5KownaO4hj8qFlifxBzjuMK6rioa5HRIRvjavK1H0e+trlMJPGsH09SwGG0ahsmmb5oJhrVpJ9bNqlh1KYcmnnLpk6Du84zWe+a6HRBbn1FiJ6oEi175di0WRXiyWfL+2Wi1j4ysvY0Gm3y7W1Zh1jNfh1XJLh-XmsNpT11N83xpGsb-Amqa5oW4OkuJ6oXa2hqPepzzzrd756Y8pmfMD3zwz88FwVoExdHYFRrXjbR-kM3RPmVUQXggVhIXQdhZQAEm8SIj4LRgdDBVElDAFEJSAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLoAwgAiAJIAypO6-FCkULpwhbCoIkorawbGXNQA+vtQNnur60a6AO60pAAWKuznkSBKutmejXDsEDEpGIrUYigg3wAgtN5gAZQ7ZaFwpQAX3BACsiCoTr1WKI3tdbLd+HATFBhKQTgR+KECCdMdjcaJgNB4PjznIALpKJRoVAIlSPPwQ5bXarvL66PhCESiarS4RiYXfb6kGAnCQnMKrcgdVqkZUq77UKD0ODUar+eYEHUyHZEUhTJ5YghiCKSo2FcXXE6bErqSmiVBwAiGo3fc6svTJfxI2HukXh3Sic0hx3JFMiDRa4Ohj1J3Qms0WmNgeapjS6LQsWimkSIBMFlUEZ1dMTVauMWv0ERU1uu9nXYDAWMw+NgTmcyJ5sCQgDirjwun8ACEALJYADSWAAjGVVxvtwAmfxyOS4fNJzNpuD8S2zheNptSim0HbR3QAMUhsPmzgviYFiYtCFLe1Tfr+riAUa4JJuel66EMoprL6xTMNmQYhmG4aRrAH6jsieAId816VhmFaBrm2FJkW5r3uWWaOp23b1k+TYti67bJMxdZwH2nGDmsw4EeOk7Tn4D6LpEB5bru+5gOusknmAZ4Ac+yYUWBpaKdue5EdB4YwK+77gT+f5qc+wGgXeyQQX+xG6LB4bwQZIJEIwJz0Eh5yof6GFUQ5uHwPecZseGpHphpjE5lhDnGqadGlgxaZVjWvENvp6kcW2crcWlPZ8dlA7UQW5zCbOY7+GJcXNhJ85ScuCmHnJS4yce8lYJCkwNf4WDOHOswAPIAHJ6U5TYuepEVabow2OLCsIWU2RnUJoJm2WZ-41VZM12VBE0IZN4W0AAXnxXneihfroZRsUGRG1xRiFlWZQWEXVBFMV5vdKq0SWjXJZWPEFRlS0FkVXGpV2vH8TlBJCSOFWEWJugzvV8k6S1qk1dNNmNejr3LcZIimZBYNJjteN7Q540qkdRqMEQdwnGSrqRT510Bl9JUPWsT2lqFhPhRRH0UdzNV-fRIvA6xQtJhDuVQyxhX9kqZWI4LKMzpjynSWAnXdR1-VDaNp7029ml43NC3k4ZxMfntttGpTpP2T9tPfOb3wgiz6ixJdUC+Td4s-UF+FI+OTtRSl5HRZh33qZLSXS-lstR97quKzLKsCfDUDlZrU6oxJOsdV1PX68bI1jV7wuMTN1uLTVK1rSTG1k9tIG7ZtNOHfmTnguCtAmLo7AqLqAbaP8Z66J8IqiC8ECsJC6DsHyAAk3iRBvKaMDoYKokoYAopyQA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_scatterplotmatrix.Rd b/man/tm_g_scatterplotmatrix.Rd index 294eae5ab..ec2645a59 100644 --- a/man/tm_g_scatterplotmatrix.Rd +++ b/man/tm_g_scatterplotmatrix.Rd @@ -82,7 +82,6 @@ data <- within(data, { profit = rnorm(50, 20, 10) ) }) -datanames(data) <- c("countries", "sales") join_keys(data) <- join_keys( join_key("countries", "countries", "id"), join_key("sales", "sales", "id"), @@ -139,8 +138,7 @@ data <- within(data, { ADSL <- rADSL ADRS <- rADRS }) -datanames(data) <- c("ADSL", "ADRS") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -189,14 +187,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLpSEGrUuvyBULpwAB6wqCJK+aSFRrpc1AD6VVA2lQUGxgDutKQAFirszeEgSrq6xOakjFGiHXkFGCbM8H4QY2O0-AnjfmAAIq54uv4AYlhhx2AAknYX-s4AyndgAAq3R-4A4ucfYAByABlngAhQ7hfwAxzPACC7zkuFG6wkRB0jAg8DI2xM6lIREYq3W6wI7AATOEyboKQBGcm03Q0+nhBkk+GIwnUKD0ODUWaJYn+ACyJBYBF6rGeWDgqEE9DoBH8qUJrLW6w5EAkgigUga2JgtFiWJxeIJhJ2DIAzOFLbprdbqUyrUzlabdByuTztvywJ8ZDAoMp5b8ABLckQBiVEP0WUJgRXrZ3rVBEaUczQkT3sAAc1oAbAB2cI5gAM4QALAX6SX6QyqRWqQyixgc+EAJwJsYsOCFPnsc0AVgrfb7FqLDL7Rb7rep5oppZH5Kb4Wz7cy-FQGfNGFLC4rJIwNa34Ub1sbFMbFcbk90jYbW5X-Dg9FIGb3zIwdsPlMXX4-25-C7-PdfzjONRG4MQ5maRZljgE0Ni2RIqUQccERVMYJjINgGk2bYwJgcpYLZIldgOZ4zmeG5nkeZ43meb5nkBEEwUuSEYThVCXVEWgAC89ESFCiLGdxynUPikhcIiV1YLtGFwvFSHYPCCNJUci0QEkiw08IUN0YSORCbYHBcOQVx0CBBDEpSRHYL1RD9ahqGeeB+FoQQYGeDlGCkZ4SDobIFW0qs9NEwzkhXAh-RCBy4AQ3QrNg4kjOccITmhAEHhSQLwmCgzEiSlcvH9TRSDiRI0TxGB2B0qkiyrDTwqIURSF5XSIAqqqq0zOqixXVBGCIEwem2crGEqnStMrEClAAX1SZpoHgURBgKWxai9DCphmZ4wJEUQFSUAArIgVAaABrOBWCW5pVuMI6TvOy6TTuiAzou3YNumMRng+rbfk2ALEWe16OH8Havt+MG9r+-gAZVIGHveohJk+qHwTASGLi9f6wG2fwPtYbCYdjVJUiUNB11qFQehNZptiGRE+CEXbtkZ4QxDguoYAaCQGlECKghkcoiFIP1NuKDmxjdblcbAB5+fIRghefUXpmKMJBN0LQWFoTlmcSOgmol9ZmgaEophxXnUDgfk0JdeZqgWsS8aRzDfo4u2xlEblrefRIvZEDRLeto2XSl3JEn8B5vY0TXtd1sREHV22PdFY6QharXpnjhpU9odPluqYBgGd5HfoAXTLlcPf9n2YozfxOygZ4JDXZ4HyfWGPcJGBhE0AjQpcd2u90PEH3cWKkqHrvBuKOvElS9LXGT004xdKvjYKU3inNwPRCtm3h-m2AnfR8DUY1wlBuoBWsX1BWg4P4fXU5aWI9l6Pn0znXZTgRO8Av00mcWol0wgTbGU8U69DThBRIWtqAWRzlAvO7NmhF1BmffwFc0b40Jp3J+NcNBzx2P4UivxyK-Eor8aivxaK-Hor8RivxQTPFYr8WEeDh492vrQfueVkgALGOvQkBDfZxQ-g-EOpow4yyjgHT+ccf6iD-hAu2ud07bC-tnNRKCChoNPrtTBZdwhekKmQHo4pfjECaqjS4fUBo9AVEI00IiiEmM1GYkq31GrNWeHYwapAOFdy4X3EQA9koCPWKPGQRDJ4RLGDPIhC8MoRNXivDWqSpoQFSLQEwuh2AqAVjibQsETK6BGCqUQ-QICsGhOgdg5MAAk3hwiNK9owVEqRppKDANNMuQA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLpSEGrUuvyBULpwAB6wqCJK+aSFRrpc1AD6VVA2lQUGxgDutKQAFirszeEgSrq6xOakjFGiHXkFGCbM8H4QY2O0-AnjfmAAIq54uv4AYlhhx2AAknYX-s4AyndgAAq3R-4A4ucfYAByABlngAhQ7hfwAxzPACC7zkuFG6wkRB0jAg8DI2xM6lIREYq3W6wI7AATOEyboKQBGcm03Q0+nhBkk+GIwnUKD0ODUWaJYn+ACyJBYBF6rGeWDgqEE9DoBH8qUJrLW6w5EAkgigUga2JgtFiWJxeIJhJ2DIAzOFLbprdbqUyrUzlabdByuTztvywJ8ZDAoMp5b8ABLckQBiVEP0WUJgRXrZ3rVBEaUczQkT3sAAc1oAbAB2cI5gAM4QALAX6SX6QyqRWqQyixgc+EAJwJsYsOCFPnsc0AVgrfb7FqLDL7Rb7rep5oppZH5Kb4Wz7cy-FQGfNGFLC4rJIwNa34Ub1sbFMbFcbk90jYbW5X-Dg9FIGb3zIwdsPlMXX4-25-C7-PdfzjONRG4MQ5maRZljgE0Ni2RIqUQccERVMYJjINgGk2bYwJgcpYLZIldgOZ4zmeG5nkeZ43meb5nkBEEwUuSEYThVCXVEWgAC89ESFCiLGdxynUPikhcIiV1YLtGFwvFSHYPCCNJUci0QEkiw08IUN0YSORCbYHBcOQVx0CBBDEpSRHYL1RD9ahqGeeB+FoQQYGeDlGCkZ4SDobIFW0qs9NEwzkhXAh-RCBy4AQ3QrNg4kjOccITmhAEHhSQLwmCgzEiSlcvH9TRSDiRI0TxGB2B0qkiyrDTwqIURSF5XSIAqqqq0zOqixXVBGCIEwem2crGEqnStMrEClAAX1SAArIgVAaABrOBWFEQYClsWoFqW1b1pNXaIBWtbdgwqYZmec7pjEZ5NgCxEjpOjh-DAkRRGeN7bt+e7Yw43Qnv2s6iEmG6Pt+L7wfCL1fu2fxrtYbD+AVVJUiUNB11qFQehNZptiGRE+CEd7tiJ4QxDguoYAaCQGlECKghkcoiFIP0LuKSmxjdbk4bAB4GfIRhmefNnpmKMJBN0LQWFoTkScSOgms59ZmgaEophxOnUDgfk0JdeZqmgeBeeuy68ElwlRG5HXn0SK2RA0LWdeVl1udyRJ-Aea2NClmW5bERAJb1-Xxl6RaQha6Xpn9hpRXDinmmAYB4ZBzCzYAXXTlcQ-tm2YozfxOygZ4JDXZ4HyfB7g-1mBhE0AjQpcf6Q7GPEH3cWKkublvBuKfPElS9LXGrpULd0bOVYKNXig1x3RG13WW4N-1YDE17wKhsexkG6hBaxfVBadxel9dTkeY9vnvefKPZdlOBA-NkfTSjlqU9BxHfu7kO49oCPtml6gFlY5h1-gnAoSd17vX8JncEhBU5TA-sjP6W91i5w0P3HY-hSK-HIr8SivxqK-For8eivxGK-FBM8VivxYRVxProWuu9aANzyskFBE9LZX1wlfI+LtTRu15l7B218-Z31EA-L++sf5-0SDfGO0iwHVAgWASG0D07Q12IVMgPRxS-GIE1KGlw+oDR6CjSRnEr4YK9Fo4qujYH6Oas8Yxg1SB0JPow+uIhG7JRQa3Rg7cMFd18aYWgfdYqDwyuwsecZR56ymhAVItATC6HYCoQWOJtCwRMroEYKpRD9AgKwaE6B2AYwACTeHCOUq2jBUSpGmkoMA0105AA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLoAwgAiAJIAypm6-IFQunAAHrCoIkolpGVGulzUAPr1UDZ1pQbGAO60pAAWKuwd4SBKuroAgtn5ADK9uoxzi1Oz2Vj5y6tb+UoAvqkd0PCiY6W2TQR+YGsLYbr+c9v+qQBWRCqtANZwrAuHWuxn4cBMUGEpFaBH4tFEBFaXx+-0BwFOsDElwacgAukolGhUMsVIM-BBph0EsVSrgNnwhCJRNSGcIsRtpqQYK0JK0EYFyIwakQuYFGLQKuTptLdNQoPQ4NRqf58gQBTJhaRdDAxRKwhzpVoWLR5UzqXRRKQpTLpR1WpVSMwNHzUHBbgabTSGmc9IkXvNHngPTbRIq3VrEqGRM7RK73RTPTa5QqlX6wPkwxpdEbxaaxIh9QnE9KCENviFmYkcyb6CIYWXaBXsVBgMB-eswLjcXI6UXi7oo+G4Pxqe77gBxVx4Z5gLAzTJT8Iq5wADXevf70pgUNoNV9SRcG83uiIjDB7hHiQch+DnpMEuH1IAYjMFvlXH3Paliz3b16oPaFSOuo0Kxm61rFhi8DKvc+yFpu97UIK1KIYKLrgX+MrJoqMEZtGWoUPwqDfGQogFkGn6Jjmla6GOAAKMxzgAsjkTwvAAagUuR2OumElg2FbUka1CCHA9blliHStv6bydri4T0YxMwsdkbH3Jx+TceutF3AxzFqTMGlaWAci-pRnqDhoj5prkABy7HOHYujGM4tnZLoADyT66HZ2SOJkdi5B5tnwce25IbuIjUteH6bmZm6WRGA6ZqBcYQf22GpjOeHhtmxp5mRoWbqWEk0dWebiY2kmlNJsGyV28XHol1k6S8k4Gexr4GdkACavHmTa4WaHu0XJEem6nueLUxeN-b3hULUvm+sX9t+iZrTKG26GtqSpLQJi6OwKiCiB2hwDYtiTAmogjBArAzOg7BEgAJN44QvaGjA6IwqSHEoYCHLiQA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLoAwgAiAJIAypm6-IFQunAAHrCoIkolpGVGulzUAPr1UDZ1pQbGAO60pAAWKuwd4SBKuroAgtn5ADK9uoxzi1Oz2Vj5y6tb+UoAvqkAVkQqrQDWcKyiY6W2TfxwJlDCpK0E-LSiBK1nF2ut2A0Hgdw6cgAukolGhUMsVIM-BBph0EsVSrgNnwhCJROiccIxMjptNSDBWhJWr9AuRGDUiOTAoxaBUSaTptQoPQ4NR0f58gRaTIGaRdDBmaywhsOVoWLRuXj0XRRKR2RzUaVWpVSMwNNTUHACOqNZqGqC9Il-GsFtKUabSaJeUaxYknSJ9aJDcaZQ7OdzefywPlnRpdHKWYqxIg7X6OQQhucQvjEhGFfQRJ9E7Rk-cGsBgNb5rawJDIXIsfa47p3S64Px0T6wDMAOKuPC6fxYGaZdvhAXOAAa-grvr9MHetBqlqSLkr1emREYz3cDcSDjnY4dJlZ9fRADEZgt8q4qw7Un7R2eOR1tRVdeoPl6jSbTR0LUG5ttY3Gd9Q6eif50gaL5bqaXI8nyVrBqGYoUPwqDnGQogxngYEahGKa6E2AAKMzdgAsjkYSds2ABqBS5HYI7zguCZJmI6JytQghwFmDHgqUBZFt+paQuEuH4TMRHZCR1oUfkVE0dhfhgHhhFieRlHUWAchXguNawXu0G5AAcmRzh2LoxjOLp2S6AA8vuuh6dkjiZHYuQWbpP7VhO-5TiI6Ibqe1bqXGtZhm6sEgT614OhBgbQSGHpimmUYoa5cb0TmjGpvKUbsalnH5oWzb7P4Zb+dWgXkGuMnWm2ikzGRR7VdkACaNHoRy7maNO3nJLR1ZLiu2mzs43W-ru5WHsevlxhe55blN0xTakqS0CYujsCodKPtocA2LYkz2qIIwQKwMzoOwcIACTeOE51OowOiMKkhxKGAhyQkAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_missing_data.Rd b/man/tm_missing_data.Rd index 505a3747a..a758b5a85 100644 --- a/man/tm_missing_data.Rd +++ b/man/tm_missing_data.Rd @@ -77,7 +77,6 @@ data <- within(data, { mtcars[["cyl"]] <- as.factor(mtcars[["cyl"]]) mtcars[["gear"]] <- as.factor(mtcars[["gear"]]) }) -datanames(data) <- c("iris", "mtcars") app <- init( data = data, @@ -97,8 +96,7 @@ data <- within(data, { ADSL <- rADSL ADRS <- rADRS }) -datanames(data) <- c("ADSL", "ADRS") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -114,14 +112,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEulIQatS6cKGwqCK6-FCkUEr9gwbGXNQA+iNQNsMDUGO6AO60pAAWKuwz0SBKurme3r6toqTE1ESM9fu6UPz8k9CiS2YWmtahtnsQBwehwFE3RE7FEnkm3BIEnYX2iJkuV3YIlKGxhtgAVLlzLQTOwAIzRDAABgArIS8QB2OTUgC6SwAcgBBW7-W4AXyUtx8tBeRl03NEtxg5xYvOMwoIos5v35QVEwDpfOK6ES7AF0Xuj2e9QOEtFCqWyp6HD1jFEGoeTygoh1ulN8uA-gIrGo-hpiuM1owJnUpER9uAjsILrdNNtAaDUhYoaWXp9Gn9IrNgf8UcYofqbPqM2g8FE2wWtj5BD8YAF5X89v8N2g6CWKjWfhlMxqOyFAmEYhqfCEInzLN0pBgkxgPNEKgk0wWcxl9XqON0atUzEsOhs31uok2EFYjPQ7DQqAAJN4Negj2DGDprkoORAwGyaUA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEulIQatS6cKGwqCK6-FCkUEr9gwbGXNQA+iNQNsMDUGO6AO60pAAWKuwz0SBKurme3r6toqTE1ESM9fu6UPz8k9CiS2YWmtahtnsQBwehwFE3RE7FEnkm3BIEnYX2iJkuV3YIlKGxhtgAVLlzLQTOwAIzRDAABgArIS8QB2OTUgC6SwAcgBBW7-W4AXyUtx8tBeRl03NEtxg5xYvOMwoIos5v35QVEwDpfOK6ES7AF0Xuj2e9QOEtFCqWyp6HD1jFEGoeTygoh1ulN8uA-gIrGo-hpiuM1owJnUpER9uAjsILrdNNtAaDUhYoaWXp9Gn9IrNgf8UcYofqbJu0HQSxUaz8MpmNR2QoEwjENT4QhEokLf10pBgkxgPNEKgk0wWcxl9XqON0atUzEsOhs31uok2EFYjPQ7DQqAAJN4Negl2DGDprkoORAwGyaUA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEugDCACIAkgDKzbpwobCoIrr8UKRQSiNjBsZc1AD6k1A2E6NQ07oA7rSkABYq7IvRIEq6uZ7evhBipMTURIz1pwCCrZ0AMuuML+8nui9YnU+-06SgAvvVFtB4KIDqtbEZdAQ-GBvm9yv5gf56gArIgqOYAazgrBhi3hxn4cBMUGEpDmBH4tFEBDmuPxRJJwEhsDEsLGcgAukolGhUOsVNs-BBTosaodfnwhCJRDVFcJeb9TqQYHMYEzRCoJAtVstpbp6vVaCZdOwVORmJYdDZbMczaI9hBWE90OxRQASbzRf2iGQ6B5gpRgUECoA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEugDCACIAkgDKzbpwobCoIrr8UKRQSiNjBsZc1AD6k1A2E6NQ07oA7rSkABYq7IvRIEq6uZ7evhBipMTURIz1pwCCrZ0AMuuML+8nui9YnU+-06SgAvvUAFZEFRzADWcFYogOq1sRmGcBMUGEpDmBH4tFEBDmUJh8MRwGg8CRizkAF0lEo0Kh1iptn4IKdFjVDr8+EIRKIanzhGJ2adTqQYHMYATRCoJAtVssObp6vVaCZdOwVORmJYdDZbMcVaI9hBWE90OwmQASbzRW2iGQ6B5gpRgUG0oA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_outliers.Rd b/man/tm_outliers.Rd index 3d76bf5b7..ff738de8d 100644 --- a/man/tm_outliers.Rd +++ b/man/tm_outliers.Rd @@ -64,7 +64,6 @@ data <- within(data, { CO2 <- CO2 CO2[["primary_key"]] <- seq_len(nrow(CO2)) }) -datanames(data) <- "CO2" join_keys(data) <- join_keys(join_key("CO2", "CO2", "primary_key")) vars <- choices_selected(variable_choices(data[["CO2"]], c("Plant", "Type", "Treatment"))) @@ -108,8 +107,7 @@ data <- teal_data() data <- within(data, { ADSL <- rADSL }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] fact_vars_adsl <- names(Filter(isTRUE, sapply(data[["ADSL"]], is.factor))) vars <- choices_selected(variable_choices(data[["ADSL"]], fact_vars_adsl)) @@ -152,14 +150,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6ugDCAPIATHHV9RVNdcDACmCojLQwLKyJANZwrJ0AumONonAAjokiEOwQjETZ7LV1cooQAL7bKdDwosUZtlmdG51KAFZEKkMjxylnxrf3w6zHbxAPHBfNeF0-zqnVKnW6vX6v06WzcEC0LFEjQI+TuBDEiWmIg0cH47ARPSg9BEiRRaLEJyC7WB4zGpQI7E6AAVqFAyKCgWA7KxUHAOZ07Iw4IF4OywFttko0KhGio8oyIJUUroALz+DK4Fp8IQiJFq7XCCktSqkGCJIiCUh0GTHY2VXQWq20GSJAmq3R0USkBX233qoKJMKkZgaTG8hl2v3+tmwPRqml4SN+rFwDTulOh0Thn1Rv2s+hwPzxsAAZULqdIugJtCJIkQoKTUbJtHReqrLBrxLgpNRLYpKWpYEuYAm9MZhBIBH5YEEqCCwxhck1itzvoz5H47s6s-nfMTK9XlRgwk0kTjugAYgBBAAyJecy8P9pMtFCuPd17vrgPue2q7-fpLkmBCBHAEhED0IFJG6aqet6jbRoGoTBuopBhqmOargcsZbkOAKPoeL7UOQjDukRJHoRGP6rgSba0QRT7Nq27oItQgjdkx-YZIOw6ju2jCiAAJOuuJAdRuYiZuaqsexPbkk83EdHhIIjnS-FCZJYlPkeJ60Ge7oOC4CGVABUamfa5kAds2y0CYujsCoJGodocA2LY5QrqIhQQKwV7oOw0qCYItClIF0yMDojDbDsShgDsYxAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6ugDCAPIATHHV9RVNdcDACmCojLQwLKyJANZwrJ0AumONonAAjokiEOwQjETZ7LV1cooQAL7bAFZEKkMjosUZtlmHx8OsZ9cQJxydG52lL814up3dvf1PnS2bggWhYokaBHyRwIYkS0xEGjg-HYoJ6UHoIkSkOhYnOQXaHzq4zGpQI7E6AAVqFAyG9vmA7KxUHA6Z07Iw4IF4LSwFttko0KhGio8uSIJUUroALz+DK4Fp8IQicEyxXCXEtSqkGCJIiCUh0GRnTWVXR6g20GSJVHS3R0USkMWm52yoKJMKkZgaOHMskml2ummwPQywlvf0u+FwDS2qPe0S+p0Bl3U+hwPyhsAAZXT0dIulRtHRIkQ4fFyed2NoMJVBZYRYxcCxUOruJSBLArzAE1J5MIJAIrLAglQQWGgLk8vLFcqcfI-FtnRHY5ZeAjAZgwk0kRDugAYgBBAAyWecU5nppMtFCSNth5Prmnye2FZfLsnEYIgTgEiIPS-SQ2jK9qOuugbuqEnrqKQPrRkmFYpNA8CLp2nznjOV7UOQjC2ph2GwX6T4VqitYkehF5VjWtqgtQghNpRbYZB2XY9nWjCiAAJHOSIfkRybcQuMo0XRzY4mc7YdKhRLdiSbGcQJvEXpUm5YbQO62g4LhgZUb4Brppr6W+2zbLQJi6OwKjYdB2hwDYtjlOWoiFBArAHug7CChxgi0KUnnTIwOiMNsOxKGAOxjEAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXQBBHwCAGWTdRkaWpQBfRQhM6HhRCtzbfIUwTuaJpQArIhU0gGs4VmHMseN+OBMoYVI0gn5aUQI0+cWVteAB2DER8LkAXTcIXY00rRZRNKh+UWobUG9wAYrRqORGOwTg4XFVRGg4hxMsBgBMphMnk8qicMO9SERGHJiUovoxRG0CCUFgQxGlRHARBo4Px2GTaFB6CJDtTaLT1rlUeimtMwFiqvjPt9fv95H0lIi2ipiuxaiFcroALzq8K4NV8IQiCnag3Ce5quqkGBpIiCUh0GTDC11XS2+20GRSxha3R0USkVUQF3BnVQNLRUjMD6iVBwAiBkMh27wH3Crp4Z2JhlM0g+7Nxg4xuMJxMh6icxmpsABRkF3TszkiRATPVB0vBqk0sQ+htcuA8rsC8JCyYizHY3Tx9EAcVceF0EwAQgBZLAAaSwAEYJsTW+3g-nmfwq-VZy3M6WYPtaHE9NqQfVmgFnHv93UTLQoiyfQ+n642+2fSARecivh2YRwBIhJ8twXo+n6AYXnUmThlEkbqIWsZTgBpbJneC6jumYGlh+EIyD6pGQvSWElm+ZLGvW3zEe2nZ8t22pfNQgj9qx-IPFAI4YmKE70QAJIe5D8KBSEhhJ34cdw3EDmxQ4CWihGiuKjHkuJtZHtJOHtleEI3iIPqwv+b5AaW1nBrZujWX0fS0CYujQqoUaaDoNi2DUbaiGUECsPU6DsIiomCLQVThQyjA6ESPRKGA3RPEAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXQBBHwCAGWTdRkaWpQBfRQgAKyIVNIBrOFZRCtzbfP44EyhhUjSCflpRAjTB4bGJ4Gh4Scy5AF03CAWNNK0WUTSoflFqNoOxdgAxWmpyRnZ1hxcVVEaDiHEywGACjAnWaUJOJyq6wwl1IREYcgxShujFEbQIJSGBDEaVEcBEGjg-HY2NoUHoIhWBNoRKOuQhUJhcIRpnUy2xdweT0xECUILaKmK7FqIVyugAvDLwrhpXwhCJcQrVcI3tK6qQYGkiIJSHQZJNdXVdEaTbQZNcWPLdHRRKQpRBLR7FVA0tFSMwrqJUHACG7PZ7Mq9HRymrC8Baw6TyaRHYng8tA8HQ2HPdQ6WSo2AAmS07oaXSRIgocr3dmPfjCWJHWX6XBGQ3WeF2dCY1yqiGOQBxVx4XRQgBCAFksABpLAARihGOrtY9qYp-AL9SHVfj2ZgS1ocT0Cve9WaAWcy5XdRMtCilMdp-Prhrtb6b93civdbCcAkaOZbh7UYR1nVdXc6kyH0oj9XkSSDftX2zCNYGPUduy6OMkLDW9vhkR1cJ+eDMwgz1+SbW5vxXetmUbBUbmoQRWxolkpk7SEMNjeEqn5AASNdyH4L9SNXYt1woxjmKZVjwQ4zkwG40tbn4sTBOE7C9wPI9HQBF9r3fbMDI9IzdAMvo+loExdD+VR-U0HQbFsGoa1EMoIFYep0HYEFeMEWgqh80lGB0dEeiUMBuhOIA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_t_crosstable.Rd b/man/tm_t_crosstable.Rd index 3cc5c5cb4..a9a1354cd 100644 --- a/man/tm_t_crosstable.Rd +++ b/man/tm_t_crosstable.Rd @@ -72,7 +72,6 @@ data <- within(data, { } mtcars[["primary_key"]] <- seq_len(nrow(mtcars)) }) -datanames(data) <- "mtcars" join_keys(data) <- join_keys(join_key("mtcars", "mtcars", "primary_key")) app <- init( @@ -114,8 +113,7 @@ data <- teal_data() data <- within(data, { ADSL <- rADSL }) -datanames(data) <- "ADSL" -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -160,14 +158,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6UhBq1Lr8UEG6cAAesKgiSgVFRrpc1AD61VA2VYVQBsYA7rSkABYq7M0RIEq6ujCkBCyinRNTM2OmRIy67Fq6KroEfoSs1OG6-lpheEcoMIf+Uiz+crajEOPjk9OMosDAWgC633NQ4hM6lIK3Yrxmnx+3zS4wAvktwe9Pv5UIxaDAWKwGgBrOCsfy-OaiTwNEQQdgQRhELpghbve5KWFpZrQeCiIbtWy1fyI05KABWRBUOLx7OaXOMguFuNY7KlEBFHB5dNOEWVb1V51R6MxiruaSUaFQcxUvT8T3y7USlqCuARAmEYmtfCEoXNzzqMAapAaBCpolEQRCcHdHt01GCcDySX8AGF-bM7MFKnglh6Stbmg1SqRmBoGqJUHAdmmwyzYHoY2BeeFSx7iSINNaG8WfYXi6Gw88I-Qo9b-ABlKOt3RaFi0ZNwRC1i1d8YEPpCghOpJjtGT32L2jLsXtZHVlUE74REt7A5nY6a-ywK5gG6MfV22dzlsaOD8a2ngj7W-3u5PudnhgYRNAqStkhcADAN0FZ+Bkd9rQcSC6zDExaBKBCkgAMQAQQAGQHVxnw9GEwzkKCPXiJIsxzPM2yLEtiOect4H7A8NRnQDX1IZth3zdtGOg8NI2jc4h0bHi1wnYNp1TJiPQXJcV1HccN0U7cxA5IJ9xrMBfhPXZv3PNUwBOW8bwvO84FuMB7gol8+PID8qzMuShOA6hQJEa1cII5x7K7NCMOc3RfMIlDxlIkjS1ItI0loEw1hUcg6O0EN7l0R5xlEAYIFYHD0HYI0ABJvAiEriUYHRGDSeEIDAWFviAA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6UhBq1Lr8UEG6cAAesKgiSgVFRrpc1AD61VA2VYVQBsYA7rSkABYq7M0RIEq6ujCkBCyinRNTM2OmRIy67Fq6KroEfoSs1OG6-lpheEcoMIf+Uiz+crajEOPjk9OMosDAWgC633NQ4hM6lIK3Yrxmnx+3zS4wAvktwe9Pv5UIxaDAWKwGgBrOCsfy-OaiTwNEQQdgQRhELpghbve5KWFpABWRBUOLxoiG7VstVZ7NxrC5-IgHI4-kRpwiErpUvOqPRmLFdzSSjQqDmKl6fie+XaiT1QVwCIEwjEBr4QlCOuedRgDVIDQIVNEoiCITgNttumowTgeSS-gAwi7ZnZgpU8EtbSUDc0GqVSMwNA1RKg4Dto97mtB4AaZW8pVnbcSRBoDaWM460xmvd7nr76P782AAMr+qu6LQsWgRuCIcLF70EPpsgjmpLdtF9p2j2jjrnNZFgSUE74RTN7A5nY5y-ywK5gG6MFXG3X18aVjRwfgGzcEfaH493M8X54wYSaCp6JIOFyvt9dBWfgZBvA0-2cAC3xMWgSjApIADEAEEABlW1cc9vRhLCoOeeIknjRNk2rdNM0w20c1gH9zlXKNyOeK9SArDsUxrMjAJ9P0A3OdsyyYqdew9Ac6I4kcxwnLsexnMT5zEbkgmXWjfg3XYH23aUwBOQ8Dx3I84FuMB7lw+tGPg84tJEwCP2oL8RANZC0MgodbRguDb0Q1D0Oc3RsNtXyfKWNI0loEw1hUchiO0T17l0R5LwGCBWCQ9B2HVAASbwInS4lGB0Rg0nhCAwFhb4gA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6AMIAIgCSAMpZuvxQQbpwAB6wqCJKpeVGulzUAPoNUDb1ZVAGxgDutKQAFirsHREgSrq6AII5BQAyfbqM80tKAL5pHdDwouM9tk3+64v+SgBWRCqtANZwrAcdx8b8cCZQwqStBPy0ogIrWutweT2Au1gYkOQTkAF0lEo0KgViohn4IDMOokSj1cNNdHwhKEcUThNCCTNSDBWj8CIwiKJREEQnAMTMObpqME4NQcf4sgymfZgnU8JSOZUcR1WlVSMwNK1RKg4AR2ZyOZD4PywGdwhLOaJearSDijSJFcrVeqNRzufReTqCsaNLotCxaKK4Ih9ZjbRyCMMbgQxDj3YxPazfkHaCHnj1gMBTgtzmA4XCIqJBPQjaakmYLJprC9dFM-f6ObR+FKmgBCd3oOIwqARFTDGRDUQRahECSx7jsACMcgiav8OTKcHCun8AAUAPIFPIADQ007ni5X1FI-jkaQrnPcpEEjAg7D20JewCrlTh+4P23x5f95pNcH4Oqy88cADkHABNX0D0Jb5aFqPQkgcFwn2AohGHedwP0glIYIPExaEqd8cQAMVmRYClcZ9OXvYjUM5eIkhlOUFR+K0xyIzUegvHU9XFBiZlfV0kk42iVXo4D7UdJJ-GdC1TXDSMRB9NjgMDYNQySCSvWjeT4yCRNkw2NMM10LMcxiHEC0sYsjlLA1-RvFYG1qDgJl0AEME+DQ4O7Xt+2oIc93M20jxPM8LzUqA5Gvas728jlH3CjiXXIJCZzAAjlyAg8YFA8CcLwgiyP9dDMLi3D8MIisSI5Er7zSNJaBMXR2BUcgaO0Nk9zMv1RFGCBWFmdB2GRAASbwIj6o1GB0Rg0k2JQwE2OEgA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6AMIAIgCSAMpZuvxQQbpwAB6wqCJKpeVGulzUAPoNUDb1ZVAGxgDutKQAFirsHREgSrq6AII5BQAyfbqM80tKAL5pAFZEKq0A1nCsouM9tk38cCZQwqStBPy0ogStewfHp8DQ8GcdcgAukolGhUCsVEM-BAZh1EiUerhpro+EJQvDUcIxNCZjNSDBWg8CIwiKJREEQnAcbiZtRgnBqPD-FkSWT7ME6nhkTTKvCOq0qqRmBpWqJUHACNSabCer89El-OtFuFudLRAyJaR4eqRCKxRKpdLafTGQqwAUNRpdFoWLQOXBECqYUbcQRhvsCGJ4TbGHbKY93bRPf8esBgIqFsqwIDARFRIJ6OqtUkzBZNNYAbops6XbjaPxeU0AIQ29Bxc5BCIqYYyIaiCLUIgSIPcdgARjkEUl-hyZTg4V0-gACgB5Ap5AAaGgHw7Hk+opH8cjSuZp7lIgkYEHYcpDQTkwHzlUBK9X2yROZdOs1cH4TLAWRHjgAcg4AJpO1co+60Wry5IuBeX5EIw1zuHeSQOIBqpGiYtCVLe8IAGKzIsBSuJeNKnlhQHSvEST8oKwoPPq3aYbiHRyveSqflelrJro156uKZFfnS9AMveFq6lqPp+iIjpcuRNJuh6XpJHx9oBmJe5QGGEYbNGsaMQmSbwqmlgZhcWYwS6R4rKWtQcBMugvBgtwaCBDZNi21DtsuulGuum7bruFZQAeR4no5uLnj5MxMeQEGDuazgTrRuYwD+f7Iah6G4bmcEIcFKFoRhubYbimWnmkaS0CYujsCo5DEdoVLLjpzqiKMECsLM6DsGCAAk3gRM16qMDojBpJsShgJsgJAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_variable_browser.Rd b/man/tm_variable_browser.Rd index 9c4c3f119..b36911ed4 100644 --- a/man/tm_variable_browser.Rd +++ b/man/tm_variable_browser.Rd @@ -64,7 +64,6 @@ data <- within(data, { faithful <- faithful CO2 <- CO2 }) -datanames(data) <- c("iris", "mtcars", "women", "faithful", "CO2") app <- init( data = data, @@ -86,8 +85,7 @@ data <- within(data, { ADSL <- rADSL ADTTE <- rADTTE }) -datanames(data) <- c("ADSL", "ADTTE") -join_keys(data) <- default_cdisc_join_keys[datanames(data)] +join_keys(data) <- default_cdisc_join_keys[names(data)] app <- init( data = data, @@ -105,14 +103,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEulLhsrr8UKRQunAAHrCoIkoLSwbGXNQA+jtQNtuLy0a65aQFKuwnUSBKuro+tKJ7b4wfL7owpAILE+VwBQMYNQgr1KRHgUKuMLhfxMUFotzM1C+KLRBQxfwAwgB5ABMXyJxKUAF9FBATtB4KIHhdbFcCH4wO8anhdP4wcDav5ERQBWBsejhCLyf4aUo0Kgvio0X4ofMLk1Hn8+EIRJ8UlrhGJla9XsVDloWLQoPQRIcmERSqIZEbja9qFa4JiUv4AGoWq0iXR2h0yfx-V408NKGm0Ey6dgqcjMSw6Gy2Z4q0R3CCsACC6HYcoAJN4okXHYwdIwaZSlGBKQBdIA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEulLhsrr8UKRQunAAHrCoIkoLSwbGXNQA+jtQNtuLy0a65aQFKuwnUSBKuro+tKJ7b4wfL7owpAILE+VwBQMYNQgr1KRHgUKuMLhfxMUFotzM1C+KLRBQxfwAwgB5ABMXyJxKUAF9FBAlGhUF8VGi-FD5hcmo8-nwhCJPilucIxCzXq9ioctCxaFB6CJDkwiKVRDJhSLXtRpXBMSl-AA1SXSkS6eWKmT+P6vGkWpQ02gmXTsFTkZiWHQ2WzPVmiO4QVgAQXQ7HpABJvFFg0rGDpGDTKUowJSALpAA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEugDCACIAkgDK07pwAB6wqCK6-FCkUEp0TCwcgSFhcIoQu-sGxlzUAPo3UDZKL3e65aQFKuwvURASl0ugAgrNFgAZT6McFQ4Fg2Z2OzOGHg5GuCAAXyuL2g8FE-z2UFsRl0BD8YDhkNq-nRKP8Vy6RBUj2CcFYhJepOM-DgJigwlIjwI-FoogIj2ZrPZnOAeNgYiJ+zkAF0lEo0KhPipaKQ-BAQR8UgCEXwhCJRE1zcIlQiQcVHloWLQoPQRI8mERSqIZAaQQHdNQ3XBqE1-AA1F1u7Zen0yfz23RXEFXK60Ey6dgqcjMSw6Gy2IGG3SiX4QVig9DsLUAEm8UTrvsYOkYVyxSjAWNVQA}{Open in Shinylive} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEugDCACIAkgDK07pwAB6wqCK6-FCkUEp0TCwcgSFhcIoQu-sGxlzUAPo3UDZKL3e65aQFKuwvURASl0ugAgrNFgAZT6McFQ4Fg2Z2OzOGHg5GuCAAXyuXSIKkewTgrFE-z2UFsRh2cBMUGEpEeBH4tFEBEeeIJRJJwGg8FJLzkAF0lEo0KhPipaKQ-BAQR8UgCEXwhCJRE1lcIxDKQSDio8tCxaFB6CJHkwiKVRDJtTqQdRjXBqE1-AA1Q3G7bmy0yfwIkFXf1KK60Ey6dgqcjMSw6Gy2IGy3SiX4QVig9DsMUAEm8USzVsYOkYVyxSjAWMFQA}{Open in Shinylive} \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/tests/testthat/helper-TealAppDriver.R b/tests/testthat/helper-TealAppDriver.R index 3e9e7cf6b..c59d7c259 100644 --- a/tests/testthat/helper-TealAppDriver.R +++ b/tests/testthat/helper-TealAppDriver.R @@ -31,22 +31,18 @@ simple_teal_data <- function() { iris <- iris mtcars <- mtcars }) - teal.data::datanames(data) <- c("iris", "mtcars") data } simple_cdisc_data <- function(datasets = c("ADSL", "ADRS", "ADTTE")) { datasets <- match.arg(datasets, several.ok = TRUE) - data <- within( - teal.data::teal_data(), - { - require(nestcolor) - ADSL <- teal.modules.general::rADSL - ADRS <- teal.modules.general::rADRS - ADTTE <- teal.modules.general::rADTTE - } + + data <- Reduce( + x = datasets, + function(u, x) eval_code(u, sprintf("%1$s <- teal.modules.general::r%1$s", x)), + init = within(teal.data::teal_data(), require(nestcolor)) ) - teal.data::datanames(data) <- datasets + teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[datasets] data } diff --git a/tests/testthat/test-shinytest2-tm_a_pca.R b/tests/testthat/test-shinytest2-tm_a_pca.R index 9c5bd6b7a..7e3badac7 100644 --- a/tests/testthat/test-shinytest2-tm_a_pca.R +++ b/tests/testthat/test-shinytest2-tm_a_pca.R @@ -5,8 +5,6 @@ app_driver_tm_a_pca <- function() { USArrests <- USArrests # nolint: object_name. }) - teal.data::datanames(data) <- "USArrests" - init_teal_app_driver( data = data, diff --git a/tests/testthat/test-shinytest2-tm_a_regression.R b/tests/testthat/test-shinytest2-tm_a_regression.R index ee09a7656..143956043 100644 --- a/tests/testthat/test-shinytest2-tm_a_regression.R +++ b/tests/testthat/test-shinytest2-tm_a_regression.R @@ -3,7 +3,6 @@ app_driver_tm_a_regression <- function() { require(nestcolor) CO2 <- CO2 # nolint: object_name. }) - teal.data::datanames(data) <- c("CO2") init_teal_app_driver( data = data, diff --git a/tests/testthat/test-shinytest2-tm_g_association.R b/tests/testthat/test-shinytest2-tm_g_association.R index a5219639e..b1ac33d87 100644 --- a/tests/testthat/test-shinytest2-tm_g_association.R +++ b/tests/testthat/test-shinytest2-tm_g_association.R @@ -3,10 +3,9 @@ app_driver_tm_g_association <- function() { require(nestcolor) require(ggplot2) CO2 <- CO2 # nolint: object_name. - factors <- names(Filter(isTRUE, vapply(CO2, is.factor, logical(1L)))) - CO2[factors] <- lapply(CO2[factors], as.character) # nolint: object_name. + .factors <- names(Filter(isTRUE, vapply(CO2, is.factor, logical(1L)))) + CO2[.factors] <- lapply(CO2[.factors], as.character) # nolint: object_name. }) - teal.data::datanames(data) <- c("CO2") init_teal_app_driver( data = data, diff --git a/tests/testthat/test-shinytest2-tm_g_bivariate.R b/tests/testthat/test-shinytest2-tm_g_bivariate.R index 146f53a4f..9be35efe6 100644 --- a/tests/testthat/test-shinytest2-tm_g_bivariate.R +++ b/tests/testthat/test-shinytest2-tm_g_bivariate.R @@ -4,7 +4,6 @@ app_driver_tm_g_bivariate <- function() { require(nestcolor) CO2 <- data.frame(CO2) # nolint: object_name. }) - teal.data::datanames(data) <- c("CO2") init_teal_app_driver( data = data, diff --git a/tests/testthat/test-shinytest2-tm_g_distribution.R b/tests/testthat/test-shinytest2-tm_g_distribution.R index f65282719..a610aa31a 100644 --- a/tests/testthat/test-shinytest2-tm_g_distribution.R +++ b/tests/testthat/test-shinytest2-tm_g_distribution.R @@ -1,10 +1,7 @@ app_driver_tm_g_distribution <- function() { data <- teal.data::teal_data() - data <- within(data, { - ADSL <- rADSL - }) - teal.data::datanames(data) <- c("ADSL") - teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[teal.data::datanames(data)] + data <- within(data, ADSL <- rADSL) + teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[names(data)] vars1 <- teal.transform::choices_selected( teal.transform::variable_choices(data[["ADSL"]], c("ARM", "COUNTRY", "SEX")), diff --git a/tests/testthat/test-shinytest2-tm_g_response.R b/tests/testthat/test-shinytest2-tm_g_response.R index 0a8bf3f8d..4f2beb28a 100644 --- a/tests/testthat/test-shinytest2-tm_g_response.R +++ b/tests/testthat/test-shinytest2-tm_g_response.R @@ -4,8 +4,7 @@ app_driver_tm_g_response <- function() { require(nestcolor) ADSL <- rADSL }) - teal.data::datanames(data) <- c("ADSL") - teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[teal.data::datanames(data)] + teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[names(data)] init_teal_app_driver( data = data, diff --git a/tests/testthat/test-shinytest2-tm_g_scatterplot.R b/tests/testthat/test-shinytest2-tm_g_scatterplot.R index 09fd72a7b..798dc9ba0 100644 --- a/tests/testthat/test-shinytest2-tm_g_scatterplot.R +++ b/tests/testthat/test-shinytest2-tm_g_scatterplot.R @@ -4,8 +4,7 @@ app_driver_tm_g_scatterplot <- function() { require(nestcolor) ADSL <- rADSL }) - teal.data::datanames(data) <- c("ADSL") - teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[teal.data::datanames(data)] + teal.data::join_keys(data) <- teal.data::default_cdisc_join_keys[names(data)] init_teal_app_driver( data = data, diff --git a/tests/testthat/test-shinytest2-tm_outliers.R b/tests/testthat/test-shinytest2-tm_outliers.R index 33141e7ad..b2af74f0f 100644 --- a/tests/testthat/test-shinytest2-tm_outliers.R +++ b/tests/testthat/test-shinytest2-tm_outliers.R @@ -4,7 +4,6 @@ app_driver_tm_outlier <- function() { CO2 <- CO2 # nolint: object_name CO2[["primary_key"]] <- seq_len(nrow(CO2)) # nolint: object_name }) - teal.data::datanames(data) <- "CO2" teal.data::join_keys(data) <- teal.data::join_keys(join_key("CO2", "CO2", "primary_key")) vars <- teal.transform::choices_selected( diff --git a/vignettes/teal-modules-general.Rmd b/vignettes/teal-modules-general.Rmd index 0980da151..867fba79a 100644 --- a/vignettes/teal-modules-general.Rmd +++ b/vignettes/teal-modules-general.Rmd @@ -51,9 +51,7 @@ data <- within(data, { ADSL <- rADSL ADTTE <- rADTTE }) -datanames <- c("ADSL", "ADTTE") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] # tm_variable_browser module tm_variable_browser_module <- tm_variable_browser( @@ -111,9 +109,7 @@ data <- within(data, { ADSL <- rADSL ADTTE <- rADTTE }) -datanames <- c("ADSL", "ADTTE") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` 3: Initialize a `teal` application with specified data and modules, in this case, the module: `tm_variable_browser`, datasets:`ADSL` and `ADTTE`. diff --git a/vignettes/using-association-plot.Rmd b/vignettes/using-association-plot.Rmd index b7f8aff42..9927d6689 100644 --- a/vignettes/using-association-plot.Rmd +++ b/vignettes/using-association-plot.Rmd @@ -47,9 +47,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADRS", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-bivariate-plot.Rmd b/vignettes/using-bivariate-plot.Rmd index 431c87929..7267ae1ca 100644 --- a/vignettes/using-bivariate-plot.Rmd +++ b/vignettes/using-bivariate-plot.Rmd @@ -49,9 +49,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADRS", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-cross-table.Rmd b/vignettes/using-cross-table.Rmd index 0a9ad3011..552976eeb 100644 --- a/vignettes/using-cross-table.Rmd +++ b/vignettes/using-cross-table.Rmd @@ -44,9 +44,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-data-table.Rmd b/vignettes/using-data-table.Rmd index 27fd1ea3c..d9ca029d8 100644 --- a/vignettes/using-data-table.Rmd +++ b/vignettes/using-data-table.Rmd @@ -39,9 +39,7 @@ data <- within(data, { ADTTE <- teal.modules.general::rADTTE ADLB <- teal.modules.general::rADLB }) -datanames <- c("ADSL", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-outliers-module.Rmd b/vignettes/using-outliers-module.Rmd index 507cf4716..5271906e5 100644 --- a/vignettes/using-outliers-module.Rmd +++ b/vignettes/using-outliers-module.Rmd @@ -40,9 +40,7 @@ data <- within(data, { ADRS <- teal.modules.general::rADRS ADLB <- teal.modules.general::rADLB }) -datanames <- c("ADSL", "ADRS", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-regression-plots.Rmd b/vignettes/using-regression-plots.Rmd index fe10bce4f..02677ad6d 100644 --- a/vignettes/using-regression-plots.Rmd +++ b/vignettes/using-regression-plots.Rmd @@ -49,9 +49,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADRS", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-response-plot.Rmd b/vignettes/using-response-plot.Rmd index 59dae80f3..af452ee15 100644 --- a/vignettes/using-response-plot.Rmd +++ b/vignettes/using-response-plot.Rmd @@ -48,9 +48,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADRS", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-scatterplot-matrix.Rmd b/vignettes/using-scatterplot-matrix.Rmd index 28d09f70e..de15d7d4a 100644 --- a/vignettes/using-scatterplot-matrix.Rmd +++ b/vignettes/using-scatterplot-matrix.Rmd @@ -50,9 +50,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADRS", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable diff --git a/vignettes/using-scatterplot.Rmd b/vignettes/using-scatterplot.Rmd index ec40e2e8d..f6379d976 100644 --- a/vignettes/using-scatterplot.Rmd +++ b/vignettes/using-scatterplot.Rmd @@ -52,9 +52,7 @@ data <- within(data, { TRUE ~ "-" ))) }) -datanames <- c("ADSL", "ADRS", "ADTTE", "ADLB") -datanames(data) <- datanames -join_keys(data) <- default_cdisc_join_keys[datanames] +join_keys(data) <- default_cdisc_join_keys[names(data)] ``` ## 3 - Create an `app` variable From cd8ac9d0f5d989a839ccb2091f80a41904409024 Mon Sep 17 00:00:00 2001 From: gogonzo Date: Fri, 8 Nov 2024 14:03:18 +0000 Subject: [PATCH 28/42] [skip actions] Bump version to 0.3.0.9054 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 580816261..3c0af05ee 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9053 -Date: 2024-11-04 +Version: 0.3.0.9054 +Date: 2024-11-08 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index b50d8ce9a..dea3b1d7e 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9053 +# teal.modules.general 0.3.0.9054 * Removed `Show Warnings` modals from modules. From 02f18ab180a8fba7488404c839f660cfee1aa51e Mon Sep 17 00:00:00 2001 From: Marcin <133694481+m7pr@users.noreply.github.com> Date: Fri, 29 Nov 2024 17:55:22 +0100 Subject: [PATCH 29/42] =?UTF-8?q?=F0=9F=97=83=EF=B8=8F=20`decorators`=20fe?= =?UTF-8?q?ature=20branch=20(#795)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Partner to https://github.com/insightsengineering/teal/pull/1357 Introduces decorators to modules. More about decorators in here https://github.com/insightsengineering/teal/issues/1384
Example with 1 tab per module ```r pkgload::load_all("../teal") pkgload::load_all(".") # ###################################################### # # _____ _ # | __ \ | | # | | | | ___ ___ ___ _ __ __ _| |_ ___ _ __ ___ # | | | |/ _ \/ __/ _ \| '__/ _` | __/ _ \| '__/ __| # | |__| | __/ (_| (_) | | | (_| | || (_) | | \__ \ # |_____/ \___|\___\___/|_| \__,_|\__\___/|_| |___/ # # # # Decorators # ##################################################### plot_grob_decorator <- function(default_footnote = "I am a good decorator", .var_to_replace = "plot") { teal_transform_module( label = "Caption (grob)", ui = function(id) shiny::textInput(shiny::NS(id, "footnote"), "Footnote", value = default_footnote), server = function(id, data) { moduleServer(id, function(input, output, session) { logger::log_info("🟠 plot_grob with default: {default_footnote}!", namespace = "teal.modules.general") reactive({ req(data(), input$footnote) logger::log_info("changing the footnote {default_footnote}", namespace = "teal.modules.general") teal.code::eval_code(data(), substitute( { footnote_grob <- grid::textGrob(footnote, x = 0, hjust = 0, gp = grid::gpar(fontsize = 10, fontface = "italic", col = "gray50")) # Arrange the plot and footnote .var_to_replace <- gridExtra::arrangeGrob( .var_to_replace, footnote_grob, ncol = 1, heights = grid::unit.c(grid::unit(1, "npc") - grid::unit(1, "lines"), grid::unit(1, "lines")) ) }, env = list( footnote = input$footnote, .var_to_replace = as.name(.var_to_replace) ))) }) }) } ) } caption_decorator <- function(default_caption = "I am a good decorator", .var_to_replace = "plot") { teal_transform_module( label = "Caption", ui = function(id) shiny::textInput(shiny::NS(id, "footnote"), "Footnote", value = default_caption), server = make_teal_transform_server( substitute({ my_name <- .var_name .var_to_replace <- .var_to_replace + ggplot2::labs(caption = footnote) }, env = list(.var_to_replace = as.name(.var_to_replace), .var_name = .var_to_replace)) ) ) } table_decorator <- function(.color1 = "#f9f9f9", .color2 = "#f0f0f0", .var_to_replace = "table") { teal_transform_module( label = "Table color", ui = function(id) { selectInput( NS(id, "style"), "Table Style", choices = c("Default", "Color1", "Color2"), selected = "Default" ) }, server = function(id, data) { moduleServer(id, function(input, output, session) { logger::log_info("🔵 Table row color called to action!", namespace = "teal.modules.general") reactive({ req(data(), input$style) logger::log_info("changing the Table row color '{input$style}'", namespace = "teal.modules.general") teal.code::eval_code(data(), substitute({ .var_to_replace <- switch( style, "Color1" = DT::formatStyle( .var_to_replace, columns = attr(.var_to_replace$x, "colnames")[-1], target = "row", backgroundColor = .color1 ), "Color2" = DT::formatStyle( .var_to_replace, columns = attr(.var_to_replace$x, "colnames")[-1], target = "row", backgroundColor = .color2 ), .var_to_replace ) }, env = list( style = input$style, .var_to_replace = as.name(.var_to_replace), .color1 = .color1, .color2 = .color2 ))) }) }) } ) } head_decorator <- function(default_value = 6, .var_to_replace = "object") { teal_transform_module( label = "Head", ui = function(id) shiny::numericInput(shiny::NS(id, "n"), "Footnote", value = default_value), server = make_teal_transform_server( substitute({ .var_to_replace <- utils::head(.var_to_replace, n = n) }, env = list(.var_to_replace = as.name(.var_to_replace))) ) ) } treelis_subtitle_decorator <- function(default_caption = "I am a good decorator", .var_to_replace = "plot") { teal_transform_module( label = "Caption", ui = function(id) shiny::textInput(shiny::NS(id, "footnote"), "Footnote", value = default_caption), server = make_teal_transform_server( substitute({ .var_to_replace <- update(.var_to_replace, sub = footnote) }, env = list(.var_to_replace = as.name(.var_to_replace))) ) ) } insert_rrow_decorator <- function(default_caption = "I am a good new row", .var_to_replace = "table") { teal_transform_module( label = "New row", ui = function(id) shiny::textInput(shiny::NS(id, "new_row"), "New row", value = default_caption), server = make_teal_transform_server( substitute({ .var_to_replace <- rtables::insert_rrow(.var_to_replace, rtables::rrow(new_row)) }, env = list(.var_to_replace = as.name(.var_to_replace))) ) ) } do_nothing_decorator <- teal_transform_module(server = function(id, data) moduleServer(id, function(input, output, session) data)) # ########################################## # # _ _ _ _ # | | | | | | | | # | |_ ___ __ _| | __| | __ _| |_ __ _ # | __/ _ \/ _` | | / _` |/ _` | __/ _` | # | || __/ (_| | || (_| | (_| | || (_| | # \__\___|\__,_|_| \__,_|\__,_|\__\__,_| # ______ # |______| # # teal_data # ######################################### data <- teal_data(join_keys = default_cdisc_join_keys[c("ADSL", "ADRS")]) data <- within(data, { require(nestcolor) ADSL <- rADSL ADRS <- rADRS }) # For tm_outliers fact_vars_adsl <- names(Filter(isTRUE, sapply(data[["ADSL"]], is.factor))) vars <- choices_selected(variable_choices(data[["ADSL"]], fact_vars_adsl)) # For tm_g_distribution vars1 <- choices_selected( variable_choices(data[["ADSL"]], c("ARM", "COUNTRY", "SEX")), selected = NULL ) init( data = data, modules = modules( # ################################################### # # _ # (_) # _ __ ___ __ _ _ __ ___ ___ ___ _ ___ _ __ # | '__/ _ \/ _` | '__/ _ \/ __/ __| |/ _ \| '_ \ # | | | __/ (_| | | | __/\__ \__ \ | (_) | | | | # |_| \___|\__, |_| \___||___/___/_|\___/|_| |_| # __/ | # |___/ # # regression # ################################################## tm_a_regression( label = "Regression", response = data_extract_spec( dataname = "ADSL", select = select_spec( label = "Select variable:", choices = "BMRKR1", selected = "BMRKR1", multiple = FALSE, fixed = TRUE ) ), regressor = data_extract_spec( dataname = "ADSL", select = select_spec( label = "Select variables:", choices = variable_choices(data[["ADSL"]], c("AGE", "SEX", "RACE")), selected = "AGE", multiple = TRUE, fixed = FALSE ) ), decorators = list(caption_decorator("I am Regression", "plot")) ), # ######################################################### # # _ _ _ _ _ _ _ # | (_) | | (_) | | | (_) # __| |_ ___| |_ _ __ _| |__ _ _| |_ _ ___ _ __ # / _` | / __| __| '__| | '_ \| | | | __| |/ _ \| '_ \ # | (_| | \__ \ |_| | | | |_) | |_| | |_| | (_) | | | | # \__,_|_|___/\__|_| |_|_.__/ \__,_|\__|_|\___/|_| |_| # # # # distribution # ######################################################## tm_g_distribution( dist_var = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], c("AGE", "BMRKR1")), selected = "BMRKR1", multiple = FALSE, fixed = FALSE ) ), strata_var = data_extract_spec( dataname = "ADSL", filter = filter_spec( vars = vars1, multiple = TRUE ) ), group_var = data_extract_spec( dataname = "ADSL", filter = filter_spec( vars = vars1, multiple = TRUE ) ), decorators = list( histogram_plot = caption_decorator("I am density!", "histogram_plot"), qq_plot = caption_decorator("I am QQ!", "qq_plot"), summary_table = table_decorator("#FFA500", "#800080", "summary_table"), test_table = table_decorator("#2FA000", "#80FF80", "test_table") ) ), # #################### # # # # _ __ ___ __ _ # | '_ \ / __/ _` | # | |_) | (_| (_| | # | .__/ \___\__,_| # | | # |_| # # pca # ################### tm_a_pca( "PCA", dat = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data = data[["ADSL"]], c("BMRKR1", "AGE", "EOSDY")), selected = c("BMRKR1", "AGE") ) ), decorators = list( elbow_plot = caption_decorator("I am PCA / elbow", "elbow_plot"), circle_plot = caption_decorator("I am a PCA / circle", "circle_plot"), biplot = caption_decorator("I am a PCA / bipot", "biplot"), eigenvector_plot = caption_decorator("I am a PCA / eigenvector", "eigenvector_plot") ) ), ###################################### # # _ _ _ # | | | (_) # ___ _ _| |_| |_ ___ _ __ ___ # / _ \| | | | __| | |/ _ \ '__/ __| # | (_) | |_| | |_| | | __/ | \__ \ # \___/ \__,_|\__|_|_|\___|_| |___/ # # # # outliers # ##################################### tm_outliers( outlier_var = list( data_extract_spec( dataname = "ADSL", select = select_spec( label = "Select variable:", choices = variable_choices(data[["ADSL"]], c("AGE", "BMRKR1")), selected = "AGE", multiple = FALSE, fixed = FALSE ) ) ), categorical_var = list( data_extract_spec( dataname = "ADSL", filter = filter_spec( vars = vars, choices = value_choices(data[["ADSL"]], vars$selected), selected = value_choices(data[["ADSL"]], vars$selected), multiple = TRUE ) ) ), decorators = list( box_plot = caption_decorator("I am a good decorator", "box_plot"), density_plot = caption_decorator("I am a good decorator", "density_plot"), cumulative_plot = caption_decorator("I am a good decorator", "cumulative_plot"), table = table_decorator("#FFA500", "#800080") ) ), # ####################################################### # # _ _ _ # (_) | | (_) # __ _ ___ ___ ___ ___ _ __ _| |_ _ ___ _ __ # / _` / __/ __|/ _ \ / __| |/ _` | __| |/ _ \| '_ \ # | (_| \__ \__ \ (_) | (__| | (_| | |_| | (_) | | | | # \__,_|___/___/\___/ \___|_|\__,_|\__|_|\___/|_| |_| # # # # association # ###################################################### tm_g_association( ref = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices( data[["ADSL"]], c("SEX", "RACE", "COUNTRY", "ARM", "STRATA1", "STRATA2", "ITTFL", "BMRKR2") ), selected = "RACE" ) ), vars = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices( data[["ADSL"]], c("SEX", "RACE", "COUNTRY", "ARM", "STRATA1", "STRATA2", "ITTFL", "BMRKR2") ), selected = "BMRKR2", multiple = TRUE ) ), decorators = list(plot_grob_decorator("I am a good grob (association)")) ), # ################################################ # # _ _ _ _ _ # | | | | | | | | | | # __| | __ _| |_ __ _ | |_ __ _| |__ | | ___ # / _` |/ _` | __/ _` || __/ _` | '_ \| |/ _ \ # | (_| | (_| | || (_| || || (_| | |_) | | __/ # \__,_|\__,_|\__\__,_| \__\__,_|_.__/|_|\___| # ______ # |______| # # data_table # ############################################### tm_data_table( variables_selected = list( iris = c("Sepal.Length", "Sepal.Width", "Petal.Length", "Petal.Width", "Species") ), dt_args = list(caption = "IRIS Table Caption"), decorators = list(table_decorator()) ), # ######################################################## # # _ _ _ # | | | | | | # ___ _ __ ___ ___ ___ ______| |_ __ _| |__ | | ___ # / __| '__/ _ \/ __/ __|______| __/ _` | '_ \| |/ _ \ # | (__| | | (_) \__ \__ \ | || (_| | |_) | | __/ # \___|_| \___/|___/___/ \__\__,_|_.__/|_|\___| # # # # cross-table # ####################################################### tm_t_crosstable( label = "Cross Table", x = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], subset = function(data) { idx <- !vapply(data, inherits, logical(1), c("Date", "POSIXct", "POSIXlt")) return(names(data)[idx]) }), selected = "COUNTRY", multiple = TRUE, ordered = TRUE ) ), y = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], subset = function(data) { idx <- vapply(data, is.factor, logical(1)) return(names(data)[idx]) }), selected = "SEX" ) ), decorators = list(insert_rrow_decorator("I am a good new row")) ), # ####################################################################################### # # _ _ _ _ _ _ # | | | | | | | | | | (_) # ___ ___ __ _| |_| |_ ___ _ __ _ __ | | ___ | |_ _ __ ___ __ _| |_ _ __ ___ __ # / __|/ __/ _` | __| __/ _ \ '__| '_ \| |/ _ \| __| | '_ ` _ \ / _` | __| '__| \ \/ / # \__ \ (_| (_| | |_| || __/ | | |_) | | (_) | |_ | | | | | | (_| | |_| | | |> < # |___/\___\__,_|\__|\__\___|_| | .__/|_|\___/ \__| |_| |_| |_|\__,_|\__|_| |_/_/\_\ # | | # |_| # # scatterplot matrix # ###################################################################################### tm_g_scatterplotmatrix( label = "Scatterplot matrix", variables = list( data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]]), selected = c("AGE", "RACE", "SEX"), multiple = TRUE, ordered = TRUE ) ), data_extract_spec( dataname = "ADRS", filter = filter_spec( label = "Select endpoints:", vars = c("PARAMCD", "AVISIT"), choices = value_choices(data[["ADRS"]], c("PARAMCD", "AVISIT"), c("PARAM", "AVISIT")), selected = "INVET - END OF INDUCTION", multiple = TRUE ), select = select_spec( choices = variable_choices(data[["ADRS"]]), selected = c("AGE", "AVAL", "ADY"), multiple = TRUE, ordered = TRUE ) ) ), decorators = list(treelis_subtitle_decorator("I am a Scatterplot matrix", "plot")) ), # ############################################# # # # # _ __ ___ ___ _ __ ___ _ __ ___ ___ # | '__/ _ \/ __| '_ \ / _ \| '_ \/ __|/ _ \ # | | | __/\__ \ |_) | (_) | | | \__ \ __/ # |_| \___||___/ .__/ \___/|_| |_|___/\___| # | | # |_| # # response # ############################################ tm_g_response( label = "Response", response = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]], c("BMRKR2", "COUNTRY"))) ), x = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]], c("SEX", "RACE")), selected = "RACE") ), decorators = list(caption_decorator("I am a Response", "plot")) ), # ############################################ # # _ _ _ _ # | | (_) (_) | | # | |__ ___ ____ _ _ __ _ __ _| |_ ___ # | '_ \| \ \ / / _` | '__| |/ _` | __/ _ \ # | |_) | |\ V / (_| | | | | (_| | || __/ # |_.__/|_| \_/ \__,_|_| |_|\__,_|\__\___| # # # # bivariate # ########################################### tm_g_bivariate( x = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]]), selected = "AGE") ), y = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]]), selected = "SEX") ), row_facet = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]]), selected = "ARM") ), col_facet = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]]), selected = "COUNTRY") ), decorators = list(caption_decorator("I am a Bivariate", "plot")) ), ##################################################### # # _ _ _ _ # | | | | | | | | # ___ ___ __ _| |_| |_ ___ _ __ _ __ | | ___ | |_ # / __|/ __/ _` | __| __/ _ \ '__| '_ \| |/ _ \| __| # \__ \ (_| (_| | |_| || __/ | | |_) | | (_) | |_ # |___/\___\__,_|\__|\__\___|_| | .__/|_|\___/ \__| # | | # |_| # # scatterplot # #################################################### tm_g_scatterplot( label = "Scatterplot", x = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]], c("AGE", "BMRKR1", "BMRKR2"))) ), y = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], c("AGE", "BMRKR1", "BMRKR2")), selected = "BMRKR1" ) ), color_by = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], c("AGE", "BMRKR1", "BMRKR2", "RACE", "REGION1")), selected = NULL ) ), size_by = data_extract_spec( dataname = "ADSL", select = select_spec(choices = variable_choices(data[["ADSL"]], c("AGE", "BMRKR1"))) ), row_facet = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], c("BMRKR2", "RACE", "REGION1")), selected = NULL ) ), col_facet = data_extract_spec( dataname = "ADSL", select = select_spec( choices = variable_choices(data[["ADSL"]], c("BMRKR2", "RACE", "REGION1")), selected = NULL ) ), decorators = list(caption_decorator("I am a scatterplot", "plot")) ), # ############################################################## # # _ _ _ _ # (_) (_) | | | | # _ __ ___ _ ___ ___ _ _ __ __ _ __| | __ _| |_ __ _ # | '_ ` _ \| / __/ __| | '_ \ / _` | / _` |/ _` | __/ _` | # | | | | | | \__ \__ \ | | | | (_| | | (_| | (_| | || (_| | # |_| |_| |_|_|___/___/_|_| |_|\__, | \__,_|\__,_|\__\__,_| # __/ |_____ # |___/______| # # missing_data # ############################################################# tm_missing_data( label = "Missing data", decorators = list( summary_plot = plot_grob_decorator("A", "summary_plot"), combination_plot = plot_grob_decorator("B", "combination_plot"), summary_table = table_decorator("table", .color1 = "#f0000055"), by_subject_plot = caption_decorator("by_subject_plot") ) ), example_module(decorators = list(head_decorator(6))) ) ) |> shiny::runApp() ``` --------- Signed-off-by: Marcin <133694481+m7pr@users.noreply.github.com> Signed-off-by: André Veríssimo <211358+averissimo@users.noreply.github.com> Co-authored-by: go_gonzo Co-authored-by: Konrad Pagacz Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: 27856297+dependabot-preview[bot]@users.noreply.github.com <27856297+dependabot-preview[bot]@users.noreply.github.com> Co-authored-by: André Veríssimo <211358+averissimo@users.noreply.github.com> --- DESCRIPTION | 3 +- R/roxygen2_templates.R | 30 + R/tm_a_pca.R | 151 +++- R/tm_a_regression.R | 795 +++++++++--------- R/tm_data_table.R | 91 +- R/tm_g_association.R | 50 +- R/tm_g_bivariate.R | 97 ++- R/tm_g_distribution.R | 218 +++-- R/tm_g_response.R | 42 +- R/tm_g_scatterplot.R | 47 +- R/tm_g_scatterplotmatrix.R | 57 +- R/tm_missing_data.R | 353 +++++--- R/tm_outliers.R | 248 ++++-- R/tm_t_crosstable.R | 44 +- R/utils.R | 132 ++- man-roxygen/ggplot2_args_multi.R | 7 - man/normalize_decorators.Rd | 18 + man/select_decorators.Rd | 22 + man/srv_decorate_teal_data.Rd | 35 + man/tm_a_pca.Rd | 59 +- man/tm_a_regression.Rd | 38 +- man/tm_data_table.Rd | 29 +- man/tm_file_viewer.Rd | 4 +- man/tm_front_page.Rd | 4 +- man/tm_g_association.Rd | 33 +- man/tm_g_bivariate.Rd | 29 +- man/tm_g_distribution.Rd | 53 +- man/tm_g_response.Rd | 29 +- man/tm_g_scatterplot.Rd | 29 +- man/tm_g_scatterplotmatrix.Rd | 29 +- man/tm_missing_data.Rd | 53 +- man/tm_outliers.Rd | 63 +- man/tm_t_crosstable.Rd | 29 +- man/tm_variable_browser.Rd | 8 +- tests/testthat/helper-functions.R | 14 + .../test-shinytest2-tm_misssing_data.R | 2 +- tests/testthat/test-shinytest2-tm_outliers.R | 6 +- 37 files changed, 2033 insertions(+), 918 deletions(-) create mode 100644 R/roxygen2_templates.R delete mode 100644 man-roxygen/ggplot2_args_multi.R create mode 100644 man/normalize_decorators.Rd create mode 100644 man/select_decorators.Rd create mode 100644 man/srv_decorate_teal_data.Rd diff --git a/DESCRIPTION b/DESCRIPTION index 3c0af05ee..e7a4d62bc 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -35,6 +35,7 @@ Imports: DT (>= 0.13), forcats (>= 1.0.0), grid, + lifecycle (>= 0.2.0), scales, shinyjs, shinyTree (>= 0.2.8), @@ -84,7 +85,7 @@ VignetteBuilder: Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, rstudio/shiny, insightsengineering/teal, insightsengineering/teal.transform, mllg/checkmate, tidyverse/dplyr, - rstudio/DT, tidyverse/forcats, r-lib/scales, daattali/shinyjs, + rstudio/DT, tidyverse/forcats, r-lib/lifecycle, r-lib/scales, daattali/shinyjs, shinyTree/shinyTree, rstudio/shinyvalidate, dreamRs/shinyWidgets, tidyverse/stringr, insightsengineering/teal.code, insightsengineering/teal.data, insightsengineering/teal.logger, diff --git a/R/roxygen2_templates.R b/R/roxygen2_templates.R new file mode 100644 index 000000000..d55c2aef4 --- /dev/null +++ b/R/roxygen2_templates.R @@ -0,0 +1,30 @@ +# nocov start +roxygen_decorators_param <- function(module_name) { + paste( + sep = " ", + lifecycle::badge("experimental"), + " (`list` of `teal_transform_module`, named `list` of `teal_transform_module` or", + "`NULL`) optional, if not `NULL`, decorator for tables or plots included in the module.", + "When a named list of `teal_transform_module`, the decorators are applied to the", + "respective output objects.\n\n", + "Otherwise, the decorators are applied to all objects, which is equivalent as using the name `default`.\n\n", + sprintf("See section \"Decorating `%s`\"", module_name), + "below for more details." + ) +} + +roxygen_ggplot2_args_param <- function(...) { + paste( + sep = " ", + "(`ggplot2_args`) optional, object created by [`teal.widgets::ggplot2_args()`]", + "with settings for all the plots or named list of `ggplot2_args` objects for plot-specific settings.", + "The argument is merged with options variable `teal.ggplot2_args` and default module setup.\n\n", + sprintf( + "List names should match the following: `c(\"default\", %s)`.\n\n", + paste("\"", unlist(rlang::list2(...)), "\"", collapse = ", ", sep = "") + ), + "For more details see the vignette: `vignette(\"custom-ggplot2-arguments\", package = \"teal.widgets\")`." + ) +} + +# nocov end diff --git a/R/tm_a_pca.R b/R/tm_a_pca.R index 7753c3101..c6a7fb55e 100644 --- a/R/tm_a_pca.R +++ b/R/tm_a_pca.R @@ -13,16 +13,46 @@ #' It controls the font size for plot titles, axis labels, and legends. #' - If vector of `length == 1` then the font sizes will have a fixed size. #' - while vector of `value`, `min`, and `max` allows dynamic adjustment. -#' @templateVar ggnames "Elbow plot", "Circle plot", "Biplot", "Eigenvector plot" -#' @template ggplot2_args_multi +#' @param ggplot2_args `r roxygen_ggplot2_args_param("Elbow plot", "Circle plot", "Biplot", "Eigenvector plot")` +#' @param decorators `r roxygen_decorators_param("tm_a_pca")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_a_pca`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `elbow_plot` (`ggplot2`) +#' - `circle_plot` (`ggplot2`) +#' - `biplot` (`ggplot2`) +#' - `eigenvector_plot` (`ggplot2`) +#' +#' Decorators can be applied to all outputs or only to specific objects using a +#' named list of `teal_transform_module` objects. +#' The `"default"` name is reserved for decorators that are applied to all outputs. +#' See code snippet below: +#' +#' ``` +#' tm_a_pca( +#' ..., # arguments for module +#' decorators = list( +#' default = list(teal_transform_module(...)), # applied to all outputs +#' elbow_plot = list(teal_transform_module(...)), # applied only to `elbow_plot` output +#' circle_plot = list(teal_transform_module(...)) # applied only to `circle_plot` output +#' biplot = list(teal_transform_module(...)) # applied only to `biplot` output +#' eigenvector_plot = list(teal_transform_module(...)) # applied only to `eigenvector_plot` output +#' ) +#' ) +#' ``` +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE #' {{ next_example }} #' @examples +#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -58,6 +88,7 @@ #' interactive <- function() TRUE #' {{ next_example }} #' @examples +#' #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -102,7 +133,8 @@ tm_a_pca <- function(label = "Principal Component Analysis", alpha = c(1, 0, 1), size = c(2, 1, 8), pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_a_pca") # Normalize the parameters @@ -152,6 +184,10 @@ tm_a_pca <- function(label = "Principal Component Analysis", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + available_decorators <- c("elbow_plot", "circle_plot", "biplot", "eigenvector_plot") + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, available_decorators) # End of assertions # Make UI args @@ -169,7 +205,8 @@ tm_a_pca <- function(label = "Principal Component Analysis", list( plot_height = plot_height, plot_width = plot_width, - ggplot2_args = ggplot2_args + ggplot2_args = ggplot2_args, + decorators = decorators ) ), datanames = teal.transform::get_extract_datanames(data_extract_list) @@ -224,6 +261,34 @@ ui_a_pca <- function(id, ...) { label = "Plot type", choices = args$plot_choices, selected = args$plot_choices[1] + ), + conditionalPanel( + condition = sprintf("input['%s'] == 'Elbow plot'", ns("plot_type")), + ui_decorate_teal_data( + ns("d_elbow_plot"), + decorators = select_decorators(args$decorators, "elbow_plot") + ) + ), + conditionalPanel( + condition = sprintf("input['%s'] == 'Circle plot'", ns("plot_type")), + ui_decorate_teal_data( + ns("d_circle_plot"), + decorators = select_decorators(args$decorators, "circle_plot") + ) + ), + conditionalPanel( + condition = sprintf("input['%s'] == 'Biplot'", ns("plot_type")), + ui_decorate_teal_data( + ns("d_biplot"), + decorators = select_decorators(args$decorators, "biplot") + ) + ), + conditionalPanel( + condition = sprintf("input['%s'] == 'Eigenvector plot'", ns("plot_type")), + ui_decorate_teal_data( + ns("d_eigenvector_plot"), + decorators = select_decorators(args$decorators, "eigenvector_plot") + ) ) ), teal.widgets::panel_item( @@ -289,7 +354,7 @@ ui_a_pca <- function(id, ...) { } # Server function for the PCA module -srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, plot_width, ggplot2_args) { +srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, plot_width, ggplot2_args, decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -549,7 +614,7 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl ) cols <- c(getOption("ggplot2.discrete.colour"), c("lightblue", "darkred", "black"))[1:3] - g <- ggplot(mapping = aes_string(x = "component", y = "value")) + + elbow_plot <- ggplot(mapping = aes_string(x = "component", y = "value")) + geom_bar( aes(fill = "Single variance"), data = dplyr::filter(elb_dat, metric == "Proportion of Variance"), @@ -569,8 +634,6 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl scale_fill_manual(values = c("Cumulative variance" = cols[2], "Single variance" = cols[1])) + ggthemes + themes - - print(g) }, env = list( ggthemes = parsed_ggplot2_args$ggtheme, @@ -628,7 +691,7 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl y = sin(seq(0, 2 * pi, length.out = 100)) ) - g <- ggplot(pca_rot) + + circle_plot <- ggplot(pca_rot) + geom_point(aes_string(x = x_axis, y = y_axis)) + geom_label( aes_string(x = x_axis, y = y_axis, label = "label"), @@ -640,7 +703,6 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl labs + ggthemes + themes - print(g) }, env = list( x_axis = x_axis, @@ -861,8 +923,7 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl qenv, substitute( expr = { - g <- plot_call - print(g) + biplot <- plot_call }, env = list( plot_call = Reduce(function(x, y) call("+", x, y), pca_plot_biplot_expr) @@ -871,8 +932,8 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl ) } - # plot pc_var ---- - plot_pc_var <- function(base_q) { + # plot eigenvector_plot ---- + plot_eigenvector <- function(base_q) { pc <- input$pc ggtheme <- input$ggtheme @@ -938,10 +999,7 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl expr = { pca_rot <- pca$rotation[, pc, drop = FALSE] %>% dplyr::as_tibble(rownames = "Variable") - - g <- plot_call - - print(g) + eigenvector_plot <- plot_call }, env = list( pc = pc, @@ -951,23 +1009,54 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl ) } - # plot final ---- - output_q <- reactive({ - req(computation()) - teal::validate_inputs(iv_r()) - teal::validate_inputs(iv_extra, header = "Plot settings are required") + # qenvs --- + output_q <- lapply( + list( + elbow_plot = plot_elbow, + circle_plot = plot_circle, + biplot = plot_biplot, + eigenvector_plot = plot_eigenvector + ), + function(fun) { + reactive({ + req(computation()) + teal::validate_inputs(iv_r()) + teal::validate_inputs(iv_extra, header = "Plot settings are required") + fun(computation()) + }) + } + ) - switch(input$plot_type, - "Elbow plot" = plot_elbow(computation()), - "Circle plot" = plot_circle(computation()), - "Biplot" = plot_biplot(computation()), - "Eigenvector plot" = plot_pc_var(computation()), + decorated_q <- mapply( + function(obj_name, q) { + srv_decorate_teal_data( + id = sprintf("d_%s", obj_name), + data = q, + decorators = select_decorators(decorators, obj_name), + expr = reactive({ + substitute(print(.plot), env = list(.plot = as.name(obj_name))) + }), + expr_is_reactive = TRUE + ) + }, + names(output_q), + output_q + ) + + # plot final ---- + decorated_output_q <- reactive({ + switch(req(input$plot_type), + "Elbow plot" = decorated_q$elbow_plot(), + "Circle plot" = decorated_q$circle_plot(), + "Biplot" = decorated_q$biplot(), + "Eigenvector plot" = decorated_q$eigenvector_plot(), stop("Unknown plot") ) }) plot_r <- reactive({ - output_q()[["g"]] + plot_name <- gsub(" ", "_", tolower(req(input$plot_type))) + req(decorated_output_q())[[plot_name]] }) pws <- teal.widgets::plot_with_settings_srv( @@ -1034,7 +1123,7 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_q()))), title = "R Code for PCA" ) @@ -1057,7 +1146,7 @@ srv_a_pca <- function(id, data, reporter, filter_panel_api, dat, plot_height, pl card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_a_regression.R b/R/tm_a_regression.R index 4e28de543..b9015c585 100644 --- a/R/tm_a_regression.R +++ b/R/tm_a_regression.R @@ -37,16 +37,27 @@ #' It takes the form of `c(value, min, max)` and it is passed to the `value_min_max` #' argument in `teal.widgets::optionalSliderInputValMinMax`. #' -#' @templateVar ggnames `r regression_names` -#' @template ggplot2_args_multi +# nolint start: line_length. +#' @param ggplot2_args `r roxygen_ggplot2_args_param("Response vs Regressor", "Residuals vs Fitted", "Scale-Location", "Cook's distance", "Residuals vs Leverage", "Cook's dist vs Leverage")` +# nolint end: line_length. +#' @param decorators `r roxygen_decorators_param("tm_a_regression")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_a_regression`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `plot` (`ggplot2`) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE #' {{ next_example }} #' @examples +#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -146,7 +157,8 @@ tm_a_regression <- function(label = "Regression Analysis", post_output = NULL, default_plot_type = 1, default_outlier_label = "USUBJID", - label_segment_threshold = c(0.5, 0, 10)) { + label_segment_threshold = c(0.5, 0, 10), + decorators = NULL) { message("Initializing tm_a_regression") # Normalize the parameters @@ -200,6 +212,7 @@ tm_a_regression <- function(label = "Regression Analysis", checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_choice(default_plot_type, seq.int(1L, length(plot_choices))) checkmate::assert_string(default_outlier_label) + checkmate::assert_list(decorators, "teal_transform_module", null.ok = TRUE) if (length(label_segment_threshold) == 1) { checkmate::assert_numeric(label_segment_threshold, any.missing = FALSE, finite = TRUE) @@ -212,6 +225,8 @@ tm_a_regression <- function(label = "Regression Analysis", .var.name = "label_segment_threshold" ) } + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, "plot", null.ok = TRUE) # End of assertions # Make UI args @@ -233,7 +248,8 @@ tm_a_regression <- function(label = "Regression Analysis", plot_height = plot_height, plot_width = plot_width, default_outlier_label = default_outlier_label, - ggplot2_args = ggplot2_args + ggplot2_args = ggplot2_args, + decorators = decorators ) ), datanames = teal.transform::get_extract_datanames(data_extract_list) @@ -247,7 +263,6 @@ ui_a_regression <- function(id, ...) { ns <- NS(id) args <- list(...) is_single_dataset_value <- teal.transform::is_single_dataset(args$regressor, args$response) - teal.widgets::standard_layout( output = teal.widgets::white_small_well(tags$div( teal.widgets::plot_with_settings_ui(id = ns("myplot")), @@ -306,6 +321,7 @@ ui_a_regression <- function(id, ...) { label = "Outlier label" ) ), + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")), teal.widgets::panel_group( teal.widgets::panel_item( title = "Plot settings", @@ -362,7 +378,8 @@ srv_a_regression <- function(id, plot_height, plot_width, ggplot2_args, - default_outlier_label) { + default_outlier_label, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -537,450 +554,441 @@ srv_a_regression <- function(id, ) }) - output_q <- reactive({ - alpha <- input$alpha - size <- input$size - ggtheme <- input$ggtheme - input_type <- input$plot_type - show_outlier <- input$show_outlier - - teal::validate_inputs(iv_r()) - - plot_type_0 <- function() { - fit <- fit_r()[["fit"]] - ANL <- anl_merged_q()[["ANL"]] + output_plot_base <- reactive({ + base_fit <- fit_r() + teal.code::eval_code( + base_fit, + quote({ + class(fit$residuals) <- NULL - stopifnot(ncol(fit$model) == 2) + data <- ggplot2::fortify(fit) - if (!is.factor(ANL[[regression_var()$regressor]])) { - shinyjs::show("size") - shinyjs::show("alpha") - plot <- substitute( - env = list( - regressor = regression_var()$regressor, - response = regression_var()$response, - size = size, - alpha = alpha - ), - expr = ggplot( - fit$model[, 2:1], - aes_string(regressor, response) - ) + - geom_point(size = size, alpha = alpha) + - stat_smooth( - method = "lm", - formula = y ~ x, - se = FALSE - ) - ) - if (show_outlier) { - plot <- substitute( - expr = plot + outlier_label, - env = list(plot = plot, outlier_label = outlier_label()) - ) - } - } else { - shinyjs::hide("size") - shinyjs::hide("alpha") - plot <- substitute( - expr = ggplot(fit$model[, 2:1], aes_string(regressor, response)) + - geom_boxplot(), - env = list(regressor = regression_var()$regressor, response = regression_var()$response) - ) - if (show_outlier) { - plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) + smooth <- function(x, y) { + as.data.frame(stats::lowess(x, y, f = 2 / 3, iter = 3)) } - } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Response vs Regressor"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - title = "Response vs Regressor", - x = varname_w_label(regression_var()$regressor, ANL), - y = varname_w_label(regression_var()$response, ANL) - ), - theme = list() - ) - ), - ggtheme = ggtheme - ) + smoothy_aes <- ggplot2::aes_string(x = "x", y = "y") - teal.code::eval_code( - fit_r(), - substitute( - expr = { - class(fit$residuals) <- NULL - data <- fortify(fit) - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) - ) - ) - } - - plot_base <- function() { - base_fit <- fit_r() - teal.code::eval_code( - base_fit, - quote({ - class(fit$residuals) <- NULL - - data <- ggplot2::fortify(fit) + reg_form <- deparse(fit$call[[2]]) + }) + ) + }) - smooth <- function(x, y) { - as.data.frame(stats::lowess(x, y, f = 2 / 3, iter = 3)) - } + output_plot_0 <- reactive({ + fit <- fit_r()[["fit"]] + ANL <- anl_merged_q()[["ANL"]] - smoothy_aes <- ggplot2::aes_string(x = "x", y = "y") + stopifnot(ncol(fit$model) == 2) - reg_form <- deparse(fit$call[[2]]) - }) - ) - } - - plot_type_1 <- function(plot_base) { + if (!is.factor(ANL[[regression_var()$regressor]])) { shinyjs::show("size") shinyjs::show("alpha") plot <- substitute( - expr = ggplot(data = data, aes(.fitted, .resid)) + + expr = ggplot(fit$model[, 2:1], aes_string(regressor, response)) + geom_point(size = size, alpha = alpha) + - geom_hline(yintercept = 0, linetype = "dashed", size = 1) + - geom_line(data = smoothy, mapping = smoothy_aes), - env = list(size = size, alpha = alpha) + stat_smooth(method = "lm", formula = y ~ x, se = FALSE), + env = list( + regressor = regression_var()$regressor, + response = regression_var()$response, + size = input$size, + alpha = input$alpha + ) ) - if (show_outlier) { + if (input$show_outlier) { + plot <- substitute( + expr = plot + outlier_label, + env = list(plot = plot, outlier_label = outlier_label()) + ) + } + } else { + shinyjs::hide("size") + shinyjs::hide("alpha") + plot <- substitute( + expr = ggplot(fit$model[, 2:1], aes_string(regressor, response)) + + geom_boxplot(), + env = list(regressor = regression_var()$regressor, response = regression_var()$response) + ) + if (input$show_outlier) { plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) } + } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Residuals vs Fitted"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - x = quote(paste0("Fitted values\nlm(", reg_form, ")")), - y = "Residuals", - title = "Residuals vs Fitted" - ) - ) - ), - ggtheme = ggtheme - ) + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Response vs Regressor"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + title = "Response vs Regressor", + x = varname_w_label(regression_var()$regressor, ANL), + y = varname_w_label(regression_var()$response, ANL) + ), + theme = list() + ) + ), + ggtheme = input$ggtheme + ) - teal.code::eval_code( - plot_base, - substitute( - expr = { - smoothy <- smooth(data$.fitted, data$.resid) - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) + teal.code::eval_code( + fit_r(), + substitute( + expr = { + class(fit$residuals) <- NULL + data <- fortify(fit) + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) ) ) - } + ) + }) - plot_type_2 <- function(plot_base) { - shinyjs::show("size") - shinyjs::show("alpha") - plot <- substitute( - expr = ggplot(data = data, aes(sample = .stdresid)) + - stat_qq(size = size, alpha = alpha) + - geom_abline(linetype = "dashed"), - env = list(size = size, alpha = alpha) - ) - if (show_outlier) { - plot <- substitute( - expr = plot + - stat_qq( - geom = ggrepel::GeomTextRepel, - label = label_col %>% - data.frame(label = .) %>% - dplyr::filter(label != "cooksd == NaN") %>% - unlist(), - color = "red", - hjust = 0, - vjust = 0, - max.overlaps = Inf, - min.segment.length = label_min_segment, - segment.alpha = .5, - seed = 123 - ), - env = list(plot = plot, label_col = label_col(), label_min_segment = label_min_segment()) - ) - } + output_plot_1 <- reactive({ + plot_base <- output_plot_base() + shinyjs::show("size") + shinyjs::show("alpha") + plot <- substitute( + expr = ggplot(data = data, aes(.fitted, .resid)) + + geom_point(size = size, alpha = alpha) + + geom_hline(yintercept = 0, linetype = "dashed", size = 1) + + geom_line(data = smoothy, mapping = smoothy_aes), + env = list(size = input$size, alpha = input$alpha) + ) + if (input$show_outlier) { + plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) + } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Normal Q-Q"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - x = quote(paste0("Theoretical Quantiles\nlm(", reg_form, ")")), - y = "Standardized residuals", - title = "Normal Q-Q" - ) + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Residuals vs Fitted"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + x = quote(paste0("Fitted values\nlm(", reg_form, ")")), + y = "Residuals", + title = "Residuals vs Fitted" ) - ), - ggtheme = ggtheme - ) + ) + ), + ggtheme = input$ggtheme + ) - teal.code::eval_code( - plot_base, - substitute( - expr = { - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) + teal.code::eval_code( + plot_base, + substitute( + expr = { + smoothy <- smooth(data$.fitted, data$.resid) + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) ) ) - } + ) + }) - plot_type_3 <- function(plot_base) { - shinyjs::show("size") - shinyjs::show("alpha") + output_plot_2 <- reactive({ + shinyjs::show("size") + shinyjs::show("alpha") + plot_base <- output_plot_base() + plot <- substitute( + expr = ggplot(data = data, aes(sample = .stdresid)) + + stat_qq(size = size, alpha = alpha) + + geom_abline(linetype = "dashed"), + env = list(size = input$size, alpha = input$alpha) + ) + if (input$show_outlier) { plot <- substitute( - expr = ggplot(data = data, aes(.fitted, sqrt(abs(.stdresid)))) + - geom_point(size = size, alpha = alpha) + - geom_line(data = smoothy, mapping = smoothy_aes), - env = list(size = size, alpha = alpha) + expr = plot + + stat_qq( + geom = ggrepel::GeomTextRepel, + label = label_col %>% + data.frame(label = .) %>% + dplyr::filter(label != "cooksd == NaN") %>% + unlist(), + color = "red", + hjust = 0, + vjust = 0, + max.overlaps = Inf, + min.segment.length = label_min_segment, + segment.alpha = .5, + seed = 123 + ), + env = list(plot = plot, label_col = label_col(), label_min_segment = label_min_segment()) ) - if (show_outlier) { - plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) - } + } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Scale-Location"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - x = quote(paste0("Fitted values\nlm(", reg_form, ")")), - y = quote(expression(sqrt(abs(`Standardized residuals`)))), - title = "Scale-Location" - ) + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Normal Q-Q"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + x = quote(paste0("Theoretical Quantiles\nlm(", reg_form, ")")), + y = "Standardized residuals", + title = "Normal Q-Q" ) - ), - ggtheme = ggtheme - ) + ) + ), + ggtheme = input$ggtheme + ) - teal.code::eval_code( - plot_base, - substitute( - expr = { - smoothy <- smooth(data$.fitted, sqrt(abs(data$.stdresid))) - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) + teal.code::eval_code( + plot_base, + substitute( + expr = { + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) ) ) - } + ) + }) - plot_type_4 <- function(plot_base) { - shinyjs::hide("size") - shinyjs::show("alpha") - plot <- substitute( - expr = ggplot(data = data, aes(seq_along(.cooksd), .cooksd)) + - geom_col(alpha = alpha), - env = list(alpha = alpha) - ) - if (show_outlier) { - plot <- substitute( - expr = plot + - geom_hline( - yintercept = c( - outlier * mean(data$.cooksd, na.rm = TRUE), - mean(data$.cooksd, na.rm = TRUE) - ), - color = "red", - linetype = "dashed" - ) + - geom_text( - aes( - x = 0, - y = mean(data$.cooksd, na.rm = TRUE), - label = paste("mu", "=", round(mean(data$.cooksd, na.rm = TRUE), 4)), - vjust = -1, - hjust = 0, - color = "red", - angle = 90 - ), - parse = TRUE, - show.legend = FALSE - ) + - outlier_label, - env = list(plot = plot, outlier = input$outlier, outlier_label = outlier_label()) - ) - } + output_plot_3 <- reactive({ + shinyjs::show("size") + shinyjs::show("alpha") + plot_base <- output_plot_base() + plot <- substitute( + expr = ggplot(data = data, aes(.fitted, sqrt(abs(.stdresid)))) + + geom_point(size = size, alpha = alpha) + + geom_line(data = smoothy, mapping = smoothy_aes), + env = list(size = input$size, alpha = input$alpha) + ) + if (input$show_outlier) { + plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) + } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Cook's distance"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - x = quote(paste0("Obs. number\nlm(", reg_form, ")")), - y = "Cook's distance", - title = "Cook's distance" - ) + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Scale-Location"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + x = quote(paste0("Fitted values\nlm(", reg_form, ")")), + y = quote(expression(sqrt(abs(`Standardized residuals`)))), + title = "Scale-Location" ) - ), - ggtheme = ggtheme - ) + ) + ), + ggtheme = input$ggtheme + ) - teal.code::eval_code( - plot_base, - substitute( - expr = { - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) + teal.code::eval_code( + plot_base, + substitute( + expr = { + smoothy <- smooth(data$.fitted, sqrt(abs(data$.stdresid))) + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) ) ) - } - + ) + }) - plot_type_5 <- function(plot_base) { - shinyjs::show("size") - shinyjs::show("alpha") + output_plot_4 <- reactive({ + shinyjs::hide("size") + shinyjs::show("alpha") + plot_base <- output_plot_base() + plot <- substitute( + expr = ggplot(data = data, aes(seq_along(.cooksd), .cooksd)) + + geom_col(alpha = alpha), + env = list(alpha = input$alpha) + ) + if (input$show_outlier) { plot <- substitute( - expr = ggplot(data = data, aes(.hat, .stdresid)) + - geom_vline( - size = 1, - colour = "black", - linetype = "dashed", - xintercept = 0 - ) + + expr = plot + geom_hline( - size = 1, - colour = "black", - linetype = "dashed", - yintercept = 0 + yintercept = c( + outlier * mean(data$.cooksd, na.rm = TRUE), + mean(data$.cooksd, na.rm = TRUE) + ), + color = "red", + linetype = "dashed" ) + - geom_point(size = size, alpha = alpha) + - geom_line(data = smoothy, mapping = smoothy_aes), - env = list(size = size, alpha = alpha) + geom_text( + aes( + x = 0, + y = mean(data$.cooksd, na.rm = TRUE), + label = paste("mu", "=", round(mean(data$.cooksd, na.rm = TRUE), 4)), + vjust = -1, + hjust = 0, + color = "red", + angle = 90 + ), + parse = TRUE, + show.legend = FALSE + ) + + outlier_label, + env = list(plot = plot, outlier = input$outlier, outlier_label = outlier_label()) ) - if (show_outlier) { - plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) - } + } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Residuals vs Leverage"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - x = quote(paste0("Standardized residuals\nlm(", reg_form, ")")), - y = "Leverage", - title = "Residuals vs Leverage" - ) + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Cook's distance"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + x = quote(paste0("Obs. number\nlm(", reg_form, ")")), + y = "Cook's distance", + title = "Cook's distance" ) - ), - ggtheme = ggtheme - ) + ) + ), + ggtheme = input$ggtheme + ) - teal.code::eval_code( - plot_base, - substitute( - expr = { - smoothy <- smooth(data$.hat, data$.stdresid) - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) + teal.code::eval_code( + plot_base, + substitute( + expr = { + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) ) ) - } + ) + }) - plot_type_6 <- function(plot_base) { - shinyjs::show("size") - shinyjs::show("alpha") - plot <- substitute( - expr = ggplot(data = data, aes(.hat, .cooksd)) + - geom_vline(xintercept = 0, colour = NA) + - geom_abline( - slope = seq(0, 3, by = 0.5), - colour = "black", - linetype = "dashed", - size = 1 - ) + - geom_line(data = smoothy, mapping = smoothy_aes) + - geom_point(size = size, alpha = alpha), - env = list(size = size, alpha = alpha) - ) - if (show_outlier) { - plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) - } + output_plot_5 <- reactive({ + shinyjs::show("size") + shinyjs::show("alpha") + plot_base <- output_plot_base() + plot <- substitute( + expr = ggplot(data = data, aes(.hat, .stdresid)) + + geom_vline( + size = 1, + colour = "black", + linetype = "dashed", + xintercept = 0 + ) + + geom_hline( + size = 1, + colour = "black", + linetype = "dashed", + yintercept = 0 + ) + + geom_point(size = size, alpha = alpha) + + geom_line(data = smoothy, mapping = smoothy_aes), + env = list(size = input$size, alpha = input$alpha) + ) + if (input$show_outlier) { + plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) + } - parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( - teal.widgets::resolve_ggplot2_args( - user_plot = ggplot2_args[["Cook's dist vs Leverage"]], - user_default = ggplot2_args$default, - module_plot = teal.widgets::ggplot2_args( - labs = list( - x = quote(paste0("Leverage\nlm(", reg_form, ")")), - y = "Cooks's distance", - title = "Cook's dist vs Leverage" - ) + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Residuals vs Leverage"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + x = quote(paste0("Standardized residuals\nlm(", reg_form, ")")), + y = "Leverage", + title = "Residuals vs Leverage" ) - ), - ggtheme = ggtheme - ) + ) + ), + ggtheme = input$ggtheme + ) - teal.code::eval_code( - plot_base, - substitute( - expr = { - smoothy <- smooth(data$.hat, data$.cooksd) - g <- plot - print(g) - }, - env = list( - plot = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) - ) + teal.code::eval_code( + plot_base, + substitute( + expr = { + smoothy <- smooth(data$.hat, data$.stdresid) + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) ) ) + ) + }) + + output_plot_6 <- reactive({ + shinyjs::show("size") + shinyjs::show("alpha") + plot_base <- output_plot_base() + plot <- substitute( + expr = ggplot(data = data, aes(.hat, .cooksd)) + + geom_vline(xintercept = 0, colour = NA) + + geom_abline( + slope = seq(0, 3, by = 0.5), + colour = "black", + linetype = "dashed", + size = 1 + ) + + geom_line(data = smoothy, mapping = smoothy_aes) + + geom_point(size = size, alpha = alpha), + env = list(size = input$size, alpha = input$alpha) + ) + if (input$show_outlier) { + plot <- substitute(expr = plot + outlier_label, env = list(plot = plot, outlier_label = outlier_label())) } - qenv <- if (input_type == "Response vs Regressor") { - plot_type_0() - } else { - plot_base_q <- plot_base() - switch(input_type, - "Residuals vs Fitted" = plot_base_q %>% plot_type_1(), - "Normal Q-Q" = plot_base_q %>% plot_type_2(), - "Scale-Location" = plot_base_q %>% plot_type_3(), - "Cook's distance" = plot_base_q %>% plot_type_4(), - "Residuals vs Leverage" = plot_base_q %>% plot_type_5(), - "Cook's dist vs Leverage" = plot_base_q %>% plot_type_6() + parsed_ggplot2_args <- teal.widgets::parse_ggplot2_args( + teal.widgets::resolve_ggplot2_args( + user_plot = ggplot2_args[["Cook's dist vs Leverage"]], + user_default = ggplot2_args$default, + module_plot = teal.widgets::ggplot2_args( + labs = list( + x = quote(paste0("Leverage\nlm(", reg_form, ")")), + y = "Cooks's distance", + title = "Cook's dist vs Leverage" + ) + ) + ), + ggtheme = input$ggtheme + ) + + teal.code::eval_code( + plot_base, + substitute( + expr = { + smoothy <- smooth(data$.hat, data$.cooksd) + plot <- graph + }, + env = list( + graph = Reduce(function(x, y) call("+", x, y), c(plot, parsed_ggplot2_args)) + ) ) - } - qenv + ) }) + output_q <- reactive({ + teal::validate_inputs(iv_r()) + switch(input$plot_type, + "Response vs Regressor" = output_plot_0(), + "Residuals vs Fitted" = output_plot_1(), + "Normal Q-Q" = output_plot_2(), + "Scale-Location" = output_plot_3(), + "Cook's distance" = output_plot_4(), + "Residuals vs Leverage" = output_plot_5(), + "Cook's dist vs Leverage" = output_plot_6() + ) + }) - fitted <- reactive(output_q()[["fit"]]) - plot_r <- reactive(output_q()[["g"]]) + decorated_output_q <- srv_decorate_teal_data( + "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = print(plot) + ) + + fitted <- reactive({ + req(output_q()) + decorated_output_q()[["fit"]] + }) + plot_r <- reactive({ + req(output_q()) + decorated_output_q()[["plot"]] + }) # Insert the plot into a plot_with_settings module from teal.widgets pws <- teal.widgets::plot_with_settings_srv( @@ -1000,7 +1008,7 @@ srv_a_regression <- function(id, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_q()))), title = "R code for the regression plot", ) @@ -1019,7 +1027,7 @@ srv_a_regression <- function(id, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) @@ -1027,8 +1035,3 @@ srv_a_regression <- function(id, ### }) } - -regression_names <- paste0( - '"Response vs Regressor", "Residuals vs Fitted", ', - '"Scale-Location", "Cook\'s distance", "Residuals vs Leverage"", "Cook\'s dist vs Leverage"' -) diff --git a/R/tm_data_table.R b/R/tm_data_table.R index 2a688f7d7..3cb2155a9 100644 --- a/R/tm_data_table.R +++ b/R/tm_data_table.R @@ -26,9 +26,18 @@ #' `list(searching = FALSE, pageLength = 30, lengthMenu = c(5, 15, 30, 100), scrollX = TRUE)` #' @param server_rendering (`logical`) should the data table be rendered server side #' (see `server` argument of [DT::renderDataTable()]) +#' @param decorators `r roxygen_decorators_param("tm_data_table")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_data_table`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `table` ([DT::datatable()]) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -96,7 +105,8 @@ tm_data_table <- function(label = "Data Table", ), server_rendering = FALSE, pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_data_table") # Start of assertions @@ -121,6 +131,9 @@ tm_data_table <- function(label = "Data Table", checkmate::assert_flag(server_rendering) checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "table") # End of assertions ans <- module( @@ -133,7 +146,8 @@ tm_data_table <- function(label = "Data Table", datasets_selected = datasets_selected, dt_args = dt_args, dt_options = dt_options, - server_rendering = server_rendering + server_rendering = server_rendering, + decorators = decorators ), ui_args = list( pre_output = pre_output, @@ -145,9 +159,7 @@ tm_data_table <- function(label = "Data Table", } # UI page module -ui_page_data_table <- function(id, - pre_output = NULL, - post_output = NULL) { +ui_page_data_table <- function(id, pre_output = NULL, post_output = NULL) { ns <- NS(id) tagList( @@ -185,7 +197,8 @@ srv_page_data_table <- function(id, variables_selected, dt_args, dt_options, - server_rendering) { + server_rendering, + decorators) { checkmate::assert_class(data, "reactive") checkmate::assert_class(isolate(data()), "teal_data") moduleServer(id, function(input, output, session) { @@ -238,7 +251,8 @@ srv_page_data_table <- function(id, ui_data_table( id = session$ns(x), choices = choices, - selected = variables_selected + selected = variables_selected, + decorators = decorators ) ) ) @@ -260,7 +274,8 @@ srv_page_data_table <- function(id, if_distinct = if_distinct, dt_args = dt_args, dt_options = dt_options, - server_rendering = server_rendering + server_rendering = server_rendering, + decorators = decorators ) } ) @@ -270,7 +285,8 @@ srv_page_data_table <- function(id, # UI function for the data_table module ui_data_table <- function(id, choices, - selected) { + selected, + decorators) { ns <- NS(id) if (!is.null(selected)) { @@ -282,6 +298,7 @@ ui_data_table <- function(id, tagList( teal.widgets::get_dt_rows(ns("data_table"), ns("dt_rows")), fluidRow( + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(decorators, "table")), teal.widgets::optionalSelectInput( ns("variables"), "Select variables:", @@ -305,7 +322,8 @@ srv_data_table <- function(id, if_distinct, dt_args, dt_options, - server_rendering) { + server_rendering, + decorators) { moduleServer(id, function(input, output, session) { iv <- shinyvalidate::InputValidator$new() iv$add_rule("variables", shinyvalidate::sv_required("Please select valid variable names")) @@ -314,27 +332,50 @@ srv_data_table <- function(id, )) iv$enable() - output$data_table <- DT::renderDataTable(server = server_rendering, { - teal::validate_inputs(iv) - + data_table_data <- reactive({ df <- data()[[dataname]] - variables <- input$variables teal::validate_has_data(df, min_nrow = 1L, msg = paste("data", dataname, "is empty")) - dataframe_selected <- if (if_distinct()) { - dplyr::count(df, dplyr::across(dplyr::all_of(variables))) - } else { - df[variables] - } + teal.code::eval_code( + data(), + substitute( + expr = { + variables <- vars + dataframe_selected <- if (if_distinct) { + dplyr::count(dataname, dplyr::across(dplyr::all_of(variables))) + } else { + dataname[variables] + } + dt_args <- args + dt_args$options <- dt_options + if (!is.null(dt_rows)) { + dt_args$options$pageLength <- dt_rows + } + dt_args$data <- dataframe_selected + table <- do.call(DT::datatable, dt_args) + }, + env = list( + dataname = as.name(dataname), + if_distinct = if_distinct(), + vars = input$variables, + args = dt_args, + dt_options = dt_options, + dt_rows = input$dt_rows + ) + ) + ) + }) - dt_args$options <- dt_options - if (!is.null(input$dt_rows)) { - dt_args$options$pageLength <- input$dt_rows - } - dt_args$data <- dataframe_selected + decorated_data_table_data <- srv_decorate_teal_data( + id = "decorator", + data = data_table_data, + decorators = select_decorators(decorators, "table") + ) - do.call(DT::datatable, dt_args) + output$data_table <- DT::renderDataTable(server = server_rendering, { + teal::validate_inputs(iv) + req(decorated_data_table_data())[["table"]] }) }) } diff --git a/R/tm_g_association.R b/R/tm_g_association.R index 3611df804..ec4a116d3 100644 --- a/R/tm_g_association.R +++ b/R/tm_g_association.R @@ -20,11 +20,19 @@ #' @param distribution_theme,association_theme (`character`) optional, `ggplot2` themes to be used by default. #' Default to `"gray"`. #' -#' @templateVar ggnames "Bivariate1", "Bivariate2" -#' @template ggplot2_args_multi +#' @param ggplot2_args `r roxygen_ggplot2_args_param("Bivariate1", "Bivariate2")` +#' @param decorators `r roxygen_decorators_param("tm_g_association")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_g_association`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `plot` (`grob` created with [ggplot2::ggplotGrob()]) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -130,7 +138,8 @@ tm_g_association <- function(label = "Association", association_theme = c("gray", "bw", "linedraw", "light", "dark", "minimal", "classic", "void"), # nolint: line_length. pre_output = NULL, post_output = NULL, - ggplot2_args = teal.widgets::ggplot2_args()) { + ggplot2_args = teal.widgets::ggplot2_args(), + decorators = NULL) { message("Initializing tm_g_association") # Normalize the parameters @@ -166,6 +175,9 @@ tm_g_association <- function(label = "Association", plot_choices <- c("Bivariate1", "Bivariate2") checkmate::assert_list(ggplot2_args, types = "ggplot2_args") checkmate::assert_subset(names(ggplot2_args), c("default", plot_choices)) + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "plot") # End of assertions # Make UI args @@ -183,7 +195,7 @@ tm_g_association <- function(label = "Association", ui_args = args, server_args = c( data_extract_list, - list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args) + list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args, decorators = decorators) ), datanames = teal.transform::get_extract_datanames(data_extract_list) ) @@ -236,6 +248,7 @@ ui_tm_g_association <- function(id, ...) { "Log transformed", value = FALSE ), + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")), teal.widgets::panel_group( teal.widgets::panel_item( title = "Plot settings", @@ -277,7 +290,8 @@ srv_tm_g_association <- function(id, vars, plot_height, plot_width, - ggplot2_args) { + ggplot2_args, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -392,8 +406,6 @@ srv_tm_g_association <- function(id, # association ref_class_cov <- ifelse(association, ref_class, "NULL") - print_call <- quote(print(p)) - var_calls <- lapply(vars_names, function(var_i) { var_class <- class(ANL[[var_i]])[1] if (is.numeric(ANL[[var_i]]) && log_transformation) { @@ -463,7 +475,6 @@ srv_tm_g_association <- function(id, ) ) } - teal.code::eval_code( merged$anl_q_r(), substitute( @@ -474,10 +485,9 @@ srv_tm_g_association <- function(id, teal.code::eval_code( substitute( expr = { - plots <- plot_calls - p <- tern::stack_grobs(grobs = lapply(plots, ggplotGrob)) - grid::grid.newpage() - grid::grid.draw(p) + plot_top <- plot_calls[[1]] + plot_bottom <- plot_calls[[1]] + plot <- tern::stack_grobs(grobs = lapply(list(plot_top, plot_bottom), ggplotGrob)) }, env = list( plot_calls = do.call( @@ -490,9 +500,19 @@ srv_tm_g_association <- function(id, ) }) + decorated_output_grob_q <- srv_decorate_teal_data( + id = "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = { + grid::grid.newpage() + grid::grid.draw(plot) + } + ) + plot_r <- reactive({ req(iv_r()$is_valid()) - output_q()[["p"]] + req(decorated_output_grob_q())[["plot"]] }) pws <- teal.widgets::plot_with_settings_srv( @@ -508,7 +528,7 @@ srv_tm_g_association <- function(id, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_grob_q()))), title = "Association Plot" ) @@ -527,7 +547,7 @@ srv_tm_g_association <- function(id, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_grob_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_g_bivariate.R b/R/tm_g_bivariate.R index 4e93151b9..aaf9b9642 100644 --- a/R/tm_g_bivariate.R +++ b/R/tm_g_bivariate.R @@ -43,9 +43,19 @@ #' @param free_y_scales (`logical`) optional, whether Y scaling shall be changeable. #' Does not allow scaling to be changed by default (`FALSE`). #' @param swap_axes (`logical`) optional, whether to swap X and Y axes. Defaults to `FALSE`. +#' @param decorators `r roxygen_decorators_param("tm_g_bivariate")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_g_bivariate`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `plot` (`ggplot2`) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -185,7 +195,8 @@ tm_g_bivariate <- function(label = "Bivariate Plots", ggtheme = c("gray", "bw", "linedraw", "light", "dark", "minimal", "classic", "void"), ggplot2_args = teal.widgets::ggplot2_args(), pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_g_bivariate") # Normalize the parameters @@ -265,6 +276,9 @@ tm_g_bivariate <- function(label = "Bivariate Plots", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "plot") # End of assertions # Make UI args @@ -288,7 +302,7 @@ tm_g_bivariate <- function(label = "Bivariate Plots", ui_args = args, server_args = c( data_extract_list, - list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args) + list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args, decorators = decorators) ), datanames = teal.transform::get_extract_datanames(data_extract_list) ) @@ -338,6 +352,7 @@ ui_g_bivariate <- function(id, ...) { justified = TRUE ) ), + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")), if (!is.null(args$row_facet) || !is.null(args$col_facet)) { tags$div( class = "data-extract-box", @@ -451,7 +466,8 @@ srv_g_bivariate <- function(id, size, plot_height, plot_width, - ggplot2_args) { + ggplot2_args, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -648,38 +664,49 @@ srv_g_bivariate <- function(id, } } - # Add labels to facets - nulled_row_facet_name <- varname_w_label(row_facet_name, ANL) - nulled_col_facet_name <- varname_w_label(col_facet_name, ANL) - without_facet <- (is.null(nulled_row_facet_name) && is.null(nulled_col_facet_name)) || !facetting - - print_call <- if (without_facet) { - quote(print(p)) - } else { - substitute( - expr = { - # Add facetting labels - # optional: grid.newpage() # nolint: commented_code. - # Prefixed with teal.modules.general as its usage will appear in "Show R code" - p <- teal.modules.general::add_facet_labels( - p, - xfacet_label = nulled_col_facet_name, - yfacet_label = nulled_row_facet_name - ) - grid::grid.newpage() - grid::grid.draw(p) - }, - env = list(nulled_col_facet_name = nulled_col_facet_name, nulled_row_facet_name = nulled_row_facet_name) - ) - } - - teal.code::eval_code(merged$anl_q_r(), substitute(expr = p <- cl, env = list(cl = cl))) %>% - teal.code::eval_code(print_call) + teal.code::eval_code(merged$anl_q_r(), substitute(expr = plot <- cl, env = list(cl = cl))) }) - plot_r <- reactive({ - output_q()[["p"]] - }) + decorated_output_q_facets <- srv_decorate_teal_data( + "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = reactive({ + ANL <- merged$anl_q_r()[["ANL"]] + row_facet_name <- as.vector(merged$anl_input_r()$columns_source$row_facet) + col_facet_name <- as.vector(merged$anl_input_r()$columns_source$col_facet) + + # Add labels to facets + nulled_row_facet_name <- varname_w_label(row_facet_name, ANL) + nulled_col_facet_name <- varname_w_label(col_facet_name, ANL) + facetting <- (isTRUE(input$facetting) && (!is.null(row_facet_name) || !is.null(col_facet_name))) + without_facet <- (is.null(nulled_row_facet_name) && is.null(nulled_col_facet_name)) || !facetting + + print_call <- if (without_facet) { + quote(print(plot)) + } else { + substitute( + expr = { + # Add facetting labels + # optional: grid.newpage() # nolint: commented_code. + # Prefixed with teal.modules.general as its usage will appear in "Show R code" + plot <- teal.modules.general::add_facet_labels( + plot, + xfacet_label = nulled_col_facet_name, + yfacet_label = nulled_row_facet_name + ) + grid::grid.newpage() + grid::grid.draw(plot) + }, + env = list(nulled_col_facet_name = nulled_col_facet_name, nulled_row_facet_name = nulled_row_facet_name) + ) + } + print_call + }), + expr_is_reactive = TRUE + ) + + plot_r <- reactive(req(decorated_output_q_facets())[["plot"]]) pws <- teal.widgets::plot_with_settings_srv( id = "myplot", @@ -690,7 +717,7 @@ srv_g_bivariate <- function(id, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_q_facets()))), title = "Bivariate Plot" ) @@ -709,7 +736,7 @@ srv_g_bivariate <- function(id, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_q_facets))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_g_distribution.R b/R/tm_g_distribution.R index 22d5fec89..8e84ed76a 100644 --- a/R/tm_g_distribution.R +++ b/R/tm_g_distribution.R @@ -22,11 +22,40 @@ #' and `max`. #' Defaults to `c(30L, 1L, 100L)`. #' -#' @templateVar ggnames "Histogram", "QQplot" -#' @template ggplot2_args_multi +#' @param ggplot2_args `r roxygen_ggplot2_args_param("Histogram", "QQplot")` +#' @param decorators `r roxygen_decorators_param("tm_g_distribution")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_g_distribution`: +#' +#' This module generates the following objects, which can be modified in place using decorators:: +#' - `histogram_plot` (`ggplot2`) +#' - `qq_plot` (`data.frame`) +#' - `summary_table` (`data.frame`) +#' - `test_table` (`data.frame`) +#' +#' Decorators can be applied to all outputs or only to specific objects using a +#' named list of `teal_transform_module` objects. +#' The `"default"` name is reserved for decorators that are applied to all outputs. +#' See code snippet below: +#' +#' ``` +#' tm_g_distribution( +#' ..., # arguments for module +#' decorators = list( +#' default = list(teal_transform_module(...)), # applied to all outputs +#' histogram_plot = list(teal_transform_module(...)), # applied only to `histogram_plot` output +#' qq_plot = list(teal_transform_module(...)) # applied only to `qq_plot` output +#' summary_table = list(teal_transform_module(...)) # applied only to `summary_table` output +#' test_table = list(teal_transform_module(...)) # applied only to `test_table` output +#' ) +#' ) +#' ``` +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -121,7 +150,8 @@ tm_g_distribution <- function(label = "Distribution Module", plot_height = c(600, 200, 2000), plot_width = NULL, pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_g_distribution") # Requires Suggested packages @@ -172,6 +202,11 @@ tm_g_distribution <- function(label = "Distribution Module", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + available_decorators <- c("histogram_plot", "qq_plot", "test_table", "summary_table") + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, names = available_decorators) + # End of assertions # Make UI args @@ -188,7 +223,12 @@ tm_g_distribution <- function(label = "Distribution Module", server = srv_distribution, server_args = c( data_extract_list, - list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args) + list( + plot_height = plot_height, + plot_width = plot_width, + ggplot2_args = ggplot2_args, + decorators = decorators + ) ), ui = ui_distribution, ui_args = args, @@ -262,6 +302,10 @@ ui_distribution <- function(id, ...) { inline = TRUE ), checkboxInput(ns("add_dens"), label = "Overlay Density", value = TRUE), + ui_decorate_teal_data( + ns("d_density"), + decorators = select_decorators(args$decorators, "histogram_plot") + ), collapsed = FALSE ) ), @@ -270,9 +314,21 @@ ui_distribution <- function(id, ...) { teal.widgets::panel_item( "QQ Plot", checkboxInput(ns("qq_line"), label = "Add diagonal line(s)", TRUE), + ui_decorate_teal_data( + ns("d_qq"), + decorators = select_decorators(args$decorators, "qq_plot") + ), collapsed = FALSE ) ), + ui_decorate_teal_data( + ns("d_summary"), + decorators = select_decorators(args$decorators, "summary_table") + ), + ui_decorate_teal_data( + ns("d_test"), + decorators = select_decorators(args$decorators, "test_table") + ), conditionalPanel( condition = paste0("input['", ns("main_type"), "'] == 'Density'"), teal.widgets::panel_item( @@ -353,7 +409,8 @@ srv_distribution <- function(id, group_var, plot_height, plot_width, - ggplot2_args) { + ggplot2_args, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -459,9 +516,10 @@ srv_distribution <- function(id, ) } } + rule_dist <- function(value) { - if (isTRUE(input$tabs == "QQplot" || - input$dist_tests %in% c( + if (isTRUE(input$tabs == "QQplot") || + isTRUE(input$dist_tests %in% c( "Kolmogorov-Smirnov (one-sample)", "Anderson-Darling (one-sample)", "Cramer-von Mises (one-sample)" @@ -471,6 +529,7 @@ srv_distribution <- function(id, } } } + iv_dist <- shinyvalidate::InputValidator$new() iv_dist$add_rule("t_dist", rule_dist) iv_dist$add_rule("dist_param1", rule_dist_1) @@ -654,12 +713,12 @@ srv_distribution <- function(id, ) } - if (length(s_var) == 0 && length(g_var) == 0) { - qenv <- teal.code::eval_code( + qenv <- if (length(s_var) == 0 && length(g_var) == 0) { + teal.code::eval_code( qenv, substitute( expr = { - summary_table <- ANL %>% + summary_table_data <- ANL %>% dplyr::summarise( min = round(min(dist_var_name, na.rm = TRUE), roundn), median = round(stats::median(dist_var_name, na.rm = TRUE), roundn), @@ -676,12 +735,12 @@ srv_distribution <- function(id, ) ) } else { - qenv <- teal.code::eval_code( + teal.code::eval_code( qenv, substitute( expr = { strata_vars <- strata_vars_raw - summary_table <- ANL %>% + summary_table_data <- ANL %>% dplyr::group_by_at(dplyr::vars(dplyr::any_of(strata_vars))) %>% dplyr::summarise( min = round(min(dist_var_name, na.rm = TRUE), roundn), @@ -691,7 +750,6 @@ srv_distribution <- function(id, sd = round(stats::sd(dist_var_name, na.rm = TRUE), roundn), count = dplyr::n() ) - summary_table # used to display table when running show-r-code code }, env = list( dist_var_name = dist_var_name, @@ -701,6 +759,20 @@ srv_distribution <- function(id, ) ) } + if (iv_r()$is_valid()) { + within(qenv, { + summary_table <- DT::datatable( + summary_table_data, + options = list( + autoWidth = TRUE, + columnDefs = list(list(width = "200px", targets = "_all")) + ), + rownames = FALSE + ) + }) + } else { + within(qenv, summary_table <- NULL) + } }) # distplot qenv ---- @@ -890,10 +962,7 @@ srv_distribution <- function(id, teal.code::eval_code( qenv, substitute( - expr = { - g <- plot_call - print(g) - }, + expr = histogram_plot <- plot_call, env = list(plot_call = Reduce(function(x, y) call("+", x, y), c(plot_call, parsed_ggplot2_args))) ) ) @@ -907,6 +976,7 @@ srv_distribution <- function(id, input$scales_type input$qq_line is.null(input$ggtheme) + input$tabs }, valueExpr = { dist_var <- merge_vars()$dist_var @@ -915,7 +985,6 @@ srv_distribution <- function(id, dist_var_name <- merge_vars()$dist_var_name s_var_name <- merge_vars()$s_var_name g_var_name <- merge_vars()$g_var_name - t_dist <- input$t_dist dist_param1 <- input$dist_param1 dist_param2 <- input$dist_param2 @@ -923,7 +992,7 @@ srv_distribution <- function(id, ggtheme <- input$ggtheme teal::validate_inputs(iv_r_dist(), iv_dist) - + t_dist <- req(input$t_dist) # Not validated when tab is not selected qenv <- common_q() plot_call <- if (length(s_var) == 0 && length(g_var) == 0) { @@ -1022,10 +1091,7 @@ srv_distribution <- function(id, teal.code::eval_code( qenv, substitute( - expr = { - g <- plot_call - print(g) - }, + expr = qq_plot <- plot_call, env = list(plot_call = Reduce(function(x, y) call("+", x, y), c(plot_call, parsed_ggplot2_args))) ) ) @@ -1174,7 +1240,7 @@ srv_distribution <- function(id, qenv, substitute( expr = { - test_stats <- ANL %>% + test_table_data <- ANL %>% dplyr::select(dist_var) %>% with(., broom::glance(do.call(test, args))) %>% dplyr::mutate_if(is.numeric, round, 3) @@ -1187,7 +1253,7 @@ srv_distribution <- function(id, qenv, substitute( expr = { - test_stats <- ANL %>% + test_table_data <- ANL %>% dplyr::select(dist_var, s_var, g_var) %>% dplyr::group_by_at(dplyr::vars(dplyr::any_of(groups))) %>% dplyr::do(tests = broom::glance(do.call(test, args))) %>% @@ -1198,52 +1264,88 @@ srv_distribution <- function(id, ) ) } - qenv %>% - # used to display table when running show-r-code code - teal.code::eval_code(quote(test_stats)) } ) # outputs ---- ## building main qenv - output_q <- reactive({ - tab <- input$tabs - req(tab) # tab is NULL upon app launch, hence will crash without this statement - - qenv_final <- common_q() + output_common_q <- reactive({ # wrapped in if since could lead into validate error - we do want to continue - test_r_qenv_out <- try(test_q(), silent = TRUE) - if (!inherits(test_r_qenv_out, c("try-error", "error"))) { - qenv_final <- c(qenv_final, test_q()) + test_q_out <- try(test_q(), silent = TRUE) + if (!inherits(test_q_out, c("try-error", "error"))) { + c( + common_q(), + within(test_q_out, { + test_table <- DT::datatable( + test_table_data, + options = list(scrollX = TRUE), + rownames = FALSE + ) + }) + ) + } else { + within(common_q(), test_table <- NULL) } + }) + + output_dist_q <- reactive(c(output_common_q(), req(dist_q()))) + output_qq_q <- reactive(c(output_common_q(), req(qq_q()))) + + decorated_output_dist_q <- srv_decorate_teal_data( + "d_density", + data = output_dist_q, + decorators = select_decorators(decorators, "histogram_plot"), + expr = print(histogram_plot) + ) + + decorated_output_qq_q <- srv_decorate_teal_data( + "d_qq", + data = output_qq_q, + decorators = select_decorators(decorators, "qq_plot"), + expr = print(qq_plot) + ) + + decorated_output_summary_q <- srv_decorate_teal_data( + "d_summary", + data = output_common_q, + decorators = select_decorators(decorators, "summary_table"), + expr = summary_table + ) + + decorated_output_test_q <- srv_decorate_teal_data( + "d_test", + data = output_common_q, + decorators = select_decorators(decorators, "test_table"), + expr = test_table + ) - qenv_final <- if (tab == "Histogram") { - req(dist_q()) - c(qenv_final, dist_q()) - } else if (tab == "QQplot") { - req(qq_q()) - c(qenv_final, qq_q()) + decorated_output_q <- reactive({ + tab <- req(input$tabs) # tab is NULL upon app launch, hence will crash without this statement + test_q_out <- try(test_q(), silent = TRUE) + decorated_test_q_out <- if (inherits(test_q_out, c("try-error", "error"))) { + teal.code::qenv() + } else { + decorated_output_test_q() } - qenv_final + + out_q <- switch(tab, + Histogram = decorated_output_dist_q(), + QQplot = decorated_output_qq_q() + ) + c(out_q, decorated_output_summary_q(), decorated_test_q_out) }) - dist_r <- reactive(dist_q()[["g"]]) + dist_r <- reactive(req(decorated_output_dist_q())[["histogram_plot"]]) - qq_r <- reactive(qq_q()[["g"]]) + qq_r <- reactive(req(decorated_output_qq_q())[["qq_plot"]]) - output$summary_table <- DT::renderDataTable( - expr = if (iv_r()$is_valid()) common_q()[["summary_table"]] else NULL, - options = list( - autoWidth = TRUE, - columnDefs = list(list(width = "200px", targets = "_all")) - ), - rownames = FALSE - ) + output$summary_table <- DT::renderDataTable(expr = decorated_output_summary_q()[["summary_table"]]) tests_r <- reactive({ req(iv_r()$is_valid()) teal::validate_inputs(iv_r_dist()) - test_q()[["test_stats"]] + req(test_q()) # Ensure original errors are displayed + decorated_output_test_q()[["test_table"]] }) pws1 <- teal.widgets::plot_with_settings_srv( @@ -1263,14 +1365,12 @@ srv_distribution <- function(id, ) output$t_stats <- DT::renderDataTable( - expr = tests_r(), - options = list(scrollX = TRUE), - rownames = FALSE + expr = tests_r() ) teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_q()))), title = "R Code for distribution" ) @@ -1302,7 +1402,7 @@ srv_distribution <- function(id, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_g_response.R b/R/tm_g_response.R index a593c46a4..85590ed9f 100644 --- a/R/tm_g_response.R +++ b/R/tm_g_response.R @@ -33,12 +33,21 @@ #' @param freq (`logical(1)`) #' Indicates whether to display frequency (`TRUE`) or density (`FALSE`). #' Defaults to density (`FALSE`). +#' @param decorators `r roxygen_decorators_param("tm_g_response")` #' #' @inherit shared_params return #' #' @note For more examples, please see the vignette "Using response plot" via #' `vignette("using-response-plot", package = "teal.modules.general")`. #' +#' @section Decorating `tm_g_response`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `plot` (`ggplot2`) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -147,7 +156,8 @@ tm_g_response <- function(label = "Response Plot", ggtheme = c("gray", "bw", "linedraw", "light", "dark", "minimal", "classic", "void"), ggplot2_args = teal.widgets::ggplot2_args(), pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_g_response") # Normalize the parameters @@ -191,6 +201,9 @@ tm_g_response <- function(label = "Response Plot", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "plot") # End of assertions # Make UI args @@ -210,7 +223,12 @@ tm_g_response <- function(label = "Response Plot", ui_args = args, server_args = c( data_extract_list, - list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args) + list( + plot_height = plot_height, + plot_width = plot_width, + ggplot2_args = ggplot2_args, + decorators = decorators + ) ), datanames = teal.transform::get_extract_datanames(data_extract_list) ) @@ -269,6 +287,7 @@ ui_g_response <- function(id, ...) { selected = ifelse(args$freq, "frequency", "density"), justified = TRUE ), + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")), teal.widgets::panel_group( teal.widgets::panel_item( title = "Plot settings", @@ -304,7 +323,8 @@ srv_g_response <- function(id, col_facet, plot_height, plot_width, - ggplot2_args) { + ggplot2_args, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -523,8 +543,7 @@ srv_g_response <- function(id, ) plot_call <- substitute(expr = { - p <- plot_call + labs + ggthemes + themes - print(p) + plot <- plot_call + labs + ggthemes + themes }, env = list( plot_call = plot_call, labs = parsed_ggplot2_args$labs, @@ -535,7 +554,14 @@ srv_g_response <- function(id, teal.code::eval_code(qenv, plot_call) }) - plot_r <- reactive(output_q()[["p"]]) + decorated_output_plot_q <- srv_decorate_teal_data( + id = "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = print(plot) + ) + + plot_r <- reactive(req(decorated_output_plot_q())[["plot"]]) # Insert the plot into a plot_with_settings module from teal.widgets pws <- teal.widgets::plot_with_settings_srv( @@ -547,7 +573,7 @@ srv_g_response <- function(id, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_plot_q()))), title = "Show R Code for Response" ) @@ -566,7 +592,7 @@ srv_g_response <- function(id, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_plot_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_g_scatterplot.R b/R/tm_g_scatterplot.R index 1f2d9d58a..28d9b0bda 100644 --- a/R/tm_g_scatterplot.R +++ b/R/tm_g_scatterplot.R @@ -27,9 +27,19 @@ #' `vignette("ggplot2-specs", package="ggplot2")`. #' @param max_deg (`integer`) optional, maximum degree for the polynomial trend line. Must not be less than 1. #' @param table_dec (`integer`) optional, number of decimal places used to round numeric values in the table. +#' @param decorators `r roxygen_decorators_param("tm_g_scatterplot")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_g_scatterplot`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `plot` (`ggplot2`) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -229,7 +239,8 @@ tm_g_scatterplot <- function(label = "Scatterplot", pre_output = NULL, post_output = NULL, table_dec = 4, - ggplot2_args = teal.widgets::ggplot2_args()) { + ggplot2_args = teal.widgets::ggplot2_args(), + decorators = NULL) { message("Initializing tm_g_scatterplot") # Requires Suggested packages @@ -297,6 +308,10 @@ tm_g_scatterplot <- function(label = "Scatterplot", checkmate::assert_scalar(table_dec) checkmate::assert_class(ggplot2_args, "ggplot2_args") + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "plot") + # End of assertions # Make UI args @@ -318,7 +333,13 @@ tm_g_scatterplot <- function(label = "Scatterplot", ui_args = args, server_args = c( data_extract_list, - list(plot_height = plot_height, plot_width = plot_width, table_dec = table_dec, ggplot2_args = ggplot2_args) + list( + plot_height = plot_height, + plot_width = plot_width, + table_dec = table_dec, + ggplot2_args = ggplot2_args, + decorators = decorators + ) ), datanames = teal.transform::get_extract_datanames(data_extract_list) ) @@ -413,6 +434,7 @@ ui_g_scatterplot <- function(id, ...) { is_single_dataset = is_single_dataset_value ) }, + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")), teal.widgets::panel_group( teal.widgets::panel_item( title = "Plot settings", @@ -491,7 +513,8 @@ srv_g_scatterplot <- function(id, plot_height, plot_width, table_dec, - ggplot2_args) { + ggplot2_args, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -981,13 +1004,19 @@ srv_g_scatterplot <- function(id, ) } - plot_call <- substitute(expr = p <- plot_call, env = list(plot_call = plot_call)) + plot_call <- substitute(expr = plot <- plot_call, env = list(plot_call = plot_call)) - teal.code::eval_code(plot_q, plot_call) %>% - teal.code::eval_code(quote(print(p))) + teal.code::eval_code(plot_q, plot_call) }) - plot_r <- reactive(output_q()[["p"]]) + decorated_output_plot_q <- srv_decorate_teal_data( + id = "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = print(plot) + ) + + plot_r <- reactive(req(decorated_output_plot_q())[["plot"]]) # Insert the plot into a plot_with_settings module from teal.widgets pws <- teal.widgets::plot_with_settings_srv( @@ -1028,7 +1057,7 @@ srv_g_scatterplot <- function(id, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_plot_q()))), title = "R Code for scatterplot" ) @@ -1047,7 +1076,7 @@ srv_g_scatterplot <- function(id, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_plot_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_g_scatterplotmatrix.R b/R/tm_g_scatterplotmatrix.R index 70f5d4b7e..ae1be8198 100644 --- a/R/tm_g_scatterplotmatrix.R +++ b/R/tm_g_scatterplotmatrix.R @@ -15,9 +15,18 @@ #' Specifies plotting variables from an incoming dataset with filtering and selecting. In case of #' `data_extract_spec` use `select_spec(..., ordered = TRUE)` if plot elements should be #' rendered according to selection order. +#' @param decorators `r roxygen_decorators_param("tm_g_scatterplotmatrix")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_g_scatterplotmatrix`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `plot` (`trellis` - output of `lattice::splom`) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -168,7 +177,8 @@ tm_g_scatterplotmatrix <- function(label = "Scatterplot Matrix", plot_height = c(600, 200, 2000), plot_width = NULL, pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_g_scatterplotmatrix") # Requires Suggested packages @@ -193,6 +203,9 @@ tm_g_scatterplotmatrix <- function(label = "Scatterplot Matrix", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "plot") # End of assertions # Make UI args @@ -203,7 +216,12 @@ tm_g_scatterplotmatrix <- function(label = "Scatterplot Matrix", server = srv_g_scatterplotmatrix, ui = ui_g_scatterplotmatrix, ui_args = args, - server_args = list(variables = variables, plot_height = plot_height, plot_width = plot_width), + server_args = list( + variables = variables, + plot_height = plot_height, + plot_width = plot_width, + decorators = decorators + ), datanames = teal.transform::get_extract_datanames(variables) ) attr(ans, "teal_bookmarkable") <- TRUE @@ -234,6 +252,7 @@ ui_g_scatterplotmatrix <- function(id, ...) { is_single_dataset = is_single_dataset_value ), tags$hr(), + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")), teal.widgets::panel_group( teal.widgets::panel_item( title = "Plot settings", @@ -267,7 +286,14 @@ ui_g_scatterplotmatrix <- function(id, ...) { } # Server function for the scatterplot matrix module -srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variables, plot_height, plot_width) { +srv_g_scatterplotmatrix <- function(id, + data, + reporter, + filter_panel_api, + variables, + plot_height, + plot_width, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -364,7 +390,7 @@ srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variab qenv, substitute( expr = { - g <- lattice::splom( + plot <- lattice::splom( ANL, varnames = varnames_value, panel = function(x, y, ...) { @@ -388,7 +414,6 @@ srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variab alpha = alpha_value, cex = cex_value ) - print(g) }, env = list( varnames_value = varnames, @@ -407,8 +432,13 @@ srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variab qenv, substitute( expr = { - g <- lattice::splom(ANL, varnames = varnames_value, pch = 16, alpha = alpha_value, cex = cex_value) - g + plot <- lattice::splom( + ANL, + varnames = varnames_value, + pch = 16, + alpha = alpha_value, + cex = cex_value + ) }, env = list(varnames_value = varnames, alpha_value = alpha, cex_value = cex) ) @@ -417,7 +447,14 @@ srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variab qenv }) - plot_r <- reactive(output_q()[["g"]]) + decorated_output_q <- srv_decorate_teal_data( + id = "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = print(plot) + ) + + plot_r <- reactive(req(decorated_output_q())[["plot"]]) # Insert the plot into a plot_with_settings module pws <- teal.widgets::plot_with_settings_srv( @@ -451,7 +488,7 @@ srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variab teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_q()))), title = "Show R Code for Scatterplotmatrix" ) @@ -470,7 +507,7 @@ srv_g_scatterplotmatrix <- function(id, data, reporter, filter_panel_api, variab card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_missing_data.R b/R/tm_missing_data.R index d57c616bd..f3309c802 100644 --- a/R/tm_missing_data.R +++ b/R/tm_missing_data.R @@ -10,13 +10,43 @@ #' @param parent_dataname (`character(1)`) Specifies the parent dataset name. Default is `ADSL` for `CDISC` data. #' If provided and exists, enables additional analysis "by subject". For non-`CDISC` data, this parameter can be #' ignored. +# nolint start: line_length. #' @param ggtheme (`character`) optional, specifies the default `ggplot2` theme for plots. Defaults to `classic`. -#' -#' @templateVar ggnames "Summary Obs", "Summary Patients", "Combinations Main", "Combinations Hist", "By Subject" -#' @template ggplot2_args_multi +#' @param ggplot2_args `r roxygen_ggplot2_args_param("Summary Obs", "Summary Patients", "Combinations Main", "Combinations Hist", "By Subject")` +# nolint end: line_length. +#' @param decorators `r roxygen_decorators_param("tm_missing_data")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_missing_data`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `summary_plot` (`grob` created with [ggplot2::ggplotGrob()]) +#' - `combination_plot` (`grob` created with [ggplot2::ggplotGrob()]) +#' - `by_subject_plot` (`ggplot2`) +#' - `table` ([DT::datatable()]) +#' +#' Decorators can be applied to all outputs or only to specific objects using a +#' named list of `teal_transform_module` objects. +#' The `"default"` name is reserved for decorators that are applied to all outputs. +#' See code snippet below: +#' +#' ``` +#' tm_missing_data( +#' ..., # arguments for module +#' decorators = list( +#' default = list(teal_transform_module(...)), # applied to all outputs +#' summary_plot = list(teal_transform_module(...)), # applied only to `summary_plot` output +#' combination_plot = list(teal_transform_module(...)) # applied only to `combination_plot` output +#' by_subject_plot = list(teal_transform_module(...)) # applied only to `by_subject_plot` output +#' table = list(teal_transform_module(...)) # applied only to `table` output +#' ) +#' ) +#' ``` +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -87,7 +117,8 @@ tm_missing_data <- function(label = "Missing data", "Combinations Main" = teal.widgets::ggplot2_args(labs = list(title = NULL)) ), pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_missing_data") # Requires Suggested packages @@ -121,14 +152,22 @@ tm_missing_data <- function(label = "Missing data", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + available_decorators <- c("summary_plot", "combination_plot", "by_subject_plot", "summary_table") + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, names = available_decorators) # End of assertions ans <- module( label, server = srv_page_missing_data, server_args = list( - parent_dataname = parent_dataname, plot_height = plot_height, - plot_width = plot_width, ggplot2_args = ggplot2_args, ggtheme = ggtheme + parent_dataname = parent_dataname, + plot_height = plot_height, + plot_width = plot_width, + ggplot2_args = ggplot2_args, + ggtheme = ggtheme, + decorators = decorators ), ui = ui_page_missing_data, datanames = "all", @@ -165,7 +204,7 @@ ui_page_missing_data <- function(id, pre_output = NULL, post_output = NULL) { # Server function for the missing data module (all datasets) srv_page_missing_data <- function(id, data, reporter, filter_panel_api, parent_dataname, - plot_height, plot_width, ggplot2_args, ggtheme) { + plot_height, plot_width, ggplot2_args, ggtheme, decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") moduleServer(id, function(input, output, session) { @@ -215,7 +254,8 @@ srv_page_missing_data <- function(id, data, reporter, filter_panel_api, parent_d id = ns(x), summary_per_patient = if_subject_plot, ggtheme = ggtheme, - datanames = datanames + datanames = datanames, + decorators = decorators ) ) } @@ -248,7 +288,8 @@ srv_page_missing_data <- function(id, data, reporter, filter_panel_api, parent_d parent_dataname = parent_dataname, plot_height = plot_height, plot_width = plot_width, - ggplot2_args = ggplot2_args + ggplot2_args = ggplot2_args, + decorators = decorators ) } ) @@ -326,7 +367,7 @@ ui_missing_data <- function(id, by_subject_plot = FALSE) { } # UI encoding for the missing data module (all datasets) -encoding_missing_data <- function(id, summary_per_patient = FALSE, ggtheme, datanames) { +encoding_missing_data <- function(id, summary_per_patient = FALSE, ggtheme, datanames, decorators) { ns <- NS(id) tagList( @@ -381,25 +422,30 @@ encoding_missing_data <- function(id, summary_per_patient = FALSE, ggtheme, data ), value = FALSE ) - } + }, + ui_decorate_teal_data(ns("dec_summary_plot"), decorators = select_decorators(decorators, "summary_plot")) ), conditionalPanel( is_tab_active_js(ns("summary_type"), "Combinations"), - uiOutput(ns("cutoff")) + uiOutput(ns("cutoff")), + ui_decorate_teal_data(ns("dec_combination_plot"), decorators = select_decorators(decorators, "combination_plot")) + ), + conditionalPanel( + is_tab_active_js(ns("summary_type"), "Grouped by Subject"), + ui_decorate_teal_data(ns("dec_by_subject_plot"), decorators = select_decorators(decorators, "by_subject_plot")) ), conditionalPanel( is_tab_active_js(ns("summary_type"), "By Variable Levels"), - tagList( - uiOutput(ns("group_by_var_ui")), - uiOutput(ns("group_by_vals_ui")), - radioButtons( - ns("count_type"), - label = "Display missing as", - choices = c("counts", "proportions"), - selected = "counts", - inline = TRUE - ) - ) + uiOutput(ns("group_by_var_ui")), + uiOutput(ns("group_by_vals_ui")), + radioButtons( + ns("count_type"), + label = "Display missing as", + choices = c("counts", "proportions"), + selected = "counts", + inline = TRUE + ), + ui_decorate_teal_data(ns("dec_summary_table"), decorators = select_decorators(decorators, "summary_table")) ), teal.widgets::panel_item( title = "Plot settings", @@ -415,8 +461,16 @@ encoding_missing_data <- function(id, summary_per_patient = FALSE, ggtheme, data } # Server function for the missing data (single dataset) -srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, parent_dataname, - plot_height, plot_width, ggplot2_args) { +srv_missing_data <- function(id, + data, + reporter, + filter_panel_api, + dataname, + parent_dataname, + plot_height, + plot_width, + ggplot2_args, + decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -462,7 +516,6 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par iv }) - data_parent_keys <- reactive({ if (length(parent_dataname) > 0 && parent_dataname %in% names(data())) { keys <- teal.data::join_keys(data())[[dataname]] @@ -553,6 +606,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ) }) + # Keep encoding panel up-to-date output$variables <- renderUI({ choices <- split(x = vars_summary()$key, f = vars_summary()$label, drop = TRUE) %>% rev() selected <- choices <- unname(unlist(choices)) @@ -631,7 +685,6 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par prev_group_by_var(input$group_by_var) # set current group_by_var validate(need(length(choices) < 100, "Please select group-by variable with fewer than 100 unique values")) - teal.widgets::optionalSelectInput( ns("group_by_vals"), label = "Filter levels", @@ -642,12 +695,47 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ) }) + combination_cutoff_q <- reactive({ + req(common_code_q()) + teal.code::eval_code( + common_code_q(), + quote( + combination_cutoff <- ANL %>% + dplyr::mutate_all(is.na) %>% + dplyr::group_by_all() %>% + dplyr::tally() %>% + dplyr::ungroup() + ) + ) + }) + + output$cutoff <- renderUI({ + x <- combination_cutoff_q()[["combination_cutoff"]]$n + + # select 10-th from the top + n <- length(x) + idx <- max(1, n - 10) + prev_value <- isolate(input$combination_cutoff) + value <- if (is.null(prev_value) || prev_value > max(x) || prev_value < min(x)) { + sort(x, partial = idx)[idx] + } else { + prev_value + } + + teal.widgets::optionalSliderInputValMinMax( + ns("combination_cutoff"), + "Combination cut-off", + c(value, range(x)) + ) + }) + + # Prepare qenvs for output objects + summary_plot_q <- reactive({ req(input$summary_type == "Summary") # needed to trigger show r code update on tab change teal::validate_has_data(data_r(), 1) qenv <- common_code_q() - if (input$any_na) { new_col_name <- "**anyna**" qenv <- teal.code::eval_code( @@ -718,7 +806,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par qenv <- teal.code::eval_code( qenv, substitute( - p1 <- summary_plot_obs %>% + summary_plot_top <- summary_plot_obs %>% ggplot() + aes( x = factor(create_cols_labels(col), levels = x_levels), @@ -800,7 +888,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par qenv <- teal.code::eval_code( qenv, substitute( - p2 <- summary_plot_patients %>% + summary_plot_bottom <- summary_plot_patients %>% ggplot() + aes_( x = ~ factor(create_cols_labels(col), levels = x_levels), @@ -833,65 +921,22 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ggthemes = parsed_ggplot2_args$ggtheme ) ) - ) %>% - teal.code::eval_code( - quote({ - g1 <- ggplotGrob(p1) - g2 <- ggplotGrob(p2) - g <- gridExtra::gtable_cbind(g1, g2, size = "first") - g$heights <- grid::unit.pmax(g1$heights, g2$heights) - grid::grid.newpage() - }) - ) - } else { - qenv <- teal.code::eval_code( - qenv, - quote({ - g <- ggplotGrob(p1) - grid::grid.newpage() - }) ) } - teal.code::eval_code( - qenv, - quote(grid::grid.draw(g)) - ) - }) - - summary_plot_r <- reactive(summary_plot_q()[["g"]]) - - combination_cutoff_q <- reactive({ - req(common_code_q()) - teal.code::eval_code( - common_code_q(), - quote( - combination_cutoff <- ANL %>% - dplyr::mutate_all(is.na) %>% - dplyr::group_by_all() %>% - dplyr::tally() %>% - dplyr::ungroup() - ) - ) - }) - - output$cutoff <- renderUI({ - x <- combination_cutoff_q()[["combination_cutoff"]]$n - - # select 10-th from the top - n <- length(x) - idx <- max(1, n - 10) - prev_value <- isolate(input$combination_cutoff) - value <- `if`( - is.null(prev_value) || prev_value > max(x) || prev_value < min(x), - sort(x, partial = idx)[idx], prev_value - ) - - teal.widgets::optionalSliderInputValMinMax( - ns("combination_cutoff"), - "Combination cut-off", - c(value, range(x)) - ) + if (isTRUE(input$if_patients_plot)) { + within(qenv, { + g1 <- ggplotGrob(summary_plot_top) + g2 <- ggplotGrob(summary_plot_bottom) + summary_plot <- gridExtra::gtable_cbind(g1, g2, size = "first") + summary_plot$heights <- grid::unit.pmax(g1$heights, g2$heights) + }) + } else { + within(qenv, { + g1 <- ggplotGrob(summary_plot_top) + summary_plot <- g1 + }) + } }) combination_plot_q <- reactive({ @@ -972,11 +1017,11 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ggtheme = input$ggtheme ) - teal.code::eval_code( + qenv <- teal.code::eval_code( qenv, substitute( expr = { - p1 <- data_combination_plot_cutoff %>% + combination_plot_top <- data_combination_plot_cutoff %>% dplyr::select(id, n) %>% dplyr::distinct() %>% ggplot(aes(x = id, y = n)) + @@ -994,7 +1039,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par graph_number_rows <- length(unique(data_combination_plot_cutoff$id)) graph_number_cols <- nrow(data_combination_plot_cutoff) / graph_number_rows - p2 <- data_combination_plot_cutoff %>% ggplot() + + combination_plot_bottom <- data_combination_plot_cutoff %>% ggplot() + aes(x = create_cols_labels(key), y = id - 0.5, fill = value) + geom_tile(alpha = 0.85, height = 0.95) + scale_fill_manual( @@ -1008,14 +1053,6 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par labs2 + ggthemes2 + themes2 - - g1 <- ggplotGrob(p1) - g2 <- ggplotGrob(p2) - - g <- gridExtra::gtable_rbind(g1, g2, size = "last") - g$heights[7] <- grid::unit(0.2, "null") # rescale to get the bar chart smaller - grid::grid.newpage() - grid::grid.draw(g) }, env = list( labs1 = parsed_ggplot2_args1$labs, @@ -1027,9 +1064,15 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ) ) ) - }) - combination_plot_r <- reactive(combination_plot_q()[["g"]]) + within(qenv, { + g1 <- ggplotGrob(combination_plot_top) + g2 <- ggplotGrob(combination_plot_bottom) + + combination_plot <- gridExtra::gtable_rbind(g1, g2, size = "last") + combination_plot$heights[7] <- grid::unit(0.2, "null") # rescale to get the bar chart smaller + }) + }) summary_table_q <- reactive({ req( @@ -1067,11 +1110,9 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par function(x) round(sum(is.na(x)) / length(x), 4) } - qenv <- common_code_q() - - if (!is.null(group_var)) { - qenv <- teal.code::eval_code( - qenv, + qenv <- if (!is.null(group_var)) { + teal.code::eval_code( + common_code_q(), substitute( expr = { summary_data <- ANL %>% @@ -1093,8 +1134,8 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ) ) } else { - qenv <- teal.code::eval_code( - qenv, + teal.code::eval_code( + common_code_q(), substitute( expr = summary_data <- ANL %>% dplyr::summarise_all(summ_fn) %>% @@ -1108,11 +1149,9 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ) } - teal.code::eval_code(qenv, quote(summary_data)) + within(qenv, table <- DT::datatable(summary_data)) }) - summary_table_r <- reactive(summary_table_q()[["summary_data"]]) - by_subject_plot_q <- reactive({ # needed to trigger show r code update on tab change req(input$summary_type == "Grouped by Subject", common_code_q()) @@ -1188,7 +1227,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par teal.code::eval_code( substitute( expr = { - g <- ggplot(summary_plot_patients, aes( + by_subject_plot <- ggplot(summary_plot_patients, aes( x = factor(id, levels = order_subjects), y = factor(col, levels = ordered_columns[["column"]]), fill = isna @@ -1209,7 +1248,6 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par labs + ggthemes + themes - print(g) }, env = list( labs = parsed_ggplot2_args$labs, @@ -1220,21 +1258,73 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par ) }) - by_subject_plot_r <- reactive(by_subject_plot_q()[["g"]]) + # Decorated outputs - output$levels_table <- DT::renderDataTable( + # Summary_plot_q + decorated_summary_plot_q <- srv_decorate_teal_data( + id = "dec_summary_plot", + data = summary_plot_q, + decorators = select_decorators(decorators, "summary_plot"), expr = { - if (length(input$variables_select) == 0) { - # so that zeroRecords message gets printed - # using tibble as it supports weird column names, such as " " - tibble::tibble(` ` = logical(0)) - } else { - summary_table_r() - } - }, - options = list(language = list(zeroRecords = "No variable selected"), pageLength = input$levels_table_rows) + grid::grid.newpage() + grid::grid.draw(summary_plot) + } ) + decorated_combination_plot_q <- srv_decorate_teal_data( + id = "dec_combination_plot", + data = combination_plot_q, + decorators = select_decorators(decorators, "combination_plot"), + expr = { + grid::grid.newpage() + grid::grid.draw(combination_plot) + } + ) + + decorated_summary_table_q <- srv_decorate_teal_data( + id = "dec_summary_table", + data = summary_table_q, + decorators = select_decorators(decorators, "summary_table"), + expr = table + ) + + decorated_by_subject_plot_q <- srv_decorate_teal_data( + id = "dec_by_subject_plot", + data = by_subject_plot_q, + decorators = select_decorators(decorators, "by_subject_plot"), + expr = print(by_subject_plot) + ) + + # Plots & tables reactives + + summary_plot_r <- reactive({ + req(decorated_summary_plot_q())[["summary_plot"]] + }) + + combination_plot_r <- reactive({ + req(decorated_combination_plot_q())[["combination_plot"]] + }) + + summary_table_r <- reactive({ + req(decorated_summary_table_q()) + + if (length(input$variables_select) == 0) { + # so that zeroRecords message gets printed + # using tibble as it supports weird column names, such as " " + DT::datatable( + tibble::tibble(` ` = logical(0)), + options = list(language = list(zeroRecords = "No variable selected."), pageLength = input$levels_table_rows) + ) + } else { + decorated_summary_table_q()[["table"]] + } + }) + + by_subject_plot_r <- reactive({ + req(decorated_by_subject_plot_q()[["by_subject_plot"]]) + }) + + # Generate output pws1 <- teal.widgets::plot_with_settings_srv( id = "summary_plot", plot_r = summary_plot_r, @@ -1249,6 +1339,8 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par width = plot_width ) + output$levels_table <- DT::renderDataTable(summary_table_r()) + pws3 <- teal.widgets::plot_with_settings_srv( id = "by_subject_plot", plot_r = by_subject_plot_r, @@ -1256,23 +1348,22 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par width = plot_width ) - final_q <- reactive({ - req(input$summary_type) - sum_type <- input$summary_type + decorated_final_q <- reactive({ + sum_type <- req(input$summary_type) if (sum_type == "Summary") { - summary_plot_q() + decorated_summary_plot_q() } else if (sum_type == "Combinations") { - combination_plot_q() + decorated_combination_plot_q() } else if (sum_type == "By Variable Levels") { - summary_table_q() + decorated_summary_table_q() } else if (sum_type == "Grouped by Subject") { - by_subject_plot_q() + decorated_by_subject_plot_q() } }) teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(final_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_final_q()))), title = "Show R Code for Missing Data" ) @@ -1308,7 +1399,7 @@ srv_missing_data <- function(id, data, reporter, filter_panel_api, dataname, par card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(final_q())) + card$append_src(teal.code::get_code(req(decorated_final_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_outliers.R b/R/tm_outliers.R index dab983f2d..28473f6c9 100644 --- a/R/tm_outliers.R +++ b/R/tm_outliers.R @@ -11,17 +11,46 @@ #' Specifies variable(s) to be analyzed for outliers. #' @param categorical_var (`data_extract_spec` or `list` of multiple `data_extract_spec`) optional, #' specifies the categorical variable(s) to split the selected outlier variables on. -#' -#' @templateVar ggnames "Boxplot","Density Plot","Cumulative Distribution Plot" -#' @template ggplot2_args_multi +#' @param ggplot2_args `r roxygen_ggplot2_args_param("Boxplot", "Density Plot", "Cumulative Distribution Plot")` +#' @param decorators `r roxygen_decorators_param("tm_outliers")` #' #' @inherit shared_params return #' +#' @section Decorating `tm_outliers`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `box_plot` (`ggplot2`) +#' - `density_plot` (`ggplot2`) +#' - `cumulative_plot` (`ggplot2`) +#' - `table` ([DT::datatable()]) +#' +#' Decorators can be applied to all outputs or only to specific objects using a +#' named list of `teal_transform_module` objects. +#' The `"default"` name is reserved for decorators that are applied to all outputs. +#' See code snippet below: +#' +#' ``` +#' tm_outliers( +#' ..., # arguments for module +#' decorators = list( +#' default = list(teal_transform_module(...)), # applied to all outputs +#' box_plot = list(teal_transform_module(...)), # applied only to `box_plot` output +#' density_plot = list(teal_transform_module(...)) # applied only to `density_plot` output +#' cumulative_plot = list(teal_transform_module(...)) # applied only to `cumulative_plot` output +#' table = list(teal_transform_module(...)) # applied only to `table` output +#' ) +#' ) +#' ``` +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE #' {{ next_example }} #' @examples +#' #' # general data example #' data <- teal_data() #' data <- within(data, { @@ -71,6 +100,7 @@ #' interactive <- function() TRUE #' {{ next_example }} #' @examples +#' #' # CDISC data example #' data <- teal_data() #' data <- within(data, { @@ -81,6 +111,8 @@ #' fact_vars_adsl <- names(Filter(isTRUE, sapply(data[["ADSL"]], is.factor))) #' vars <- choices_selected(variable_choices(data[["ADSL"]], fact_vars_adsl)) #' +#' +#' #' app <- init( #' data = data, #' modules = modules( @@ -125,7 +157,8 @@ tm_outliers <- function(label = "Outliers Module", plot_height = c(600, 200, 2000), plot_width = NULL, pre_output = NULL, - post_output = NULL) { + post_output = NULL, + decorators = NULL) { message("Initializing tm_outliers") # Normalize the parameters @@ -162,6 +195,10 @@ tm_outliers <- function(label = "Outliers Module", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) + + available_decorators <- c("box_plot", "density_plot", "cumulative_plot", "table") + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, names = available_decorators) # End of assertions # Make UI args @@ -172,12 +209,16 @@ tm_outliers <- function(label = "Outliers Module", categorical_var = categorical_var ) + ans <- module( label = label, server = srv_outliers, server_args = c( data_extract_list, - list(plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args) + list( + plot_height = plot_height, plot_width = plot_width, ggplot2_args = ggplot2_args, + decorators = decorators + ) ), ui = ui_outliers, ui_args = args, @@ -300,6 +341,28 @@ ui_outliers <- function(id, ...) { uiOutput(ns("ui_outlier_help")) ) ), + conditionalPanel( + condition = paste0("input['", ns("tabs"), "'] == 'Boxplot'"), + ui_decorate_teal_data( + ns("d_box_plot"), + decorators = select_decorators(args$decorators, "box_plot") + ) + ), + conditionalPanel( + condition = paste0("input['", ns("tabs"), "'] == 'Density Plot'"), + ui_decorate_teal_data( + ns("d_density_plot"), + decorators = select_decorators(args$decorators, "density_plot") + ) + ), + conditionalPanel( + condition = paste0("input['", ns("tabs"), "'] == 'Cumulative Distribution Plot'"), + ui_decorate_teal_data( + ns("d_cumulative_plot"), + decorators = select_decorators(args$decorators, "cumulative_plot") + ) + ), + ui_decorate_teal_data(ns("d_table"), decorators = select_decorators(args$decorators, "table")), teal.widgets::panel_item( title = "Plot settings", selectInput( @@ -319,9 +382,10 @@ ui_outliers <- function(id, ...) { ) } +# Server function for the outliers module # Server function for the outliers module srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, - categorical_var, plot_height, plot_width, ggplot2_args) { + categorical_var, plot_height, plot_width, ggplot2_args, decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -561,7 +625,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, ) ) - if (length(categorical_var) > 0) { + qenv <- if (length(categorical_var) > 0) { qenv <- teal.code::eval_code( qenv, substitute( @@ -617,7 +681,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, ) } - qenv <- teal.code::eval_code( + teal.code::eval_code( qenv, substitute( expr = { @@ -645,7 +709,6 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, tidyr::pivot_longer(-categorical_var_name) %>% tidyr::pivot_wider(names_from = categorical_var, values_from = value) %>% tibble::column_to_rownames("name") - summary_table }, env = list( categorical_var = categorical_var, @@ -653,8 +716,22 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, ) ) ) + } else { + within(qenv, summary_table <- data.frame()) } + # Datatable is generated in qenv to allow for output decoration + qenv <- within(qenv, { + table <- DT::datatable( + summary_table, + options = list( + dom = "t", + autoWidth = TRUE, + columnDefs = list(list(width = "200px", targets = "_all")) + ) + ) + }) + if (length(categorical_var) > 0 && nrow(qenv[["ANL_OUTLIER"]]) > 0) { shinyjs::show("order_by_outlier") } else { @@ -664,26 +741,8 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, qenv }) - output$summary_table <- DT::renderDataTable( - expr = { - if (iv_r()$is_valid()) { - categorical_var <- as.vector(merged$anl_input_r()$columns_source$categorical_var) - if (!is.null(categorical_var)) { - DT::datatable( - common_code_q()[["summary_table"]], - options = list( - dom = "t", - autoWidth = TRUE, - columnDefs = list(list(width = "200px", targets = "_all")) - ) - ) - } - } - } - ) - # boxplot/violinplot # nolint commented_code - boxplot_q <- reactive({ + box_plot_q <- reactive({ req(common_code_q()) ANL <- common_code_q()[["ANL"]] ANL_OUTLIER <- common_code_q()[["ANL_OUTLIER"]] @@ -761,7 +820,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, teal.code::eval_code( common_code_q(), substitute( - expr = g <- plot_call + + expr = box_plot <- plot_call + scale_color_manual(values = c("TRUE" = "red", "FALSE" = "black")) + labs + ggthemes + themes, env = list( @@ -771,8 +830,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, themes = parsed_ggplot2_args$theme ) ) - ) %>% - teal.code::eval_code(quote(print(g))) + ) }) # density plot @@ -823,7 +881,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, teal.code::eval_code( common_code_q(), substitute( - expr = g <- plot_call + labs + ggthemes + themes, + expr = density_plot <- plot_call + labs + ggthemes + themes, env = list( plot_call = plot_call, labs = parsed_ggplot2_args$labs, @@ -831,8 +889,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, ggthemes = parsed_ggplot2_args$ggtheme ) ) - ) %>% - teal.code::eval_code(quote(print(g))) + ) }) # Cumulative distribution plot @@ -925,7 +982,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, teal.code::eval_code( qenv, substitute( - expr = g <- plot_call + + expr = cumulative_plot <- plot_call + geom_point(data = outlier_points, aes(x = outlier_var_name, y = y, color = is_outlier_selected)) + scale_color_manual(values = c("TRUE" = "red", "FALSE" = "black")) + labs + ggthemes + themes, @@ -937,40 +994,63 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, ggthemes = parsed_ggplot2_args$ggtheme ) ) - ) %>% - teal.code::eval_code(quote(print(g))) + ) }) - final_q <- reactive({ - req(input$tabs) - tab_type <- input$tabs - result_q <- if (tab_type == "Boxplot") { - boxplot_q() - } else if (tab_type == "Density Plot") { - density_plot_q() - } else if (tab_type == "Cumulative Distribution Plot") { - cumulative_plot_q() - } - # used to display table when running show-r-code code - # added after the plots so that a change in selected columns doesn't affect - # brush selection. - teal.code::eval_code( - result_q, - substitute( - expr = { - columns_index <- union( - setdiff(names(ANL_OUTLIER), c("is_outlier_selected", "order")), - table_columns - ) - ANL_OUTLIER_EXTENDED[ANL_OUTLIER_EXTENDED$is_outlier_selected, columns_index] - }, - env = list( - table_columns = input$table_ui_columns - ) - ) + current_tab_r <- reactive({ + switch(req(input$tabs), + "Boxplot" = "box_plot", + "Density Plot" = "density_plot", + "Cumulative Distribution Plot" = "cumulative_plot" ) }) + decorated_q <- mapply( + function(obj_name, q) { + srv_decorate_teal_data( + id = sprintf("d_%s", obj_name), + data = q, + decorators = select_decorators(decorators, obj_name), + expr = reactive({ + substitute( + expr = { + columns_index <- union( + setdiff(names(ANL_OUTLIER), c("is_outlier_selected", "order")), + table_columns + ) + ANL_OUTLIER_EXTENDED[ANL_OUTLIER_EXTENDED$is_outlier_selected, columns_index] + print(.plot) + }, + env = list(table_columns = input$table_ui_columns, .plot = as.name(obj_name)) + ) + }), + expr_is_reactive = TRUE + ) + }, + rlang::set_names(c("box_plot", "density_plot", "cumulative_plot")), + c(box_plot_q, density_plot_q, cumulative_plot_q) + ) + + decorated_final_q_no_table <- reactive(decorated_q[[req(current_tab_r())]]()) + + decorated_final_q <- srv_decorate_teal_data( + "d_table", + data = decorated_final_q_no_table, + decorators = select_decorators(decorators, "table"), + expr = table + ) + + output$summary_table <- DT::renderDataTable( + expr = { + if (iv_r()$is_valid()) { + categorical_var <- as.vector(merged$anl_input_r()$columns_source$categorical_var) + if (!is.null(categorical_var)) { + decorated_final_q()[["table"]] + } + } + } + ) + # slider text output$ui_outlier_help <- renderUI({ req(input$method) @@ -1019,22 +1099,22 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, } }) - boxplot_r <- reactive({ + box_plot_r <- reactive({ teal::validate_inputs(iv_r()) - boxplot_q()[["g"]] + req(decorated_q$box_plot())[["box_plot"]] }) density_plot_r <- reactive({ teal::validate_inputs(iv_r()) - density_plot_q()[["g"]] + req(decorated_q$density_plot())[["density_plot"]] }) cumulative_plot_r <- reactive({ teal::validate_inputs(iv_r()) - cumulative_plot_q()[["g"]] + req(decorated_q$cumulative_plot())[["cumulative_plot"]] }) box_pws <- teal.widgets::plot_with_settings_srv( id = "box_plot", - plot_r = boxplot_r, + plot_r = box_plot_r, height = plot_height, width = plot_width, brushing = TRUE @@ -1080,16 +1160,20 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, ANL_OUTLIER_EXTENDED <- common_code_q()[["ANL_OUTLIER_EXTENDED"]] ANL <- common_code_q()[["ANL"]] - plot_brush <- if (tab == "Boxplot") { - boxplot_r() - box_pws$brush() - } else if (tab == "Density Plot") { - density_plot_r() - density_pws$brush() - } else if (tab == "Cumulative Distribution Plot") { - cumulative_plot_r() - cum_density_pws$brush() - } + plot_brush <- switch(current_tab_r(), + box_plot = { + box_plot_r() + box_pws$brush() + }, + density_plot = { + density_plot_r() + density_pws$brush() + }, + cumulative_plot = { + cumulative_plot_r() + cum_density_pws$brush() + } + ) # removing unused column ASAP ANL_OUTLIER$order <- ANL$order <- NULL @@ -1217,7 +1301,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(final_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_final_q()))), title = "Show R Code for Outlier" ) @@ -1239,7 +1323,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, } card$append_text("Plot", "header3") if (tab_type == "Boxplot") { - card$append_plot(boxplot_r(), dim = box_pws$dim()) + card$append_plot(box_plot_r(), dim = box_pws$dim()) } else if (tab_type == "Density Plot") { card$append_plot(density_plot_r(), dim = density_pws$dim()) } else if (tab_type == "Cumulative Distribution Plot") { @@ -1249,7 +1333,7 @@ srv_outliers <- function(id, data, reporter, filter_panel_api, outlier_var, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(final_q())) + card$append_src(teal.code::get_code(req(decorated_final_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/tm_t_crosstable.R b/R/tm_t_crosstable.R index 47d84bcfd..5c8621fc3 100644 --- a/R/tm_t_crosstable.R +++ b/R/tm_t_crosstable.R @@ -19,12 +19,21 @@ #' @param show_total (`logical(1)`) #' Indicates whether to show total column. #' Defaults to `TRUE`. +#' @param decorators `r roxygen_decorators_param("tm_t_crosstable")` #' #' @note For more examples, please see the vignette "Using cross table" via #' `vignette("using-cross-table", package = "teal.modules.general")`. #' #' @inherit shared_params return #' +#' @section Decorating `tm_t_crosstable`: +#' +#' This module generates the following objects, which can be modified in place using decorators: +#' - `table` (`ElementaryTable` - output of `rtables::build_table`) +#' +#' For additional details and examples of decorators, refer to the vignette +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' #' @examplesShinylive #' library(teal.modules.general) #' interactive <- function() TRUE @@ -134,7 +143,8 @@ tm_t_crosstable <- function(label = "Cross Table", show_total = TRUE, pre_output = NULL, post_output = NULL, - basic_table_args = teal.widgets::basic_table_args()) { + basic_table_args = teal.widgets::basic_table_args(), + decorators = NULL) { message("Initializing tm_t_crosstable") # Requires Suggested packages @@ -158,6 +168,9 @@ tm_t_crosstable <- function(label = "Cross Table", checkmate::assert_multi_class(pre_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_multi_class(post_output, c("shiny.tag", "shiny.tag.list", "html"), null.ok = TRUE) checkmate::assert_class(basic_table_args, classes = "basic_table_args") + + decorators <- normalize_decorators(decorators) + assert_decorators(decorators, null.ok = TRUE, "plot") # End of assertions # Make UI args @@ -167,7 +180,8 @@ tm_t_crosstable <- function(label = "Cross Table", label = label, x = x, y = y, - basic_table_args = basic_table_args + basic_table_args = basic_table_args, + decorators = decorators ) ans <- module( @@ -184,6 +198,7 @@ tm_t_crosstable <- function(label = "Cross Table", # UI function for the cross-table module ui_t_crosstable <- function(id, x, y, show_percentage, show_total, pre_output, post_output, ...) { + args <- list(...) ns <- NS(id) is_single_dataset <- teal.transform::is_single_dataset(x, y) @@ -221,7 +236,8 @@ ui_t_crosstable <- function(id, x, y, show_percentage, show_total, pre_output, p checkboxInput(ns("show_percentage"), "Show column percentage", value = show_percentage), checkboxInput(ns("show_total"), "Show total column", value = show_total) ) - ) + ), + ui_decorate_teal_data(ns("decorator"), decorators = select_decorators(args$decorators, "plot")) ), forms = tagList( teal.widgets::verbatim_popup_ui(ns("rcode"), "Show R code") @@ -232,7 +248,7 @@ ui_t_crosstable <- function(id, x, y, show_percentage, show_total, pre_output, p } # Server function for the cross-table module -srv_t_crosstable <- function(id, data, reporter, filter_panel_api, label, x, y, basic_table_args) { +srv_t_crosstable <- function(id, data, reporter, filter_panel_api, label, x, y, basic_table_args, decorators) { with_reporter <- !missing(reporter) && inherits(reporter, "Reporter") with_filter <- !missing(filter_panel_api) && inherits(filter_panel_api, "FilterPanelAPI") checkmate::assert_class(data, "reactive") @@ -351,7 +367,7 @@ srv_t_crosstable <- function(id, data, reporter, filter_panel_api, label, x, y, teal.code::eval_code( substitute( expr = { - lyt <- basic_tables %>% + table <- basic_tables %>% split_call %>% # styler: off rtables::add_colcounts() %>% tern::analyze_vars( @@ -387,19 +403,25 @@ srv_t_crosstable <- function(id, data, reporter, filter_panel_api, label, x, y, substitute( expr = { ANL <- tern::df_explicit_na(ANL) - tbl <- rtables::build_table(lyt = lyt, df = ANL[order(ANL[[y_name]]), ]) - tbl + table <- rtables::build_table(lyt = table, df = ANL[order(ANL[[y_name]]), ]) }, env = list(y_name = y_name) ) ) }) - output$title <- renderText(output_q()[["title"]]) + decorated_output_q <- srv_decorate_teal_data( + id = "decorator", + data = output_q, + decorators = select_decorators(decorators, "plot"), + expr = table + ) + + output$title <- renderText(req(decorated_output_q())[["title"]]) table_r <- reactive({ req(iv_r()$is_valid()) - output_q()[["tbl"]] + req(decorated_output_q())[["table"]] }) teal.widgets::table_with_settings_srv( @@ -409,7 +431,7 @@ srv_t_crosstable <- function(id, data, reporter, filter_panel_api, label, x, y, teal.widgets::verbatim_popup_srv( id = "rcode", - verbatim_content = reactive(teal.code::get_code(output_q())), + verbatim_content = reactive(teal.code::get_code(req(decorated_output_q()))), title = "Show R Code for Cross-Table" ) @@ -428,7 +450,7 @@ srv_t_crosstable <- function(id, data, reporter, filter_panel_api, label, x, y, card$append_text("Comment", "header3") card$append_text(comment) } - card$append_src(teal.code::get_code(output_q())) + card$append_src(teal.code::get_code(req(decorated_output_q()))) card } teal.reporter::simple_reporter_srv("simple_reporter", reporter = reporter, card_fun = card_fun) diff --git a/R/utils.R b/R/utils.R index 5876abcab..dcb0ebd17 100644 --- a/R/utils.R +++ b/R/utils.R @@ -25,7 +25,6 @@ #' with text placed before the output to put the output into context. For example a title. #' @param post_output (`shiny.tag`) optional, text or UI element to be displayed after the module's output, #' adding context or further instructions. Elements like `shiny::helpText()` are useful. -#' #' @param alpha (`integer(1)` or `integer(3)`) optional, specifies point opacity. #' - When the length of `alpha` is one: the plot points will have a fixed opacity. #' - When the length of `alpha` is three: the plot points opacity are dynamically adjusted based on @@ -278,3 +277,134 @@ assert_single_selection <- function(x, } invisible(TRUE) } + +#' Wrappers around `srv_transform_teal_data` that allows to decorate the data +#' @inheritParams teal::srv_transform_teal_data +#' @param expr (`expression` or `reactive`) to evaluate on the output of the decoration. +#' When an expression it must be inline code. See [within()] +#' Default is `NULL` which won't evaluate any appending code. +#' @param expr_is_reactive (`logical(1)`) whether `expr` is a reactive expression +#' that skips defusing the argument. +#' @details +#' `srv_decorate_teal_data` is a wrapper around `srv_transform_teal_data` that +#' allows to decorate the data with additional expressions. +#' When original `teal_data` object is in error state, it will show that error +#' first. +#' +#' @keywords internal +srv_decorate_teal_data <- function(id, data, decorators, expr, expr_is_reactive = FALSE) { + checkmate::assert_class(data, classes = "reactive") + checkmate::assert_list(decorators, "teal_transform_module") + checkmate::assert_flag(expr_is_reactive) + + missing_expr <- missing(expr) + if (!missing_expr && !expr_is_reactive) { + expr <- rlang::enexpr(expr) + } + + moduleServer(id, function(input, output, session) { + decorated_output <- srv_transform_teal_data("inner", data = data, transformators = decorators) + + reactive({ + # ensure original errors are displayed and `eval_code` is never executed with NULL + req(data(), decorated_output()) + if (missing_expr) { + decorated_output() + } else if (expr_is_reactive) { + teal.code::eval_code(decorated_output(), expr()) + } else { + teal.code::eval_code(decorated_output(), expr) + } + }) + }) +} + +#' @rdname srv_decorate_teal_data +#' @details +#' `ui_decorate_teal_data` is a wrapper around `ui_transform_teal_data`. +#' @keywords internal +ui_decorate_teal_data <- function(id, decorators, ...) { + teal::ui_transform_teal_data(NS(id, "inner"), transformators = decorators, ...) +} + +#' Internal function to check if decorators is a valid object +#' @noRd +check_decorators <- function(x, names = NULL, null.ok = FALSE) { # nolint: object_name. + checkmate::qassert(null.ok, "B1") + + check_message <- checkmate::check_list( + x, + null.ok = null.ok, + names = "named" + ) + + if (!is.null(names)) { + check_message <- if (isTRUE(check_message)) { + out_message <- checkmate::check_names(names(x), subset.of = c("default", names)) + # see https://github.com/insightsengineering/teal.logger/issues/101 + if (isTRUE(out_message)) { + out_message + } else { + gsub("\\{", "(", gsub("\\}", ")", out_message)) + } + } else { + check_message + } + } + + if (!isTRUE(check_message)) { + return(check_message) + } + + valid_elements <- vapply( + x, + checkmate::test_list, + types = "teal_transform_module", + null.ok = TRUE, + FUN.VALUE = logical(1L) + ) + + if (all(valid_elements)) { + return(TRUE) + } + + "May only contain the type 'teal_transform_module' or a named list of 'teal_transform_module'." +} + +#' Internal assertion on decorators +#' @noRd +assert_decorators <- checkmate::makeAssertionFunction(check_decorators) + +#' Subset decorators based on the scope +#' +#' `default` is a protected decorator name that is always included in the output, +#' if it exists +#' +#' @param scope (`character`) a character vector of decorator names to include. +#' @param decorators (named `list`) of list decorators to subset. +#' +#' @return A flat list with all decorators to include. +#' It can be an empty list if none of the scope exists in `decorators` argument. +#' @keywords internal +select_decorators <- function(decorators, scope) { + checkmate::assert_character(scope, null.ok = TRUE) + scope <- intersect(union("default", scope), names(decorators)) + c(list(), unlist(decorators[scope], recursive = FALSE)) +} + +#' Convert flat list of `teal_transform_module` to named lists +#' +#' @param decorators (list of `teal_transform_module`) to normalize. +#' @return A named list of lists with `teal_transform_module` objects. +#' @keywords internal +normalize_decorators <- function(decorators) { + if (checkmate::test_list(decorators, "teal_transform_module", null.ok = TRUE)) { + if (checkmate::test_names(names(decorators))) { + lapply(decorators, list) + } else { + list(default = decorators) + } + } else { + decorators + } +} diff --git a/man-roxygen/ggplot2_args_multi.R b/man-roxygen/ggplot2_args_multi.R deleted file mode 100644 index dc0497942..000000000 --- a/man-roxygen/ggplot2_args_multi.R +++ /dev/null @@ -1,7 +0,0 @@ -#' @param ggplot2_args (`ggplot2_args`) optional, object created by [`teal.widgets::ggplot2_args()`] -#' with settings for all the plots or named list of `ggplot2_args` objects for plot-specific settings. -#' The argument is merged with options variable `teal.ggplot2_args` and default module setup. -#' -#' List names should match the following: `c("default", <%=ggnames%>)`. -#' -#' For more details see the vignette: `vignette("custom-ggplot2-arguments", package = "teal.widgets")`. diff --git a/man/normalize_decorators.Rd b/man/normalize_decorators.Rd new file mode 100644 index 000000000..257342765 --- /dev/null +++ b/man/normalize_decorators.Rd @@ -0,0 +1,18 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/utils.R +\name{normalize_decorators} +\alias{normalize_decorators} +\title{Convert flat list of \code{teal_transform_module} to named lists} +\usage{ +normalize_decorators(decorators) +} +\arguments{ +\item{decorators}{(list of \code{teal_transform_module}) to normalize.} +} +\value{ +A named list of lists with \code{teal_transform_module} objects. +} +\description{ +Convert flat list of \code{teal_transform_module} to named lists +} +\keyword{internal} diff --git a/man/select_decorators.Rd b/man/select_decorators.Rd new file mode 100644 index 000000000..2c7403dca --- /dev/null +++ b/man/select_decorators.Rd @@ -0,0 +1,22 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/utils.R +\name{select_decorators} +\alias{select_decorators} +\title{Subset decorators based on the scope} +\usage{ +select_decorators(decorators, scope) +} +\arguments{ +\item{decorators}{(named \code{list}) of list decorators to subset.} + +\item{scope}{(\code{character}) a character vector of decorator names to include.} +} +\value{ +A flat list with all decorators to include. +It can be an empty list if none of the scope exists in \code{decorators} argument. +} +\description{ +\code{default} is a protected decorator name that is always included in the output, +if it exists +} +\keyword{internal} diff --git a/man/srv_decorate_teal_data.Rd b/man/srv_decorate_teal_data.Rd new file mode 100644 index 000000000..18201124e --- /dev/null +++ b/man/srv_decorate_teal_data.Rd @@ -0,0 +1,35 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/utils.R +\name{srv_decorate_teal_data} +\alias{srv_decorate_teal_data} +\alias{ui_decorate_teal_data} +\title{Wrappers around \code{srv_transform_teal_data} that allows to decorate the data} +\usage{ +srv_decorate_teal_data(id, data, decorators, expr, expr_is_reactive = FALSE) + +ui_decorate_teal_data(id, decorators, ...) +} +\arguments{ +\item{id}{(\code{character(1)}) Module id} + +\item{data}{(\verb{reactive teal_data})} + +\item{expr}{(\code{expression} or \code{reactive}) to evaluate on the output of the decoration. +When an expression it must be inline code. See \code{\link[=within]{within()}} +Default is \code{NULL} which won't evaluate any appending code.} + +\item{expr_is_reactive}{(\code{logical(1)}) whether \code{expr} is a reactive expression +that skips defusing the argument.} +} +\description{ +Wrappers around \code{srv_transform_teal_data} that allows to decorate the data +} +\details{ +\code{srv_decorate_teal_data} is a wrapper around \code{srv_transform_teal_data} that +allows to decorate the data with additional expressions. +When original \code{teal_data} object is in error state, it will show that error +first. + +\code{ui_decorate_teal_data} is a wrapper around \code{ui_transform_teal_data}. +} +\keyword{internal} diff --git a/man/tm_a_pca.Rd b/man/tm_a_pca.Rd index ac4f506ba..101f5d6e6 100644 --- a/man/tm_a_pca.Rd +++ b/man/tm_a_pca.Rd @@ -16,7 +16,8 @@ tm_a_pca( alpha = c(1, 0, 1), size = c(2, 1, 8), pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -34,9 +35,7 @@ specifying columns used to compute PCA.} \item{ggtheme}{(\code{character}) optional, \code{ggplot2} theme to be used by default. Defaults to \code{"gray"}.} -\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} -with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. -The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. +\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. List names should match the following: \code{c("default", "Elbow plot", "Circle plot", "Biplot", "Eigenvector plot")}. @@ -72,6 +71,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_a_pca}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -82,7 +87,40 @@ ways of visualizing the outcomes, including elbow plot, circle plot, biplot, and Additionally, it enables dynamic customization of plot aesthetics, such as opacity, size, and font size, through UI inputs. } +\section{Decorating \code{tm_a_pca}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{elbow_plot} (\code{ggplot2}) +\item \code{circle_plot} (\code{ggplot2}) +\item \code{biplot} (\code{ggplot2}) +\item \code{eigenvector_plot} (\code{ggplot2}) +} + +Decorators can be applied to all outputs or only to specific objects using a +named list of \code{teal_transform_module} objects. +The \code{"default"} name is reserved for decorators that are applied to all outputs. +See code snippet below: + +\if{html}{\out{
}}\preformatted{tm_a_pca( + ..., # arguments for module + decorators = list( + default = list(teal_transform_module(...)), # applied to all outputs + elbow_plot = list(teal_transform_module(...)), # applied only to `elbow_plot` output + circle_plot = list(teal_transform_module(...)) # applied only to `circle_plot` output + biplot = list(teal_transform_module(...)) # applied only to `biplot` output + eigenvector_plot = list(teal_transform_module(...)) # applied only to `eigenvector_plot` output + ) +) +}\if{html}{\out{
}} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ + # general data example data <- teal_data() data <- within(data, { @@ -113,6 +151,7 @@ if (interactive()) { shinyApp(app$ui, app$server) } + # CDISC data example data <- teal_data() data <- within(data, { @@ -148,14 +187,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlY4AygCCjNUtonG6fYPDpKJKAL5dSmioYyp57BX+GboAvJtBuBt8QiKju0fCYuvdlbqkMIlQiagEqRs3ugpgAAoAwv2fB2u7xiOz2jzCpGYGkSolQcAIV3ewIy0HgoM+EyGYmmALeSNEcBEGlBBKJpBhcIReKRugI+SItAIYlBWhYtCg9BEiTpDKZokRNKRKVBKWAwAxAyxI0+AF0ZaUqWAALKCRj8GQAj5gfqiURQYSkTUYxj0KAQL5EVBGsBYNBwT5dQU3OSAp2VUnw8j8UGKlVqjV4LU6vUGh2ut0wA20SJ6XYOFzU53hmkmWjUciMUEAOUcABlc4nHc6Nl0urQTLp2CoM+pNDobLZytdRIUIKx+uh2EsACT1Uo9gmMHSdOZKMCzGVAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokrcQAxLqkQ11XfxQpFC6cAAesKgiSoHBBsZc1AD6sVA2MUEhRroA7rSkABYq7Km4uiBKurqMcACOgrQ17L6ipMTURIyKEFWOAMoAgow1raLxuv1DI6SiSgC+3UpoqOMq+eyVAZm6ALxbwbibfEIiY3vHwmIbPVW6pDBJUEmoBGmbt7oKYAAKAMIDX0ONw+sV2+ye4VIzA0SVEqDgBGuHxBmWg8DBX0mwzEM0B72RojgIg0YMJxNIsPhiPxyN0BAKRFoBDEYK0LFoUHoIiS9MZzNESNpyNSYNSwGAmMG2NGXwAurKytSwABZQSMfgyQGfMADUSiKDCUhazGMehQCDfIioY1gLBoOBfbpC25yIHOqpkhHkfhgpWq9WavDa3X6w2Ot3umCG2hRPR7BwuGkuiO0ky0ajkRhggByjgAMnmk06XZtut1aCZdOwVJn1JodDZbBUbqIihBWAN0OxlgASBplXuExg6LrzJRgOayoA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkoGlUAQsn9kboFGAAApeQYEsFIvGJGGZNLRUjMDRpUSoOAERF4ym5B56YEEqajMm4jmiOAiDQwkVi47M1nsjl4gglJYEMQwrQsWhQegiE5K2gqzZC+V1TLU3LAYB8kYCsAvF5VNkEgBCAFksABpLAARjJ+LAgwA4q48H7nAB5AI+ACaBP6xuRcnJ8bqktZ5H4MMdYFdHu9vr5QdjSeTMCOtDiPPsTlcFI5iaNyJMtGo5EYMIAco5RgLa3U4wm-v1+rQTLp2CpW+pNDobLYakjRGUIKxBuh2GhUAASFpVDebkWMHR9WZKMAzF5AA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokrcQAxLoDCAEQCSAMreuvxQpFC6cAAesKgiSmERBsZc1AD6SVA2ieGRRroA7rSkABYq7Fm4uiBKurqMcACOgrSN7BBipMTURIyKEPUAgr6BADIpDSPjSgC+AwBWRCrpANZwrKKVebYF-HAmUMKk6QT8tKIE6Usr65vA0PBbWXIAuu5oqJMqJex1oXldABeAERXD-PhCESiYG6SHCMR-Qb1XSkGDpKDpVAEbL-FG6BRgAAK3iGhPByPxSVhWXSMVIzA06VEqDgBCR+KpeUeehBhOmY3JeM5ojgIg0sNF4pOLLZHM5+IIpWWBDEsK0LFoUHoIlOytoqq2woV9SyNLywGA-NGgrAr1e1XZhIAQgBZLAAaSwAEZyQSwEMAOKuPD+5wAeUCvgAmoSBiaUXIKQn6lK2eR+LCnWA3Z6fX7+cG48mUzBjrR4rz7E5XJTOUnjSiTLRqORGLCAHKOMaCuv1eOJ-4DAa0Ey6dgqNvqTQ6Gy2WrI0TlCCsIbodifAAkrWqW9FjB0-TmSjAs1eQA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_a_regression.Rd b/man/tm_a_regression.Rd index 85b3c578d..cd4621cc6 100644 --- a/man/tm_a_regression.Rd +++ b/man/tm_a_regression.Rd @@ -18,7 +18,8 @@ tm_a_regression( post_output = NULL, default_plot_type = 1, default_outlier_label = "USUBJID", - label_segment_threshold = c(0.5, 0, 10) + label_segment_threshold = c(0.5, 0, 10), + decorators = NULL ) } \arguments{ @@ -53,11 +54,9 @@ vector of \code{value}, \code{min}, and \code{max}. \item{ggtheme}{(\code{character}) optional, \code{ggplot2} theme to be used by default. Defaults to \code{"gray"}.} -\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} -with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. -The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. +\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. -List names should match the following: \verb{c("default", "Response vs Regressor", "Residuals vs Fitted", "Scale-Location", "Cook's distance", "Residuals vs Leverage"", "Cook's dist vs Leverage")}. +List names should match the following: \code{c("default", "Response vs Regressor", "Residuals vs Fitted", "Scale-Location", "Cook's distance", "Residuals vs Leverage", "Cook's dist vs Leverage")}. For more details see the vignette: \code{vignette("custom-ggplot2-arguments", package = "teal.widgets")}.} @@ -96,6 +95,12 @@ It can take the following forms: It takes the form of \code{c(value, min, max)} and it is passed to the \code{value_min_max} argument in \code{teal.widgets::optionalSliderInputValMinMax}. }} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_a_regression}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -110,7 +115,20 @@ visualize residuals, and identify outliers. For more examples, please see the vignette "Using regression plots" via \code{vignette("using-regression-plots", package = "teal.modules.general")}. } +\section{Decorating \code{tm_a_regression}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{plot} (\code{ggplot2}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ + # general data example data <- teal_data() data <- within(data, { @@ -194,14 +212,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QNKAL5dSmiowyp57BX+GboAvMtBuEt8QiKia7o7wmKL3ZW6pDCJUInVEtWiolYQp+fn1FD0cH7rCmBYcHuYieJD+WzObweqBIoj06xSiTCpGYGkSolQcAIrze5xS0HgBz+ozBSxxulhIg0BwpmNIaIxWNJZN0Hy+P10fwAyt9abotCxaJ8RIgSRDmQR8kRaAQxISwIJUEEANZwUXM840jRwfhyhXK1V4JlkmDCTSROG6ABiAEEADKc5zg9WVEy0ULag4OFxG85dMlyJ04u4PUQdA4IpEounozHYsl42AWomDNXMzWkak81Exxlisms75y7mUjP8xiC+h7EWGvM4iVSmX7dZlisiRL16UnFLAYDJsZgAC6A9KjMIJAIYI5YDs1UC8DIfzkAZ9b3THt+Y4sqfVJuoZpEnqcjpX51d7p16xt9tctcqfpx97vSy6XVoJl07BU5Cj2jgNls5RnKIhQQKw1roOwMwACT1KU0GwowOidBMShgOMA5AA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokrcQAxLqkQ11XfxQpFC6cAAesKgiSoHBBsZc1AD6sVA2MUEhRroA7rSkABYq7Km4uiBKurqMcACOgrQ17L6ipMTURIyKEFUAwgDyAEzxugODSgC+3UpoqCMq+eyVAZm6ALwrwbjLfEIiouu6u8JiSz1VuqQwSVBJNRI1oqJWEGcXF9RQ9HD+GwpgWDgDzEzxI-2253ej1QJFEeg2qSS4VIzA0SVEqDgBDe7wuqWg8EO-zG4OWuN0cJEGkOlKxpHRmOxZPJuk+31+un+AGUfnTdFoWLQviJEKTISyCAUiLQCGIiWBBKhggBrOBilkXWkaOD8eWKlVqvDM8kwYSaKLw3QAMQAggAZLnOCEaqomWhhHWHBwuY0XbrkuTO3H3R6iTqHRHI1H0jFYnHk-GwS3Eobqlla0g03lo2NM8Xktk-eU8qmZgWMIX0faio353GS6Wyg4bcuVkRJBsy06pYDAFPjMAAXUHZSZhBIBHBnLAdhqQXgZH+ckDvveGc9f3HFjTGtN1HNIi9Tidq4ubo9uo2todrjrVX9uIf9+W3W6tBMunYKnI0e0cBstgVOcohFBArA2ug7CzAAJA0ZQwXCjA6F0kxKGAEyDkAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkoGkGhIGqJRFYIIjkcjqFB6HBqDCFGAsHBsWI8SQqWCkUScagSKI9MDMmloqRmBo0qJUHACISicjMg8uboqVNRky-hLdJyRBoYarRcdhaLxcq6iSyRTgVSAuStbotCxaKSRIhFSz9QQSksCGJKWAAEIAWSwAGksABGB365GajRwfgen3+oMh0Owo60OIygBig1GAWczITploUUjMIcLiVEv6yrkOYlWJxol6MJ5fIF2pFYtLRKlsBlcpGCrw7bD5vVwPDLd1A6JhvJHrNatIluttrE9v7juVztd7uBVsYNvoIhOLtobqeuWAwB70zALxeVTbYEGAHFXHhZWAswANJlvrCDLwvuRKwnQc50LE0H2feNQxgJMUyLJxs2AuoTHzMDdHTTNXDXZFyzLUtcP6fpaBMXR2BUchm20OAbFsGokVEMoIFYQZ0HYNBUAAEhaKp2I4zlGB0PpZiUMAZheIA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_data_table.Rd b/man/tm_data_table.Rd index 3d105c6c0..ca1db1ea6 100644 --- a/man/tm_data_table.Rd +++ b/man/tm_data_table.Rd @@ -13,7 +13,8 @@ tm_data_table( scrollX = TRUE), server_rendering = FALSE, pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -46,6 +47,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_data_table}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -61,6 +68,18 @@ Configure the \code{DT.TOJSON_ARGS} option via \code{options(DT.TOJSON_ARGS = list(na = "string"))} before running the module. Note though that sorting of numeric columns with \code{NA}/\code{Inf} will be lexicographic not numerical. } +\section{Decorating \code{tm_data_table}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{table} (\code{\link[DT:datatable]{DT::datatable()}}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ # general data example data <- teal_data() @@ -110,13 +129,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQ20onG6vaJKAL5dSmioAyp57BX+GboAvAtBuPN8QiL9K5vCYnPdlbqkMMkZiUH0IofHx1ostFDXYomicCIacPzLunQttzuxyGvwIczAAGU4KhuBgADIUCQFBR4XQoqEwngAdVo-GRqJRAAU4EEeAiIEj8ijSkSSbCcXiqQTIag4ARaGIUV0gbo5Osjnc8YkWBIdn8+qR2AQ0JoSL8UQBJLAKiH2Z4iXQAYRlVggXPmlW5vKUXVoJl07BU5GYlh0Nls5SOokKEFYAEF0OxJgASeqlH3vRg6TqjJRgEYAXSAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYBlcmlwvQRIjkcitCxaFBsWI0qI4CINHB+DC6KJSOwpuNgQRfmAAnZHD4AJp+HwKPC6AWOAKOABCACk+QKqgLRZLpYK5X47M5FbKwIMAOKuJXs5wADQFcjkYKReP4xxYEmhwLpDIIaE0JBhAqZ9mJIm8TqsEGNfzq-UDSn6tBMunYKnIzEsOhsthqSNEZQgrEG6HYaFQABIWlUs9nyYwdH1ZkowDMXkA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_file_viewer.Rd b/man/tm_file_viewer.Rd index cf3b5cdd3..a1617b9db 100644 --- a/man/tm_file_viewer.Rd +++ b/man/tm_file_viewer.Rd @@ -54,8 +54,8 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXSSfTLCME2Z4dgBGRQgAX1KlNFRslRj2dJyvXQBeJuTGviERUVbdLuExBogMjNIYfxNaEX8tWjhImWHR0ZVUQVJ-VE9YvrpRUmWV0ZMian4ZPtFWA7gYPOm4BrBRWFQZqZ6FPF1tggBrKBSPrfPy8ASDcRSCBqajfOS4RrHX4QCRXG7ke6fJ7fV4wd5wSaPUQAejxBKJIgwqFR3xSf0BwLaoLg3HB3TEkmksnhiJGyN0pAAHqR0bcsY9nuSPsSyW8ZVThaQ6b91Iy9MywGCBj0uTCeWAEUjjoJGNQQWBYqRSKhRIgSSSTB5JEQtI7ZfxGIIJKT1vR9rE4PwSQAFIiMLz+uCGAAiRAIgngZEMADFwzBPIYAMqoOAEWhTAieKwQcSofgmb7GjKlFa13SlUoF3TsFTkZiWHQ2WxpfmieIQVgAQXQ7GqABJBLQUhPRDIdIxSmUlGAygBdIA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_front_page.Rd b/man/tm_front_page.Rd index 35b1c3e9d..7da5acb05 100644 --- a/man/tm_front_page.Rd +++ b/man/tm_front_page.Rd @@ -85,8 +85,8 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqX8opKAeNdqAfQ8vG3dPbyNdAHdaUgALFXYgqFxdECVdXUY4AEdBWiz2CDFSYmoiRkUIDIBBABEAZQAZH0y6pvTdT1JGdjbGlIUweC8kwdsIulFSdkHqwTjywd0AXl1BgDlnertdLhhBgbAk-1EiQUYCOCXVwdFWMli4TQJdUbBKgF9KgCsiFX8ANZwViiRJhcbGfhwExQYSkfwEfi0UQEfy-f5AkHAaDwUFJOQAXTcZCg9BE-gAjC0khgTMx4OwAJIQExEFa6AgzMDVA5rMAAITGKTscAAHqR2ZzZrzBoL3pUvGS4P4AEzUsK0+lwdgAAwAwkRqIIYFUKTrJVy9TKwLUhbp9YbjVUVebVpyAKwYd0pABsGB9chSDqNJt0AGZXRyuTy8Hy5XIFaTyWH1V5NbBtczWRbBq5Y4MAGJ2kXinNgADi1oAEmNKkpFeSVKh5i1JtMOoM7Em9BTrrtu5TcB2wF2lboVX2G8qVUOqnzRyJw5OB2GlHXoOgWioYjM50l2UlZxk+EIRKJ2SfhGJdxkMqQYP46SR4agoFIb7eMo8oFDGP5yKWbofp+GSDIyMCoOUXhkLoKisowMCeFYEB9mBEoEFAVQSGyjxZBgBwdCBfIAPJxDIsEsuUiGaCQqFgHqmG6Nhui4XA+FgIRt6Bpxd7dueqxTv4TbzEeIE-kiNHQAEXgSPxuhVnYACyjTRvwEnIdw8lKc05S6KI8QQKw-ayUxOEyHo+hMAAfEKPGmEQRCkBAjliGWAAadHIrsjymPkUz2Y5znkNaACasHnmRelwMQED8AFTkubZc6fvpRCRP4ww-mE7IOC4nGVBk3Fzt+v7sjJogACSxBSXL1LAqCLtU6B0BhklJRkrIuYwZVvpVqDRs1tCtch8UyEl660CYujsCo5DMJYOg2LYaRzvpKisE1-VoKgFV5Ck20VaIMg6BUSgfEoYAfASQA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_association.Rd b/man/tm_g_association.Rd index c239f6051..4ca13c313 100644 --- a/man/tm_g_association.Rd +++ b/man/tm_g_association.Rd @@ -17,7 +17,8 @@ tm_g_association( "void"), pre_output = NULL, post_output = NULL, - ggplot2_args = teal.widgets::ggplot2_args() + ggplot2_args = teal.widgets::ggplot2_args(), + decorators = NULL ) } \arguments{ @@ -50,13 +51,17 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} -\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} -with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. -The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. +\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. List names should match the following: \code{c("default", "Bivariate1", "Bivariate2")}. For more details see the vignette: \code{vignette("custom-ggplot2-arguments", package = "teal.widgets")}.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_g_association}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -70,6 +75,18 @@ It supports configuring the appearance of the plots, including themes and whethe For more examples, please see the vignette "Using association plot" via \code{vignette("using-association-plot", package = "teal.modules.general")}. } +\section{Decorating \code{tm_g_association}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{plot} (\code{grob} created with \code{\link[ggplot2:ggplotGrob]{ggplot2::ggplotGrob()}}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ # general data example data <- teal_data() @@ -159,13 +176,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHG6-QMVpuqkHaLD0PCi7ABitNTkjOy0og4upVpokRyjpZsYJpMdpe0StATc7ACMADJyL129g8BnGtMAusPU+2ohw+XymjFEP1KUHEBHyLEmMi6AF8ukp9sMVHl2OMUroALz+DK4cZ8IQiGYE0nCMTY7qVXSkGCJCSJaGiIgEWiBKwQWn0+nVEz4wlBRJhUjMDSJUSoOAEPn8+kpOZ6AkKMCjdXEumK3SiOAiDTC-WG0jS2Xy8a6yoA+gG4XqgDKBrlpF0e0YXPoIkQWqt1thRBuYmFHq9IkSgeDCxSwGA6s1YB+kN0lrAAAUAWQtbp1XZWLKc3nqoF4NmwC9tdb6SbXXB+A6M1nSH6ddaTLRQvXhYsAIKPR2uNv8t6KuRVxUeikiqBi0ISybmuUK3XK2Cq3Mawat6u1o0EvdmmXL-26232tVgZ2m90scNiX14U+KqMEEMEsNQb1wSP5INvmMMjjBNtyTFM00zKBy1KPMCzgIswDsEtGQoFsK3HZ9+UPbtLyQuBS1Qndq10GBhE0SIN22ZwJ2rDsuwbAk+wHIdq1HEd-VHLouloIUNlUSVNB0GxbHKOlREKCBWF7dB2H2AASeooXQOT9UYHROiUJElDAJEfiAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkJGkoKJREQCLQwlYIIjkciGiYYZk0tFSMwNGlRKg4ARiSTkZkHnpgQowFNRtywUjWbpRHARBoYSKxccGUyWUK6tQoPRRTDuQFRUzSLotCx8fQRIh+X95boCCUlgQxDCdYw9SITubaJbNsaTSCoMBgNzedyXi8BW7kcy1c4ABr83TcrCDLyuPCRsBeADyjgAcg4AJoR71YACy2bAAQcgzsgwAjAWi9HSwAmAt+Ox2ABifPj3IAQrmsABpLB1sD9QNyANuyWauD8VVgaOxo2C+UmWhRCcwpuDUYBVzzkmD1nD111G3Q4GU6m06WM4Pbtm5DlTn14A-Isfi4Evi+yp8kxXK6hT9VStqupKlChqPteJJmhaVrAjadpwA60EuhBrKZJ63ojK2fojoGwaFmGBYznGVTcsmaaZgWgx5pWxalhWbaFrRgz9iRYANs2rasZ2PZ9tyu4mvuKF1O+K5cmA3G9ixX7IjARy0HEnL2E4zg4QuS6iboa4bluAlPvxui7v0-S0OS7AqOQ57aHANi2DUSKiGUECsIM6DsGgqAACQtFU7keSKjA6H0sxKGAMwvEAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_bivariate.Rd b/man/tm_g_bivariate.Rd index cce2711a0..177b714a1 100644 --- a/man/tm_g_bivariate.Rd +++ b/man/tm_g_bivariate.Rd @@ -25,7 +25,8 @@ tm_g_bivariate( ggtheme = c("gray", "bw", "linedraw", "light", "dark", "minimal", "classic", "void"), ggplot2_args = teal.widgets::ggplot2_args(), pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -100,6 +101,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_g_bivariate}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -115,6 +122,18 @@ This is a general module to visualize 1 & 2 dimensional data. For more examples, please see the vignette "Using bivariate plot" via \code{vignette("using-bivariate-plot", package = "teal.modules.general")}. } +\section{Decorating \code{tm_g_bivariate}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{plot} (\code{ggplot2}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ # general data example data <- teal_data() @@ -228,13 +247,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlQDCAPIATHH+GRgmzPDs-QNdAL5dSmiowyp57BUjsQC8m1C4G3xCIqK6O6QwiRKJ9NostIFw692VuqGnu4lhpMwaiaKocAITxeLxS0Hg7wUYGmUP2zxBojgIg070RyNIfwBQI2IMq1Cg9CRkLAAGUkYDSLotHcCSJELCcbiCPkiLQCGJ3tTGPd6CJEszWezRMUMsBgFCYWAALpSuRw3EvNEUuD8YnECwM+G4ky0UIq94AMQAggAZEmuLWVLoguWM1jvFKfULfdQY-6A4G4sGwPQ7CWDTUKpUonbBt1Yz0K-GEvx+0nklFcnl0wMK3QCtkcnZJ2lwfkszPClJi-0DKEy22WxUJ8iquOCVBBADWcFTCpgwk0kV9umNZuc8rTOr1dd7pvNjKtjMrIMYRGyiRM6jglJ2jq+P3DHsnu3BPdLber6NRNcx26reIJRLjZOPOd5cHpeB3lQzQs5NIf+cFYhFQRL0IBtKsqDkGNb6nGdisACh4gsOEFjv2O7Wi8M4vG0i7LquHwbq6Z7YlW3oQnGkqgUeFInui+GRri0bXroUK3hR94ps+F7pgW77Zp+fJvr+xbioBZbAWhYHoghUJ2NUgTwGQsEvPBo59hOVYoVOzxdF0tAmLo7AqOQm7aI8ci2OUzyiIUECsEa6DsEsAAk9SlA5iKMDonRKLMShgLMUpAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgbpSDA0hI0vRtCxaGE4L8BnVdFEYZk0tFSMwNGlRKg4ARMdjsZkHnpgQowFNRoywVjqaI4CINDDOdzjmSKVTqdjqFB6FyYYyAlyKaRdFpUeKRIhWX8RboCCUlgQxDDFYw0fQRCdtbRdU9csBgIzmYyXi85GyNXU+XK4PwpUyAOKuPDqkUmWhRD0wgBig1GAVc7Ox-WpToDrDxuQJUSJ6gF5MpAbqtNg9N0tpGLP9sddsp5wLdJMFOfLovFkoZYBl-IVSuNcFVZZdmrNFv1nZNWp1Yi24WtxemYAdiYbFf5oZb0YAGmqF7oYEdaHFCxGo85nS6gyHPcCD9Hc7p43Hj3VGEQCmkDrr5cD8YTiVmhdf8-AvTtXsRRrd9dFA0ls2FDUxQlagvTbOUO0NZVuw3PtR3NPVgQNI0RwHcdMinJkS3tR17xAytyHPIsmSwABZdCT2DZddEvGMNVvOp52pboX3UOAwM-dNv0g38G3-Qtp1LCjFyQ6sqLE+s+1g5taMQnlcNQntZOxTDBxw4c4FNMdLUnG0SJnOddLkjRWMZLwAHlHAAOQcABNJiNVPVj2OvLibz+fp+loExdHYFRyG-bQMTkWwaixUQyggVhBnQdg0FQAASFoqkyrLOUYHQ+lmJQwBmF4gA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_distribution.Rd b/man/tm_g_distribution.Rd index 0b7cae9be..91b880f29 100644 --- a/man/tm_g_distribution.Rd +++ b/man/tm_g_distribution.Rd @@ -16,7 +16,8 @@ tm_g_distribution( plot_height = c(600, 200, 2000), plot_width = NULL, pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -37,9 +38,7 @@ Defaults to density (\code{FALSE}).} \item{ggtheme}{(\code{character}) optional, \code{ggplot2} theme to be used by default. Defaults to \code{"gray"}.} -\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} -with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. -The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. +\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. List names should match the following: \code{c("default", "Histogram", "QQplot")}. @@ -64,6 +63,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, with text placed after the output to put the output into context. For example the \code{\link[shiny:helpText]{shiny::helpText()}} elements are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_g_distribution}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -73,6 +78,38 @@ Module is designed to explore the distribution of a single variable within a giv It offers several tools, such as histograms, Q-Q plots, and various statistical tests to visually and statistically analyze the variable's distribution. } +\section{Decorating \code{tm_g_distribution}}{ + + +This module generates the following objects, which can be modified in place using decorators:: +\itemize{ +\item \code{histogram_plot} (\code{ggplot2}) +\item \code{qq_plot} (\code{data.frame}) +\item \code{summary_table} (\code{data.frame}) +\item \code{test_table} (\code{data.frame}) +} + +Decorators can be applied to all outputs or only to specific objects using a +named list of \code{teal_transform_module} objects. +The \code{"default"} name is reserved for decorators that are applied to all outputs. +See code snippet below: + +\if{html}{\out{
}}\preformatted{tm_g_distribution( + ..., # arguments for module + decorators = list( + default = list(teal_transform_module(...)), # applied to all outputs + histogram_plot = list(teal_transform_module(...)), # applied only to `histogram_plot` output + qq_plot = list(teal_transform_module(...)) # applied only to `qq_plot` output + summary_table = list(teal_transform_module(...)) # applied only to `summary_table` output + test_table = list(teal_transform_module(...)) # applied only to `test_table` output + ) +) +}\if{html}{\out{
}} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ \dontshow{if (require("ggpmisc", quietly = TRUE) && require("ggpp", quietly = TRUE) && require("goftest", quietly = TRUE) && require("MASS", quietly = TRUE) && require("broom", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example @@ -148,13 +185,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLpSEGrUuvxQpFC6cAAesKgiSlc3BsZc1AD6b1A2r2utyMugA7rRSAALFTsP6REBKXS6HyhD7IxihJQAX0UECUaFQaJUEL8ECRf3KcMRuj4QhEonKdGapKRSNIMG+El+oVIGPogk01mprMuPO+WhYlKB3wevPUpG+olQcAILJFrL+0Hg5X8KNEEWF6tEcBEGnKxtNCqVKvYEoxUHoIm+BEhRFoBDEQz1-jkkX8AAVYtwMAAZCgSKE+w1I3Ei2O6XG42gmXTsFTkZiWHQ2WwIsm6UTQiCsUbodgEgAk3kileNjB0jFxWKUYCxAF0gA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6B6BFR3rHxSSkuGVk53nkBRCbkoqRF0aUJyQ6VupnZnrVwfmAAsgCCAMrjrSVxHRVpPdX9PoP+TEREMNMxs+VdaUoAxLoAwgAiAJLjJ7r8UKRQunAAHrCoIkp3DwbGXNQA+l8oDZPvdHkZdAB3WikAAWKnYQMiICUul0ozO4wAMj9shjsUoAL6KCAAKyIKn+AGs4KxRIiwbYIfw4CYoMJSP8CPxQgR-uTKTS6cBoPB6UC5ABdJRKLQsUQARlxBFhFIIYn+ojgIg0cH4fggaLljFoUHoIi5qto6vFYOAwH8+Kx-klksiBCGoywwyK-hOAHlHAA5BwATV9YHGzgAGv45HJcKjdFqdeR+OUg44sc6ICSlGhULiVDCDWigeUkUm+EIRKJytXhGJS2jdKQYP8JIDQqQTfRBJprEmW7du-9jRWwf8Xj31JzRKg4B6h8PbmDRXpko7Mc68MvhynF6RygeNJqF0vDSvhyq1WJysbTea4Jbb7aHvatwSwK73Z6AOKuHguj+AAQsMWAANJYAqcYJnuK4nmm5SgeBUEwbul5XmiMAcrQ7wbroABioxYlGiaYVhJi0M8erlMRpGuBRw4klecFMcmM4PGOLATlx07MKe86Ls2V5AuuyFgE6ETwWiVHUOQjDlHJClnsJMktsadbJJpCrkVhLY4fJeEiHsqTqSxK5sVeEiMEQgioNxinJECU7PDOgnniJK5ibABGfjuemUbQ8kyEpwUqUJF76Ua8r3vKunqdhuH4aZLjmfBFlohZJIkrQJi6OwKgKbO2iDPGugopeojwhArCjOg7AFgAJN4kTNVqjA6IwJKEkoYCEpKQA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_response.Rd b/man/tm_g_response.Rd index 4c34a0f6f..e5454501b 100644 --- a/man/tm_g_response.Rd +++ b/man/tm_g_response.Rd @@ -19,7 +19,8 @@ tm_g_response( ggtheme = c("gray", "bw", "linedraw", "light", "dark", "minimal", "classic", "void"), ggplot2_args = teal.widgets::ggplot2_args(), pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -80,6 +81,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_g_response}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -96,6 +103,18 @@ as frequency or density. For more examples, please see the vignette "Using response plot" via \code{vignette("using-response-plot", package = "teal.modules.general")}. } +\section{Decorating \code{tm_g_response}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{plot} (\code{ggplot2}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ # general data example data <- teal_data() @@ -184,13 +203,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6uoxwAI6CtNXsPqKkxNREjIoQlTCtLKJxur0E-RWmHbrsWroqugTsCoSs1Iuli1qiq7qLsFuLUiyLcrbl3ZVDfYyiwMBaALp3g1DiJuqkHezD-Tf3d12VAF8lACuko0KhBio8gszildABefwZXBjPhCEQDRFo4RiGHnXSkGCJCSJaqiVAkURwPH43TUKD0OB+RGLLBiCkQKm6AAK7VImzwY3xZI5XMRKUSYVIzA0iXJcHmQtpKWg8AR2zAXyuqyV+KpIg06v1CtIctQCpptPO9MZzI1AGUmSbdFoWLQGSJEDqzlbKgR8kRaAQxOrXYx3fQRIl-YHg6JihkbostQKHqVFUsVngNQdGEc5Cifb7jRo4Px1YsCMtvb7zjBhJpInpEQAxACCABl7c5C7XKiZaKEy+r213XEX8f9aQXdbpQuqJVKZab5YqJ+cVbBmxqUzXi07DYiSyvzWu+3SGUyK2BHQbSC63R64F7Bev8TGgyHEWGI1GP3GEyCJNNUuVM7nTBYwA2PYUBgfNez7Y9hxZKCBQQ2t62oRsRBHTtu3Q30ByHctWzw8daynSclSnLouloExJhUchl20aljjKMZREKCBWDbdB2HBAASepSiEqlGB0TpgSUMAATuIA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXUY4AEdBWgb2CDFSYmoiRkUIOoBBHwCAGWT64bGlAF9+gCsiFTSAazhWUQrc23z+OBMoYVI0gn5aUQI0xeW1jeBoeE3MuQBdN2h0CZVi9lqQ3N0AF5-uFcH8+EIRKIgboIcIxL8BnVdKQYGkJGkGqJUCRRHBEcjkdQoPQ4NQYQowFgxDiIHjdAAFHqkUSUsFIwlY2n04GZNLRUjMDRpbFwAgEwnIzIPPTAylTUZsv6S3R4kQaGFqsXHUXi5Uq3TE0nkuVgAJk7W6LQsWgkkSIJUcg0EEpLAhiGHWxi2+giE6u2jup65YDAeUjRVgF4vKp6sAAIQAslgANJYABMbN0lK8AHlHAA5BwATUpcjk7INyK1Gjg-ApCeTaczeH1KpgR1ocVlugAYoNRgFnJWq6ZaFE6zD+4PXE7Cf0VRW27oojC+QKhTrUGKJSrpbAe+Hpq259WLRrgTWtzvl4SjWSG+b1aQrTa7XAHSfR7oXW6PcCvR9P1f0DBFMlDI9I2jWNfjNZwAA0s0pLBBi8VwwHLEcqyvSdTRQtDHW-DtqE0bspwHIcsINExx1wvsKNnKsF0lZi6mY-p+loExdHYFRyE3bR8XLao-lEMoIFYQZ0HYNBUAAEhaKpZLkvFGB0PpZiUMAZheIA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_scatterplot.Rd b/man/tm_g_scatterplot.Rd index 5c1c306f7..4f90024f2 100644 --- a/man/tm_g_scatterplot.Rd +++ b/man/tm_g_scatterplot.Rd @@ -23,7 +23,8 @@ tm_g_scatterplot( pre_output = NULL, post_output = NULL, table_dec = 4, - ggplot2_args = teal.widgets::ggplot2_args() + ggplot2_args = teal.widgets::ggplot2_args(), + decorators = NULL ) } \arguments{ @@ -93,6 +94,12 @@ with settings for the module plot. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. For more details see the vignette: \code{vignette("custom-ggplot2-arguments", package = "teal.widgets")}} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_g_scatterplot}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -107,6 +114,18 @@ trend line additions, and dynamic adjustments of point opacity and size through For more examples, please see the vignette "Using scatterplot" via \code{vignette("using-scatterplot", package = "teal.modules.general")}. } +\section{Decorating \code{tm_g_scatterplot}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{plot} (\code{ggplot2}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ \dontshow{if (require("ggpmisc", quietly = TRUE) && require("ggExtra", quietly = TRUE) && require("colourpicker", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example @@ -280,13 +299,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLpSEGrUuvxQpFC6cIWwqCJK84sGxlzUAPpbUDabC0tGugDutKQAFirsR5EgSrrZno1w7NOipMStjEUEDeAGEAPIAJh2unBEKUAF8gUo0KhoSobn5gXMztUnq9dHwhCJRNVCcIxJi3m9SDB9hJ9mEFuQOq1SJSqW9qFB6HBZsl-ABlAhMmTrIikGG3IhdMQRfEcwq4s77FYldSkBmoOAEdkct5HaDwar+WFyrF63SiXnaiXJK0iDSa7W6i26Lk8vm6QXWjS6LQsWjckSIM2uqkEKUyknJf2MQP0ET7CPSggUo7AYAmyH+AC6OciOv8xAsZX8glQi16-jkclw8td9ptcH4xuaJbw9YtMGEmnWemSADEAIIAGQFzjr5tdJlohWb1WHY9cU45QIttc7uiG2MWKuKzEdoi1hZXVINsH7XrApo7p7ejd9dp9GqPzs3HPdvNbAuffoDQbgENbzDN5kyjapY3jRMwNTURHjODMszhMA8wLPw23CPAr3LSs4GrDc7ypB9yBbfkwBwqAq2AkDu2oXsRAXUdx0nEDTFnedByY5cwzXPUCItf4iEYfZ6G3I49zVQ9jxdDlzyNMibxYhtfyfB0X2k98qU-T1vTUv84wAoClLDGCxAg-8EzgJNI1gmTXXTTNr2zFD800jlCzAAAFLkyFLMA7FYLU-LsdwFngXysKLEhMMiMsK0ovCwF4njjOUtSON0AA5RwRxHVKux7Wg+0Ypd8r1Gc51I3RF3HTTkqpfi9VEWgAC8rNEpVd1VA91LfQi5MvJDQzSm1qmIp0T1Y7Tv1-SDDOGkybLMmMLOgpa4IcoaXLQqL21i8j4qomsyo5YiMri3CFtdWj6MvGqJzctjKpK2rCPqt5Go5RgiEufYTHUWJOqgCSeomuz9TOQ1Bqc5CTstFT4bUsHHumsifz0ubLKMx7TOjfSoKs3H4MWRCYdzfNdA87yoAi-aAqCyL-NCmkKFIfC4fvZ8Muy3KOYJQris40rHoqjL7rqzdPvDFo-oB20d2B7r1WR-rIYvVtFM04ixufFWpu5L80dm1bAKugT1vMgzLOslM0wQxyb1Qyn0Op2mr3pxK6eZ8K2aSqWLTOqqebyx6bqKhiheYkX2Kq8W3sl+teKBIFaBMXR2BUZl1W0L4a10F4sVEe4IFYId0HYFEABJvEiKurUYHRAQRJQwHhHMgA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBISqDC0ogT+uLpetHCk1Ky6ALz2Ts62AGTpuu7Rvv6BzgAepMwRUd6x8UkpLhlZOd55hETURIKMqLQEANYyZdGVCckOtUoAxLoAwgAiAJIAypO6-FCkULpwhbCoIkorawbGXNQA+vtQNnur60a6AO60pAAWKuznkSBKutmejXDsEDEpGIrUYigg3wAgtN5gAZQ7ZaFwpQAX3BACsiCoTr1WKI3tdbLd+HATFBhKQTgR+KECCdMdjcaJgNB4PjznIALpKJRoVAIlSPPwQ5bXarvL66PhCESiarS4RiYXfb6kGAnCQnMKrcgdVqkZUq77UKD0ODUar+eYEHUyHZEUhTJ5YghiCKSo2FcXXE6bErqSmiVBwAiGo3fc6svTJfxI2HukXh3Sic0hx3JFMiDRa4Ohj1J3Qms0WmNgeapjS6LQsWimkSIBMFlUEZ1dMTVauMWv0ERU1uu9nXYDAWMw+NgTmcyJ5sCQgDirjwun8ACEALJYADSWAAjGVVxvtwAmfxyOS4fNJzNpuD8S2zheNptSim0HbR3QAMUhsPmzgviYFiYtCFLe1Tfr+riAUa4JJuel66EMoprL6xTMNmQYhmG4aRrAH6jsieAId816VhmFaBrm2FJkW5r3uWWaOp23b1k+TYti67bJMxdZwH2nGDmsw4EeOk7Tn4D6LpEB5bru+5gOusknmAZ4Ac+yYUWBpaKdue5EdB4YwK+77gT+f5qc+wGgXeyQQX+xG6LB4bwQZIJEIwJz0Eh5yof6GFUQ5uHwPecZseGpHphpjE5lhDnGqadGlgxaZVjWvENvp6kcW2crcWlPZ8dlA7UQW5zCbOY7+GJcXNhJ85ScuCmHnJS4yce8lYJCkwNf4WDOHOswAPIAHJ6U5TYuepEVabow2OLCsIWU2RnUJoJm2WZ-41VZM12VBE0IZN4W0AAXnxXneihfroZRsUGRG1xRiFlWZQWEXVBFMV5vdKq0SWjXJZWPEFRlS0FkVXGpV2vH8TlBJCSOFWEWJugzvV8k6S1qk1dNNmNejr3LcZIimZBYNJjteN7Q540qkdRqMEQdwnGSrqRT510Bl9JUPWsT2lqFhPhRRH0UdzNV-fRIvA6xQtJhDuVQyxhX9kqZWI4LKMzpjynSWAnXdR1-VDaNp7029ml43NC3k4ZxMfntttGpTpP2T9tPfOb3wgiz6ixJdUC+Td4s-UF+FI+OTtRSl5HRZh33qZLSXS-lstR97quKzLKsCfDUDlZrU6oxJOsdV1PX68bI1jV7wuMTN1uLTVK1rSTG1k9tIG7ZtNOHfmTnguCtAmLo7AqLqAbaP8Z66J8IqiC8ECsJC6DsHyAAk3iRBvKaMDoYKokoYAopyQA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_g_scatterplotmatrix.Rd b/man/tm_g_scatterplotmatrix.Rd index ec2645a59..a0af16a82 100644 --- a/man/tm_g_scatterplotmatrix.Rd +++ b/man/tm_g_scatterplotmatrix.Rd @@ -10,7 +10,8 @@ tm_g_scatterplotmatrix( plot_height = c(600, 200, 2000), plot_width = NULL, pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -34,6 +35,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_g_scatterplotmatrix}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -47,6 +54,18 @@ providing the overview of correlations and distributions across selected data. For more examples, please see the vignette "Using scatterplot matrix" via \code{vignette("using-scatterplot-matrix", package = "teal.modules.general")}. } +\section{Decorating \code{tm_g_scatterplotmatrix}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{plot} (\code{trellis} - output of \code{lattice::splom}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ \dontshow{if (require("lattice", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example @@ -188,13 +207,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLpSEGrUuvyBULpwAB6wqCJK+aSFRrpc1AD6VVA2lQUGxgDutKQAFirszeEgSrq6xOakjFGiHXkFGCbM8H4QY2O0-AnjfmAAIq54uv4AYlhhx2AAknYX-s4AyndgAAq3R-4A4ucfYAByABlngAhQ7hfwAxzPACC7zkuFG6wkRB0jAg8DI2xM6lIREYq3W6wI7AATOEyboKQBGcm03Q0+nhBkk+GIwnUKD0ODUWaJYn+ACyJBYBF6rGeWDgqEE9DoBH8qUJrLW6w5EAkgigUga2JgtFiWJxeIJhJ2DIAzOFLbprdbqUyrUzlabdByuTztvywJ8ZDAoMp5b8ABLckQBiVEP0WUJgRXrZ3rVBEaUczQkT3sAAc1oAbAB2cI5gAM4QALAX6SX6QyqRWqQyixgc+EAJwJsYsOCFPnsc0AVgrfb7FqLDL7Rb7rep5oppZH5Kb4Wz7cy-FQGfNGFLC4rJIwNa34Ub1sbFMbFcbk90jYbW5X-Dg9FIGb3zIwdsPlMXX4-25-C7-PdfzjONRG4MQ5maRZljgE0Ni2RIqUQccERVMYJjINgGk2bYwJgcpYLZIldgOZ4zmeG5nkeZ43meb5nkBEEwUuSEYThVCXVEWgAC89ESFCiLGdxynUPikhcIiV1YLtGFwvFSHYPCCNJUci0QEkiw08IUN0YSORCbYHBcOQVx0CBBDEpSRHYL1RD9ahqGeeB+FoQQYGeDlGCkZ4SDobIFW0qs9NEwzkhXAh-RCBy4AQ3QrNg4kjOccITmhAEHhSQLwmCgzEiSlcvH9TRSDiRI0TxGB2B0qkiyrDTwqIURSF5XSIAqqqq0zOqixXVBGCIEwem2crGEqnStMrEClAAX1SAArIgVAaABrOBWFEQYClsWoFqW1b1pNXaIBWtbdgwqYZmec7pjEZ5NgCxEjpOjh-DAkRRGeN7bt+e7Yw43Qnv2s6iEmG6Pt+L7wfCL1fu2fxrtYbD+AVVJUiUNB11qFQehNZptiGRE+CEd7tiJ4QxDguoYAaCQGlECKghkcoiFIP0LuKSmxjdbk4bAB4GfIRhmefNnpmKMJBN0LQWFoTkScSOgms59ZmgaEophxOnUDgfk0JdeZqmgeBeeuy68ElwlRG5HXn0SK2RA0LWdeVl1udyRJ-Aea2NClmW5bERAJb1-Xxl6RaQha6Xpn9hpRXDinmmAYB4ZBzCzYAXXTlcQ-tm2YozfxOygZ4JDXZ4HyfB7g-1mBhE0AjQpcf6Q7GPEH3cWKkublvBuKfPElS9LXGrpULd0bOVYKNXig1x3RG13WW4N-1YDE17wKhsexkG6hBaxfVBadxel9dTkeY9vnvefKPZdlOBA-NkfTSjlqU9BxHfu7kO49oCPtml6gFlY5h1-gnAoSd17vX8JncEhBU5TA-sjP6W91i5w0P3HY-hSK-HIr8SivxqK-For8eivxGK-FBM8VivxYRVxProWuu9aANzyskFBE9LZX1wlfI+LtTRu15l7B218-Z31EA-L++sf5-0SDfGO0iwHVAgWASG0D07Q12IVMgPRxS-GIE1KGlw+oDR6CjSRnEr4YK9Fo4qujYH6Oas8Yxg1SB0JPow+uIhG7JRQa3Rg7cMFd18aYWgfdYqDwyuwsecZR56ymhAVItATC6HYCoQWOJtCwRMroEYKpRD9AgKwaE6B2AYwACTeHCOUq2jBUSpGmkoMA0105AA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CmlCkmgRw-ri6XrRwpNSsugC89k7OihAAxLoAwgAiAJIAypm6-IFQunAAHrCoIkolpGVGulzUAPr1UDZ1pQbGAO60pAAWKuwd4SBKuroAgtn5ADK9uoxzi1Oz2Vj5y6tb+UoAvqkAVkQqrQDWcKyiY6W2TfxwJlDCpK0E-LSiBK1nF2ut2A0Hgdw6cgAukolGhUMsVIM-BBph0EsVSrgNnwhCJROiccIxMjptNSDBWhJWr9AuRGDUiOTAoxaBUSaTptQoPQ4NR0f58gRaTIGaRdDBmaywhsOVoWLRuXj0XRRKR2RzUaVWpVSMwNNTUHACOqNZqGqC9Il-GsFtKUabSaJeUaxYknSJ9aJDcaZQ7OdzefywPlnRpdHKWYqxIg7X6OQQhucQvjEhGFfQRJ9E7Rk-cGsBgNb5rawJDIXIsfa47p3S64Px0T6wDMAOKuPC6fxYGaZdvhAXOAAa-grvr9MHetBqlqSLkr1emREYz3cDcSDjnY4dJlZ9fRADEZgt8q4qw7Un7R2eOR1tRVdeoPl6jSbTR0LUG5ttY3Gd9Q6eif50gaL5bqaXI8nyVrBqGYoUPwqDnGQogxngYEahGKa6E2AAKMzdgAsjkYSds2ABqBS5HYI7zguCZJmI6JytQghwFmDHgqUBZFt+paQuEuH4TMRHZCR1oUfkVE0dhfhgHhhFieRlHUWAchXguNawXu0G5AAcmRzh2LoxjOLp2S6AA8vuuh6dkjiZHYuQWbpP7VhO-5TiI6Ibqe1bqXGtZhm6sEgT614OhBgbQSGHpimmUYoa5cb0TmjGpvKUbsalnH5oWzb7P4Zb+dWgXkGuMnWm2ikzGRR7VdkACaNHoRy7maNO3nJLR1ZLiu2mzs43W-ru5WHsevlxhe55blN0xTakqS0CYujsCodKPtocA2LYkz2qIIwQKwMzoOwcIACTeOE51OowOiMKkhxKGAhyQkAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_missing_data.Rd b/man/tm_missing_data.Rd index a758b5a85..c6cd75b96 100644 --- a/man/tm_missing_data.Rd +++ b/man/tm_missing_data.Rd @@ -14,7 +14,8 @@ tm_missing_data( list(caption = NULL)), `Combinations Main` = teal.widgets::ggplot2_args(labs = list(title = NULL))), pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -33,9 +34,7 @@ ignored.} \item{ggtheme}{(\code{character}) optional, specifies the default \code{ggplot2} theme for plots. Defaults to \code{classic}.} -\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} -with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. -The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. +\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. List names should match the following: \code{c("default", "Summary Obs", "Summary Patients", "Combinations Main", "Combinations Hist", "By Subject")}. @@ -47,6 +46,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_missing_data}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -57,6 +62,38 @@ gain insights into the completeness of their data. It is useful for clinical data analysis within the context of \code{CDISC} standards and adaptable for general data analysis purposes. } +\section{Decorating \code{tm_missing_data}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{summary_plot} (\code{grob} created with \code{\link[ggplot2:ggplotGrob]{ggplot2::ggplotGrob()}}) +\item \code{combination_plot} (\code{grob} created with \code{\link[ggplot2:ggplotGrob]{ggplot2::ggplotGrob()}}) +\item \code{by_subject_plot} (\code{ggplot2}) +\item \code{table} (\code{\link[DT:datatable]{DT::datatable()}}) +} + +Decorators can be applied to all outputs or only to specific objects using a +named list of \code{teal_transform_module} objects. +The \code{"default"} name is reserved for decorators that are applied to all outputs. +See code snippet below: + +\if{html}{\out{
}}\preformatted{tm_missing_data( + ..., # arguments for module + decorators = list( + default = list(teal_transform_module(...)), # applied to all outputs + summary_plot = list(teal_transform_module(...)), # applied only to `summary_plot` output + combination_plot = list(teal_transform_module(...)) # applied only to `combination_plot` output + by_subject_plot = list(teal_transform_module(...)) # applied only to `by_subject_plot` output + table = list(teal_transform_module(...)) # applied only to `table` output + ) +) +}\if{html}{\out{
}} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ \dontshow{if (require("gridExtra", quietly = TRUE) && require("rlang", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general example data @@ -113,13 +150,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEulIQatS6cKGwqCK6-FCkUEr9gwbGXNQA+iNQNsMDUGO6AO60pAAWKuwz0SBKurme3r6toqTE1ESM9fu6UPz8k9CiS2YWmtahtnsQBwehwFE3RE7FEnkm3BIEnYX2iJkuV3YIlKGxhtgAVLlzLQTOwAIzRDAABgArIS8QB2OTUgC6SwAcgBBW7-W4AXyUtx8tBeRl03NEtxg5xYvOMwoIos5v35QVEwDpfOK6ES7AF0Xuj2e9QOEtFCqWyp6HD1jFEGoeTygoh1ulN8uA-gIrGo-hpiuM1owJnUpER9uAjsILrdNNtAaDUhYoaWXp9Gn9IrNgf8UcYofqbJu0HQSxUaz8MpmNR2QoEwjENT4QhEokLf10pBgkxgPNEKgk0wWcxl9XqON0atUzEsOhs31uok2EFYjPQ7DQqAAJN4Negl2DGDprkoORAwGyaUA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsBKMtPzOAB6kzP64ul60cKTUrLoAvPZOzrYAZJm67rG+-ozUUBASUTHe8YkpaS6KEADEugDCACIAkgDKzbpwobCoIrr8UKRQSiNjBsZc1AD6k1A2E6NQ07oA7rSkABYq7IvRIEq6uZ7evhBipMTURIz1pwCCrZ0AMuuML+8nui9YnU+-06SgAvvUAFZEFRzADWcFYogOq1sRmGcBMUGEpDmBH4tFEBDmUJh8MRwGg8CRizkAF0lEo0Kh1iptn4IKdFjVDr8+EIRKIanzhGJ2adTqQYHMYATRCoJAtVssObp6vVaCZdOwVORmJYdDZbMcVaI9hBWE90OwmQASbzRW2iGQ6B5gpRgUG0oA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_outliers.Rd b/man/tm_outliers.Rd index ff738de8d..106ba0ec4 100644 --- a/man/tm_outliers.Rd +++ b/man/tm_outliers.Rd @@ -13,7 +13,8 @@ tm_outliers( plot_height = c(600, 200, 2000), plot_width = NULL, pre_output = NULL, - post_output = NULL + post_output = NULL, + decorators = NULL ) } \arguments{ @@ -28,11 +29,9 @@ specifies the categorical variable(s) to split the selected outlier variables on \item{ggtheme}{(\code{character}) optional, \code{ggplot2} theme to be used by default. Defaults to \code{"gray"}.} -\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} -with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. -The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. +\item{ggplot2_args}{(\code{ggplot2_args}) optional, object created by \code{\link[teal.widgets:ggplot2_args]{teal.widgets::ggplot2_args()}} with settings for all the plots or named list of \code{ggplot2_args} objects for plot-specific settings. The argument is merged with options variable \code{teal.ggplot2_args} and default module setup. -List names should match the following: \code{c("default", "Boxplot","Density Plot","Cumulative Distribution Plot")}. +List names should match the following: \code{c("default", "Boxplot", "Density Plot", "Cumulative Distribution Plot")}. For more details see the vignette: \code{vignette("custom-ggplot2-arguments", package = "teal.widgets")}.} @@ -48,6 +47,12 @@ with text placed before the output to put the output into context. For example a \item{post_output}{(\code{shiny.tag}) optional, text or UI element to be displayed after the module's output, adding context or further instructions. Elements like \code{shiny::helpText()} are useful.} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_outliers}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -57,7 +62,40 @@ Module to analyze and identify outliers using different methods such as IQR, Z-score, and Percentiles, and offers visualizations including box plots, density plots, and cumulative distribution plots to help interpret the outliers. } +\section{Decorating \code{tm_outliers}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{box_plot} (\code{ggplot2}) +\item \code{density_plot} (\code{ggplot2}) +\item \code{cumulative_plot} (\code{ggplot2}) +\item \code{table} (\code{\link[DT:datatable]{DT::datatable()}}) +} + +Decorators can be applied to all outputs or only to specific objects using a +named list of \code{teal_transform_module} objects. +The \code{"default"} name is reserved for decorators that are applied to all outputs. +See code snippet below: + +\if{html}{\out{
}}\preformatted{tm_outliers( + ..., # arguments for module + decorators = list( + default = list(teal_transform_module(...)), # applied to all outputs + box_plot = list(teal_transform_module(...)), # applied only to `box_plot` output + density_plot = list(teal_transform_module(...)) # applied only to `density_plot` output + cumulative_plot = list(teal_transform_module(...)) # applied only to `cumulative_plot` output + table = list(teal_transform_module(...)) # applied only to `table` output + ) +) +}\if{html}{\out{
}} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ + # general data example data <- teal_data() data <- within(data, { @@ -102,6 +140,7 @@ if (interactive()) { shinyApp(app$ui, app$server) } + # CDISC data example data <- teal_data() data <- within(data, { @@ -112,6 +151,8 @@ join_keys(data) <- default_cdisc_join_keys[names(data)] fact_vars_adsl <- names(Filter(isTRUE, sapply(data[["ADSL"]], is.factor))) vars <- choices_selected(variable_choices(data[["ADSL"]], fact_vars_adsl)) + + app <- init( data = data, modules = modules( @@ -150,14 +191,14 @@ if (interactive()) { \section{Examples in Shinylive}{ \describe{ \item{example-1}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXVIhrqu-lCkULpwAB6wqCJKAUEGxlzUAPoxUDbRgcFGugDutKQAFirsKbi6IEq6ugDCAPIATHHV9RVNdcDACmCojLQwLKyJANZwrJ0AumONonAAjokiEOwQjETZ7LV1cooQAL7bAFZEKkMjosUZtlmHx8OsZ9cQJxydG52lL814up3dvf1PnS2bggWhYokaBHyRwIYkS0xEGjg-HYoJ6UHoIkSkOhYnOQXaHzq4zGpQI7E6AAVqFAyG9vmA7KxUHA6Z07Iw4IF4LSwFttko0KhGio8uSIJUUroALz+DK4Fp8IQicEyxXCXEtSqkGCJIiCUh0GRnTWVXR6g20GSJVHS3R0USkMWm52yoKJMKkZgaOHMskml2ummwPQywlvf0u+FwDS2qPe0S+p0Bl3U+hwPyhsAAZXT0dIulRtHRIkQ4fFyed2NoMJVBZYRYxcCxUOruJSBLArzAE1J5MIJAIrLAglQQWGgLk8vLFcqcfI-FtnRHY5ZeAjAZgwk0kRDugAYgBBAAyWecU5nppMtFCSNth5Prmnye2FZfLsnEYIgTgEiIPS-SQ2jK9qOuugbuqEnrqKQPrRkmFYpNA8CLp2nznjOV7UOQjC2ph2GwX6T4VqitYkehF5VjWtqgtQghNpRbYZB2XY9nWjCiAAJHOSIfkRybcQuMo0XRzY4mc7YdKhRLdiSbGcQJvEXpUm5YbQO62g4LhgZUb4Brppr6W+2zbLQJi6OwKjYdB2hwDYtjlOWoiFBArAHug7CChxgi0KUnnTIwOiMNsOxKGAOxjEAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokrcQAxLqkQ11XfxQpFC6cAAesKgiSoHBBsZc1AD6sVA2MUEhRroA7rSkABYq7Km4uiBKuroAwgDyAEzxNQ2VzfXAwApgqIy0MCysSQDWcKxdALrjTaJwAI5JIhDsEIxEOex19XKKEAC+OwBWRCrDo6IlmbbZRycjrOc3EKccXZtdZa8teLpdPX0Dzy623cWhYoiaBAKxwIYiSMxEGjg-HYoN6UHoIiSkOhYguwQ6n3qE3GZQI7C6AAVqFAyO8fmA7KxUHA6V07Iw4EF4LSwNsdko0Kgmip8uSIFVUroALwBTK4Vp8IQicEyxXCXGtKqkGBJIiCUh0GTnTVVXR6g20GRJVHS3R0USkMWm52y4JJcKkZgaOHMskml2ummwPQywnvf0u+FwDS2qPe0S+p0Bl3U+hwfyhsAAZXT0dIulRtHRIkQ4fFyed2NoMJVBZYRYxcCxUOruNSBLAbzAk1J5MIJAIrLAglQwRGQLk8vLFaqcfI-FtXRHY5ZeAjAZgwk0URDugAYgBBAAyWecU5nppMtDCSNth5PrmnyZ2FZfLsnEYIQTgEiIvS-yQ2jK9qOuugbumEnrqKQPrRkmFapNA8CLp2XznjOV7UOQjC2ph2GwX6T4VqitYkehF5VjWtqgtQghNpRbaZB2XY9nWjCiAAJHOSIfkRybcQuMo0XRzY4uc7adKhRLdiSbGcQJvEXlUm5YbQO62g4LhgVUb4Brppr6W+Ow7LQJi6OwKjYdB2hwDYtgVOWohFBArAHug7CChxgi0GUnkzIwOiMDsuxKGAuzjEAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ - \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokqUBiXQGEAIgEkAZS9dfihSKF04AA9YVBElUPCDYy5qAH1EqBsEsIijXQB3WlIACxV2TNxdECVdXQBBHwCAGWTdRkaWpQBfRQgAKyIVNIBrOFZRCtzbfP44EyhhUjSCflpRAjTB4bGJ4Gh4Scy5AF03CAWNNK0WUTSoflFqNoOxdgAxWmpyRnZ1hxcVVEaDiHEywGACjAnWaUJOJyq6wwl1IREYcgxShujFEbQIJSGBDEaVEcBEGjg-HY2NoUHoIhWBNoRKOuQhUJhcIRpnUy2xdweT0xECUILaKmK7FqIVyugAvDLwrhpXwhCJcQrVcI3tK6qQYGkiIJSHQZJNdXVdEaTbQZNcWPLdHRRKQpRBLR7FVA0tFSMwrqJUHACG7PZ7Mq9HRymrC8Baw6TyaRHYng8tA8HQ2HPdQ6WSo2AAmS07oaXSRIgocr3dmPfjCWJHWX6XBGQ3WeF2dCY1yqiGOQBxVx4XRQgBCAFksABpLAARihGOrtY9qYp-AL9SHVfj2ZgS1ocT0Cve9WaAWcy5XdRMtCilMdp-Prhrtb6b93civdbCcAkaOZbh7UYR1nVdXc6kyH0oj9XkSSDftX2zCNYGPUduy6OMkLDW9vhkR1cJ+eDMwgz1+SbW5vxXetmUbBUbmoQRWxolkpk7SEMNjeEqn5AASNdyH4L9SNXYt1woxjmKZVjwQ4zkwG40tbn4sTBOE7C9wPI9HQBF9r3fbMDI9IzdAMvo+loExdD+VR-U0HQbFsGoa1EMoIFYep0HYEFeMEWgqh80lGB0dEeiUMBuhOIA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAokrcQAxLoDCAEQCSAMreuvxQpFC6cAAesKgiSmERBsZc1AD6SVA2ieGRRroA7rSkABYq7Fm4uiBKuroAgr6BADIpuoxNrUoAvooQAFZEKukA1nCsopV5tgX8cCZQwqTpBPy0ogTpQyPjk8DQ8FNZcgC67osa6VosoulQ-KLU7Ydi7ABitNTkjOwbDi5qqI0PEOFlgMAFGAui0oadTtUNhhLqQiIw5BilDdGKJ2gRSsMCGJ0qI4CINHB+OxsbQoPQRKsCbQicc8hCoTC4QjTOoVti7g8npiIO4lCD2ioSuw6qE8roALyyiK4GV8IQiXGKtXCN4y+qkGDpIiCUh0GRTPX1XTG020GTXFgK3R0USkaUQK2epVQdIxUjMK6iVBwAjur1erKvJ0c5qwvCW8Ok8mkJ1JkMrIMhsPhr3UOlk6NgQJk9O6Gl0kSIKEqj05z34wliJ3l+lwRmN1kRdnQ2Nc6qhjkAcVceF0UIAQgBZLAAaSwAEYoRia3XPWmKfxCw1h9WEzmYMtaPE9Ir3g0WoFnCvV-UTLRopSnWeL65a3X+u+93Jr-XwnAJGizLcA6jBOi6bp7vUWS+tE-q8iSwYDm+OaRrAJ5jj23Txsh4Z3t8MhOnhPwIVmkFevyza3D+q4NsyTaKjc1CCG2tEstMXaQphcbwtU-IACTruQ-DfmRa4lhulFMSxTJseCnGcmAPFlrcAniUJIk4fuh7Hk6AKvjeH45oZnrGbohn9P0tAmLofyqAGmg6DYti1LWojlBArANOg7Agnxgi0NUvmkowOjor0ShgD0pxAA}{Open in Shinylive} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_t_crosstable.Rd b/man/tm_t_crosstable.Rd index a9a1354cd..dc3ab1578 100644 --- a/man/tm_t_crosstable.Rd +++ b/man/tm_t_crosstable.Rd @@ -12,7 +12,8 @@ tm_t_crosstable( show_total = TRUE, pre_output = NULL, post_output = NULL, - basic_table_args = teal.widgets::basic_table_args() + basic_table_args = teal.widgets::basic_table_args(), + decorators = NULL ) } \arguments{ @@ -49,6 +50,12 @@ with settings for the module table. The argument is merged with options variable \code{teal.basic_table_args} and default module setup. For more details see the vignette: \code{vignette("custom-basic-table-arguments", package = "teal.widgets")}} + +\item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. + +Otherwise, the decorators are applied to all objects, which is equivalent as using the name \code{default}. + +See section "Decorating \code{tm_t_crosstable}" below for more details.} } \value{ Object of class \code{teal_module} to be used in \code{teal} applications. @@ -61,6 +68,18 @@ options for showing percentages and sub-totals. For more examples, please see the vignette "Using cross table" via \code{vignette("using-cross-table", package = "teal.modules.general")}. } +\section{Decorating \code{tm_t_crosstable}}{ + + +This module generates the following objects, which can be modified in place using decorators: +\itemize{ +\item \code{table} (\code{ElementaryTable} - output of \code{rtables::build_table}) +} + +For additional details and examples of decorators, refer to the vignette +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +} + \examples{ \dontshow{if (require("rtables", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # general data example @@ -159,13 +178,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6UhBq1Lr8UEG6cAAesKgiSgVFRrpc1AD61VA2VYVQBsYA7rSkABYq7M0RIEq6ujCkBCyinRNTM2OmRIy67Fq6KroEfoSs1OG6-lpheEcoMIf+Uiz+crajEOPjk9OMosDAWgC633NQ4hM6lIK3Yrxmnx+3zS4wAvktwe9Pv5UIxaDAWKwGgBrOCsfy-OaiTwNEQQdgQRhELpghbve5KWFpABWRBUOLxoiG7VstVZ7NxrC5-IgHI4-kRpwiErpUvOqPRmLFdzSSjQqDmKl6fie+XaiT1QVwCIEwjEBr4QlCOuedRgDVIDQIVNEoiCITgNttumowTgeSS-gAwi7ZnZgpU8EtbSUDc0GqVSMwNA1RKg4Dto97mtB4AaZW8pVnbcSRBoDaWM460xmvd7nr76P782AAMr+qu6LQsWgRuCIcLF70EPpsgjmpLdtF9p2j2jjrnNZFgSUE74RTN7A5nY5y-ywK5gG6MFXG3X18aVjRwfgGzcEfaH493M8X54wYSaCp6JIOFyvt9dBWfgZBvA0-2cAC3xMWgSjApIADEAEEABlW1cc9vRhLCoOeeIknjRNk2rdNM0w20c1gH9zlXKNyOeK9SArDsUxrMjAJ9P0A3OdsyyYqdew9Ac6I4kcxwnLsexnMT5zEbkgmXWjfg3XYH23aUwBOQ8Dx3I84FuMB7lw+tGPg84tJEwCP2oL8RANZC0MgodbRguDb0Q1D0Oc3RsNtXyfKWNI0loEw1hUchiO0T17l0R5LwGCBWCQ9B2HVAASbwInS4lGB0Rg0nhCAwFhb4gA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsIykUPQiov64ul60cKTUrLoAvPZOzooQAMS6AMIAIgCSAMpZuvxQQbpwAB6wqCJKpeVGulzUAPoNUDb1ZVAGxgDutKQAFirsHREgSrq6AII5BQAyfbqM80tKAL5pAFZEKq0A1nCsouM9tk38cCZQwqStBPy0ogStewfHp8DQ8GcdcgAukolGhUCsVEM-BAZh1EiUerhpro+EJQvDUcIxNCZjNSDBWg8CIwiKJREEQnAcbiZtRgnBqPD-FkSWT7ME6nhkTTKvCOq0qqRmBpWqJUHACNSabCer89El-OtFuFudLRAyJaR4eqRCKxRKpdLafTGQqwAUNRpdFoWLQOXBECqYUbcQRhvsCGJ4TbGHbKY93bRPf8esBgIqFsqwIDARFRIJ6OqtUkzBZNNYAbops6XbjaPxeU0AIQ29Bxc5BCIqYYyIaiCLUIgSIPcdgARjkEUl-hyZTg4V0-gACgB5Ap5AAaGgHw7Hk+opH8cjSuZp7lIgkYEHYcpDQTkwHzlUBK9X2yROZdOs1cH4TLAWRHjgAcg4AJpO1co+60Wry5IuBeX5EIw1zuHeSQOIBqpGiYtCVLe8IAGKzIsBSuJeNKnlhQHSvEST8oKwoPPq3aYbiHRyveSqflelrJro156uKZFfnS9AMveFq6lqPp+iIjpcuRNJuh6XpJHx9oBmJe5QGGEYbNGsaMQmSbwqmlgZhcWYwS6R4rKWtQcBMugvBgtwaCBDZNi21DtsuulGuum7bruFZQAeR4no5uLnj5MxMeQEGDuazgTrRuYwD+f7Iah6G4bmcEIcFKFoRhubYbimWnmkaS0CYujsCo5DEdoVLLjpzqiKMECsLM6DsGCAAk3gRM16qMDojBpJsShgJsgJAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/man/tm_variable_browser.Rd b/man/tm_variable_browser.Rd index b36911ed4..752c4c83d 100644 --- a/man/tm_variable_browser.Rd +++ b/man/tm_variable_browser.Rd @@ -104,13 +104,13 @@ if (interactive()) { \describe{ \item{example-1}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEulLhsrr8UKRQunAAHrCoIkoLSwbGXNQA+jtQNtuLy0a65aQFKuwnUSBKuro+tKJ7b4wfL7owpAILE+VwBQMYNQgr1KRHgUKuMLhfxMUFotzM1C+KLRBQxfwAwgB5ABMXyJxKUAF9FBAlGhUF8VGi-FD5hcmo8-nwhCJPilucIxCzXq9ioctCxaFB6CJDkwiKVRDJhSLXtRpXBMSl-AA1SXSkS6eWKmT+P6vGkWpQ02gmXTsFTkZiWHQ2WzPVmiO4QVgAQXQ7HpABJvFFg0rGDpGDTKUowJSALpAA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } \item{example-2}{ \href{https://shinylive.io/r/app/#code=NobwRAdghgtgpmAXGKAHVA6ASmANGAYwHsIAXOMpMAGwEsAjAJykYE8AKcqajGIgEwCu1OAGcMAcwpxm1AJQAdCLTIyoBUrQBucAAQAeALS6AZoIgbaJdnN0AVLAFUAoksZwAjoNrv2CsKKoLADWdBBw-ri6XrRwpNSsugC89k7OtgBkGbruMb7+ABakMNQA7rT8UqSikdHecQnJqS6Z2bne+WAAVqIkdOS1MQ2JKQ4tSgDEugDCACIAkgDK07pwAB6wqCK6-FCkUEp0TCwcgSFhcIoQu-sGxlzUAPo3UDZKL3e65aQFKuwvURASl0ugAgrNFgAZT6McFQ4Fg2Z2OzOGHg5GuCAAXyuXSIKkewTgrFE-z2UFsRh2cBMUGEpEeBH4tFEBEeeIJRJJwGg8FJLzkAF0lEo0KhPipaKQ-BAQR8UgCEXwhCJRE1lcIxDKQSDio8tCxaFB6CJHkwiKVRDJtTqQdRjXBqE1-AA1Q3G7bmy0yfwIkFXf1KK60Ey6dgqcjMSw6Gy2IGy3SiX4QVig9DsMUAEm8USzVsYOkYVyxSjAWMFQA}{Open in Shinylive} - \if{html}{\out{}} - \if{html}{\out{}} + \if{html}{\out{}} + \if{html}{\out{}} } } } diff --git a/tests/testthat/helper-functions.R b/tests/testthat/helper-functions.R index 1bc8546bb..4eb8908de 100644 --- a/tests/testthat/helper-functions.R +++ b/tests/testthat/helper-functions.R @@ -10,3 +10,17 @@ mock_data_extract_spec <- function(dataname = "MOCK_DATASET", ) ) } + +normalize_math_italic_text <- function(text) { + # Unicode range for mathematical italic (uppercase/lowercase) + math_italic <- intToUtf8(seq(0x1D434, 0x1D467)) # A-z + + # Standard letters + latin <- c(LETTERS, letters) + + # Replace math italic letters with standard ones + stringr::str_replace_all( + text, + setNames(latin, unlist(stringr::str_split(math_italic, ""))) + ) +} diff --git a/tests/testthat/test-shinytest2-tm_misssing_data.R b/tests/testthat/test-shinytest2-tm_misssing_data.R index af35629ab..debfcc1b1 100644 --- a/tests/testthat/test-shinytest2-tm_misssing_data.R +++ b/tests/testthat/test-shinytest2-tm_misssing_data.R @@ -109,7 +109,7 @@ test_that("e2e - tm_missing_data: Check default settings and visibility of the c ) ) - testthat::expect_equal(app_driver$get_active_module_input("iris-combination_cutoff"), 1L) + testthat::expect_equal(app_driver$get_active_module_input("iris-combination_cutoff"), 2L) app_driver$set_active_module_input("iris-combination_cutoff", 10L) app_driver$expect_no_validation_error() diff --git a/tests/testthat/test-shinytest2-tm_outliers.R b/tests/testthat/test-shinytest2-tm_outliers.R index b2af74f0f..a0b3a206e 100644 --- a/tests/testthat/test-shinytest2-tm_outliers.R +++ b/tests/testthat/test-shinytest2-tm_outliers.R @@ -198,7 +198,7 @@ testthat::test_that("e2e - tm_outliers: # IQR METHOD testthat::expect_identical(app_driver$get_active_module_input("method"), "IQR") testthat::expect_match( - app_driver$active_module_element_text("ui_outlier_help"), + normalize_math_italic_text(app_driver$active_module_element_text("ui_outlier_help")), "x Date: Fri, 29 Nov 2024 16:56:16 +0000 Subject: [PATCH 30/42] [skip actions] Bump version to 0.3.0.9055 --- DESCRIPTION | 27 ++++++++++++++------------- NEWS.md | 2 +- 2 files changed, 15 insertions(+), 14 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index e7a4d62bc..54e1e308a 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9054 -Date: 2024-11-08 +Version: 0.3.0.9055 +Date: 2024-11-29 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), @@ -85,17 +85,18 @@ VignetteBuilder: Config/Needs/verdepcheck: haleyjeppson/ggmosaic, tidyverse/ggplot2, rstudio/shiny, insightsengineering/teal, insightsengineering/teal.transform, mllg/checkmate, tidyverse/dplyr, - rstudio/DT, tidyverse/forcats, r-lib/lifecycle, r-lib/scales, daattali/shinyjs, - shinyTree/shinyTree, rstudio/shinyvalidate, dreamRs/shinyWidgets, - tidyverse/stringr, insightsengineering/teal.code, - insightsengineering/teal.data, insightsengineering/teal.logger, - insightsengineering/teal.reporter, insightsengineering/teal.widgets, - insightsengineering/tern, tidyverse/tibble, tidyverse/tidyr, - tidymodels/broom, daattali/colourpicker, daattali/ggExtra, - aphalo/ggpmisc, aphalo/ggpp, slowkow/ggrepel, baddstats/goftest, - ramnathv/htmlwidgets, jeroen/jsonlite, yihui/knitr, daroczig/logger, - deepayan/lattice, insightsengineering/nestcolor, r-lib/pkgload, - r-lib/rlang, rstudio/rmarkdown, insightsengineering/roxy.shinylive, + rstudio/DT, tidyverse/forcats, r-lib/lifecycle, r-lib/scales, + daattali/shinyjs, shinyTree/shinyTree, rstudio/shinyvalidate, + dreamRs/shinyWidgets, tidyverse/stringr, + insightsengineering/teal.code, insightsengineering/teal.data, + insightsengineering/teal.logger, insightsengineering/teal.reporter, + insightsengineering/teal.widgets, insightsengineering/tern, + tidyverse/tibble, tidyverse/tidyr, tidymodels/broom, + daattali/colourpicker, daattali/ggExtra, aphalo/ggpmisc, aphalo/ggpp, + slowkow/ggrepel, baddstats/goftest, ramnathv/htmlwidgets, + jeroen/jsonlite, yihui/knitr, daroczig/logger, deepayan/lattice, + insightsengineering/nestcolor, r-lib/pkgload, r-lib/rlang, + rstudio/rmarkdown, insightsengineering/roxy.shinylive, insightsengineering/rtables, tidyverse/rvest, htmlwidgets/sparkline, rstudio/shinytest2, r-lib/testthat, r-lib/withr Config/Needs/website: insightsengineering/nesttemplate diff --git a/NEWS.md b/NEWS.md index dea3b1d7e..6002a2f88 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9054 +# teal.modules.general 0.3.0.9055 * Removed `Show Warnings` modals from modules. From 6745604f1d0d32ace6de751ee2d0524bc523709c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Llu=C3=ADs=20Revilla?= <185338939+llrs-roche@users.noreply.github.com> Date: Tue, 3 Dec 2024 12:26:57 +0100 Subject: [PATCH 31/42] Teal version bump (#814) # Pull Request Fixes #813 --- DESCRIPTION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/DESCRIPTION b/DESCRIPTION index 54e1e308a..4c3373fab 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -27,7 +27,7 @@ Depends: ggplot2 (>= 3.4.0), R (>= 3.6), shiny (>= 1.6.0), - teal (>= 0.15.2.9079), + teal (>= 0.15.2.9091), teal.transform (>= 0.5.0.9015) Imports: checkmate (>= 2.1.0), From 94ff38103e9f68bbfba3bbfea2c9590279568263 Mon Sep 17 00:00:00 2001 From: llrs-roche Date: Tue, 3 Dec 2024 11:27:58 +0000 Subject: [PATCH 32/42] [skip actions] Bump version to 0.3.0.9056 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 4c3373fab..7cbd6fb1c 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9055 -Date: 2024-11-29 +Version: 0.3.0.9056 +Date: 2024-12-03 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 6002a2f88..8571b7c8a 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9055 +# teal.modules.general 0.3.0.9056 * Removed `Show Warnings` modals from modules. From fbafae85c3b63353781e72340497ba851d7a0ee2 Mon Sep 17 00:00:00 2001 From: Vedha Viyash <49812166+vedhav@users.noreply.github.com> Date: Wed, 11 Dec 2024 18:06:27 +0530 Subject: [PATCH 33/42] add setup-r-dependencies (#815) Related to https://github.com/insightsengineering/nestdevs-tasks/issues/65 Switch to setup-r-dependencies. Added `teal.modules.general` for lookup-refs. --- .github/workflows/check.yaml | 64 ++++++++++++++++++++++++++++++++ .github/workflows/docs.yaml | 16 ++++++++ .github/workflows/release.yaml | 62 +++++++++++++++++++++++++++++++ .github/workflows/scheduled.yaml | 12 ++++-- staged_dependencies.yaml | 41 -------------------- 5 files changed, 151 insertions(+), 44 deletions(-) delete mode 100644 staged_dependencies.yaml diff --git a/.github/workflows/check.yaml b/.github/workflows/check.yaml index e7b7ebc6b..187f8bb41 100644 --- a/.github/workflows/check.yaml +++ b/.github/workflows/check.yaml @@ -42,6 +42,22 @@ jobs: checking top-level files .* NOTE unit-test-report-brand: >- https://raw.githubusercontent.com/insightsengineering/hex-stickers/main/thumbs/teal.png + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/teal.slice + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor r-cmd-non-cran: name: R CMD Check (non-CRAN) 🧬 uses: insightsengineering/r.pkg.template/.github/workflows/build-check-install.yaml@main @@ -64,6 +80,22 @@ jobs: checking Rd .usage sections .* NOTE checking for unstated dependencies in vignettes .* NOTE checking top-level files .* NOTE + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/teal.slice + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor coverage: name: Coverage 📔 uses: insightsengineering/r.pkg.template/.github/workflows/test-coverage.yaml@main @@ -72,6 +104,22 @@ jobs: with: additional-env-vars: | NOT_CRAN=true + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/teal.slice + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor linter: if: github.event_name != 'push' name: SuperLinter 🦸‍♀️ @@ -83,6 +131,22 @@ jobs: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} with: auto-update: true + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/teal.slice + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor gitleaks: name: gitleaks 💧 uses: insightsengineering/r.pkg.template/.github/workflows/gitleaks.yaml@main diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml index 57ae80042..2e3d8a86c 100644 --- a/.github/workflows/docs.yaml +++ b/.github/workflows/docs.yaml @@ -42,3 +42,19 @@ jobs: with: default-landing-page: latest-tag additional-unit-test-report-directories: unit-test-report-non-cran + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/teal.slice + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index aa3e7bb45..4d94ee58d 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -16,12 +16,43 @@ jobs: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} with: default-landing-page: latest-tag + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/tern + insightsengineering/nestcolor + insightsengineering/roxy.shinylive + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer validation: name: R Package Validation report 📃 needs: release uses: insightsengineering/r.pkg.template/.github/workflows/validation.yaml@main secrets: REPO_GITHUB_TOKEN: ${{ secrets.REPO_GITHUB_TOKEN }} + with: + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/tern + insightsengineering/nestcolor + insightsengineering/roxy.shinylive + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer release: name: Create release 🎉 uses: insightsengineering/r.pkg.template/.github/workflows/release.yaml@main @@ -46,6 +77,21 @@ jobs: checking top-level files .* NOTE unit-test-report-brand: >- https://raw.githubusercontent.com/insightsengineering/hex-stickers/main/thumbs/teal.png + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor coverage: name: Coverage 📔 needs: [release, docs] @@ -55,6 +101,22 @@ jobs: with: additional-env-vars: | NOT_CRAN=true + deps-installation-method: setup-r-dependencies + lookup-refs: | + insightsengineering/roxy.shinylive + insightsengineering/teal + insightsengineering/teal.transform + insightsengineering/teal.code + insightsengineering/teal.data + insightsengineering/teal.logger + insightsengineering/teal.reporter + insightsengineering/teal.widgets + insightsengineering/teal.slice + insightsengineering/tern + insightsengineering/formatters + insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor wasm: name: Build WASM packages 🧑‍🏭 needs: release diff --git a/.github/workflows/scheduled.yaml b/.github/workflows/scheduled.yaml index 2aace5e2b..50cc3e050 100644 --- a/.github/workflows/scheduled.yaml +++ b/.github/workflows/scheduled.yaml @@ -3,7 +3,7 @@ name: Scheduled 🕰️ on: schedule: - - cron: '45 3 * * 0' + - cron: "45 3 * * 0" workflow_dispatch: inputs: chosen-workflow: @@ -63,12 +63,15 @@ jobs: insightsengineering/teal.transform insightsengineering/teal.code insightsengineering/teal.data - insightsengineering/teal.slice insightsengineering/teal.logger insightsengineering/teal.reporter insightsengineering/teal.widgets + insightsengineering/teal.slice insightsengineering/tern + insightsengineering/formatters insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor rhub: if: > github.event_name == 'schedule' || ( @@ -84,9 +87,12 @@ jobs: insightsengineering/teal.transform insightsengineering/teal.code insightsengineering/teal.data - insightsengineering/teal.slice insightsengineering/teal.logger insightsengineering/teal.reporter insightsengineering/teal.widgets + insightsengineering/teal.slice insightsengineering/tern + insightsengineering/formatters insightsengineering/rtables + insightsengineering/rtables.officer + insightsengineering/nestcolor diff --git a/staged_dependencies.yaml b/staged_dependencies.yaml deleted file mode 100644 index d484dfe68..000000000 --- a/staged_dependencies.yaml +++ /dev/null @@ -1,41 +0,0 @@ -current_repo: - repo: insightsengineering/teal.modules.general - host: https://github.com -upstream_repos: - insightsengineering/nestcolor: - repo: insightsengineering/nestcolor - host: https://github.com - insightsengineering/roxy.shinylive: - repo: insightsengineering/roxy.shinylive - host: https://github.com - insightsengineering/teal.logger: - repo: insightsengineering/teal.logger - host: https://github.com - insightsengineering/teal.widgets: - repo: insightsengineering/teal.widgets - host: https://github.com - insightsengineering/teal.data: - repo: insightsengineering/teal.data - host: https://github.com - insightsengineering/teal.code: - repo: insightsengineering/teal.code - host: https://github.com - insightsengineering/teal.reporter: - repo: insightsengineering/teal.reporter - host: https://github.com - insightsengineering/teal.slice: - repo: insightsengineering/teal.slice - host: https://github.com - insightsengineering/teal.transform: - repo: insightsengineering/teal.transform - host: https://github.com - insightsengineering/teal: - repo: insightsengineering/teal - host: https://github.com - insightsengineering/tern: - repo: insightsengineering/tern - host: https://github.com - insightsengineering/rtables: - repo: insightsengineering/rtables - host: https://github.com -downstream_repos: From 0ab3e75040f8a3d96eb8d9ccbb56a34bea7e5bc4 Mon Sep 17 00:00:00 2001 From: m7pr Date: Wed, 11 Dec 2024 12:37:25 +0000 Subject: [PATCH 34/42] [skip actions] Bump version to 0.3.0.9057 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 7cbd6fb1c..001771d14 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9056 -Date: 2024-12-03 +Version: 0.3.0.9057 +Date: 2024-12-11 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 8571b7c8a..90f2763a7 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9056 +# teal.modules.general 0.3.0.9057 * Removed `Show Warnings` modals from modules. From a11b5925e1268775bb7d594e1b739c42f305b6e7 Mon Sep 17 00:00:00 2001 From: Vedha Viyash <49812166+vedhav@users.noreply.github.com> Date: Wed, 11 Dec 2024 18:55:21 +0530 Subject: [PATCH 35/42] get back staged deps config (#816) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- man/tm_g_distribution.Rd | 4 ++-- staged_dependencies.yaml | 41 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 staged_dependencies.yaml diff --git a/man/tm_g_distribution.Rd b/man/tm_g_distribution.Rd index 91b880f29..680958fc6 100644 --- a/man/tm_g_distribution.Rd +++ b/man/tm_g_distribution.Rd @@ -58,10 +58,10 @@ Defaults to \code{c(30L, 1L, 100L)}. \item{plot_width}{(\code{numeric}) optional, specifies the plot width as a three-element vector of \code{value}, \code{min}, and \code{max} for a slider encoding the plot width.} -\item{pre_output}{(\code{shiny.tag}) optional,\cr +\item{pre_output}{(\code{shiny.tag}, optional)\cr with text placed before the output to put the output into context. For example a title.} -\item{post_output}{(\code{shiny.tag}) optional, with text placed after the output to put the output +\item{post_output}{(\code{shiny.tag}, optional) with text placed after the output to put the output into context. For example the \code{\link[shiny:helpText]{shiny::helpText()}} elements are useful.} \item{decorators}{\ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#experimental}{\figure{lifecycle-experimental.svg}{options: alt='[Experimental]'}}}{\strong{[Experimental]}} (\code{list} of \code{teal_transform_module}, named \code{list} of \code{teal_transform_module} or \code{NULL}) optional, if not \code{NULL}, decorator for tables or plots included in the module. When a named list of \code{teal_transform_module}, the decorators are applied to the respective output objects. diff --git a/staged_dependencies.yaml b/staged_dependencies.yaml new file mode 100644 index 000000000..d484dfe68 --- /dev/null +++ b/staged_dependencies.yaml @@ -0,0 +1,41 @@ +current_repo: + repo: insightsengineering/teal.modules.general + host: https://github.com +upstream_repos: + insightsengineering/nestcolor: + repo: insightsengineering/nestcolor + host: https://github.com + insightsengineering/roxy.shinylive: + repo: insightsengineering/roxy.shinylive + host: https://github.com + insightsengineering/teal.logger: + repo: insightsengineering/teal.logger + host: https://github.com + insightsengineering/teal.widgets: + repo: insightsengineering/teal.widgets + host: https://github.com + insightsengineering/teal.data: + repo: insightsengineering/teal.data + host: https://github.com + insightsengineering/teal.code: + repo: insightsengineering/teal.code + host: https://github.com + insightsengineering/teal.reporter: + repo: insightsengineering/teal.reporter + host: https://github.com + insightsengineering/teal.slice: + repo: insightsengineering/teal.slice + host: https://github.com + insightsengineering/teal.transform: + repo: insightsengineering/teal.transform + host: https://github.com + insightsengineering/teal: + repo: insightsengineering/teal + host: https://github.com + insightsengineering/tern: + repo: insightsengineering/tern + host: https://github.com + insightsengineering/rtables: + repo: insightsengineering/rtables + host: https://github.com +downstream_repos: From e9dc76cf93ef9170ac7f75dcb191ec820361b013 Mon Sep 17 00:00:00 2001 From: vedhav Date: Wed, 11 Dec 2024 13:26:15 +0000 Subject: [PATCH 36/42] [skip actions] Bump version to 0.3.0.9058 --- DESCRIPTION | 2 +- NEWS.md | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 001771d14..e407ae6a5 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,7 +1,7 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9057 +Version: 0.3.0.9058 Date: 2024-12-11 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), diff --git a/NEWS.md b/NEWS.md index 90f2763a7..017066db1 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9057 +# teal.modules.general 0.3.0.9058 * Removed `Show Warnings` modals from modules. From d3fb05b0ba4c501a04941052c857e028925bef0f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Llu=C3=ADs=20Revilla?= <185338939+llrs-roche@users.noreply.github.com> Date: Thu, 12 Dec 2024 09:15:40 +0100 Subject: [PATCH 37/42] Fix documentation note about links on r-devel (#817) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- R/tm_a_pca.R | 2 +- R/tm_a_regression.R | 2 +- R/tm_data_table.R | 2 +- R/tm_g_association.R | 2 +- R/tm_g_bivariate.R | 2 +- R/tm_g_distribution.R | 2 +- R/tm_g_response.R | 2 +- R/tm_g_scatterplot.R | 2 +- R/tm_g_scatterplotmatrix.R | 2 +- R/tm_missing_data.R | 2 +- R/tm_outliers.R | 2 +- R/tm_t_crosstable.R | 2 +- man/tm_a_pca.Rd | 2 +- man/tm_a_regression.Rd | 2 +- man/tm_data_table.Rd | 2 +- man/tm_g_association.Rd | 2 +- man/tm_g_bivariate.Rd | 2 +- man/tm_g_distribution.Rd | 2 +- man/tm_g_response.Rd | 2 +- man/tm_g_scatterplot.Rd | 2 +- man/tm_g_scatterplotmatrix.Rd | 2 +- man/tm_missing_data.Rd | 2 +- man/tm_outliers.Rd | 2 +- man/tm_t_crosstable.Rd | 2 +- 24 files changed, 24 insertions(+), 24 deletions(-) diff --git a/R/tm_a_pca.R b/R/tm_a_pca.R index c6a7fb55e..e5960be33 100644 --- a/R/tm_a_pca.R +++ b/R/tm_a_pca.R @@ -45,7 +45,7 @@ #' ``` #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_a_regression.R b/R/tm_a_regression.R index b9015c585..508c04d4b 100644 --- a/R/tm_a_regression.R +++ b/R/tm_a_regression.R @@ -50,7 +50,7 @@ #' - `plot` (`ggplot2`) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_data_table.R b/R/tm_data_table.R index 3cb2155a9..022026e7a 100644 --- a/R/tm_data_table.R +++ b/R/tm_data_table.R @@ -36,7 +36,7 @@ #' - `table` ([DT::datatable()]) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_g_association.R b/R/tm_g_association.R index ec4a116d3..f2c4f479e 100644 --- a/R/tm_g_association.R +++ b/R/tm_g_association.R @@ -31,7 +31,7 @@ #' - `plot` (`grob` created with [ggplot2::ggplotGrob()]) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_g_bivariate.R b/R/tm_g_bivariate.R index aaf9b9642..ae88491cc 100644 --- a/R/tm_g_bivariate.R +++ b/R/tm_g_bivariate.R @@ -53,7 +53,7 @@ #' - `plot` (`ggplot2`) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' #' @examplesShinylive diff --git a/R/tm_g_distribution.R b/R/tm_g_distribution.R index 8e84ed76a..1c7b5aa92 100644 --- a/R/tm_g_distribution.R +++ b/R/tm_g_distribution.R @@ -54,7 +54,7 @@ #' ``` #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_g_response.R b/R/tm_g_response.R index 85590ed9f..219463a55 100644 --- a/R/tm_g_response.R +++ b/R/tm_g_response.R @@ -46,7 +46,7 @@ #' - `plot` (`ggplot2`) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_g_scatterplot.R b/R/tm_g_scatterplot.R index 28d9b0bda..eaab0e1e5 100644 --- a/R/tm_g_scatterplot.R +++ b/R/tm_g_scatterplot.R @@ -37,7 +37,7 @@ #' - `plot` (`ggplot2`) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' #' @examplesShinylive diff --git a/R/tm_g_scatterplotmatrix.R b/R/tm_g_scatterplotmatrix.R index ae1be8198..37c4899d7 100644 --- a/R/tm_g_scatterplotmatrix.R +++ b/R/tm_g_scatterplotmatrix.R @@ -25,7 +25,7 @@ #' - `plot` (`trellis` - output of `lattice::splom`) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_missing_data.R b/R/tm_missing_data.R index f3309c802..bd49368e7 100644 --- a/R/tm_missing_data.R +++ b/R/tm_missing_data.R @@ -45,7 +45,7 @@ #' ``` #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_outliers.R b/R/tm_outliers.R index 28473f6c9..4fc3ba7b4 100644 --- a/R/tm_outliers.R +++ b/R/tm_outliers.R @@ -43,7 +43,7 @@ #' ``` #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/R/tm_t_crosstable.R b/R/tm_t_crosstable.R index 5c8621fc3..9c8737fa6 100644 --- a/R/tm_t_crosstable.R +++ b/R/tm_t_crosstable.R @@ -32,7 +32,7 @@ #' - `table` (`ElementaryTable` - output of `rtables::build_table`) #' #' For additional details and examples of decorators, refer to the vignette -#' `vignette("decorate-modules-output", package = "teal")` or the [`teal_transform_module()`] documentation. +#' `vignette("decorate-modules-output", package = "teal")` or the [`teal::teal_transform_module()`] documentation. #' #' @examplesShinylive #' library(teal.modules.general) diff --git a/man/tm_a_pca.Rd b/man/tm_a_pca.Rd index 101f5d6e6..99ac47867 100644 --- a/man/tm_a_pca.Rd +++ b/man/tm_a_pca.Rd @@ -116,7 +116,7 @@ See code snippet below: }\if{html}{\out{}} For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_a_regression.Rd b/man/tm_a_regression.Rd index cd4621cc6..818a0e841 100644 --- a/man/tm_a_regression.Rd +++ b/man/tm_a_regression.Rd @@ -124,7 +124,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_data_table.Rd b/man/tm_data_table.Rd index ca1db1ea6..7c9e5fe4e 100644 --- a/man/tm_data_table.Rd +++ b/man/tm_data_table.Rd @@ -77,7 +77,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_g_association.Rd b/man/tm_g_association.Rd index 4ca13c313..bc0e37728 100644 --- a/man/tm_g_association.Rd +++ b/man/tm_g_association.Rd @@ -84,7 +84,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_g_bivariate.Rd b/man/tm_g_bivariate.Rd index 177b714a1..e02d5ef16 100644 --- a/man/tm_g_bivariate.Rd +++ b/man/tm_g_bivariate.Rd @@ -131,7 +131,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_g_distribution.Rd b/man/tm_g_distribution.Rd index 680958fc6..9a55dbbde 100644 --- a/man/tm_g_distribution.Rd +++ b/man/tm_g_distribution.Rd @@ -107,7 +107,7 @@ See code snippet below: }\if{html}{\out{}} For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_g_response.Rd b/man/tm_g_response.Rd index e5454501b..c8d53f14a 100644 --- a/man/tm_g_response.Rd +++ b/man/tm_g_response.Rd @@ -112,7 +112,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_g_scatterplot.Rd b/man/tm_g_scatterplot.Rd index 4f90024f2..a68d7eee9 100644 --- a/man/tm_g_scatterplot.Rd +++ b/man/tm_g_scatterplot.Rd @@ -123,7 +123,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_g_scatterplotmatrix.Rd b/man/tm_g_scatterplotmatrix.Rd index a0af16a82..b0dcca28e 100644 --- a/man/tm_g_scatterplotmatrix.Rd +++ b/man/tm_g_scatterplotmatrix.Rd @@ -63,7 +63,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_missing_data.Rd b/man/tm_missing_data.Rd index c6cd75b96..b28eaf245 100644 --- a/man/tm_missing_data.Rd +++ b/man/tm_missing_data.Rd @@ -91,7 +91,7 @@ See code snippet below: }\if{html}{\out{}} For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_outliers.Rd b/man/tm_outliers.Rd index 106ba0ec4..473f92ac5 100644 --- a/man/tm_outliers.Rd +++ b/man/tm_outliers.Rd @@ -91,7 +91,7 @@ See code snippet below: }\if{html}{\out{}} For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ diff --git a/man/tm_t_crosstable.Rd b/man/tm_t_crosstable.Rd index dc3ab1578..c8d5c7d4b 100644 --- a/man/tm_t_crosstable.Rd +++ b/man/tm_t_crosstable.Rd @@ -77,7 +77,7 @@ This module generates the following objects, which can be modified in place usin } For additional details and examples of decorators, refer to the vignette -\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[=teal_transform_module]{teal_transform_module()}} documentation. +\code{vignette("decorate-modules-output", package = "teal")} or the \code{\link[teal:teal_transform_module]{teal::teal_transform_module()}} documentation. } \examples{ From 46e5267951f341d7245042a1826d31406c0f2417 Mon Sep 17 00:00:00 2001 From: llrs-roche Date: Thu, 12 Dec 2024 08:16:38 +0000 Subject: [PATCH 38/42] [skip actions] Bump version to 0.3.0.9059 --- DESCRIPTION | 4 ++-- NEWS.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index e407ae6a5..6bfe1b280 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,8 +1,8 @@ Type: Package Package: teal.modules.general Title: General Modules for 'teal' Applications -Version: 0.3.0.9058 -Date: 2024-12-11 +Version: 0.3.0.9059 +Date: 2024-12-12 Authors@R: c( person("Dawid", "Kaledkowski", , "dawid.kaledkowski@roche.com", role = c("aut", "cre")), person("Pawel", "Rucki", , "pawel.rucki@roche.com", role = "aut"), diff --git a/NEWS.md b/NEWS.md index 017066db1..fb8b0df6a 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,4 +1,4 @@ -# teal.modules.general 0.3.0.9058 +# teal.modules.general 0.3.0.9059 * Removed `Show Warnings` modals from modules. From 5cf5f142dd747885672d4677cd289a223ab137b6 Mon Sep 17 00:00:00 2001 From: Marcin <133694481+m7pr@users.noreply.github.com> Date: Mon, 16 Dec 2024 10:01:02 +0100 Subject: [PATCH 39/42] 87 remove datasets - decrease package size (#818) In the spirit of package size reduction https://github.com/insightsengineering/nestdevs-tasks/issues/87 I replaced all the calls for tmg datasets with their respective datasets from teal.data. This way we no longer need to have datasets copies in tmg. --------- Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- R/data.R | 39 ------------------ R/tm_a_pca.R | 2 +- R/tm_a_regression.R | 2 +- R/tm_data_table.R | 2 +- R/tm_front_page.R | 2 +- R/tm_g_association.R | 2 +- R/tm_g_bivariate.R | 2 +- R/tm_g_distribution.R | 2 +- R/tm_g_response.R | 2 +- R/tm_g_scatterplot.R | 2 +- R/tm_g_scatterplotmatrix.R | 4 +- R/tm_missing_data.R | 2 +- R/tm_outliers.R | 2 +- R/tm_t_crosstable.R | 2 +- R/tm_variable_browser.R | 4 +- data-raw/data.R | 15 ------- data/rADAE.rda | Bin 102669 -> 0 bytes data/rADLB.rda | Bin 430378 -> 0 bytes data/rADRS.rda | Bin 58598 -> 0 bytes data/rADSL.rda | Bin 22556 -> 0 bytes data/rADTTE.rda | Bin 64158 -> 0 bytes man/rADAE.Rd | 20 --------- man/rADLB.Rd | 20 --------- man/rADRS.Rd | 20 --------- man/rADSL.Rd | 20 --------- man/rADTTE.Rd | 20 --------- man/tm_a_pca.Rd | 6 +-- man/tm_a_regression.Rd | 6 +-- man/tm_data_table.Rd | 6 +-- man/tm_front_page.Rd | 6 +-- man/tm_g_association.Rd | 6 +-- man/tm_g_bivariate.Rd | 6 +-- man/tm_g_distribution.Rd | 6 +-- man/tm_g_response.Rd | 6 +-- man/tm_g_scatterplot.Rd | 6 +-- man/tm_g_scatterplotmatrix.Rd | 8 ++-- man/tm_missing_data.Rd | 6 +-- man/tm_outliers.Rd | 6 +-- man/tm_t_crosstable.Rd | 6 +-- man/tm_variable_browser.Rd | 8 ++-- tests/testthat/helper-TealAppDriver.R | 2 +- .../test-shinytest2-tm_g_distribution.R | 2 +- .../testthat/test-shinytest2-tm_g_response.R | 2 +- .../test-shinytest2-tm_g_scatterplot.R | 2 +- vignettes/teal-modules-general.Rmd | 8 ++-- vignettes/using-association-plot.Rmd | 8 ++-- vignettes/using-bivariate-plot.Rmd | 8 ++-- vignettes/using-cross-table.Rmd | 4 +- vignettes/using-data-table.Rmd | 6 +-- vignettes/using-outliers-module.Rmd | 6 +-- vignettes/using-regression-plots.Rmd | 8 ++-- vignettes/using-response-plot.Rmd | 8 ++-- vignettes/using-scatterplot-matrix.Rmd | 8 ++-- vignettes/using-scatterplot.Rmd | 14 +++---- 54 files changed, 103 insertions(+), 257 deletions(-) delete mode 100644 R/data.R delete mode 100644 data-raw/data.R delete mode 100644 data/rADAE.rda delete mode 100644 data/rADLB.rda delete mode 100644 data/rADRS.rda delete mode 100644 data/rADSL.rda delete mode 100644 data/rADTTE.rda delete mode 100644 man/rADAE.Rd delete mode 100644 man/rADLB.Rd delete mode 100644 man/rADRS.Rd delete mode 100644 man/rADSL.Rd delete mode 100644 man/rADTTE.Rd diff --git a/R/data.R b/R/data.R deleted file mode 100644 index 0f8a64e04..000000000 --- a/R/data.R +++ /dev/null @@ -1,39 +0,0 @@ -#' Random adverse events -#' @docType data -#' @usage rADAE -#' @keywords datasets internal -#' @source internal -#' @name rADAE -"rADAE" - -#' Random lab analysis -#' @docType data -#' @usage rADLB -#' @keywords datasets internal -#' @source internal -#' @name rADLB -"rADLB" - -#' Random response -#' @docType data -#' @usage rADRS -#' @keywords datasets internal -#' @source internal -#' @name rADRS -"rADRS" - -#' Random patient listing -#' @docType data -#' @usage rADSL -#' @keywords datasets internal -#' @source internal -#' @name rADSL -"rADSL" - -#' Random time to event analysis dataset -#' @docType data -#' @usage rADTTE -#' @keywords datasets internal -#' @source internal -#' @name rADTTE -"rADTTE" diff --git a/R/tm_a_pca.R b/R/tm_a_pca.R index e5960be33..0398ac555 100644 --- a/R/tm_a_pca.R +++ b/R/tm_a_pca.R @@ -93,7 +93,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_a_regression.R b/R/tm_a_regression.R index 508c04d4b..e5d76d95c 100644 --- a/R/tm_a_regression.R +++ b/R/tm_a_regression.R @@ -106,7 +106,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_data_table.R b/R/tm_data_table.R index 022026e7a..0f1e6a9a8 100644 --- a/R/tm_data_table.R +++ b/R/tm_data_table.R @@ -74,7 +74,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_front_page.R b/R/tm_front_page.R index 6cdbb0ce8..841b38f86 100644 --- a/R/tm_front_page.R +++ b/R/tm_front_page.R @@ -25,7 +25,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' attr(ADSL, "metadata") <- list("Author" = "NEST team", "data_source" = "synthetic data") #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] diff --git a/R/tm_g_association.R b/R/tm_g_association.R index f2c4f479e..941448f67 100644 --- a/R/tm_g_association.R +++ b/R/tm_g_association.R @@ -86,7 +86,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_g_bivariate.R b/R/tm_g_bivariate.R index ae88491cc..26c7b5c86 100644 --- a/R/tm_g_bivariate.R +++ b/R/tm_g_bivariate.R @@ -123,7 +123,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_g_distribution.R b/R/tm_g_distribution.R index 1c7b5aa92..445ce5791 100644 --- a/R/tm_g_distribution.R +++ b/R/tm_g_distribution.R @@ -94,7 +94,7 @@ #' # CDISC data example #' data <- teal_data() #' data <- within(data, { -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_g_response.R b/R/tm_g_response.R index 219463a55..98d7647e1 100644 --- a/R/tm_g_response.R +++ b/R/tm_g_response.R @@ -104,7 +104,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_g_scatterplot.R b/R/tm_g_scatterplot.R index eaab0e1e5..96d8d2b73 100644 --- a/R/tm_g_scatterplot.R +++ b/R/tm_g_scatterplot.R @@ -140,7 +140,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_g_scatterplotmatrix.R b/R/tm_g_scatterplotmatrix.R index 37c4899d7..ec7d4c2b2 100644 --- a/R/tm_g_scatterplotmatrix.R +++ b/R/tm_g_scatterplotmatrix.R @@ -122,8 +122,8 @@ #' # CDISC data example #' data <- teal_data() #' data <- within(data, { -#' ADSL <- rADSL -#' ADRS <- rADRS +#' ADSL <- teal.data::rADSL +#' ADRS <- teal.data::rADRS #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_missing_data.R b/R/tm_missing_data.R index bd49368e7..97469e39e 100644 --- a/R/tm_missing_data.R +++ b/R/tm_missing_data.R @@ -90,7 +90,7 @@ #' data <- teal_data() #' data <- within(data, { #' require(nestcolor) -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' ADRS <- rADRS #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] diff --git a/R/tm_outliers.R b/R/tm_outliers.R index 4fc3ba7b4..b9fdd90e6 100644 --- a/R/tm_outliers.R +++ b/R/tm_outliers.R @@ -104,7 +104,7 @@ #' # CDISC data example #' data <- teal_data() #' data <- within(data, { -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_t_crosstable.R b/R/tm_t_crosstable.R index 9c8737fa6..de65386f2 100644 --- a/R/tm_t_crosstable.R +++ b/R/tm_t_crosstable.R @@ -91,7 +91,7 @@ #' # CDISC data example #' data <- teal_data() #' data <- within(data, { -#' ADSL <- rADSL +#' ADSL <- teal.data::rADSL #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/R/tm_variable_browser.R b/R/tm_variable_browser.R index 708c835e7..96c58718d 100644 --- a/R/tm_variable_browser.R +++ b/R/tm_variable_browser.R @@ -61,8 +61,8 @@ #' library(sparkline) #' data <- teal_data() #' data <- within(data, { -#' ADSL <- rADSL -#' ADTTE <- rADTTE +#' ADSL <- teal.data::rADSL +#' ADTTE <- teal.data::rADTTE #' }) #' join_keys(data) <- default_cdisc_join_keys[names(data)] #' diff --git a/data-raw/data.R b/data-raw/data.R deleted file mode 100644 index a01b65119..000000000 --- a/data-raw/data.R +++ /dev/null @@ -1,15 +0,0 @@ -## code to prepare `data` for testing examples -rADAE <- random.cdisc.data::cadae -usethis::use_data(rADAE) - -rADLB <- random.cdisc.data::cadlb -usethis::use_data(rADLB) - -rADRS <- random.cdisc.data::cadrs -usethis::use_data(rADRS) - -rADSL <- random.cdisc.data::cadsl -usethis::use_data(rADSL) - -rADTTE <- random.cdisc.data::cadtte -usethis::use_data(rADTTE) diff --git a/data/rADAE.rda b/data/rADAE.rda deleted file mode 100644 index a1ad1463f24366eba09dce6221cd1913ac6f1b05..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 102669 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 P|M7PuQ-uiyvJXgrYlYiF diff --git a/data/rADLB.rda b/data/rADLB.rda deleted file mode 100644 index 188087301226a5e86b5e55b5f261a97cf198f787..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 430378 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
  • ! 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%0AKbi7hRtkhqPbf>04b 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