R/downloadFile.R

Defines functions downloadFile downloadFileUI

#' @export
downloadFileUI <- function(id, text = "Download", class = NULL) {

  # indicators taken from https://github.com/daattali/advanced-shiny#proxy-click
  ns <- shiny::NS(id)
  loadingGif <- ""

  shiny::addResourcePath(prefix = 'downloadInfo', directoryPath = system.file("js", package = "dsmodules"))

  tagList(shiny::tagList(shiny::singleton(shiny::tags$body(shiny::tags$script( src =  "downloadInfo/downloadGen.js")))),
          shiny::div(`data-for-btn` = ns("downloadFile"),
                     shiny::downloadButton(ns("downloadFile"), text, class = class, style = "width: 200px; display: inline-block;"),
                     #button,
                     shiny::span(class = "btn-loading-container",
                                 shiny::img(src = loadingGif, class = "btn-loading-indicator", style = "display: none"),
                                 shiny::HTML("<i class = 'btn-done-indicator fa fa-check' style='display: none'> </i>"))))

}


#' @export
downloadFile <- function(input, output, session, path = NULL, name = "widget") {

  ns <- session$ns

  buttonId <- ns("downloadFile")
  # loadingEl <- sprintf(paste0("[data-for-btn=%s] .", ns("btn-loading-indicator")), buttonId)
  # doneEl <- sprintf(paste0("[data-for-btn=%s] .", ns("btn-done-indicator")), buttonId)
  # errEl <- sprintf(paste0("[data-for-btn=%s] .",ns("btn-err")), buttonId)

  # on.exit({
  #   shinyjs::enable(buttonId)
  #   shinyjs::hide(selector = loadingEl)
  # })

  output$downloadFile <- shiny::downloadHandler(
    filename = function() {
      session$sendCustomMessage('setButtonState', c('loading', buttonId))
      if (shiny::is.reactive(name))
        name <- name()
      if (shiny::is.reactive(path))
        path <- path()
      paste0(name, "-", gsub(" ", "_", substr(as.POSIXct(Sys.time()), 1, 19)), ".", file_ext(path))
    },
    content = function(file) {
      if (shiny::is.reactive(path))
        path <- path()
      file.copy(path, file)
      session$sendCustomMessage('setButtonState', c('done', buttonId))
    }
  )

}
datasketch/dsmodules documentation built on Feb. 22, 2025, 11:23 a.m.