R/handle_resize.R

Defines functions handle_resize plot_width plot_height connect_resize

Documented in handle_resize plot_height plot_width

#' Handlers and interactive inputs for plot sizing.
#'
#' @param vis Visualisation to listen to.
#' @param on_resize Callback function with arguments:
#'   \describe{
#'    \item{width,height}{Width and height in pixels}
#'    \item{padding}{A named list of four components giving the padding in
#'      each direction}
#'    \item{session}{The session, used to communicate with the browser}
#'   }
#' @export
#' @examples
#' # This example just prints out the current dimensions to the console
#' mtcars %>% ggvis(~mpg, ~wt) %>%
#'   layer_points() %>%
#'   handle_resize(function(width, height, ...) cat(width, "x", height, "\n"))
#'
#' # Use plot_width() and plot_height() to dynamically get the plot size
#' # inside the plot.
#' mtcars %>% ggvis(~mpg, ~wt) %>% layer_text(text := plot_width())
#' mtcars %>% ggvis(~mpg, ~wt) %>% layer_text(text := plot_height())
handle_resize <- function(vis, on_resize) {
  broker <- create_broker(
    reactive(NULL),
    connect = connect_resize(on_resize),
    spec = list(type = "resize")
  )
  register_reactive(vis, broker)
}


#' @export
#' @rdname handle_resize
plot_width <- function(vis) {
  vals <- shiny::reactiveValues()
  vals$x <- 100
  on_resize <- function(width, ...) {
    vals$x <- width
  }

  create_broker(
    reactive(vals$x),
    connect = connect_resize(on_resize),
    spec = list(type = "resize")
  )
}

#' @export
#' @rdname handle_resize
plot_height <- function(vis) {
  vals <- shiny::reactiveValues()
  vals$x <- 100
  on_resize <- function(height, ...) {
    vals$x <- height
  }

  create_broker(
    reactive(vals$x),
    connect = connect_resize(on_resize),
    spec = list(type = "resize")
  )
}


connect_resize <- function(on_resize) {
  check_callback(on_resize, c("width", "height", "padding", "session"))

  function(session, plot_id) {
    id <- paste0(plot_id, "_resize")
    shiny::observe({
      value <- session$input[[id]]
      if (is.null(value)) return()

      on_resize(width = value$width, height = value$height,
        padding = value$padding, session = value$session)
    })
  }
}
rpruim/ggvis2 documentation built on May 28, 2019, 2:34 a.m.