This vignettes will guide the user in the exploration of the functionalities of easyreporting.
For the usage you just need to load the easyreporting package, which will load the R6 and rmarkdown packages.
if(!requireNamespace("BiocManager", quietly = TRUE))
    install.packages("BiocManager")
BiocManager::install("easyreporting")library("easyreporting")For simplicity we setup a project directory path starting from the working directory for our report, but you can just enter any path. The filenamepath and the title parameters are mandatory, while the author(s) paramenter is optional.
Once created the easyreporting class instance, we can use it in our further code to make other operations. It stores some variables for us, in order to not be called again during next opreations. For example the name and the path of the report, the type of report and the general rmarkdown options of the document.
proj.path <- file.path(tempdir(), "general_report")
er <- easyreporting(filenamePath=proj.path, title="example_report",
                  author=c(
                      person(given="Dario", family="Righelli", 
                          email="fake_email@gmail.com",
                          comment=c(ORCID="ORCIDNUMBER", 
                                    url="www.fakepersonalurl.com",
                                    affiliation="Institute of Applied Mathematics, CNR, Naples, IT", 
                                    affiliation_url="www.fakeurl.com")),
                    person(given="Claudia", family="Angelini",
                    comment=c(ORCID="ORCIDNUMBER",
                              url="www.fakepersonalurl.com",
                              affiliation="Institute of Applied Mathematics, CNR, Naples, IT",
                              affiliation_url="www.fakeurl.com"))
                    )
                  )
                    
er <- easyreporting(filenamePath=proj.path, title="example_report",
                        author=c("Dario Righelli"))Easyreporting enables to include rmarkdown titles from first (default) to sixth level. The good norm, when writing reports, is always to add a title to a new code chunk (CC) followed by a natural language text, which describes the CC.
mkdTitle(er, title="Code Chunks", level=1)
mkdGeneralMsg(er, "A simple paragraph useful to describe my code chunk...")The most mechanical way to create and populate a CC is to manually open the CC, to insert the code, and then to close it. Here we show how to insert a variable assignenent inside a CC.
mkdTitle(er, title="Manual code chunk", level=2)
mkdCodeChunkSt(er)#> Please remember to close the Code Chunk!
#> Just invoke mkdCodeChunkEnd() once you complete your function calling :)variable <- 1
mkdVariableAssignment(er, "variable", `variable`, show=TRUE)
mkdCodeChunkEnd(er)By using the standard function makeOptionsList, it is possible to create a custom list of options (an optionsList), as described from rmarkdown. In this way we are able to personalize even single code chunks, depending on specific cases.
Here we create an optionsList where the includeFlag is set to TRUE (our default is FALSE).
When opening the code chunk, it is possible to pass the new optionsList to the easyreporting class mkdCodeChunkSt method.
optList <- makeOptionsList(echoFlag=TRUE, includeFlag=TRUE)
mkdCodeChunkSt(er, optionList=optList)#> Please remember to close the Code Chunk!
#> Just invoke mkdCodeChunkEnd() once you complete your function calling :)mkdCodeChunkEnd(er)If you have one or more files with some functions that you want to use inside your code, it is possible to add them by using the sourceFilesList parameter.
## moreover I can add a list of files to source in che code chunk
RFilesList <- list.files(system.file("script", package="easyreporting"), 
                        full.names=TRUE)
mkdCodeChunkSt(er, optionList=optList, sourceFilesList=RFilesList)#> Copying /tmp/Rtmp55wVyC/Rinst19222a353a0a48/easyreporting/script/fakeFunctions.R to /tmp/RtmpCPDNOd//fakeFunctions.R#> Copying /tmp/Rtmp55wVyC/Rinst19222a353a0a48/easyreporting/script/geneFunctions.R to /tmp/RtmpCPDNOd//geneFunctions.R#> Copying /tmp/Rtmp55wVyC/Rinst19222a353a0a48/easyreporting/script/importFunctions.R to /tmp/RtmpCPDNOd//importFunctions.R#> Copying /tmp/Rtmp55wVyC/Rinst19222a353a0a48/easyreporting/script/plotFunctions.R to /tmp/RtmpCPDNOd//plotFunctions.R#> Please remember to close the Code Chunk!
#> Just invoke mkdCodeChunkEnd() once you complete your function calling :)mkdGeneralMsg(er, message="(v <- fakeFunction(10))")
mkdCodeChunkEnd(er)It is also possible to create a complete chunk by using the mkdCodeChunkComplete function.
mkdCodeChunkComplete(er, code="v <- fakeFunction(11)")Finally, it is possible to create a unique code chunk within all the functionalities desribed before.
optList <- makeOptionsList(includeFlag=TRUE, cacheFlag=TRUE)
mkdCodeChunkCommented(er, 
                comment="This is the comment of the following code chunk",
                code="v <- fakeFunction(12)",
                optionList=optList,
                sourceFilesList=NULL)Once finished our analysis it is possible to compile the produced rmarkdown report simply by using the compile method. The compile method appends a sessionInfo() to the report to trace all the packages and versions used for the analysis.
compile(er)sessionInfo()#> R version 4.2.1 (2022-06-23)
#> Platform: x86_64-pc-linux-gnu (64-bit)
#> Running under: Ubuntu 20.04.5 LTS
#> 
#> Matrix products: default
#> BLAS:   /home/biocbuild/bbs-3.16-bioc/R/lib/libRblas.so
#> LAPACK: /home/biocbuild/bbs-3.16-bioc/R/lib/libRlapack.so
#> 
#> locale:
#>  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
#>  [3] LC_TIME=en_GB              LC_COLLATE=C              
#>  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
#>  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
#>  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
#> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
#> 
#> attached base packages:
#> [1] stats     graphics  grDevices utils     datasets  methods   base     
#> 
#> other attached packages:
#> [1] distill_1.5          easyreporting_1.10.0 BiocStyle_2.26.0    
#> 
#> loaded via a namespace (and not attached):
#>  [1] knitr_1.40          magrittr_2.0.3      downlit_0.4.2      
#>  [4] R6_2.5.1            rlang_1.0.6         fastmap_1.1.0      
#>  [7] stringr_1.4.1       tools_4.2.1         xfun_0.34          
#> [10] cli_3.4.1           jquerylib_0.1.4     withr_2.5.0        
#> [13] htmltools_0.5.3     yaml_2.3.6          digest_0.6.30      
#> [16] bookdown_0.29       BiocManager_1.30.19 formatR_1.12       
#> [19] sass_0.4.2          memoise_2.0.1       cachem_1.0.6       
#> [22] evaluate_0.17       rmarkdown_2.17      stringi_1.7.8      
#> [25] compiler_4.2.1      bslib_0.4.0         jsonlite_1.8.3