diff --git a/DESCRIPTION b/DESCRIPTION index 6160037009..4dc9cc5ee7 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,7 +1,7 @@ Package: tern Title: Create Common TLGs Used in Clinical Trials -Version: 0.9.4.9010 -Date: 2024-06-16 +Version: 0.9.4.9007 +Date: 2024-05-14 Authors@R: c( person("Joe", "Zhu", , "joe.zhu@roche.com", role = c("aut", "cre")), person("Daniel", "Sabanés Bové", , "daniel.sabanes_bove@roche.com", role = "aut"), @@ -25,7 +25,7 @@ URL: https://insightsengineering.github.io/tern/, BugReports: https://github.com/insightsengineering/tern/issues Depends: R (>= 3.6), - rtables (>= 0.6.7.9004) + rtables (>= 0.6.7) Imports: broom (>= 0.5.4), car (>= 3.0-13), @@ -34,7 +34,7 @@ Imports: dplyr (>= 1.0.0), emmeans (>= 1.8.0), forcats (>= 1.0.0), - formatters (>= 0.5.7.9000), + formatters (>= 0.5.6), ggplot2 (>= 3.5.0), grid, gridExtra (>= 2.0.0), diff --git a/NEWS.md b/NEWS.md index 686b154985..255900ad9f 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,14 +1,12 @@ -# tern 0.9.4.9010 +# tern 0.9.4.9007 ### Enhancements * Added `facet_var` to `g_lineplot` to allow plot faceting by a factor variable. * Updated `g_lineplot` legend to follow factor levels set by users. * Added examples and tests for `label_all` parameter to `extract_survival_biomarkers` and `extract_survival_subgroups`. -* Added the `xticks`, `xlim`, and `ylim` arguments to `g_lineplot` to allow for customization of the x and y axes. ### Bug Fixes * Fixed bug in `s_ancova` that prevented statistics from being printed when arm levels include special characters. -* Fixed bug in `decorate_grob` that prevented the right margins to be respected when adding title and footers decorations. ### Miscellaneous * Began deprecation of the unused `label_all` parameter to `tabulate_survival_biomarkers` and `tabulate_survival_subgroups`, with redirection to the same parameter in their associated `extract_*` functions. @@ -36,7 +34,7 @@ ### Miscellaneous * Added function `expect_snapshot_ggplot` to test setup file to process plot snapshot tests and allow plot dimensions to be set. * Adapted to argument renames introduced in `ggplot2` 3.5.0. -* Renamed `individual_patient_plot.R` to `g_ipp.R`. +* Renamed `individual_patient_plot.R` to `g_ipp.R`. * Removed all instances of deprecated parameters `time_unit_input`, `time_unit_output`, `na_level` and `indent_mod`. * Removed deprecated functions `summarize_vars`, `control_summarize_vars`, `a_compare`, `create_afun_summary`, `create_afun_compare`, and `summary_custom`. * Removed `vdiffr` package from Suggests in DESCRIPTION file. diff --git a/R/argument_convention.R b/R/argument_convention.R index bc6a7220d8..2a357223e9 100644 --- a/R/argument_convention.R +++ b/R/argument_convention.R @@ -67,11 +67,6 @@ #' @param vars (`character`)\cr variable names for the primary analysis variable to be iterated over. #' @param var (`string`)\cr single variable name for the primary analysis variable. #' @param x (`numeric`)\cr vector of numbers we want to analyze. -#' @param xlim (`numeric(2)`)\cr vector containing lower and upper limits for the x-axis, respectively. -#' If `NULL` (default), the default scale range is used. -#' @param ylim (`numeric(2)`)\cr vector containing lower and upper limits for the y-axis, respectively. -#' If `NULL` (default), the default scale range is used. -#' #' #' @details Although this function just returns `NULL` it has two uses, for #' the `tern` users it provides a documentation of arguments that are diff --git a/R/decorate_grob.R b/R/decorate_grob.R index 73b5ecdf9a..68a85dd2b8 100644 --- a/R/decorate_grob.R +++ b/R/decorate_grob.R @@ -11,22 +11,14 @@ #' according to the page width. #' @param footnotes (`character`)\cr footnotes. Uses the same formatting rules as `titles`. #' @param page (`string` or `NULL`)\cr page numeration. If `NULL` then no page number is displayed. -#' @param width_titles (`grid::unit`)\cr width of titles. Usually defined as all the available space -#' `grid::unit(1, "npc")`, it is affected by the parameter `outer_margins`. Right margins (`outer_margins[4]`) -#' need to be subtracted to the allowed width. -#' @param width_footnotes (`grid::unit`)\cr width of footnotes. Same default and margin correction as `width_titles`. +#' @param width_titles (`grid::unit`)\cr width of titles. +#' @param width_footnotes (`grid::unit`)\cr width of footnotes. #' @param border (`flag`)\cr whether a border should be drawn around the plot or not. -#' @param padding (`grid::unit`)\cr padding. A unit object of length 4. Innermost margin between the plot (`grob`) -#' and, possibly, the border of the plot. Usually expressed in 4 identical values (usually `"lines"`). It defaults -#' to `grid::unit(rep(1, 4), "lines")`. -#' @param margins (`grid::unit`)\cr margins. A unit object of length 4. Margins between the plot and the other -#' elements in the list (e.g. titles, plot, and footers). This is usually expressed in 4 `"lines"`, where the -#' lateral ones are 0s, while top and bottom are 1s. It defaults to `grid::unit(c(1, 0, 1, 0), "lines")`. -#' @param outer_margins (`grid::unit`)\cr outer margins. A unit object of length 4. It defines the general margin of -#' the plot, considering also decorations like titles, footnotes, and page numbers. It defaults to -#' `grid::unit(c(2, 1.5, 3, 1.5), "cm")`. -#' @param gp_titles (`gpar`)\cr a `gpar` object. Mainly used to set different `"fontsize"`. -#' @param gp_footnotes (`gpar`)\cr a `gpar` object. Mainly used to set different `"fontsize"`. +#' @param margins (`grid::unit`)\cr margins. A unit object of length 4. +#' @param padding (`grid::unit`)\cr padding. A unit object of length 4. +#' @param outer_margins (`grid::unit`)\cr outer margins. A unit object of length 4. +#' @param gp_titles (`gpar`)\cr a `gpar` object. +#' @param gp_footnotes (`gpar`)\cr a `gpar` object. #' #' @return A grid grob (`gTree`). #' @@ -140,24 +132,17 @@ decorate_grob <- function(grob, titles, footnotes, page = "", - width_titles = grid::unit(1, "npc"), - width_footnotes = grid::unit(1, "npc"), + width_titles = grid::unit(1, "npc") - grid::unit(1.5, "cm"), + width_footnotes = grid::unit(1, "npc") - grid::unit(1.5, "cm"), border = TRUE, - padding = grid::unit(rep(1, 4), "lines"), margins = grid::unit(c(1, 0, 1, 0), "lines"), + padding = grid::unit(rep(1, 4), "lines"), outer_margins = grid::unit(c(2, 1.5, 3, 1.5), "cm"), gp_titles = grid::gpar(), gp_footnotes = grid::gpar(fontsize = 8), name = NULL, gp = grid::gpar(), vp = NULL) { - # External margins need to be taken into account when defining the width of titles and footers - # because the text is split in advance depending on only the width of the viewport. - if (any(as.numeric(outer_margins) > 0)) { - width_titles <- width_titles - outer_margins[4] - width_footnotes <- width_footnotes - outer_margins[4] - } - st_titles <- split_text_grob( titles, x = 0, y = 1, @@ -184,23 +169,6 @@ decorate_grob <- function(grob, gp = gp_footnotes ) - # Initial decoration of the grob -> border, paddings, and margins are used here - main_plot <- grid::gTree( - children = grid::gList( - if (border) grid::rectGrob(), - grid::gTree( - children = grid::gList( - grob - ), - vp = grid::plotViewport(margins = padding) # innermost margins of the grob plot - ) - ), - vp = grid::vpStack( - grid::viewport(layout.pos.row = 2, layout.pos.col = 1), - grid::plotViewport(margins = margins) # margins around the border plot - ) - ) - grid::gTree( grob = grob, titles = titles, @@ -208,6 +176,9 @@ decorate_grob <- function(grob, page = page, width_titles = width_titles, width_footnotes = width_footnotes, + border = border, + margins = margins, + padding = padding, outer_margins = outer_margins, gp_titles = gp_titles, gp_footnotes = gp_footnotes, @@ -215,14 +186,28 @@ decorate_grob <- function(grob, grid::gTree( children = grid::gList( st_titles, - main_plot, # main plot with border, padding, and margins + grid::gTree( + children = grid::gList( + if (border) grid::rectGrob(), + grid::gTree( + children = grid::gList( + grob + ), + vp = grid::plotViewport(margins = padding) + ) + ), + vp = grid::vpStack( + grid::viewport(layout.pos.row = 2, layout.pos.col = 1), + grid::plotViewport(margins = margins) + ) + ), st_footnotes, pg_footnote ), childrenvp = NULL, name = "titles_grob_footnotes", vp = grid::vpStack( - grid::plotViewport(margins = outer_margins), # Main external margins + grid::plotViewport(margins = outer_margins), grid::viewport( layout = grid::grid.layout( nrow = 4, ncol = 1, @@ -400,7 +385,6 @@ split_string <- function(text, width) { if (length(newline_str) > 1) { for (i in seq(2, length(newline_str))) { width_i <- grid::stringWidth(newline_str[i]) - # Main conversion of allowed text width -> npc units are 0 -this is title that is very long dasd asdas dasljdklasjdklasjlk dakldsj -akldjakls jkald jaklsj dklsajklaj skldajkl jsakldjal jsadlk dasj lasjdlkasjkl -ajskld asl jalksjd lkasjlk alkj dlkadlka sjd lakjsdl a - +this is title that is very long dasd asdas dasljdklasjdklasjlk dakldsj akldjakls jkald jaklsj +dklsajklaj skldajkl jsakldjal jsadlk dasj lasjdlkasjkl ajskld asl jalksjd lkasjlk alkj dlkadlka +sjd lakjsdl a + - - + + - - + + - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + -2.0 -2.5 -3.0 -3.5 -4.0 -4.5 - - - - - - - - - - -5 -6 -7 -8 -Sepal.Length -Sepal.Width -this is footnotes that is super super supre long long asdad as dasd ad ada ad -asdadkhasdalksjdlkaj kdlajskl dsajlkd ajldja lkdjas jdklas jdkasj dlasl;jd klasjdkl aldja lkjdlkaj -lkfjalksd a +2.0 +2.5 +3.0 +3.5 +4.0 +4.5 + + + + + + + + + + +5 +6 +7 +8 +Sepal.Length +Sepal.Width +this is footnotes that is super super supre long long asdad as dasd ad ada ad asdadkhasdalksjdlkaj kdlajskl dsajlkd ajldja lkdjas +jdklas jdkasj dlasl;jd klasjdkl aldja lkjdlkaj lkfjalksd a Page 1 of 10 diff --git a/tests/testthat/_snaps/g_lineplot/g_lineplot_xlim_ylim.svg b/tests/testthat/_snaps/g_lineplot/g_lineplot_xlim_ylim.svg deleted file mode 100644 index c49fa4929e..0000000000 --- a/tests/testthat/_snaps/g_lineplot/g_lineplot_xlim_ylim.svg +++ /dev/null @@ -1,121 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -17 -18 -19 -20 -21 - - - - - - - - - - - -1 -2 -3 -4 -5 -6 -Analysis Visit (N) - -Description of Planned Arm - - - - - - - - - -A: Drug X (N = 69) -B: Placebo (N = 73) -C: Combination (N = 58) -ALT (U/L) -Plot of Mean and 95% Confidence Limits by Visit - - diff --git a/tests/testthat/_snaps/g_lineplot/g_lineplot_xticks.svg b/tests/testthat/_snaps/g_lineplot/g_lineplot_xticks.svg deleted file mode 100644 index d9c80653a3..0000000000 --- a/tests/testthat/_snaps/g_lineplot/g_lineplot_xticks.svg +++ /dev/null @@ -1,144 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -18 -19 -20 -21 -22 - - - - - - - - -0.0 -2.5 -5.0 -Analysis Visit (N) - -Description of Planned Arm - - - - - - - - - -A: Drug X (N = 69) -B: Placebo (N = 73) -C: Combination (N = 58) -ALT (U/L) -Plot of Mean and 95% Confidence Limits by Visit - - diff --git a/tests/testthat/_snaps/g_lineplot/g_lineplot_xticks_by.svg b/tests/testthat/_snaps/g_lineplot/g_lineplot_xticks_by.svg deleted file mode 100644 index 7e0463174f..0000000000 --- a/tests/testthat/_snaps/g_lineplot/g_lineplot_xticks_by.svg +++ /dev/null @@ -1,150 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -18 -19 -20 -21 -22 - - - - - - - - - - - -0 -1 -2 -3 -4 -5 -Analysis Visit (N) - -Description of Planned Arm - - - - - - - - - -A: Drug X (N = 69) -B: Placebo (N = 73) -C: Combination (N = 58) -ALT (U/L) -Plot of Mean and 95% Confidence Limits by Visit - - diff --git a/tests/testthat/test-decorate_grob.R b/tests/testthat/test-decorate_grob.R index e7c7e7b741..bbb59f7a58 100644 --- a/tests/testthat/test-decorate_grob.R +++ b/tests/testthat/test-decorate_grob.R @@ -1,7 +1,6 @@ testthat::test_that("decorate_grob returns no warnings when creating an empty plot", { titles <- "Edgar Anderson's Iris Data" footnotes <- "The species are Iris setosa, versicolor, and virginica." - all_ones <- grid::unit(c(1, 1, 1, 1), "cm") grid::grid.newpage() testthat::expect_silent( @@ -11,9 +10,9 @@ testthat::test_that("decorate_grob returns no warnings when creating an empty pl titles = titles, footnotes = footnotes, page = "Page 4 of 10", - outer_margins = all_ones, - margins = all_ones, - padding = all_ones + outer_margins = c(1, 1, 1, 1), + margins = c(1, 1, 1, 1), + padding = c(1, 1, 1, 1) ) ) ) diff --git a/tests/testthat/test-g_lineplot.R b/tests/testthat/test-g_lineplot.R index 804e2f3f98..55673365e6 100644 --- a/tests/testthat/test-g_lineplot.R +++ b/tests/testthat/test-g_lineplot.R @@ -99,43 +99,6 @@ testthat::test_that("g_lineplot works with facet_var specified", { expect_snapshot_ggplot(title = "g_lineplot_facets", fig = g_lineplot_facets, width = 10, height = 8) }) -testthat::test_that("g_lineplot xticks, xlim, and ylim arguments work", { - g_lineplot_xticks_by <- withr::with_options( - opts_partial_match_old, - g_lineplot( - adlb, - adsl, - variables = control_lineplot_vars(x = "AVISITN"), - xticks = 1 - ) - ) - expect_snapshot_ggplot(title = "g_lineplot_xticks_by", fig = g_lineplot_xticks_by, width = 10, height = 8) - - g_lineplot_xticks <- withr::with_options( - opts_partial_match_old, - g_lineplot( - adlb, - adsl, - variables = control_lineplot_vars(x = "AVISITN"), - xticks = c(0, 2.5, 5) - ) - ) - expect_snapshot_ggplot(title = "g_lineplot_xticks", fig = g_lineplot_xticks, width = 10, height = 8) - - g_lineplot_xlim_ylim <- withr::with_options( - opts_partial_match_old, - g_lineplot( - adlb, - adsl, - variables = control_lineplot_vars(x = "AVISITN"), - xlim = c(1, 6), - ylim = c(17, 21), - xticks = 1:6 - ) - ) - expect_snapshot_ggplot(title = "g_lineplot_xlim_ylim", fig = g_lineplot_xlim_ylim, width = 10, height = 8) -}) - testthat::test_that("control_lineplot_vars works", { testthat::expect_silent(control_lineplot_vars(group_var = NA))