R/shiny_module_compare_inputs.R

Defines functions compareInputsModuleServer compareInputsModuleUI

compareInputsModuleUI <- function(id, allowCompare = TRUE) {
  ns <- NS(id)
  if (allowCompare) {
    shiny::uiOutput(ns("content"))
  } else {
    tags$div(
      style = "visibility:hidden;",
      shiny::uiOutput(ns("content"))
    )
  }
}

compareInputsModuleServer <- function(input, output, session, ctrl) {
  ns <- session$ns

  output$content <- shiny::renderUI({
    shiny::tagList(
      tags$div(class="separator"),
      checkboxInput(ns("compare"), ctrl$translations$compare, value = ctrl$ncharts > 1),
      shiny::conditionalPanel(
        sprintf("input['%s']", ns("compare")),
        shiny::selectInput(
          ns(".compareVars"), ctrl$translations$compareVars,
          choices = ctrl$uiSpec$getShareable(),
          selected = intersect(ctrl$uiSpec$getShareable(), ctrl$uiSpec$inputList$unshared()),
          multiple = TRUE
        ),
        tags$div(
          class = "compare-inputs",
          tags$div(
            shiny::numericInput(ns("nbCharts"), ctrl$translations$ncharts,
                                value = max(2, ctrl$ncharts), min = 2, max = 12)
          ),
          tags$div(
            shiny::selectInput(ns("ncols"), ctrl$translations$ncol, c("auto", 1:4), selected = ctrl$ncol)
          )
        )
      )
    )
  })

  nbCharts <- reactive({if (is.null(input$compare)) ctrl$ncharts else if (input$compare) input$nbCharts else 1})

  observeEvent(input$compare, {
    if (!is.null(input$compare) && !input$compare) {
      for (n in intersect(ctrl$uiSpec$getShareable(), input$.compareVars)) {
        ctrl$uiSpec$shareInput(n)
      }
      updateSelectInput(session, ".compareVars", selected = list())
    }
  }, ignoreInit = TRUE, ignoreNULL = FALSE)

  res <- reactiveValues()

  observe({
    req(nbCharts())
    i_ncols <- input$ncols
    if(is.null(i_ncols)) i_ncols <- ctrl$ncol
    if(is.null(i_ncols)) i_ncols <- "auto"
    if (nbCharts() == 1) {
      ncol <- 1
    } else if (i_ncols== "auto") {
      ncol <- NULL
    } else {
      ncol <- as.numeric(i_ncols)
    }
    dim <- .getRowAndCols(nbCharts(), ncol = ncol)
    res$n <- dim$n
    res$ncol <- dim$ncol
    res$nrow <- dim$nrow
  })

  observeEvent(ignoreNULL = FALSE, ignoreInit = TRUE, input$.compareVars, {
    toUnshare <- setdiff(input$.compareVars, ctrl$uiSpec$inputList$unshared())
    toShare <- setdiff(
      setdiff(ctrl$uiSpec$getShareable(), input$.compareVars),
      ctrl$uiSpec$inputList$shared()
    )

    for (n in toUnshare) {
      ctrl$uiSpec$unshareInput(n)
    }

    for (n in toShare) {
      newSharedInputs <- ctrl$uiSpec$shareInput(n)
      if (length(newSharedInputs) > 0 & nbCharts() > 1) {
        for (i in 2:nbCharts()) ctrl$updateChart(i)
      }
    }

    unshared <- intersect(ctrl$uiSpec$getShareable(), ctrl$uiSpec$inputList$unshared())
    if (!identical(sort(input$.compareVars), sort(unshared))) {
      shiny::updateSelectInput(session, ".compareVars", selected = unshared)
    }
  })

  res$.compareVars <- reactive(input$.compareVars)

  res
}

Try the manipulateWidget package in your browser

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

manipulateWidget documentation built on Oct. 5, 2021, 9:10 a.m.