inst/examples/dev.R

library(shiny)

description <-
  "function(rule) {
    if (rule.operator && ['in', 'not_in'].indexOf(rule.operator.type) !== -1) {
      return 'Use a pipe (|) to separate multiple values with in and not in operators';}}"

# description <- "function(rule) {
#         return 'The description for ' + (rule.operator ? rule.operator.type : 'anything');}"

# class(description) <- "json"

filters <- list(
  list(
    id = "name",
    label = "Name",
    type = "string",
    description = description
  ),
  list(
    id = "carb",
    label = "Carb",
    type = "integer",
    description = description
  ),
  list(
    id = "rate",
    label = "Slider",
    type = "integer",
    validation = list(
      min = 0,
      max = 100
    ),
    plugin = "slider",
    plugin_config = list(
      min = 0,
      max = 100,
      value = 0
    )
  ),
  list(
    id = "date",
    label = "Datepicker",
    type = "date",
    validation = list(
      format = "YYYY/MM/DD"
    ),
    plugin = "datepicker",
    plugin_config = list(
      format = "yyyy/mm/dd",
      todayBtn = "linked",
      todayHighlight = TRUE,
      autoclose = TRUE
    )
  ),
  list(
    id = "state",
    label = "State",
    icon = "glyphicon glyphicon-globe",
    type = "string",
    input = "select",
    multiple = T,
    plugin = "selectize",
    plugin_config = list(
      valueField = "id",
      labelField = "name",
      searchField = "name",
      sortField = "name",
      options = list(
        list(id = "AL", name = "Alabama"),
        list(id = "AK", name = "Alaska"),
        list(id = "AZ", name = "Arizona"),
        list(id = "AR", name = "Arkansas"),
        list(id = "CA", name = "California"),
        list(id = "CO", name = "Colorado"),
        list(id = "CT", name = "Connecticut"),
        list(id = "DE", name = "Delaware"),
        list(id = "DC", name = "District of Columbia"),
        list(id = "FL", name = "Florida"),
        list(id = "GA", name = "Georgia"),
        list(id = "HI", name = "Hawaii"),
        list(id = "ID", name = "Idaho")
      )
    )
  ),
  list(
    id = "category",
    label = "Category",
    type = "integer",
    input = "checkbox",
    values = list(
      "Books",
      "Movies",
      "Music",
      "Tools",
      "Goodies",
      "Clothes"
    ),
    operators = c(
      "equal",
      "not_equal",
      "in",
      "not_in",
      "is_null",
      "is_not_null"
    )
  ),
  list(
    id = "coord",
    label = "Coordinates",
    type = "string",
    input = "function(rule, name) {
      var $container = rule.$el.find('.rule-value-container');

      $container.on('change', '[name='+ name +'_1]', function(){
        var h = '';

        switch ($(this).val()) {
          case 'A':
            h = '<option value=\"-1\">-</option> <option value=\"1\">1</option> <option value=\"2\">2</option>';
            break;
          case 'B':
            h = '<option value=\"-1\">-</option> <option value=\"3\">3</option> <option value=\"4\">4</option>';
            break;
          case 'C':
            h = '<option value=\"-1\">-</option> <option value=\"5\">5</option> <option value=\"6\">6</option>';
            break;
        }

        $container.find('[name$=_2]')
          .html(h).toggle(!!h)
          .val('-1').trigger('change');
      });

      return '\\
      <select name=\"'+ name +'_1\"> \\
        <option value=\"-1\">-</option> \\
        <option value=\"A\">A</option> \\
        <option value=\"B\">B</option> \\
        <option value=\"C\">C</option> \\
      </select> \\
      <select name=\"'+ name +'_2\" style=\"display:none;\"></select>';
    }",
    valueGetter = "function(rule) {
      return rule.$el.find('.rule-value-container [name$=_1]').val()
        +'.'+ rule.$el.find('.rule-value-container [name$=_2]').val();
    }",
    valueSetter = "function(rule, value) {
      if (rule.operator.nb_inputs > 0) {
        var val = value.split('.');

        rule.$el.find('.rule-value-container [name$=_1]').val(val[0]).trigger('change');
        rule.$el.find('.rule-value-container [name$=_2]').val(val[1]).trigger('change');
      }
    }"
  )
)



# rules <- list(
#   rules = list(
#     list(
#       id = "name",
#       operator = "equal",
#       value = "hello"
#     )
#   )
# )

plugins <- list(
  # "sortable" = NULL
  "filter-description" = list("mode" = "inline")
  # "bt-checkbox" = NULL,
  # "invert" = NULL
)
options(
  shiny.launch.browser = function(...) .vsc.browser(..., viewer = FALSE),
  shiny.port = httpuv::randomPort()
)

ui <- fluidPage(
  theme = bslib::bs_theme(version = "5"),
  useQueryBuilder(bs_version = "5"),
  tags$head(
    tags$script(
      "
    $( document ).ready(function() {
    $('#qb').on('afterCreateRuleInput.queryBuilder', function(e, rule) {
  if (rule.filter.plugin == 'selectize') {
    rule.$el.find('.rule-value-container').css('min-width', '200px')
      .find('.selectize-control').removeClass('form-control');
  }
});
});"
    )
  ),
  fluidRow(
    column(
      width = 6,
      queryBuilderInput(
        "qb",
        filters = filters,
        # rules = rules,
        plugins = plugins,
        return_value = "r_rules",
        display_errors = TRUE
      )
    ),
    column(
      width = 4,
      actionButton("update", "Update")
    )
  ),
  fluidRow(
    column(
      width = 6,
      tableOutput("table")
    )
  )
)

server <- function(input, output, session) {
  observe({
    req(input$qb_valid)
    print(input$qb)
  })

  new_rules <- list(
    list(
      id = "go",
      type = "string"
    )
  )

  observe({
    updateQueryBuilder(
      inputId = "qb",
      addFilter = list(
        filter = new_rules
      )
    )
  }) |>
    bindEvent(input$update)

  output$table <- renderTable({
    req(input$qb_valid)
    filter_table(
      data = mtcars,
      filters = input$qb,
      output = "table"
    )
  })



  session$onSessionEnded(function() {
    shiny::stopApp()
  })
}

shinyApp(ui = ui, server = server)

# rsconnect::deployApp(
#   appDir = "./inst/app",
#   appName = "qbr_demo"
# )



library(shiny)

ui <- fluidPage(
  useQueryBuilder(bs_version = "5"),
  queryBuilderInput(
    inputId = "basic",
    filters = filters,
    rules = rules_basic,
    return_value = "r_rules"
  )
)

server <- function(input, output, session) {
  observe({
    print(input$basic)
  })
}


shinyApp(ui, server)

Try the jqbr package in your browser

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

jqbr documentation built on Aug. 15, 2023, 9:07 a.m.