inst/shiny/modules/corpus.R

#' @rdname shiny_helper_functions
#' @export corpusUiInput
corpusUiInput <- function(){
  list(
    corpus = selectInput("corpus_corpus", "corpus", choices = corpus()[["corpus"]], selected = corpus()[["corpus"]][1])
  )
}


#' @rdname shiny_helper_functions
#' @export corpusUiOutput
corpusUiOutput <- function(){
}


#' @rdname shiny_helper_functions
#' @export corpusServer
corpusServer <- function(input, output, session){

  observeEvent(
    input$corpus_corpus,
    {
      infoFile <- registry_get_info(input$corpus_corpus)
      if (file.exists(infoFile)){
        content <- readLines(infoFile)
        if (grepl(".md$", infoFile)){
            content <- markdown::markdownToHTML(text = content)
            content <-  htmltools::HTML(gsub("^.*<body>(.*?)</body>.*?$", "\\1", as.character(content)))
        }
      } else {
        content <- htmltools::HTML("</br><i>no corpus info file available</i>")
      }
      output$corpus_info <- renderUI(content)
    }
  )
  
}

Try the polmineR package in your browser

Any scripts or data that you put into this service are public.

polmineR documentation built on Nov. 2, 2023, 5:52 p.m.