From 6c611cc54ad39cdd4179679963bff313495d51f6 Mon Sep 17 00:00:00 2001 From: Daniel Sjoberg Date: Wed, 20 Nov 2024 17:38:51 -0800 Subject: [PATCH 1/4] Updated examples in `add_p.tbl_continuous()` (#2073) * Updated examples in `add_p.tbl_continuous()` * Improving error messaging --- R/add_p.R | 2 +- R/add_p.tbl_continuous.R | 10 ++++++++-- man/add_p.tbl_continuous.Rd | 10 ++++++++-- tests/testthat/test-add_p.tbl_continuous.R | 8 ++++++++ 4 files changed, 25 insertions(+), 5 deletions(-) diff --git a/R/add_p.R b/R/add_p.R index d403f660d..12a11fa05 100644 --- a/R/add_p.R +++ b/R/add_p.R @@ -269,7 +269,7 @@ calculate_and_add_test_results <- function(x, include, group = NULL, test.args, if (!is.null(lst_captured_results[["result"]])) return(lst_captured_results[["result"]]) # styler: off # otherwise, construct a {cards}-like object with error dplyr::tibble( - group1 = x$inputs$by, + group1 = switch(!is_empty(x$inputs$by), x$inputs$by), variable = variable, stat_name = switch(calling_fun, "add_p" = "p.value", diff --git a/R/add_p.tbl_continuous.R b/R/add_p.tbl_continuous.R index f3d2cb765..d7914c95a 100644 --- a/R/add_p.tbl_continuous.R +++ b/R/add_p.tbl_continuous.R @@ -11,10 +11,16 @@ #' @export #' @return 'tbl_continuous' object #' -#' @examplesIf gtsummary:::is_pkg_installed("cardx") +#' @examplesIf (identical(Sys.getenv("NOT_CRAN"), "true") || identical(Sys.getenv("IN_PKGDOWN"), "true")) && gtsummary:::is_pkg_installed("cardx") +#' # Example 1 ---------------------------------- #' trial |> #' tbl_continuous(variable = age, by = trt, include = grade) |> -#' add_p() +#' add_p(pvalue_fun = label_style_pvalue(digits = 2)) +#' +#' # Example 2 ---------------------------------- +#' trial |> +#' tbl_continuous(variable = age, include = grade) |> +#' add_p(test = everything() ~ "kruskal.test") add_p.tbl_continuous <- function(x, test = NULL, pvalue_fun = label_style_pvalue(digits = 1), diff --git a/man/add_p.tbl_continuous.Rd b/man/add_p.tbl_continuous.Rd index 13fa7ef2a..33aedecdb 100644 --- a/man/add_p.tbl_continuous.Rd +++ b/man/add_p.tbl_continuous.Rd @@ -51,9 +51,15 @@ Default is \code{NULL}. See \link{tests} for methods that utilize the \code{grou Add p-values } \examples{ -\dontshow{if (gtsummary:::is_pkg_installed("cardx")) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} +\dontshow{if ((identical(Sys.getenv("NOT_CRAN"), "true") || identical(Sys.getenv("IN_PKGDOWN"), "true")) && gtsummary:::is_pkg_installed("cardx")) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} +# Example 1 ---------------------------------- trial |> tbl_continuous(variable = age, by = trt, include = grade) |> - add_p() + add_p(pvalue_fun = label_style_pvalue(digits = 2)) + +# Example 2 ---------------------------------- +trial |> + tbl_continuous(variable = age, include = grade) |> + add_p(test = everything() ~ "kruskal.test") \dontshow{\}) # examplesIf} } diff --git a/tests/testthat/test-add_p.tbl_continuous.R b/tests/testthat/test-add_p.tbl_continuous.R index 0a5376fdf..91154dde3 100644 --- a/tests/testthat/test-add_p.tbl_continuous.R +++ b/tests/testthat/test-add_p.tbl_continuous.R @@ -111,3 +111,11 @@ test_that("add_p.tbl_continuous(group) works", { unlist(compare) ) }) + +test_that("add_p.tbl_continuous() messaging", { + expect_message( + tbl_continuous(trial, variable = age, include = grade) |> + add_p(test = ~"lme4"), + "*argument cannot be missing*" + ) +}) From 46fa590aec6d5815e05688fe175fb0417bcb0704 Mon Sep 17 00:00:00 2001 From: Daniel Sjoberg Date: Wed, 20 Nov 2024 18:12:09 -0800 Subject: [PATCH 2/4] doc updates (#2074) --- R/tbl_ard_summary.R | 16 ++++++++++++++++ man/tbl_ard_summary.Rd | 15 +++++++++++++++ 2 files changed, 31 insertions(+) diff --git a/R/tbl_ard_summary.R b/R/tbl_ard_summary.R index 73d54b7be..547018ac0 100644 --- a/R/tbl_ard_summary.R +++ b/R/tbl_ard_summary.R @@ -36,6 +36,22 @@ #' Default is `FALSE`. #' @inheritParams tbl_summary #' +#' @details +#' There are three types of additional data that can be included in the ARD to +#' improve the default appearance of the table. +#' +#' 1. **Attributes**: When attributes are included, the default labels will be +#' the variable labels, when available. Attributes can be included in an ARD +#' with `cards::ard_attributes()` or `ard_stack(.attributes = TRUE)`. +#' +#' 2. **Missing**: When missing results are included, users can include +#' missing counts or rates for variables with `tbl_ard_summary(missing = c("ifany", "always"))`. +#' The missing statistics can be included in an ARD with +#' `cards::ard_missing()` or `ard_stack(.missing = TRUE)`. +#' +#' 3. **Total N**: The total N is saved internally when available, and it can +#' be calculated with `cards::ard_total_n()` or `ard_stack(.total_n = TRUE)`. +#' #' @return a gtsummary table of class `"tbl_ard_summary"` #' @export #' diff --git a/man/tbl_ard_summary.Rd b/man/tbl_ard_summary.Rd index 8edbc1e29..cf6ffa7f8 100644 --- a/man/tbl_ard_summary.Rd +++ b/man/tbl_ard_summary.Rd @@ -70,6 +70,21 @@ The \code{tbl_ard_summary()} function tables descriptive statistics for continuous, categorical, and dichotomous variables. The functions accepts an ARD object. } +\details{ +There are three types of additional data that can be included in the ARD to +improve the default appearance of the table. +\enumerate{ +\item \strong{Attributes}: When attributes are included, the default labels will be +the variable labels, when available. Attributes can be included in an ARD +with \code{cards::ard_attributes()} or \code{ard_stack(.attributes = TRUE)}. +\item \strong{Missing}: When missing results are included, users can include +missing counts or rates for variables with \code{tbl_ard_summary(missing = c("ifany", "always"))}. +The missing statistics can be included in an ARD with +\code{cards::ard_missing()} or \code{ard_stack(.missing = TRUE)}. +\item \strong{Total N}: The total N is saved internally when available, and it can +be calculated with \code{cards::ard_total_n()} or \code{ard_stack(.total_n = TRUE)}. +} +} \examples{ library(cards) From 25c739d258cc1ba2fa3b6eea17febd5e68045562 Mon Sep 17 00:00:00 2001 From: Daniel Sjoberg Date: Wed, 20 Nov 2024 18:41:57 -0800 Subject: [PATCH 3/4] doc update (#2075) --- R/tbl_strata.R | 3 +-- man/tbl_strata.Rd | 3 +-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/R/tbl_strata.R b/R/tbl_strata.R index 83341d23f..ddfe5df06 100644 --- a/R/tbl_strata.R +++ b/R/tbl_strata.R @@ -85,8 +85,7 @@ #' modify_header(stat_0 = "**Rate (95% CI)**") |> #' modify_footnote(stat_0 = NA), #' .combine_with = "tbl_stack", -#' .combine_args = list(group_header = NULL), -#' .quiet = TRUE +#' .combine_args = list(group_header = NULL) #' ) |> #' modify_caption("**Response Rate by Grade**") NULL diff --git a/man/tbl_strata.Rd b/man/tbl_strata.Rd index 807b38950..b5df493bf 100644 --- a/man/tbl_strata.Rd +++ b/man/tbl_strata.Rd @@ -129,8 +129,7 @@ trial |> modify_header(stat_0 = "**Rate (95\% CI)**") |> modify_footnote(stat_0 = NA), .combine_with = "tbl_stack", - .combine_args = list(group_header = NULL), - .quiet = TRUE + .combine_args = list(group_header = NULL) ) |> modify_caption("**Response Rate by Grade**") } From ad4005f800176b94cc2ae385526269566848771b Mon Sep 17 00:00:00 2001 From: Daniel Sjoberg Date: Thu, 21 Nov 2024 13:14:56 -0800 Subject: [PATCH 4/4] Adding `modify_source_note()` function (#2071) * adding source note functions * Update _pkgdown.yml --- NAMESPACE | 2 + R/add_glance.R | 11 ++- R/add_p.tbl_cross.R | 9 ++- R/as_flex_table.R | 15 ++-- R/as_gt.R | 20 +++-- R/as_hux_table.R | 15 ++-- R/modify_source_note.R | 89 +++++++++++++++++++++ R/utils-as.R | 5 ++ R/utils-gtsummary_core.R | 7 ++ man/modify_source_note.Rd | 38 +++++++++ pkgdown/_pkgdown.yml | 1 + tests/testthat/_snaps/modify_source_note.md | 27 +++++++ tests/testthat/test-add_glance.R | 18 +++-- tests/testthat/test-add_p.tbl_cross.R | 3 +- tests/testthat/test-as_flex_table.R | 2 +- tests/testthat/test-as_gt.R | 2 +- tests/testthat/test-as_hux_table.R | 2 +- tests/testthat/test-modify_source_note.R | 74 +++++++++++++++++ 18 files changed, 301 insertions(+), 39 deletions(-) create mode 100644 R/modify_source_note.R create mode 100644 man/modify_source_note.Rd create mode 100644 tests/testthat/_snaps/modify_source_note.md create mode 100644 tests/testthat/test-modify_source_note.R diff --git a/NAMESPACE b/NAMESPACE index 6fa0cb371..21100d773 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -163,6 +163,7 @@ export(modify_column_unhide) export(modify_fmt_fun) export(modify_footnote) export(modify_header) +export(modify_source_note) export(modify_spanning_header) export(modify_table_body) export(modify_table_styling) @@ -180,6 +181,7 @@ export(pool_and_tidy_mice) export(proportion_summary) export(ratio_summary) export(remove_row_type) +export(remove_source_note) export(reset_gtsummary_theme) export(scope_header) export(scope_table_body) diff --git a/R/add_glance.R b/R/add_glance.R index 36f810f10..5e684ff5c 100644 --- a/R/add_glance.R +++ b/R/add_glance.R @@ -140,6 +140,7 @@ add_glance_source_note <- function(x, text_interpret <- arg_match(text_interpret) check_string(sep1) check_string(sep2) + text_interpret <- arg_match(text_interpret, error_call = get_cli_abort_call()) # calculate and prepare the glance function results -------------------------- lst_prep_glance <- @@ -161,9 +162,13 @@ add_glance_source_note <- function(x, } # compile stats into source note --------------------------------------------- - x$table_styling$source_note <- - paste(lst_prep_glance$df_glance$label, lst_prep_glance$df_glance$estimate_fmt, sep = sep1, collapse = sep2) - attr(x$table_styling$source_note, "text_interpret") <- match.arg(text_interpret) + x <- + modify_source_note( + x, + source_note = + paste(lst_prep_glance$df_glance$label, lst_prep_glance$df_glance$estimate_fmt, sep = sep1, collapse = sep2), + text_interpret = text_interpret + ) # returning gtsummary table -------------------------------------------------- x$call_list <- updated_call_list diff --git a/R/add_p.tbl_cross.R b/R/add_p.tbl_cross.R index 5b32e13af..3dbe7bddd 100644 --- a/R/add_p.tbl_cross.R +++ b/R/add_p.tbl_cross.R @@ -109,11 +109,12 @@ add_p.tbl_cross <- function(x, columns = "p.value", footnote = NA_character_, hide = TRUE + ) |> + modify_source_note( + source_note = + paste(test_name, pvalue_fun(discard(x$table_body$p.value, is.na)), sep = ", "), + text_interpret = "md" ) - - x$table_styling$source_note <- - paste(test_name, pvalue_fun(discard(x$table_body$p.value, is.na)), sep = ", ") - attr(x$table_styling$source_note, "text_interpret") <- "md" } # strip markdown bold around column label ------------------------------------ diff --git a/R/as_flex_table.R b/R/as_flex_table.R index 6a5630538..fb08dac42 100644 --- a/R/as_flex_table.R +++ b/R/as_flex_table.R @@ -317,12 +317,15 @@ table_styling_to_flextable_calls <- function(x, ...) { # source note ---------------------------------------------------------------- # in flextable, this is just a footnote associated without column or symbol - if (!is.null(x$table_styling$source_note)) { - flextable_calls[["source_note"]] <- - expr( - flextable::add_footer_lines(value = flextable::as_paragraph(!!x$table_styling$source_note)) - ) - } + flextable_calls[["source_note"]] <- + map( + seq_len(nrow(x$table_styling$source_note)), + \(i) { + expr( + flextable::add_footer_lines(value = flextable::as_paragraph(!!x$table_styling$source_note$source_note[i])) + ) + } + ) # border --------------------------------------------------------------------- flextable_calls[["border"]] <- diff --git a/R/as_gt.R b/R/as_gt.R index 2cfd0935a..f54ebfe4d 100644 --- a/R/as_gt.R +++ b/R/as_gt.R @@ -325,14 +325,18 @@ table_styling_to_gt_calls <- function(x, ...) { # tab_source_note ----------------------------------------------------------- # adding other calls from x$table_styling$source_note - if (!is.null(x$table_styling$source_note)) { - source_note <- - rlang::call2( - get(attr(x$table_styling$source_note, "text_interpret"), envir = asNamespace("gt")), - x$table_styling$source_note - ) - gt_calls[["tab_source_note"]] <- expr(gt::tab_source_note(source_note = !!source_note)) - } + gt_calls[["tab_source_note"]] <- + map( + seq_len(nrow(x$table_styling$source_note)), + \(i) { + expr( + gt::tab_source_note(source_note = + !!do.call(eval(rlang::parse_expr(x$table_styling$source_note$text_interpret[i])), + args = list(x$table_styling$source_note$source_note[i]))) + ) + } + ) + # cols_hide ------------------------------------------------------------------ gt_calls[["cols_hide"]] <- diff --git a/R/as_hux_table.R b/R/as_hux_table.R index 3a0ad5ee8..8af3841b2 100644 --- a/R/as_hux_table.R +++ b/R/as_hux_table.R @@ -206,14 +206,15 @@ table_styling_to_huxtable_calls <- function(x, ...) { } # source note ---------------------------------------------------------------- - if (!is.null(x$table_styling$source_note)) { - huxtable_calls[["add_footnote"]] <- append( - huxtable_calls[["add_footnote"]], - expr( - huxtable::add_footnote(text = !!x$table_styling$source_note) - ) + huxtable_calls[["source_note"]] <- + map( + seq_len(nrow(x$table_styling$source_note)), + \(i) { + expr( + huxtable::add_footnote(text = !!x$table_styling$source_note$source_note[i]) + ) + } ) - } # bold ----------------------------------------------------------------------- df_bold <- diff --git a/R/modify_source_note.R b/R/modify_source_note.R new file mode 100644 index 000000000..05ed03c26 --- /dev/null +++ b/R/modify_source_note.R @@ -0,0 +1,89 @@ +#' Modify source note +#' +#' @description +#' Add and remove source notes from a table. +#' Source notes are similar to footnotes, expect they are not linked to a cell in +#' the table. +#' +#' @param x (`gtsummary`)\cr +#' A gtsummary object. +#' @param source_note (`string`)\cr +#' A string to add as a source note. +#' @param source_note_id (`integers`)\cr +#' Integers specifying the ID of the source note to remove. +#' Source notes are indexed sequentially at the time of creation. +#' @inheritParams modify +#' +#' @details +#' Source notes are not supported by `as_kable_extra()`. +#' +#' +#' @return gtsummary object +#' @name modify_source_note +#' +#' @examplesIf identical(Sys.getenv("NOT_CRAN"), "true") || identical(Sys.getenv("IN_PKGDOWN"), "true") +#' +NULL + +#' @export +#' @rdname modify_source_note +modify_source_note <- function(x, source_note, text_interpret = c("md", "html")) { + set_cli_abort_call() + updated_call_list <- c(x$call_list, list(modify_source_note = match.call())) + + # check inputs --------------------------------------------------------------- + check_not_missing(x) + check_not_missing(source_note) + check_class(x, "gtsummary") + check_string(source_note) + text_interpret <- arg_match(text_interpret, error_call = get_cli_abort_call()) + + # add source note to table_styling ------------------------------------------- + x$table_styling$source_note <- + dplyr::bind_rows( + x$table_styling$source_note, + dplyr::tibble( + id = nrow(x$table_styling$source_note) + 1L, + source_note = source_note, + text_interpret = paste0("gt::", text_interpret), + remove = FALSE + ) + ) + + # return table --------------------------------------------------------------- + x$call_list <- updated_call_list + x +} + +#' @export +#' @rdname modify_source_note +remove_source_note <- function(x, source_note_id) { + set_cli_abort_call() + updated_call_list <- c(x$call_list, list(remove_source_note = match.call())) + + # check inputs --------------------------------------------------------------- + check_not_missing(x) + check_not_missing(source_note_id) + check_class(x, "gtsummary") + check_integerish(source_note_id, allow_empty = TRUE) + + # mark source note for removal ----------------------------------------------- + if (!is_empty(source_note_id)) { + if (any(!source_note_id %in% x$table_styling$source_note$id)) { + cli::cli_abort( + c("Argument {.arg source_note_id} is out of bounds.", + i = "Must be one or more of {.val {x$table_styling$source_note$id}} or {.code NULL}."), + call = get_cli_abort_call() + ) + } + + x$table_styling$source_note$remove[x$table_styling$source_note$id %in% source_note_id] <- TRUE + } + else { + x$table_styling$source_note$remove <- TRUE + } + + # return table --------------------------------------------------------------- + x$call_list <- updated_call_list + x +} diff --git a/R/utils-as.R b/R/utils-as.R index 259ed7698..eba2e73be 100644 --- a/R/utils-as.R +++ b/R/utils-as.R @@ -71,6 +71,11 @@ dplyr::select("column", "row_numbers", everything()) %>% dplyr::ungroup() + # source_note ---------------------------------------------------------------- + x$table_styling$source_note <- + x$table_styling$source_note |> + dplyr::filter(.data$remove == FALSE) + # indentation ---------------------------------------------------------------- x$table_styling$indent <- x$table_styling$indent %>% diff --git a/R/utils-gtsummary_core.R b/R/utils-gtsummary_core.R index 4b0ccfa71..e48a05468 100644 --- a/R/utils-gtsummary_core.R +++ b/R/utils-gtsummary_core.R @@ -39,6 +39,13 @@ column = character(), rows = list(), text_interpret = character(), footnote = character() ) + x$table_styling$source_note <- + dplyr::tibble( + id = integer(), + source_note = character(), + text_interpret = character(), + remove = logical() + ) x$table_styling$text_format <- dplyr::tibble( column = character(), rows = list(), diff --git a/man/modify_source_note.Rd b/man/modify_source_note.Rd new file mode 100644 index 000000000..eaaa71c2c --- /dev/null +++ b/man/modify_source_note.Rd @@ -0,0 +1,38 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/modify_source_note.R +\name{modify_source_note} +\alias{modify_source_note} +\alias{remove_source_note} +\title{Modify source note} +\usage{ +modify_source_note(x, source_note, text_interpret = c("md", "html")) + +remove_source_note(x, source_note_id) +} +\arguments{ +\item{x}{(\code{gtsummary})\cr +A gtsummary object.} + +\item{source_note}{(\code{string})\cr +A string to add as a source note.} + +\item{text_interpret}{(\code{string})\cr +String indicates whether text will be interpreted with +\code{\link[gt:md]{gt::md()}} or \code{\link[gt:html]{gt::html()}}. Must be \code{"md"} (default) or \code{"html"}.} + +\item{source_note_id}{(\code{integers})\cr +Integers specifying the ID of the source note to remove. +Source notes are indexed sequentially at the time of creation.} +} +\value{ +gtsummary object +} +\description{ +Add and remove source notes from a table. +Source notes are similar to footnotes, expect they are not linked to a cell in +the table. +} +\examples{ +\dontshow{if (identical(Sys.getenv("NOT_CRAN"), "true") || identical(Sys.getenv("IN_PKGDOWN"), "true")) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} +\dontshow{\}) # examplesIf} +} diff --git a/pkgdown/_pkgdown.yml b/pkgdown/_pkgdown.yml index 99a55d843..b195af0ad 100644 --- a/pkgdown/_pkgdown.yml +++ b/pkgdown/_pkgdown.yml @@ -161,6 +161,7 @@ reference: - subtitle: Style Summary Tables - contents: - modify + - modify_source_note - modify_caption - bold_italicize_labels_levels - bold_p diff --git a/tests/testthat/_snaps/modify_source_note.md b/tests/testthat/_snaps/modify_source_note.md new file mode 100644 index 000000000..5856839cf --- /dev/null +++ b/tests/testthat/_snaps/modify_source_note.md @@ -0,0 +1,27 @@ +# modify_source_note() messaging + + Code + modify_source_note(tbl_summary(trial, include = trt), source_note = letters) + Condition + Error in `modify_source_note()`: + ! The `source_note` argument must be a string, not a character vector. + +--- + + Code + modify_source_note(tbl_summary(trial, include = trt), source_note = "ttt", + text_interpret = letters) + Condition + Error in `modify_source_note()`: + ! `text_interpret` must be one of "md" or "html", not "a". + +# remove_source_note(source_note_id) messaging + + Code + remove_source_note(modify_source_note(tbl_summary(trial, include = trt), + "Created June 26, 2015"), source_note_id = 100) + Condition + Error in `remove_source_note()`: + ! Argument `source_note_id` is out of bounds. + i Must be one or more of 1 or `NULL`. + diff --git a/tests/testthat/test-add_glance.R b/tests/testthat/test-add_glance.R index f628c5067..dc77fee96 100644 --- a/tests/testthat/test-add_glance.R +++ b/tests/testthat/test-add_glance.R @@ -8,6 +8,7 @@ test_that("add_glance_source_note(x)", { tbl_regression() |> add_glance_source_note() |> getElement("table_styling") |> + getElement("source_note") |> getElement("source_note"), "R² = 0.000; Adjusted R² = -0.005; Sigma = 14.3; Statistic = 0.044; p-value = 0.8; df = 1; Log-likelihood = -771; AIC = 1,547; BIC = 1,557; Deviance = 38,499; Residual df = 187; No. Obs. = 189", ignore_attr = TRUE @@ -20,6 +21,7 @@ test_that("add_glance_source_note(include,label)", { tbl_regression() |> add_glance_source_note(include = r.squared, label = r.squared ~ "R * R") |> getElement("table_styling") |> + getElement("source_note") |> getElement("source_note"), "R * R = 0.000", ignore_attr = TRUE @@ -32,6 +34,7 @@ test_that("add_glance_source_note(fmt_fn)", { tbl_regression() |> add_glance_source_note(fmt_fun = ~label_style_sigfig(digits = 5), include = 1:3) |> getElement("table_styling") |> + getElement("source_note") |> getElement("source_note"), "R² = 0.00024; Adjusted R² = -0.00511; Sigma = 14.348", ignore_attr = TRUE @@ -44,11 +47,13 @@ test_that("add_glance_source_note(glance_fun)", { tbl_regression() |> add_glance_source_note(glance_fun = \(x, ...) broom::glance(x, ...) |> dplyr::select(1:3)) |> getElement("table_styling") |> + getElement("source_note") |> getElement("source_note"), lm(age ~ trt, trial) |> tbl_regression() |> add_glance_source_note(include = 1:3) |> getElement("table_styling") |> + getElement("source_note") |> getElement("source_note") ) }) @@ -60,8 +65,8 @@ test_that("add_glance_source_note(text_interpret)", { add_glance_source_note(text_interpret = "html") |> getElement("table_styling") |> getElement("source_note") |> - attr("text_interpret"), - "html" + getElement("text_interpret"), + "gt::html" ) }) @@ -71,7 +76,8 @@ test_that("add_glance_source_note(sep1,sep2)", { tbl_regression() |> add_glance_source_note(include = 1:3, sep1 = "==", sep2 = " | ") |> getElement("table_styling") |> - getElement("source_note") , + getElement("source_note") |> + getElement("source_note"), "R²==0.000 | Adjusted R²==-0.005 | Sigma==14.3", ignore_attr = TRUE ) @@ -132,9 +138,8 @@ test_that("add_glance_table(glance_fun) for mice models", { tbl <- mice::mice(mice::nhanes2, print = FALSE, maxit = 1) |> with(lm(bmi ~ age)) |> tbl_regression() - glance <- tbl$inputs$x |> - mice::pool() |> - broom::glance() |> + glance <- tbl$inputs$x %>% + {suppressWarnings(broom::glance(mice::pool(.)))} |> dplyr::mutate( across(c(nimp, nobs), label_style_number()), across(c(r.squared, adj.r.squared), label_style_number(digits = 3)) @@ -156,6 +161,7 @@ test_that("add_glance_table(glance_fun) for mice models", { label = names(glance) |> as.list() |> setNames(names(glance)) ) |> getElement("table_styling") |> + getElement("source_note") |> getElement("source_note"), imap(glance, ~paste0(.y, " = ", .x)) |> unlist() |> paste(collapse = "; "), ignore_attr = TRUE diff --git a/tests/testthat/test-add_p.tbl_cross.R b/tests/testthat/test-add_p.tbl_cross.R index 54efa1791..d488b373e 100644 --- a/tests/testthat/test-add_p.tbl_cross.R +++ b/tests/testthat/test-add_p.tbl_cross.R @@ -19,8 +19,7 @@ test_that("add_p.tbl_cross(source_note) works", { expect_equal(round(out$table_body$p.value[1], 4), 0.8662) source_nt <- "Pearson's Chi-squared test, p=0.9" - attr(source_nt, "text_interpret") <- "md" - expect_equal(out$table_styling$source_note, source_nt) + expect_equal(out$table_styling$source_note$source_note, source_nt) }) test_that("add_p.tbl_cross(source_note) errors properly", { diff --git a/tests/testthat/test-as_flex_table.R b/tests/testthat/test-as_flex_table.R index 982573661..e6830028e 100644 --- a/tests/testthat/test-as_flex_table.R +++ b/tests/testthat/test-as_flex_table.R @@ -302,7 +302,7 @@ test_that("as_flex_table passes appended glance statistics correctly", { ignore_attr = c("class", "names") ) expect_equal( - tbl$table_styling$source_note[1], + tbl$table_styling$source_note$source_note, ft_tbl$footer$content$data[2, ]$label$txt ) expect_equal(length(ft_tbl$body$hrule), 3) diff --git a/tests/testthat/test-as_gt.R b/tests/testthat/test-as_gt.R index 7e8fb6d12..8114ca4fd 100644 --- a/tests/testthat/test-as_gt.R +++ b/tests/testthat/test-as_gt.R @@ -302,7 +302,7 @@ test_that("as_gt passes appended glance statistics correctly", { ignore_attr = "class" ) expect_equal( - tbl$table_styling$source_note, + tbl$table_styling$source_note$source_note, gt_tbl$`_source_notes`[[1]], ignore_attr = "class" ) diff --git a/tests/testthat/test-as_hux_table.R b/tests/testthat/test-as_hux_table.R index ce2b7fa18..4e9014b80 100644 --- a/tests/testthat/test-as_hux_table.R +++ b/tests/testthat/test-as_hux_table.R @@ -25,7 +25,7 @@ test_that("as_hux_table(return_calls) works as expected", { # correct elements are returned expect_equal( names(ht), - c("tibble", "fmt", "cols_merge", "cols_hide", "huxtable", "set_left_padding", "add_footnote", + c("tibble", "fmt", "cols_merge", "cols_hide", "huxtable", "set_left_padding", "add_footnote", "source_note", "set_bold", "set_italic", "fmt_missing", "insert_row", "set_markdown", "align", "set_number_format") ) }) diff --git a/tests/testthat/test-modify_source_note.R b/tests/testthat/test-modify_source_note.R new file mode 100644 index 000000000..afd9786f6 --- /dev/null +++ b/tests/testthat/test-modify_source_note.R @@ -0,0 +1,74 @@ +skip_on_cran() + +test_that("modify_source_note(source_note)", { + expect_silent( + tbl <- tbl_summary(trial, include = trt) |> + modify_source_note("Created June 26, 2015") |> + modify_source_note("Created June 26, 2015") + ) + + expect_equal( + tbl$table_styling$source_note$source_note, + rep_len("Created June 26, 2015", length.out = 2L) + ) +}) + +test_that("modify_source_note(text_interpret)", { + expect_silent( + tbl <- tbl_summary(trial, include = trt) |> modify_source_note("Created June 26, 2015", text_interpret = "html") + ) + + expect_equal( + tbl$table_styling$source_note$text_interpret, + "gt::html" + ) +}) + +test_that("modify_source_note() messaging", { + expect_snapshot( + error = TRUE, + tbl_summary(trial, include = trt) |> + modify_source_note(source_note = letters) + ) + + expect_snapshot( + error = TRUE, + tbl_summary(trial, include = trt) |> + modify_source_note(source_note = "ttt", text_interpret = letters) + ) +}) + +test_that("remove_source_note(source_note_id)", { + expect_silent( + tbl <- tbl_summary(trial, include = trt) |> + modify_source_note("Created June 26, 2015") |> + modify_source_note("Created June 26, 2015") + ) + + expect_true( + tbl |> + remove_source_note(source_note_id = 1:2) |> + getElement("table_styling") |> + getElement("source_note") |> + getElement("remove") |> + unique() + ) + + expect_true( + tbl |> + remove_source_note(source_note_id = NULL) |> + getElement("table_styling") |> + getElement("source_note") |> + getElement("remove") |> + unique() + ) +}) + +test_that("remove_source_note(source_note_id) messaging", { + expect_snapshot( + error = TRUE, + tbl_summary(trial, include = trt) |> + modify_source_note("Created June 26, 2015") |> + remove_source_note(source_note_id = 100) + ) +})