R shiny - pop up window with options

后端 未结 2 1124
北恋
北恋 2021-02-15 12:45

Im creating a shiny app that queries an SQL database. I want to warn the user if the queried data has entries on two dates. Moreover, I want the user to be able to select which

2条回答
  •  时光取名叫无心
    2021-02-15 13:31

    I created a sample App which should give you a good introduction on how you can use Alerts. I'm not using the alerts from shinyBS package as you can see, but instead I used session$sendCustomMessage to send a message with JS alert functionality. I've added some comments in the code so have a look. Note that I make use of the sub function to create the desired text by substituting my expression into the SOMETHING part of the string.

    rm(list = ls())
    library(shiny)
    library(DT)
    
    ui <- fluidPage(
    
      # Inlcude the line below in ui.R so you can send messages
      tags$head(tags$script(HTML('Shiny.addCustomMessageHandler("jsCode",function(message) {eval(message.value);});'))),
      titlePanel("Pop-up Alerts"),
      sidebarPanel(
        sliderInput("my_slider", "Range Slider:", min = 0, max = 150, value = 40, step=1),
        dateInput('my_daterange',label = '',value = Sys.Date()),
        actionButton("run","Execute")),
      mainPanel(DT::dataTableOutput('tbl'))
    )
    
    server <- function(input, output, session) {
    
      # Alert below will trigger if the slider is over 100
      observe({
        if(input$my_slider >= 100)
        {
          my_slider_check_test <- "Your slider value is above 100 - no data will be displayed"
          js_string <- 'alert("SOMETHING");'
          js_string <- sub("SOMETHING",my_slider_check_test,js_string)
          session$sendCustomMessage(type='jsCode', list(value = js_string))
        }
      })
    
    
      # Alert below about dates will notify you if you selected today
      observe({
        if (is.null(input$run) || input$run == 0){return()}
        isolate({
          input$run
          if(input$my_daterange == Sys.Date())
          {
            my_date_check_test <- "Today Selected"
            js_string <- 'alert("SOMETHING");'
            js_string <- sub("SOMETHING",my_date_check_test,js_string)
            session$sendCustomMessage(type='jsCode', list(value = js_string))
          }
          # Alert will also trigger and will notify about the dates
          if(input$my_daterange == Sys.Date())
          {
            my_date_check_test <- paste0("You selected: ",input$my_daterange)
            js_string <- 'alert("SOMETHING");'
            js_string <- sub("SOMETHING",my_date_check_test,js_string)
            session$sendCustomMessage(type='jsCode', list(value = js_string))
          }
    
        })
      })
    
      my_data <- reactive({
    
        if(input$run==0){return()}
        isolate({
          input$run
          if(input$my_slider >= 100)
          {
            # Alert below will trigger if you adjusted the date but slider is still 100
            my_slider_check_test <- "Slider is still over 100"
            js_string <- 'alert("SOMETHING");'
            js_string <- sub("SOMETHING",my_slider_check_test,js_string)
            session$sendCustomMessage(type='jsCode', list(value = js_string))
          }
          if(input$my_slider < 100)
          {
            iris[1:input$my_slider,]
          }
        })  
    })
    output$tbl = DT::renderDataTable(my_data(), options = list(lengthChange = FALSE))
    }
    
    shinyApp(ui = ui, server = server)
    

    The output below of some pop-ups is in IE, Google Chrome will be different:

    #1 Slider over 100 alert

    #2 Dates: Today Selected

    #3 Dates: Simply alerting by printing the date

    #4 Alert to show that the slider is still over 100

    #5 If the slider is under 100, you get tableoutput

提交回复
热议问题