diff --git a/DESCRIPTION b/DESCRIPTION index c1ff79f81..c95353746 100755 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -80,6 +80,7 @@ Collate: 'ael01_nollt.R' 'ael02.R' 'ael03.R' + 'ael04.R' 'aet01.R' 'aet01_aesi.R' 'aet02.R' diff --git a/NAMESPACE b/NAMESPACE index 348e90ac0..c7161733f 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -22,6 +22,9 @@ export(ael02_pre) export(ael03) export(ael03_main) export(ael03_pre) +export(ael04) +export(ael04_main) +export(ael04_pre) export(aet01) export(aet01_aesi) export(aet01_aesi_main) diff --git a/NEWS.md b/NEWS.md index 1e2258f06..726e923c7 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,6 +1,6 @@ # chevron 0.2.6.9020 -* Add `AEL02`, `AEL03`, `CML02A_gl` templates. +* Add `AEL02`, `AEL03`, `AEL04`, `CML02A_gl` templates. * Modify the post processing of `MHT01` to allow multiple `row_split_var`. * Improve the `report_null` method to facilitate the creation of null reports * Export the `std_postprocessing` function to simplify post processing logic. diff --git a/R/ael04.R b/R/ael04.R new file mode 100644 index 000000000..4df35410f --- /dev/null +++ b/R/ael04.R @@ -0,0 +1,64 @@ +# ael04_main ---- + +#' @describeIn ael04 Main TLG function +#' +#' @inheritParams gen_args +#' @returns the main function returns an `rlistings` or a `list` object. +#' @export +#' +ael04_main <- modify_default_args( + std_listing, + dataset = "adsl", + key_cols = "ID", + disp_cols = c("ASR", "TRTSDTM", "EOSDY", "DTHADY", "DTHCAUS", "ADTHAUT"), + split_into_pages_by_var = "ACTARM" +) + + +#' @describeIn ael04 Preprocessing +#' +#' @inheritParams ael04_main +#' @inheritParams gen_args +#' +#' @export +#' +ael04_pre <- function(adam_db, + dataset = "adsl", + split_into_pages_by_var = "ACTARM", + ...) { + adam_db[[dataset]] <- adam_db[[dataset]] %>% + filter(!is.na(.data$DTHADY)) %>% + mutate( + across( + all_of(c(split_into_pages_by_var, "DTHCAUS", "ADTHAUT")), + ~ reformat(.x, missing_rule) + ) + ) %>% + mutate( + ID = create_id_listings(.data$SITEID, .data$SUBJID), + ASR = with_label(paste(.data$AGE, .data$SEX, .data$RACE, sep = "/"), "Age/Sex/Race"), + TRTSDTM = with_label( + .data$TRTSDTM, + "Date of\nFirst Study\nDrug\nAdministration" + ), + !!split_into_pages_by_var := with_label(.data[[split_into_pages_by_var]], "Treatment"), + EOSDY = with_label(.data$EOSDY, "Day of Last\nStudy Drug\nAdministration"), + DTHADY = with_label(.data$DTHADY, "Day of\nDeath"), + DTHCAUS = with_label(.data$DTHCAUS, "Cause of Death"), + ADTHAUT = with_label(.data$ADTHAUT, "Autopsy\nPerformed?") + ) + + adam_db +} + +#' `AEL04` Listing 1 (Default) Listing of Patient Deaths. +#' +#' @include chevron_tlg-S4class.R +#' @export +#' +#' @examples +#' res <- run(ael04, syn_data) +ael04 <- chevron_l( + main = ael04_main, + preprocess = ael04_pre +) diff --git a/_pkgdown.yaml b/_pkgdown.yaml index bd7447b65..38fbbdd47 100644 --- a/_pkgdown.yaml +++ b/_pkgdown.yaml @@ -55,6 +55,7 @@ reference: - ael01_nollt - ael02 - ael03 + - ael04 - aet01 - aet01_aesi - aet02 diff --git a/data-raw/syn_data_creation.R b/data-raw/syn_data_creation.R index 07fd9c43b..d67e090ec 100644 --- a/data-raw/syn_data_creation.R +++ b/data-raw/syn_data_creation.R @@ -155,6 +155,10 @@ syn_test_data <- function() { sd$adsl$ETHNIC <- factor(trimws(sd$adsl$ETHNIC), levels = trimws(levels(sd$adsl$ETHNIC))) attr(sd$adsl$ETHNIC, "label") <- "Ethnicity" + # useful for ael04 + sd$adsl$TRTSDTM <- lubridate::force_tz(sd$adsl$TRTSDTM, tzone = "UTC") + + adsub <- sd$adsub adsub_wide_ls <- dunlin::poly_pivot_wider( adsub, diff --git a/data/syn_data.rda b/data/syn_data.rda index 1728b9b81..57013b0c5 100644 Binary files a/data/syn_data.rda and b/data/syn_data.rda differ diff --git a/man/ael04.Rd b/man/ael04.Rd new file mode 100644 index 000000000..799934436 --- /dev/null +++ b/man/ael04.Rd @@ -0,0 +1,56 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/ael04.R +\docType{data} +\name{ael04_main} +\alias{ael04_main} +\alias{ael04_pre} +\alias{ael04} +\title{\code{AEL04} Listing 1 (Default) Listing of Patient Deaths.} +\format{ +An object of class \code{chevron_l} of length 1. +} +\usage{ +ael04_main( + adam_db, + dataset = "adsl", + key_cols = "ID", + disp_cols = c("ASR", "TRTSDTM", "EOSDY", "DTHADY", "DTHCAUS", "ADTHAUT"), + split_into_pages_by_var = "ACTARM", + ... +) + +ael04_pre(adam_db, dataset = "adsl", split_into_pages_by_var = "ACTARM", ...) + +ael04 +} +\arguments{ +\item{adam_db}{(\code{list} of \code{data.frames}) object containing the \code{ADaM} datasets} + +\item{dataset}{(\code{string}) the name of a table in the \code{adam_db} object.} + +\item{key_cols}{(\code{character}) names of columns that should be treated as key columns when rendering the listing. +Key columns allow you to group repeat occurrences.} + +\item{disp_cols}{(\code{character}) names of non-key columns which should be displayed when the listing is rendered.} + +\item{split_into_pages_by_var}{(\code{character} or \code{NULL}) the name of the variable to split the listing by.} + +\item{...}{not used.} +} +\value{ +the main function returns an \code{rlistings} or a \code{list} object. +} +\description{ +\code{AEL04} Listing 1 (Default) Listing of Patient Deaths. +} +\section{Functions}{ +\itemize{ +\item \code{ael04_main()}: Main TLG function + +\item \code{ael04_pre()}: Preprocessing + +}} +\examples{ +res <- run(ael04, syn_data) +} +\keyword{datasets} diff --git a/tests/testthat/_snaps/ael04.md b/tests/testthat/_snaps/ael04.md new file mode 100644 index 000000000..7103e53eb --- /dev/null +++ b/tests/testthat/_snaps/ael04.md @@ -0,0 +1,143 @@ +# ael04 works with adsl dataset + + Code + cat(export_as_txt(res, lpp = 100, cpp = 110)) + Output + ACTARM: C: Combination + + —————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death + —————————————————————————————————————————————————————————————————————————————————————————————————— + BRA-11/9 40/M/ASIAN 25MAR2019 1056 1091 DISEASE PROGRESSION + CHN-15/201 49/M/ASIAN 05MAR2019 1082 1084 ADVERSE EVENT + CHN-15/245 34/F/WHITE 29MAR2019 1057 1056 DISEASE PROGRESSION + \s\nACTARM: C: Combination + + ——————————————————————————————— + + + Autopsy + Center/Patients ID Performed? + ——————————————————————————————— + BRA-11/9 Yes + CHN-15/201 Yes + CHN-15/245 Yes + \s\nACTARM: B: Placebo + + ————————————————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of Autopsy + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death Performed? + ————————————————————————————————————————————————————————————————————————————————————————————————————————————— + CAN-1/341 43/F/ASIAN 23MAY2019 998 1013 SUICIDE Yes + CHN-1/307 24/M/ASIAN 11MAR2019 1076 1121 LOST TO FOLLOW UP + CHN-13/240 42/M/ASIAN 08APR2019 1044 1086 ADVERSE EVENT Yes + CHN-7/126 27/M/WHITE 02MAY2019 1025 1066 ADVERSE EVENT Yes + \s\nACTARM: A: Drug X + + —————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death + —————————————————————————————————————————————————————————————————————————————————————————————————— + CHN-3/128 32/M/ASIAN 24FEB2019 1084 1105 ADVERSE EVENT + RUS-1/52 40/F/ASIAN 18MAR2019 1064 1069 DISEASE PROGRESSION + \s\nACTARM: A: Drug X + + ——————————————————————————————— + + + Autopsy + Center/Patients ID Performed? + ——————————————————————————————— + CHN-3/128 Yes + RUS-1/52 Yes + +# ael04 can handle all missing values + + Code + cat(export_as_txt(res, lpp = 100, cpp = 110)) + Output + ACTARM: + + —————————————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of Autopsy + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death Performed? + —————————————————————————————————————————————————————————————————————————————————————————————————————————— + BRA-11/9 40/M/ASIAN 25MAR2019 1056 1091 Yes + CAN-1/341 43/F/ASIAN 23MAY2019 998 1013 Yes + CHN-1/307 24/M/ASIAN 11MAR2019 1076 1121 + CHN-13/240 42/M/ASIAN 08APR2019 1044 1086 Yes + CHN-15/201 49/M/ASIAN 05MAR2019 1082 1084 Yes + CHN-15/245 34/F/WHITE 29MAR2019 1057 1056 Yes + CHN-3/128 32/M/ASIAN 24FEB2019 1084 1105 Yes + CHN-7/126 27/M/WHITE 02MAY2019 1025 1066 Yes + RUS-1/52 40/F/ASIAN 18MAR2019 1064 1069 Yes + +# ael04 functions work as expected + + Code + cat(export_as_txt(res, lpp = 100, cpp = 110)) + Output + ACTARM: C: Combination + + —————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death + —————————————————————————————————————————————————————————————————————————————————————————————————— + BRA-11/9 40/M/ASIAN 25MAR2019 1056 1091 DISEASE PROGRESSION + CHN-15/201 49/M/ASIAN 05MAR2019 1082 1084 ADVERSE EVENT + CHN-15/245 34/F/WHITE 29MAR2019 1057 1056 DISEASE PROGRESSION + \s\nACTARM: C: Combination + + ——————————————————————————————— + + + Autopsy + Center/Patients ID Performed? + ——————————————————————————————— + BRA-11/9 Yes + CHN-15/201 Yes + CHN-15/245 Yes + \s\nACTARM: B: Placebo + + ————————————————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of Autopsy + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death Performed? + ————————————————————————————————————————————————————————————————————————————————————————————————————————————— + CAN-1/341 43/F/ASIAN 23MAY2019 998 1013 SUICIDE Yes + CHN-1/307 24/M/ASIAN 11MAR2019 1076 1121 LOST TO FOLLOW UP + CHN-13/240 42/M/ASIAN 08APR2019 1044 1086 ADVERSE EVENT Yes + CHN-7/126 27/M/WHITE 02MAY2019 1025 1066 ADVERSE EVENT Yes + \s\nACTARM: A: Drug X + + —————————————————————————————————————————————————————————————————————————————————————————————————— + Date of + First Study Day of Last + Drug Study Drug Day of + Center/Patients ID Age/Sex/Race Administration Administration Death Cause of Death + —————————————————————————————————————————————————————————————————————————————————————————————————— + CHN-3/128 32/M/ASIAN 24FEB2019 1084 1105 ADVERSE EVENT + RUS-1/52 40/F/ASIAN 18MAR2019 1064 1069 DISEASE PROGRESSION + \s\nACTARM: A: Drug X + + ——————————————————————————————— + + + Autopsy + Center/Patients ID Performed? + ——————————————————————————————— + CHN-3/128 Yes + RUS-1/52 Yes + diff --git a/tests/testthat/test-ael04.R b/tests/testthat/test-ael04.R new file mode 100644 index 000000000..e8825aa27 --- /dev/null +++ b/tests/testthat/test-ael04.R @@ -0,0 +1,27 @@ +# ael04 ---- + +test_that("ael04 works with adsl dataset", { + expect_silent( + res <- run(ael04, syn_data, dataset = "adsl") + ) + expect_snapshot(cat(export_as_txt(res, lpp = 100, cpp = 110))) +}) + +test_that("ael04 can handle all missing values", { + proc_data <- syn_data + proc_data$adsl <- proc_data$adsl %>% + mutate( + ACTARM = NA_character_, + DTHCAUS = NA_character_ + ) + + expect_silent(res <- run(ael04, proc_data)) + expect_snapshot(cat(export_as_txt(res, lpp = 100, cpp = 110))) +}) + +# ael04 functions ---- + +test_that("ael04 functions work as expected", { + expect_silent(res <- ael04_pre(syn_data) %>% ael04_main()) + expect_snapshot(cat(export_as_txt(res, lpp = 100, cpp = 110))) +})