setClassUnion("NumericOrNULL", c("numeric", "NULL"))
setClassUnion("ListOrNULL", c("list", "NULL"))
#' Data container for an Epiviz web component.
#'
#' @field chr (CharacterOrNULL) Chromosome location.
#' @field start (NumericOrNULL) Start location.
#' @field end (NumericOrNULL) End location.
#' @field measurements (ListOrNULL) list of measurements of class [`EpivizMeasurement`].
#' @import htmltools
#' @importFrom methods new
#' @md
EpivizViewComponent <- setRefClass("EpivizViewComponent",
contains="EpivizWebComponent",
fields=list(
measurements="ListOrNULL",
chr="CharacterOrNULL",
start="NumericOrNULL",
end="NumericOrNULL"
),
methods=list(
initialize=function(measurements=NULL, chr=NULL,
start=NULL, end=NULL, ...) {
.self$measurements <- measurements
.self$chr <- chr
.self$start <- start
.self$end <- end
callSuper(...)
},
get_measurements=function() {
"Get measurements"
.self$measurements
},
get_chr=function() {
"Get chromosome"
.self$chr
},
get_start=function() {
"Get start"
.self$start
},
get_end=function() {
"Get end"
.self$end
},
set_measurements=function(ms) {
"Set measurements"
.self$measurements <- ms
invisible()
},
set_chr=function(chr) {
"Set the chromosome"
.self$chr <- chr
invisible()
},
set_start=function(start) {
"Set start"
.self$start <- start
invisible()
},
set_end=function(end) {
"Set end"
.self$end <- end
invisible()
},
get_attributes=function() {
"Get attributes for rendering chart"
ms <- lapply(.self$measurements, as.list)
if (.self$is_interactive()) {
for (i in seq_len(length(ms))) {
ms[[i]]$dataprovider <- .self$get_provider_id()
}
}
c(list(
measurements=json_writer(ms), chr=.self$chr,
start=.self$start, end=.self$end
),
callSuper()
)
},
get_dependencies=function(shiny=FALSE) {
# TODO
# c(list(EpivizViewComponent=htmlDependency(
# name="",
# version=0,
# head="",
# src="",
# all_files=TRUE)),
# callSuper())
callSuper(shiny)
}
)
)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.