inst/shiny/skeleSimShinyGUI/modules/tableinput.R

#' @title Matrix input
#' @description Creates an adjustable-length matrix input widget for shiny.
#'
#' @param inputId Input variable to assign the control's value to.
#' @param label Display label for the control.
#' @param data The initial values to use for the matrix.
#'
#' @import shiny
#' @export
#'
matrixInput <- function(inputId, label, data) {
  addResourcePath(
    prefix='tableinput',
    directoryPath=system.file('tableinput', package = 'skeleSim')
  )

  tagList(
    singleton(
      tags$head(
        tags$link(
          rel = 'stylesheet', type = 'text/css',
          href = 'tableinput/tableinput.css'
        ),
        tags$script(src = 'tableinput/tableinput.js')
      )
    ),
    tags$label(class = "control-label", label),
    tags$table(
      id = inputId,
      class = 'tableinput data table table-bordered table-condensed',
      tags$colgroup(
        lapply(names(data), function(name) {
          tags$col('data-name' = name, 'data-field' = name, 'data-type' = 'numeric')
        })
      ),
      tags$thead(
        class = 'hide',
        tags$tr(
          lapply(names(data), function(name) tags$th(name))
        )
      ),
      tags$tbody(
        lapply(1:nrow(data), function(i) {
          tags$tr(
            lapply(names(data), function(name) {
              tags$td(div(tabindex=0, as.character(data[i,name])))
            })
          )
        })
      )
    ),
    tags$div(
      class = 'tableinput-editor modal hide fade',
      tags$div(
        class = 'modal-header',
        HTML('<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>'),
        tags$h3(label)
      ),
      tags$div(
        class = 'modal-body',
        HTML('
          <form class="form-horizontal">
            <div class="control-group">
              <label class="control-label">Rows</label>
              <div class="controls">
                <input type="number" class="tableinput-rowcount">
              </div>
            </div>
            <div class="control-group">
              <label class="control-label">Columns</label>
              <div class="controls">
                <input type="number" class="tableinput-colcount">
              </div>
            </div>
          </form>'
        )
      ),
      tags$div(
        class = 'modal-footer',
        tags$a(href = '#', class = 'btn btn-primary tableinput-edit', 'OK'),
        tags$a(
          href = '#', class = 'btn', 'data-dismiss' = 'modal',
          'aria-hidden' = 'true', 'Cancel'
        )
      )
    )
  )
}

Try the skeleSim package in your browser

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

skeleSim documentation built on May 2, 2019, 5:16 a.m.