From ca9cd53f4468e2709a579795e0dc524cd2f9b5d6 Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 29 May 2024 13:54:44 +0200 Subject: [PATCH 1/7] prototype cml02a_gl --- DESCRIPTION | 1 + NAMESPACE | 3 +++ R/cml02a_gl.R | 50 +++++++++++++++++++++++++++++++++++++ _pkgdown.yaml | 1 + man/cml02a_gl.Rd | 65 ++++++++++++++++++++++++++++++++++++++++++++++++ 5 files changed, 120 insertions(+) create mode 100644 R/cml02a_gl.R create mode 100644 man/cml02a_gl.Rd diff --git a/DESCRIPTION b/DESCRIPTION index 38171b1d4..a5cfabcc8 100755 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -98,6 +98,7 @@ Collate: 'cfbt01.R' 'checks.R' 'chevron_tlg-S4methods.R' + 'cml02a_gl.R' 'cmt01a.R' 'cmt02_pt.R' 'coxt01.R' diff --git a/NAMESPACE b/NAMESPACE index 67212398e..7931089a5 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -65,6 +65,9 @@ export(chevron_g) export(chevron_l) export(chevron_simple) export(chevron_t) +export(cml02a_gl) +export(cml02a_gl_main) +export(cml02a_gl_pre) export(cmt01_label) export(cmt01a) export(cmt01a_main) diff --git a/R/cml02a_gl.R b/R/cml02a_gl.R new file mode 100644 index 000000000..2ec9bb04a --- /dev/null +++ b/R/cml02a_gl.R @@ -0,0 +1,50 @@ +# cml02a_gl_main ---- + +#' @describeIn cml02a_gl Main TLG function +#' +#' @inheritParams gen_args +#' @returns the main function returns an `rlistings` or a `list` object. +#' @export +#' +cml02a_gl_main <- modify_default_args(std_listing, + dataset = "adcm", + key_cols = c("ATC2", "CMDECOD", "CMTRT"), + disp_cols = c("ATC2", "CMDECOD", "CMTRT"), + split_into_pages_by_var = NULL +) + +#' @describeIn cml02a_gl Preprocessing +#' +#' @inheritParams cml02a_gl_main +#' @inheritParams gen_args +#' @returns the preprocessing function returns a `list` of `data.frame`. +#' +#' @export +#' +cml02a_gl_pre <- function(adam_db, + dataset = "adcm", + key_cols = c("ATC2", "CMDECOD", "CMTRT"), + ...) { + adam_db[[dataset]] <- adam_db[[dataset]] %>% + mutate(across(all_of(key_cols), ~ reformat(.x, nocoding))) %>% + mutate( + ATC2 = with_label(.data$ATC2, "ATC Class Level 2"), + CMDECOD = with_label(.data$CMDECOD, "WHODrug Preferred Name"), + CMTRT = with_label(.data$CMTRT, "Investigator-Specified\nTreatment Term") + ) + + adam_db +} + +#' `CML02A_GL` Listing 1 (Default) Concomitant Medication Class Level 2, Preferred Name, and Investigator-Specified +#' Terms. +#' +#' @include chevron_tlg-S4class.R +#' @export +#' +#' @examples +#' run(cml02a_gl, syn_data) +cml02a_gl <- chevron_l( + main = cml02a_gl_main, + preprocess = cml02a_gl_pre +) diff --git a/_pkgdown.yaml b/_pkgdown.yaml index 6f1892c2a..c24ee9821 100644 --- a/_pkgdown.yaml +++ b/_pkgdown.yaml @@ -62,6 +62,7 @@ reference: - aet05_all - aet10 - cfbt01 + - cml02a_gl - cmt01a - cmt02_pt - coxt01 diff --git a/man/cml02a_gl.Rd b/man/cml02a_gl.Rd new file mode 100644 index 000000000..56b911d8e --- /dev/null +++ b/man/cml02a_gl.Rd @@ -0,0 +1,65 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/cml02a_gl.R +\docType{data} +\name{cml02a_gl_main} +\alias{cml02a_gl_main} +\alias{cml02a_gl_pre} +\alias{cml02a_gl} +\title{\code{CML02A_GL} Listing 1 (Default) Concomitant Medication Class Level 2, Preferred Name, and Investigator-Specified +Terms.} +\format{ +An object of class \code{chevron_l} of length 1. +} +\usage{ +cml02a_gl_main( + adam_db, + dataset = "adcm", + key_cols = c("ATC2", "CMDECOD", "CMTRT"), + disp_cols = c("ATC2", "CMDECOD", "CMTRT"), + split_into_pages_by_var = NULL, + ... +) + +cml02a_gl_pre( + adam_db, + dataset = "adcm", + key_cols = c("ATC2", "CMDECOD", "CMTRT"), + ... +) + +cml02a_gl +} +\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. + +the preprocessing function returns a \code{list} of \code{data.frame}. +} +\description{ +\code{CML02A_GL} Listing 1 (Default) Concomitant Medication Class Level 2, Preferred Name, and Investigator-Specified +Terms. +} +\section{Functions}{ +\itemize{ +\item \code{cml02a_gl_main()}: Main TLG function + +\item \code{cml02a_gl_pre()}: Preprocessing + +}} +\examples{ +run(cml02a_gl, syn_data) +} +\keyword{datasets} From a37bfaa0b013059c598cb4b9704784172af9d2bf Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 29 May 2024 13:57:13 +0200 Subject: [PATCH 2/7] add test --- tests/testthat/_snaps/cml02a_gl.md | 70 ++++++++++++++++++++++++++++++ tests/testthat/test-cml02a_gl.R | 23 ++++++++++ 2 files changed, 93 insertions(+) create mode 100644 tests/testthat/_snaps/cml02a_gl.md create mode 100644 tests/testthat/test-cml02a_gl.R diff --git a/tests/testthat/_snaps/cml02a_gl.md b/tests/testthat/_snaps/cml02a_gl.md new file mode 100644 index 000000000..ca31813c2 --- /dev/null +++ b/tests/testthat/_snaps/cml02a_gl.md @@ -0,0 +1,70 @@ +# cml02a_gl works with adcm dataset + + Code + cat(export_as_txt(res, lpp = 100)) + Output + Investigator-Specified + ATC Class Level 2 WHODrug Preferred Name Treatment Term + ——————————————————————————————————————————————————————————————————— + ATCCLAS2 A medname A_1/3 A_1/3 + medname A_2/3 A_2/3 + medname A_3/3 A_3/3 + ATCCLAS2 A p2 medname A_3/3 A_3/3 + ATCCLAS2 B medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + medname B_3/4 B_3/4 + medname B_4/4 B_4/4 + ATCCLAS2 B p2 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 B p3 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 C medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p2 medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p3 medname C_2/2 C_2/2 + +# cml02a_gl works with missing data + + Code + cat(export_as_txt(res, lpp = 100)) + Output + Investigator-Specified + ATC Class Level 2 WHODrug Preferred Name Treatment Term + ————————————————————————————————————————————————————————————————————— + No Coding Available medname A_1/3 A_1/3 + medname A_2/3 A_2/3 + medname A_3/3 A_3/3 + medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + medname B_3/4 B_3/4 + medname B_4/4 B_4/4 + medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + +# cml02a_gl functions work as expected + + Code + cat(export_as_txt(res, lpp = 100)) + Output + Investigator-Specified + ATC Class Level 2 WHODrug Preferred Name Treatment Term + ——————————————————————————————————————————————————————————————————— + ATCCLAS2 A medname A_1/3 A_1/3 + medname A_2/3 A_2/3 + medname A_3/3 A_3/3 + ATCCLAS2 A p2 medname A_3/3 A_3/3 + ATCCLAS2 B medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + medname B_3/4 B_3/4 + medname B_4/4 B_4/4 + ATCCLAS2 B p2 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 B p3 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 C medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p2 medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p3 medname C_2/2 C_2/2 + diff --git a/tests/testthat/test-cml02a_gl.R b/tests/testthat/test-cml02a_gl.R new file mode 100644 index 000000000..733839b26 --- /dev/null +++ b/tests/testthat/test-cml02a_gl.R @@ -0,0 +1,23 @@ +# cml02a_gl ---- + +test_that("cml02a_gl works with adcm dataset", { + expect_silent(res <- run(cml02a_gl, syn_data)) + expect_snapshot(cat(export_as_txt(res, lpp = 100))) +}) + +test_that("cml02a_gl works with missing data", { + proc_data <- syn_data + proc_data$adcm$ATC2 <- NA_character_ + expect_silent(res <- run(cml02a_gl, proc_data)) + expect_snapshot(cat(export_as_txt(res, lpp = 100))) +}) + +# cml02a_gl functions ---- + +test_that("cml02a_gl functions work as expected", { + expect_silent( + res <- cml02a_gl_pre(syn_data) %>% + cml02a_gl_main() + ) + expect_snapshot(cat(export_as_txt(res, lpp = 100))) +}) From cbd991dded0baaf0bf7a26a11a4fcadae4adc3ed Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 5 Jun 2024 12:24:36 +0200 Subject: [PATCH 3/7] update --- tests/testthat/_snaps/cml02a_gl.md | 6 +++--- tests/testthat/test-cml02a_gl.R | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/tests/testthat/_snaps/cml02a_gl.md b/tests/testthat/_snaps/cml02a_gl.md index ca31813c2..17882907b 100644 --- a/tests/testthat/_snaps/cml02a_gl.md +++ b/tests/testthat/_snaps/cml02a_gl.md @@ -1,7 +1,7 @@ # cml02a_gl works with adcm dataset Code - cat(export_as_txt(res, lpp = 100)) + cat(export_as_txt(res, lpp = 100, cpp = 110)) Output Investigator-Specified ATC Class Level 2 WHODrug Preferred Name Treatment Term @@ -27,7 +27,7 @@ # cml02a_gl works with missing data Code - cat(export_as_txt(res, lpp = 100)) + cat(export_as_txt(res, lpp = 100, cpp = 110)) Output Investigator-Specified ATC Class Level 2 WHODrug Preferred Name Treatment Term @@ -45,7 +45,7 @@ # cml02a_gl functions work as expected Code - cat(export_as_txt(res, lpp = 100)) + cat(export_as_txt(res, lpp = 100, cpp = 110)) Output Investigator-Specified ATC Class Level 2 WHODrug Preferred Name Treatment Term diff --git a/tests/testthat/test-cml02a_gl.R b/tests/testthat/test-cml02a_gl.R index 733839b26..8890293bc 100644 --- a/tests/testthat/test-cml02a_gl.R +++ b/tests/testthat/test-cml02a_gl.R @@ -2,14 +2,14 @@ test_that("cml02a_gl works with adcm dataset", { expect_silent(res <- run(cml02a_gl, syn_data)) - expect_snapshot(cat(export_as_txt(res, lpp = 100))) + expect_snapshot(cat(export_as_txt(res, lpp = 100, cpp = 110))) }) test_that("cml02a_gl works with missing data", { proc_data <- syn_data proc_data$adcm$ATC2 <- NA_character_ expect_silent(res <- run(cml02a_gl, proc_data)) - expect_snapshot(cat(export_as_txt(res, lpp = 100))) + expect_snapshot(cat(export_as_txt(res, lpp = 100, cpp = 110))) }) # cml02a_gl functions ---- @@ -19,5 +19,5 @@ test_that("cml02a_gl functions work as expected", { res <- cml02a_gl_pre(syn_data) %>% cml02a_gl_main() ) - expect_snapshot(cat(export_as_txt(res, lpp = 100))) + expect_snapshot(cat(export_as_txt(res, lpp = 100, cpp = 110))) }) From 42383bbcd45b250684c6fa8891c8beef351240c3 Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 5 Jun 2024 15:44:55 +0200 Subject: [PATCH 4/7] circumvent bug --- R/cml02a_gl.R | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/R/cml02a_gl.R b/R/cml02a_gl.R index 2ec9bb04a..2b7569c60 100644 --- a/R/cml02a_gl.R +++ b/R/cml02a_gl.R @@ -8,7 +8,7 @@ #' cml02a_gl_main <- modify_default_args(std_listing, dataset = "adcm", - key_cols = c("ATC2", "CMDECOD", "CMTRT"), + key_cols = c("ATC2", "CMDECOD"), disp_cols = c("ATC2", "CMDECOD", "CMTRT"), split_into_pages_by_var = NULL ) From 9b7d01c0145ba3644e71c028dd74d310a6f58906 Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 5 Jun 2024 16:46:14 +0200 Subject: [PATCH 5/7] document --- man/cml02a_gl.Rd | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/man/cml02a_gl.Rd b/man/cml02a_gl.Rd index 56b911d8e..c09eb3c7a 100644 --- a/man/cml02a_gl.Rd +++ b/man/cml02a_gl.Rd @@ -14,7 +14,7 @@ An object of class \code{chevron_l} of length 1. cml02a_gl_main( adam_db, dataset = "adcm", - key_cols = c("ATC2", "CMDECOD", "CMTRT"), + key_cols = c("ATC2", "CMDECOD"), disp_cols = c("ATC2", "CMDECOD", "CMTRT"), split_into_pages_by_var = NULL, ... From 8fd348df230627fb68c91f6404558fa4f74719e5 Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 3 Jul 2024 14:52:45 +0200 Subject: [PATCH 6/7] update unique_rows --- DESCRIPTION | 2 +- R/ael01_nollt.R | 3 ++- R/cml02a_gl.R | 7 ++++--- R/utils.R | 3 ++- man/ael01_nollt.Rd | 3 +++ man/ael02.Rd | 3 +++ man/ael03.Rd | 3 +++ man/cml02a_gl.Rd | 5 ++++- man/std_listing.Rd | 3 +++ 9 files changed, 25 insertions(+), 7 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index fb56eed50..99383f04e 100755 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -79,7 +79,7 @@ Encoding: UTF-8 Language: en-US LazyData: true Roxygen: list(markdown = TRUE) -RoxygenNote: 7.3.1 +RoxygenNote: 7.3.2 Collate: 'report_null.R' 'utils.R' diff --git a/R/ael01_nollt.R b/R/ael01_nollt.R index d3ba55213..77d129174 100644 --- a/R/ael01_nollt.R +++ b/R/ael01_nollt.R @@ -21,7 +21,8 @@ ael01_nollt_main <- modify_default_args( dataset = "adae", key_cols = c("AEBODSYS", "AEDECOD"), disp_cols = "AETERM", - split_into_pages_by_var = NULL + split_into_pages_by_var = NULL, + unique_rows = TRUE ) #' @describeIn ael01_nollt Preprocessing diff --git a/R/cml02a_gl.R b/R/cml02a_gl.R index 2b7569c60..6dfddebd0 100644 --- a/R/cml02a_gl.R +++ b/R/cml02a_gl.R @@ -10,7 +10,8 @@ cml02a_gl_main <- modify_default_args(std_listing, dataset = "adcm", key_cols = c("ATC2", "CMDECOD"), disp_cols = c("ATC2", "CMDECOD", "CMTRT"), - split_into_pages_by_var = NULL + split_into_pages_by_var = NULL, + unique_rows = TRUE ) #' @describeIn cml02a_gl Preprocessing @@ -23,10 +24,10 @@ cml02a_gl_main <- modify_default_args(std_listing, #' cml02a_gl_pre <- function(adam_db, dataset = "adcm", - key_cols = c("ATC2", "CMDECOD", "CMTRT"), + disp_cols = c("ATC2", "CMDECOD", "CMTRT"), ...) { adam_db[[dataset]] <- adam_db[[dataset]] %>% - mutate(across(all_of(key_cols), ~ reformat(.x, nocoding))) %>% + mutate(across(all_of(disp_cols), ~ reformat(.x, nocoding))) %>% mutate( ATC2 = with_label(.data$ATC2, "ATC Class Level 2"), CMDECOD = with_label(.data$CMDECOD, "WHODrug Preferred Name"), diff --git a/R/utils.R b/R/utils.R index 0d415c633..7ea505ba6 100755 --- a/R/utils.R +++ b/R/utils.R @@ -46,6 +46,7 @@ std_listing <- function(adam_db, key_cols, disp_cols, split_into_pages_by_var, + unique_rows = FALSE, ...) { assert_all_tablenames(adam_db, dataset) assert_valid_variable(adam_db[[dataset]], c(key_cols, disp_cols), label = paste0("adam_db$", dataset)) @@ -58,7 +59,7 @@ std_listing <- function(adam_db, split_into_pages_by_var = split_into_pages_by_var, ..., default_formatting = listing_format_chevron(), - unique_rows = TRUE + unique_rows = unique_rows ) } diff --git a/man/ael01_nollt.Rd b/man/ael01_nollt.Rd index a73252fb9..26dc765be 100644 --- a/man/ael01_nollt.Rd +++ b/man/ael01_nollt.Rd @@ -16,6 +16,7 @@ ael01_nollt_main( key_cols = c("AEBODSYS", "AEDECOD"), disp_cols = "AETERM", split_into_pages_by_var = NULL, + unique_rows = TRUE, ... ) @@ -41,6 +42,8 @@ Key columns allow you to group repeat occurrences.} \item{split_into_pages_by_var}{(\code{character} or \code{NULL}) the name of the variable to split the listing by.} +\item{unique_rows}{(\code{flag}) whether to keep only unique rows in listing.} + \item{...}{additional arguments passed to \code{\link[rlistings:listings]{rlistings::as_listing}}.} } \value{ diff --git a/man/ael02.Rd b/man/ael02.Rd index ac4e8fb4d..2c037443d 100644 --- a/man/ael02.Rd +++ b/man/ael02.Rd @@ -17,6 +17,7 @@ ael02_main( disp_cols = c("AEDECOD", "TRTSDTM", "ASTDY", "ADURN", "AESER", "ASEV", "AREL", "AEOUT", "AECONTRT", "AEACN"), split_into_pages_by_var = "ACTARM", + unique_rows = FALSE, ... ) @@ -36,6 +37,8 @@ Key columns allow you to group repeat occurrences.} \item{split_into_pages_by_var}{(\code{character} or \code{NULL}) the name of the variable to split the listing by.} +\item{unique_rows}{(\code{flag}) whether to keep only unique rows in listing.} + \item{...}{not used.} \item{arm_var}{(\code{string}) variable used for column splitting} diff --git a/man/ael03.Rd b/man/ael03.Rd index 9d999b6f0..b192b05c9 100644 --- a/man/ael03.Rd +++ b/man/ael03.Rd @@ -17,6 +17,7 @@ ael03_main( disp_cols = c("AEDECOD", "TRTSDTM", "ASTDY", "ADURN", "ASEV", "AREL", "AEOUT", "AECONTRT", "AEACN", "SERREAS"), split_into_pages_by_var = "ACTARM", + unique_rows = FALSE, ... ) @@ -36,6 +37,8 @@ Key columns allow you to group repeat occurrences.} \item{split_into_pages_by_var}{(\code{character} or \code{NULL}) the name of the variable to split the listing by.} +\item{unique_rows}{(\code{flag}) whether to keep only unique rows in listing.} + \item{...}{not used.} \item{arm_var}{(\code{string}) variable used for column splitting} diff --git a/man/cml02a_gl.Rd b/man/cml02a_gl.Rd index c09eb3c7a..4691f0de7 100644 --- a/man/cml02a_gl.Rd +++ b/man/cml02a_gl.Rd @@ -17,13 +17,14 @@ cml02a_gl_main( key_cols = c("ATC2", "CMDECOD"), disp_cols = c("ATC2", "CMDECOD", "CMTRT"), split_into_pages_by_var = NULL, + unique_rows = TRUE, ... ) cml02a_gl_pre( adam_db, dataset = "adcm", - key_cols = c("ATC2", "CMDECOD", "CMTRT"), + disp_cols = c("ATC2", "CMDECOD", "CMTRT"), ... ) @@ -41,6 +42,8 @@ Key columns allow you to group repeat occurrences.} \item{split_into_pages_by_var}{(\code{character} or \code{NULL}) the name of the variable to split the listing by.} +\item{unique_rows}{(\code{flag}) whether to keep only unique rows in listing.} + \item{...}{not used.} } \value{ diff --git a/man/std_listing.Rd b/man/std_listing.Rd index 2a907dec4..257c745a4 100644 --- a/man/std_listing.Rd +++ b/man/std_listing.Rd @@ -10,6 +10,7 @@ std_listing( key_cols, disp_cols, split_into_pages_by_var, + unique_rows = FALSE, ... ) } @@ -25,6 +26,8 @@ Key columns allow you to group repeat occurrences.} \item{split_into_pages_by_var}{(\code{character} or \code{NULL}) the name of the variable to split the listing by.} +\item{unique_rows}{(\code{flag}) whether to keep only unique rows in listing.} + \item{...}{additional arguments passed to \code{\link[rlistings:listings]{rlistings::as_listing}}.} } \value{ From 958db4be1e3b16c8d51e04ed0c6e18b640d6e544 Mon Sep 17 00:00:00 2001 From: BFalquet Date: Wed, 11 Sep 2024 11:15:14 +0200 Subject: [PATCH 7/7] remove line break in column title --- NEWS.md | 2 +- R/cml02a_gl.R | 2 +- tests/testthat/_snaps/cml02a_gl.md | 101 ++++++++++++++--------------- 3 files changed, 51 insertions(+), 54 deletions(-) diff --git a/NEWS.md b/NEWS.md index b81468b68..3e141b132 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,6 +1,6 @@ # chevron 0.2.6.9019 -* Add `AEL02`, `AEL03` templates. +* Add `AEL02`, `AEL03`, `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/cml02a_gl.R b/R/cml02a_gl.R index 6dfddebd0..5777d6e3a 100644 --- a/R/cml02a_gl.R +++ b/R/cml02a_gl.R @@ -31,7 +31,7 @@ cml02a_gl_pre <- function(adam_db, mutate( ATC2 = with_label(.data$ATC2, "ATC Class Level 2"), CMDECOD = with_label(.data$CMDECOD, "WHODrug Preferred Name"), - CMTRT = with_label(.data$CMTRT, "Investigator-Specified\nTreatment Term") + CMTRT = with_label(.data$CMTRT, "Investigator-Specified Treatment Term") ) adam_db diff --git a/tests/testthat/_snaps/cml02a_gl.md b/tests/testthat/_snaps/cml02a_gl.md index 17882907b..582013aa2 100644 --- a/tests/testthat/_snaps/cml02a_gl.md +++ b/tests/testthat/_snaps/cml02a_gl.md @@ -3,68 +3,65 @@ Code cat(export_as_txt(res, lpp = 100, cpp = 110)) Output - Investigator-Specified - ATC Class Level 2 WHODrug Preferred Name Treatment Term - ——————————————————————————————————————————————————————————————————— - ATCCLAS2 A medname A_1/3 A_1/3 - medname A_2/3 A_2/3 - medname A_3/3 A_3/3 - ATCCLAS2 A p2 medname A_3/3 A_3/3 - ATCCLAS2 B medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - medname B_3/4 B_3/4 - medname B_4/4 B_4/4 - ATCCLAS2 B p2 medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - ATCCLAS2 B p3 medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - ATCCLAS2 C medname C_1/2 C_1/2 - medname C_2/2 C_2/2 - ATCCLAS2 C p2 medname C_1/2 C_1/2 - medname C_2/2 C_2/2 - ATCCLAS2 C p3 medname C_2/2 C_2/2 + ATC Class Level 2 WHODrug Preferred Name Investigator-Specified Treatment Term + —————————————————————————————————————————————————————————————————————————————————— + ATCCLAS2 A medname A_1/3 A_1/3 + medname A_2/3 A_2/3 + medname A_3/3 A_3/3 + ATCCLAS2 A p2 medname A_3/3 A_3/3 + ATCCLAS2 B medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + medname B_3/4 B_3/4 + medname B_4/4 B_4/4 + ATCCLAS2 B p2 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 B p3 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 C medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p2 medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p3 medname C_2/2 C_2/2 # cml02a_gl works with missing data Code cat(export_as_txt(res, lpp = 100, cpp = 110)) Output - Investigator-Specified - ATC Class Level 2 WHODrug Preferred Name Treatment Term - ————————————————————————————————————————————————————————————————————— - No Coding Available medname A_1/3 A_1/3 - medname A_2/3 A_2/3 - medname A_3/3 A_3/3 - medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - medname B_3/4 B_3/4 - medname B_4/4 B_4/4 - medname C_1/2 C_1/2 - medname C_2/2 C_2/2 + ATC Class Level 2 WHODrug Preferred Name Investigator-Specified Treatment Term + ———————————————————————————————————————————————————————————————————————————————————— + No Coding Available medname A_1/3 A_1/3 + medname A_2/3 A_2/3 + medname A_3/3 A_3/3 + medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + medname B_3/4 B_3/4 + medname B_4/4 B_4/4 + medname C_1/2 C_1/2 + medname C_2/2 C_2/2 # cml02a_gl functions work as expected Code cat(export_as_txt(res, lpp = 100, cpp = 110)) Output - Investigator-Specified - ATC Class Level 2 WHODrug Preferred Name Treatment Term - ——————————————————————————————————————————————————————————————————— - ATCCLAS2 A medname A_1/3 A_1/3 - medname A_2/3 A_2/3 - medname A_3/3 A_3/3 - ATCCLAS2 A p2 medname A_3/3 A_3/3 - ATCCLAS2 B medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - medname B_3/4 B_3/4 - medname B_4/4 B_4/4 - ATCCLAS2 B p2 medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - ATCCLAS2 B p3 medname B_1/4 B_1/4 - medname B_2/4 B_2/4 - ATCCLAS2 C medname C_1/2 C_1/2 - medname C_2/2 C_2/2 - ATCCLAS2 C p2 medname C_1/2 C_1/2 - medname C_2/2 C_2/2 - ATCCLAS2 C p3 medname C_2/2 C_2/2 + ATC Class Level 2 WHODrug Preferred Name Investigator-Specified Treatment Term + —————————————————————————————————————————————————————————————————————————————————— + ATCCLAS2 A medname A_1/3 A_1/3 + medname A_2/3 A_2/3 + medname A_3/3 A_3/3 + ATCCLAS2 A p2 medname A_3/3 A_3/3 + ATCCLAS2 B medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + medname B_3/4 B_3/4 + medname B_4/4 B_4/4 + ATCCLAS2 B p2 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 B p3 medname B_1/4 B_1/4 + medname B_2/4 B_2/4 + ATCCLAS2 C medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p2 medname C_1/2 C_1/2 + medname C_2/2 C_2/2 + ATCCLAS2 C p3 medname C_2/2 C_2/2