R/reports.R

Defines functions create_fusion_report

Documented in create_fusion_report

#' Create a Fusion Report
#'
#' This function will create a html report with an overplot and a sortable,
#' searchable table with the fusion data.
#'
#' @param fusions A list of Fusion objects.
#' @param output_filename Output html-file filename.
#' @param quiet Parameter passed to rmarkdown::render() to toggle its output.
#'
#' @return Creates a html report with an overplot and a sortable, searchable
#' table with the fusion data.
#'
#' @examples
#' # Load data
#' defuse833ke <- system.file(
#'   "extdata",
#'   "defuse_833ke_results.filtered.tsv",
#'   package="chimeraviz")
#' fusions <- import_defuse(defuse833ke, "hg19", 3)
#' # Temporary file to store the report
#' random_filename <- paste0(
#'   paste0(sample(LETTERS, 5, replace = TRUE), collapse=''),
#'   ".png"
#' )
#' # Create report
#' create_fusion_report(fusions, random_filename)
#' # Delete the file
#' file.remove(random_filename)
#'
#' @importFrom DT datatable
#' @importFrom plyr ldply
#'
#' @export
create_fusion_report <- function(
  fusions,
  output_filename,
  quiet = TRUE
) {

  # Check if we got a list of fusion objects
  if (class(fusions[[1]]) != "Fusion") {
    stop("fusions argument must be a list of Fusion objects")
  }

  # Full path to the output file
  output_path <- paste0(getwd(), "/", output_filename)

  # Get reference to the fusion list report file
  fusion_report_rmd <- system.file(
    "reports",
    "fusionListReport.Rmd",
    package = "chimeraviz")

  # Render the report
  rmarkdown::render(
    fusion_report_rmd,
    output_file = output_path,
    params = list(fusions = fusions),
    quiet = quiet)
}
stianlagstad/chimeraviz documentation built on Dec. 3, 2023, 8:11 p.m.