Skip to content

Conversation

@cpsievert
Copy link
Collaborator

@cpsievert cpsievert commented Jun 10, 2025

This update gets renderPlot() interactive ggplot2 feature working with ggplot2's upcoming transition from S3 to S7 (tidyverse/ggplot2#6364).

Note that #4226 fixed a similar issue, but only for our unit tests. The same problem exists in renderPlot()'s interactive feature, which we don't have any automated tests for.

For a minimal example, with this app, no brushed points are returned when brushing the plot.

library(shiny)
library(ggplot2)
library(bslib)

ui <- page_fixed(
    card(
    card_header("Interactive Brushing Plot"),
    plotOutput("plot", brush = "plot_brush"),
    card_footer("Drag to select points on the plot")
  ),
  card(
    card_header("Selected Data Points"),
    tableOutput("brushed_data")
  )
)

server <- function(input, output, session) {
  
  output$plot <- renderPlot({
    ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, color = Species)) +
      geom_point(size = 3) +
      theme_minimal()
  })
  
  output$brushed_data <- renderTable({
    req(input$plot_brush)
    
    brushed_data <- brushedPoints(
      iris, input$plot_brush, 
      xvar = "Sepal.Length", yvar = "Sepal.Width"
    )
    
    if(nrow(brushed_data) == 0) {
      return(data.frame(Message = "No points selected"))
    }
    
    brushed_data
  })
}

shinyApp(ui = ui, server = server)
Screenshot 2025-06-10 at 10 01 20 AM

With this change, you'll get the expected behavior:

Screenshot 2025-06-10 at 10 04 23 AM

Testing notes

  • First, verify the example above is broken by installing the new ggplot2 remotes::install_github("tidyverse/ggplot2#6364")
  • Next, install this change, and verify the problem is fixed: remotes::install_github("rstudio/shiny#4228")

More generally, we should do more testing of shiny's interactive ggplot2 plot feature to make sure there isn't more changes that we're missing. We still have a handful of apps that we designed for manually testing, but never got automated tests:

093-plot-interaction-basic
094-image-interaction-basic
095-plot-interaction-advanced
096-plot-interaction-article-1
097-plot-interaction-article-2
098-plot-interaction-article-3
099-plot-interaction-article-4
100-plot-interaction-article-5
101-plot-interaction-article-6
102-plot-interaction-article-7
103-plot-interaction-article-8
104-plot-interaction-select
105-plot-interaction-zoom
106-plot-interaction-exclude

It'd also be great to verify that these apps are working as intended with the latest ggplot2 (plus this change). Testing across different environments isn't that important (we're just looking for changes in ggplot2's R code that we're not accounting for).

@cpsievert cpsievert requested a review from wch June 10, 2025 15:15
@karangattu
Copy link

The tests across all listed apps showed no issues with the ggplot2 plotting functionality in this branch of Shiny.

@cpsievert cpsievert force-pushed the fix/ggplot2-4.0-compat branch from 24ecd0d to 522fe88 Compare June 12, 2025 21:12
@cpsievert cpsievert merged commit 57bb3a1 into main Jun 12, 2025
12 checks passed
@cpsievert cpsievert deleted the fix/ggplot2-4.0-compat branch June 12, 2025 21:23
schloerke added a commit that referenced this pull request Jul 6, 2025
* main: (32 commits)
  Revert the addition of spacing between `icon` and `label` in `actionButton()` (#4248)
  Restrict `icon`/`label` separator spacing to `actionButton()` (#4247)
  Fix front-end action button label updating logic (#4242)
  Update news
  Properly handle undefined value for input subscribe callback (#4243)
  Start new version (#4241)
  v1.11.0 release candidate (#4232)
  Follow up to #3996: fix front-end checkbox label updating logic (#4238)
  feat(InputBinding): subscribe callback now supports event priority (#4211)
  Follow up to #3996 when label is unspecified (i.e., NULL), don't include it in the message (#4237)
  Run routine (#4234)
  chore: #4175 update jquery-ui to 1.14.1 (#4205)
  Update jQuery to 3.7.1 (#3969)
  Fix 404 in example 08_html (shiny.min.css) (#4221)
  Follow up to #3870: fix location of news item (#4233)
  Bugfix for error found in tests (#3870)
  Allow update input labels with HTML (#3996)
  Adds mirai to documentation (#4230)
  family->given for R Core authorship (#4222)
  fix(renderPlot): get interactive plotting working with ggplot2 v4.0 (#4228)
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants