在 Shiny 中保存多个 TinyMCE 的内容

Posted

技术标签:

【中文标题】在 Shiny 中保存多个 TinyMCE 的内容【英文标题】:saving content of multiple TinyMCE in Shiny 【发布时间】:2021-08-29 08:52:05 【问题描述】:

我在闪亮中使用了两个 tinyMCE 实例。我想使用单个操作按钮将这两个实例的内容保存为 csv 文件。我可以使用两个操作按钮,但这违背了我的目标。 javascript 以及如何使其在 R 中工作并不是很好。我能够获取一些代码来保存第一个实例的输出。以下是一个工作示例。

library(shiny)

# Define UI for application that draws a histogram
ui <-  fluidRow(
        titlePanel("tinyMCE Shiny"),
        br(),
        column(width=6,
               tags$script(src='https://cloud.tinymce.com/stable/tinymce.min.js'),
               tags$form(method="post",
                         tags$textarea(id="textHolder1"),
                         tags$textarea(id="textHolder2")
               ),
               br(),
               actionButton("fetch", "Get Results!", icon=icon("lightbulb-o"),class="btn-primary",
                            onclick = "Shiny.onInputChange('typedText', tinyMCE.get('textHolder1').getContent());"),
               tags$script("
                           tinymce.init(
                           selector:'#textHolder1',
                           theme: 'modern',
                           height: 500,
                           plugins: ['advlist autolink link image lists charmap preview hr table','wordcount',],
                           menubar: true,
                           toolbar: 'undo redo | bold italic | bullist | link | image ',
                           );"),
               tags$script("
                           tinymce.init(
                           selector:'#textHolder2',
                           theme: 'modern',
                           height: 500,
                           plugins: ['advlist autolink link image lists charmap preview hr table','wordcount',],
                           menubar: true,
                           toolbar: 'undo redo | bold italic | bullist | link | image ',
                           );")
  ),
  column(width=6,
         tags$style(html('pre height:240px;')),
         tags$label(`for`="rawText", "Raw String"),
         hr(),
         tags$pre(textOutput("rawText")),
         br(),
         tags$label(`for`="htmlText", "HTML Version"),
         hr(),
         tags$pre(htmlOutput("htmlText"))
  )
    )

# Define server logic required to draw a histogram
server <- function(input, output) 
   
    output$htmlText <- renderUI(
        req(input$typedText)
        HTML(enc2utf8(input$typedText))
    )
    
    output$rawText <- renderText(
        req(input$typedText)
        enc2utf8(input$typedText)
    )
    
    observeEvent(input$fetch,
        j <- data.frame("t"= HTML(enc2utf8(input$typedText)))
        write.csv(j,"test.csv")
    )
    


# Run the application 
shinyApp(ui = ui, server = server)

【问题讨论】:

【参考方案1】:

您可以连接来自onclick 中的两个文本的输入-

actionButton("fetch", "Get Results!", icon=icon("lightbulb-o"),class="btn-primary",
                      onclick = "Shiny.onInputChange('typedText', tinyMCE.get('textHolder1').getContent() + tinyMCE.get('textHolder2').getContent());")

完整的应用代码 -

ui <-  fluidRow(
  titlePanel("tinyMCE Shiny"),
  br(),
  column(width=6,
         tags$script(src='https://cloud.tinymce.com/stable/tinymce.min.js'),
         tags$form(method="post",
                   tags$textarea(id="textHolder1"),
                   tags$textarea(id="textHolder2")
         ),
         br(),
         actionButton("fetch", "Get Results!", icon=icon("lightbulb-o"),class="btn-primary",
                      onclick = "Shiny.onInputChange('typedText', tinyMCE.get('textHolder1').getContent() + tinyMCE.get('textHolder2').getContent());"),
         tags$script("
                           tinymce.init(
                           selector:'#textHolder1',
                           theme: 'modern',
                           height: 500,
                           plugins: ['advlist autolink link image lists charmap preview hr table','wordcount',],
                           menubar: true,
                           toolbar: 'undo redo | bold italic | bullist | link | image ',
                           );"),
         tags$script("
                           tinymce.init(
                           selector:'#textHolder2',
                           theme: 'modern',
                           height: 500,
                           plugins: ['advlist autolink link image lists charmap preview hr table','wordcount',],
                           menubar: true,
                           toolbar: 'undo redo | bold italic | bullist | link | image ',
                           );")
  ),
  column(width=6,
         tags$style(HTML('pre height:240px;')),
         tags$label(`for`="rawText", "Raw String"),
         hr(),
         tags$pre(textOutput("rawText")),
         br(),
         tags$label(`for`="htmlText", "HTML Version"),
         hr(),
         tags$pre(htmlOutput("htmlText"))
  )
)

# Define server logic required to draw a histogram
server <- function(input, output) 
  
  output$htmlText <- renderUI(
    req(input$typedText)
    HTML(enc2utf8(input$typedText))
  )
  
  output$rawText <- renderText(
    req(input$typedText)
    enc2utf8(input$typedText)
  )
  
  observeEvent(input$fetch,
    j <- data.frame(t = HTML(enc2utf8(input$typedText)))
    write.csv(j,"test.csv")
  )
  


# Run the application 
shinyApp(ui = ui, server = server)

【讨论】:

谢谢,但是这个解决方案并不能解决我的问题。我的问题应该更清楚。如果您注意到我使用 textholder1 和 textholder2 识别了 2 个 TinyMCE 实例。我只能使用操作按钮保存 textholder1 的输出。我想使用单个操作按钮保存 textholder1 和 textholder2 的输出。 @AtmajitsinhGohil 知道了,你能试试更新的答案吗? 这是完美的。谢谢...这是一个非常好的解决方案。我对 javascript 真的很陌生。

以上是关于在 Shiny 中保存多个 TinyMCE 的内容的主要内容,如果未能解决你的问题,请参考以下文章

tinymce - 如何禁用智能粘贴

Tinymce wiris数学编辑

WORD里头的图片如何直接复制到tinymce编辑器

根据文件选择保存和加载用户选择 - R Shiny

如何将 TinyMCE 保存为文件?

在 Wordpress 中保存小部件后 TinyMCE 消失