inst/shinyApps/SqlDeveloper/server.R

library(shiny)
library(SqlRender)

shinyServer(function(input, output, session) {

  # cache <- reactiveValues(target = '', clicks = 0, parameters = NULL)

  parameters <- reactive({
    params <- regmatches(input$source, gregexpr("@[a-zA-Z0-9_]+", input$source))[[1]]
    params <- unique(params)
    params <- params[order(params)]
    params <- substr(params, 2, nchar(params))
    return(params)
  })

  output$target <- renderText({
    parameterValues <- list()
    for (param in parameters()) {
      value <- input[[param]]
      if (!is.null(value)) {
        parameterValues[[param]] <- value
      }
    }
    sql <- do.call("render", append(input$source, parameterValues))
    warningString <- c()
    handleWarning <- function(e) {
      output$warnings <- e$message
    }
    tempEmulationSchema <- input$tempEmulationSchema
    if (tempEmulationSchema == "")
      tempEmulationSchema <- NULL
    sql <- withCallingHandlers(suppressWarnings(translate(sql,
                                                          targetDialect = tolower(input$dialect),
                                                          tempEmulationSchema = tempEmulationSchema)), warning = handleWarning)
    if (!is.null(warningString))
      output$warnings <- warningString
    return(sql)
  })

  output$parameterInputs <- renderUI({
    params <- parameters()
    sourceSql <- input$source

    createRow <- function(param, sourceSql) {
      # Get current values if already exists:
      value <- isolate(input[[param]])

      if (is.null(value)) {
        # Get default values:
        value <- regmatches(sourceSql,
                            regexpr(paste0("\\{\\s*DEFAULT\\s*@", param, "\\s=[^}]+}"), sourceSql))
        if (length(value) == 1) {
          value <- sub(paste0("\\{\\s*DEFAULT\\s*@", param, "\\s=\\s*"), "", sub("\\}$", "", value))
        } else {
          value <- ""
        }
      }
      textInput(param, param, value = value)
    }
    lapply(params, createRow, sourceSql = sourceSql)
  })

  observeEvent(input$open, {
    sql <- SqlRender::readSql(input$open$datapath)
    updateTextAreaInput(session, "source", value = sql)
  })

  output$save <- downloadHandler(filename = function() {
    paste("query-", Sys.Date(), ".sql", sep = "")
  }, content = function(con) {
    SqlRender::writeSql(sql = input$source, targetFile = con)
  })
})

Try the SqlRender package in your browser

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

SqlRender documentation built on Oct. 7, 2023, 9:07 a.m.