R/EpivizChart-class.R

setClassUnion("EpivizEnvOrNULL", c("EpivizEnvironment", "NULL"))
setClassUnion("CharacterOrNULL", c("character", "NULL"))
setClassUnion("ListOrNULL", c("list", "NULL"))
#' Data container for an Epiviz chart component.
#'
#' @field data (list) Values of an epiviz chart's data attribute.
#' @field colors (character) Epiviz chart's colors attribute.
#' @field settings (list) Epiviz chart's settings attribute.
#' @field parent An object of class [`EpivizEnvironment`] where chart is appended.
#' @import epivizrData
#' @import htmltools
#' @importFrom methods new
#' @md
EpivizChart <- setRefClass("EpivizChart",
  contains="EpivizViewComponent",
  fields=list(
    data="ListOrNULL",
    colors="CharacterOrNULL",
    settings="ListOrNULL",
    parent="EpivizEnvOrNULL"
  ),
  methods=list(
    initialize=function(data=NULL, colors=NULL,
      settings=NULL, parent=NULL, ...) {
      .self$data <- data

      .self$colors <- .self$get_default_colors()
      .self$set_colors(colors)

      .self$settings <- .self$get_default_settings()
      .self$set_settings(settings)

      .self$parent <- parent

      callSuper(class="charts", ...)
    },
    get_data=function() {
      "Get chart data"
      .self$data
    },
    get_colors=function() {
      "Get chart colors"
      .self$colors
    },
    get_settings=function() {
      "Get chart settings"
      .self$settings
    },
    set_data=function(data) {
      "Set chart data"
      .self$data <- data
      invisible()
    },
    set_colors=function(colors) {
      "Set chart colors"
      .self$colors[seq_len(length(colors))] <- colors
      invisible()
    },
    set_settings=function(settings) {
      "Modify current settings
      \\describe{
        \\item{settings}{List of new settings.
          Call get_available_settings for settings available to modify.
        }
      }"
      chart_settings <- .self$settings
      for (setting in names(settings)) {
        if (setting %in% names(chart_settings))
          chart_settings[[setting]] <- settings[[setting]]
      }
      .self$settings <- chart_settings

      invisible()
    },
    get_parent=function() {
      "Get parent"
      .self$parent
    },
    get_attributes=function() {
      "Get attributes for rendering component"
      if(.self$is_interactive()) {
        json_data <- NULL
      } else {
        json_data <- json_writer(.self$data)
      }

      c(list(
        "json-data"=json_data,
        colors=json_writer(.self$colors),
        settings=json_writer(.self$settings)),
        callSuper())
    },
    is_interactive=function() {
      !is.null(.self$parent) && .self$parent$is_interactive()
    },
    get_provider_id=function() {
      if (.self$is_interactive()) {
        return(.self$parent$get_provider_id())
      } else {
        return(NULL)
      }
    },
    render_component=function(shiny=FALSE) {
      "Render to html"
      chart <- tag(.self$get_name(), .self$get_attributes())
      
      htmltools::attachDependencies(chart,
                      .self$get_dependencies(shiny))
    },
     revisualize=function(chart_type) {
       "Revisualize chart as the given chart type
       \\describe{
         \\item{chart_type}{The type of chart to be visualized
         (BlocksTrack, HeatmapPlot, LinePlot, LineTrack, ScatterPlot,
         StackedLinePlot, StackedLineTrack)}
       }"
       epiviz_chart <- .initialize_chart(
         chart_type=chart_type,
         data_mgr=.self$get_data_mgr(),
         measurements=.self$get_measurements(),
         data=.self$data,
         chr=.self$get_chr(),
         start=.self$get_start(),
         end=.self$get_end(),
         settings=.self$settings,
         colors=.self$colors,
         parent=.self$parent)

       if (!is.null(.self$parent))
         .self$parent$append_chart(epiviz_chart)

       epiviz_chart
     },
    navigate=function(chr, start, end) {
      "Navigate chart to a genomic location
      \\describe{
        \\item{chr}{Chromosome}
        \\item{start}{Start location}
        \\item{end}{End location}
      }"
      .self$set_chr(chr)
      .self$set_start(start)
      .self$set_end(end)

      ms_data <- .self$data_mgr$get_data(
        measurements=.self$get_measurements(),
        chr=chr, start=start, end=end)

      .self$data <- ms_data$data

      invisible(.self)
    },
    get_available_settings=function() {
      "Get available settings"
      chart_defaults <- chart_default_settings_colors(
        .self$get_component_type())

      print(.settings_as_df(chart_defaults$settings))
    },
    get_dependencies=function(shiny=FALSE) {
      # TODO
      # c(list(charts=htmlDependency(
      #  name="",
      #  version=0,
      #  head="",
      #  src="",
      #  all_files=TRUE)),
      #  callSuper(shiny))
      callSuper(shiny)
    }
  )
)
briangottfried/epivizrChart documentation built on Aug. 2, 2021, 3:13 a.m.