inst/examples/conditional_app.R

library(shiny)
library(leaflet)
library(sf)
library(leaflet.extras2)

breweries91 <- st_as_sf(breweries91)
lines <- st_as_sf(atlStorms2005)
polys <- st_as_sf(leaflet::gadmCHE)
groups <- c("atlStorms","breweries","gadmCHE")

ui <- fluidPage(
  leafletOutput("map", height = 900),
  actionButton("remove", "Remove by Group"),
  actionButton("clear", "Clear")
)

server <- function(input, output, session) {
  output$map <- renderLeaflet({
    leaflet()  %>%
      addTiles() %>%
      leafem::addMouseCoordinates() %>%
      addPolylines(data = lines, label = ~Name, group = groups[1]) %>%
      addCircleMarkers(data = breweries91, label = ~brewery, group = groups[2]) %>%
      addPolygons(data = polys, label = ~NAME_1, group = groups[3]) %>%
      addLayerGroupConditional(groups = groups,
                               conditions = list(
                                 "(zoomLevel) => zoomLevel < 4" = groups[1],
                                 "(zoomLevel) => zoomLevel >= 4 & zoomLevel < 6 " = groups[2],
                                 "(zoomLevel) => zoomLevel >= 6" = c(groups[3])
                               )) %>%
      hideGroup(groups) %>%
      addLayersControl(overlayGroups = groups,
                       options = layersControlOptions(collapsed=FALSE))
  })
  observeEvent(input$clear, {
    leafletProxy("map") %>%
      clearConditionalLayers()
  })
  observeEvent(input$remove, {
    leafletProxy("map") %>%
      removeConditionalLayer(groups=groups[1])
  })
}
shinyApp(ui, server)

Try the leaflet.extras2 package in your browser

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

leaflet.extras2 documentation built on April 3, 2025, 10:46 p.m.