R/rk.JS.scan.R

Defines functions rk.JS.scan

Documented in rk.JS.scan

# Copyright 2010-2014 Meik Michalke <meik.michalke@hhu.de>
#
# This file is part of the R package rkwarddev.
#
# rkwarddev is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# rkwarddev is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with rkwarddev.  If not, see <http://www.gnu.org/licenses/>.


#' Create JavaScript variables and functions from plugin XML
#'
#' @param pXML Either an object of class \code{XiMpLe.doc} or \code{XiMpLe.node}, or path to a plugin XML file.
#' @param js Logical, if \code{TRUE} usable JavaScript code will be returned, otherwise a character
#'    vector with only the relevant ID names.
#' @param add.abbrev Logical, if \code{TRUE} the JavaScript variables will all have a prefix with an
#'    three letter abbreviation of the XML tag type to improve the readability of the code. But it's
#'    probably better to add this in the XML code in the first place.
#' @param guess.getter Logical, if \code{TRUE} try to get a good default getter function for JavaScript
#'    variable values. This will use some functions which were added with RKWard 0.6.1, and therefore
#'    raise the dependencies for your plugin/component accordingly. Nonetheless, it's recommended.
#' @param indent.by Character string used to indent each entry if \code{js=TRUE}.
#' @param mode Character string to set the operation mode. Currently, only \code{"vars"} and \code{"preview"}
#'    are supported. If \code{mode="vars"}, scans for relevant tags and returns variable definitions or IDs.
#'    If \code{mode="preview"}, scans only for occurring \code{<preview />} nodes and returns proper function
#'    definitions for the JavaScript file.
#' @param script Character string (or list of), the actual body of the JavaScript section we're scanning for. If not NULL,
#'    \code{rk.JS.scan} will try return only varaible definitions that are actually being used in the script code.
#' @return A character vector.
#' @seealso \href{help:rkwardplugins}{Introduction to Writing Plugins for RKWard}
#' @export

rk.JS.scan <- function(pXML, js=TRUE, add.abbrev=FALSE, guess.getter=FALSE, indent.by=rk.get.indent(), mode="vars", script=NULL){

  if(!mode %in% c("vars", "preview")){
    stop(simpleError("rk.JS.scan: \"mode\" must be either \"vars\" or \"preview\"!"))
  } else {}

  # all the next block is actually only relevant in "vars" mode
  # these are tags to scan normally, no special treatment
  JS.relevant.tags.default <- c("browser", "dropdown", "formula", "input", "matrix", "optioncolumn",
    "radio", "saveobject", "select", "spinbox", "valueslot", "varslot")
  # these tags should get a default modifier if guess.getter=TRUE
  if(isTRUE(guess.getter)){
    JS.relevant.tags.state <- c("checkbox")
  } else {
    JS.relevant.tags.state <- c()
    JS.relevant.tags.default <- c(JS.relevant.tags.default, "checkbox")
  }
  # special tags: must be checkable and get "checked" property
  JS.relevant.tags.checked <- c("frame")

  # getting the relevant IDs out of optionsets is a little tricky
  # this function will probe for sets and return single tags
  single.tags <- check.optionset.tags(XML.obj=pXML, drop=c("comments","cdata", "declarations", "doctype"))

  if(identical(mode, "vars")){
    # now go through the various cases of XML nodes, appending the results
    result <- check.JS.lines(relevant.tags=JS.relevant.tags.default, single.tags=single.tags,
      add.abbrev=add.abbrev, js=js, indent.by=indent.by, guess.getter=guess.getter, script=script)
    result <- check.JS.lines(relevant.tags=JS.relevant.tags.state, single.tags=single.tags,
      add.abbrev=add.abbrev, js=js, indent.by=indent.by, guess.getter=guess.getter,
      modifiers="state", append.modifier=FALSE, script=script, result=result)
    result <- check.JS.lines(relevant.tags=JS.relevant.tags.checked, single.tags=single.tags,
      add.abbrev=add.abbrev, js=js, indent.by=indent.by, guess.getter=guess.getter,
      modifiers="checked", only.checkable=TRUE, script=script, result=result)
  } else if(identical(mode, "preview")){
    have.previews <- filter.relevant.tags(single.tags=single.tags, relevant.tags="preview")
    if(length(have.previews) > 0){
      if(length(have.previews) > 1){
        warning("rk.JS.scan: there's more than one preview in your plugin, this might fail!")
      } else {}
      result <- paste0("function preview(){\n",
        rk.paste.JS(
          "preprocess(true);",
          "calculate(true);",
          "printout(true);",
          level=2, indent.by=indent.by
        ),
        "\n}\n\n"
      )
    } else {
      result <- ""
    }
  } else {}

  return(result)
}
rkward-community/rkwarddev documentation built on May 9, 2022, 3:02 p.m.