Как вызвать обработчик загрузки из пользовательской кнопки в Shiny - PullRequest
0 голосов
/ 16 апреля 2020

У меня блестящее приложение. Приложение содержит таблицу. Каждая строка в таблице содержит одну кнопку, которая должна позволять пользователю загружать данные из этой строки в отчет.

Я просто застрял в возможности подключить пользовательскую кнопку строки к обработчику загрузки. Обычно я использовал бы кнопку загрузки, чтобы сделать это, но как я могу сделать это с пользовательской кнопкой.

Мое событие наблюдения:

observeEvent(input$lastClick,
               {
                 if (input$lastClickId%like%"letter")
                 {
                   row_to_report=as.numeric(gsub("letter_","",input$lastClickId))
                   MyLetter=RV4$data[row_to_report,]

Как я могу инициировать загрузку здесь, используя downloadHandler:

                 downloadHandler(
                 filename = "letter.docx",
                 content = function(file) {
                   tempReport <- file.path(tempdir(), "letter.Rmd")
                   file.copy("letter.Rmd", tempReport, overwrite = TRUE)

                   # Set up parameters to pass to Rmd document
                   params <- list(MyLetter)

                   rmarkdown::render(tempReport, output_file = file,
                                     params = params,
                                     envir = new.env(parent = globalenv()),

                   )
                 }
               )
             }
             else if (input$lastClickId%like%"delete")
             {
               row_to_del=as.numeric(gsub("delete_","",input$lastClickId))
               RV3$data=RV3$data[-row_to_del,]
             }
           }

)

Моя таблица данных создается следующим образом:

  output$drilldownBarr <- DT::renderDT({

      if (!is.null(drilldataBarrd())) {  

        browser()
        drilldataBarrdf<-drilldataBarrd()
        drilldataBarrdf$Actions<-
         paste0('
                <div class="btn-group" role="group" aria-label="Basic example">
                <button type="button" class="btn btn-secondary letter" id=letter_',1:nrow(drilldataBarrd()),'>Letter</button>
                </div>
                ')
     }

    datatable(drilldataBarrdf,escape=F, extensions = c("Select","Buttons"), selection = "none",

              options = list(
                scrollX = TRUE,
                scrollY = TRUE,
                pageLength = 200,
                select = "api",
                dom = 'Bfrtip',
                buttons = c('copy', 'csv', 'excel', 'pdf', 'print','colvis'))
    )
  })

Возможно, есть лучший способ? Например, создать кнопку загрузки в каждой строке. Но как это сделать?

1 Ответ

1 голос
/ 16 апреля 2020

Вот решение с использованием кодировки base64 файла отчета. Он не использует downloadHandler.

library(shiny)
library(DT)
library(base64enc)
library(rmarkdown)

js <- '
Shiny.addCustomMessageHandler("download", function(b64){
  const a = document.createElement("a");
  document.body.append(a);
  a.download = "report.docx";
  a.href = b64;
  a.click();
  a.remove();
})
'

buttonHTML <- function(i){
  as.character(
    actionButton(
      paste0("button_", i), label = "Report", 
      onclick = sprintf("Shiny.setInputValue('button', %d);", i)           
    )
  )
}

dat <- iris[1:5,]
dat$Action <- sapply(1:nrow(dat), buttonHTML)

ui <- fluidPage(
  tags$head(tags$script(HTML(js))),
  br(),
  DTOutput("dtable")
)

server <- function(input, output, session){

  output[["dtable"]] <- renderDT({
    datatable(dat, escape = -ncol(dat)-1)
  })

  observeEvent(input[["button"]], {
    showNotification("Creating report...", type = "message")
    tmpReport <- tempfile(fileext = ".Rmd")
    file.copy("report.Rmd", tmpReport)
    outfile <- file.path(tempdir(), "report.docx")
    render(tmpReport, output_file = outfile, 
           params = list(data = dat[input[["button"]], -ncol(dat)]))
    b64 <- dataURI(
      file = outfile, 
      mime = "application/vnd.openxmlformats-officedocument.wordprocessingml.document"
    )
    session$sendCustomMessage("download", b64)
  })

}

shinyApp(ui, server)

Файл rmarkdown report.Rmd :

---
title: "Untitled"
author: "Stéphane Laurent"
date: "16 avril 2020"
output: word_document
params:
  data: "x"
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE)
```

```{r}
params$data
```
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...