Page tree

Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

ConfiForms Form Definition
formNameformA

optionOption[111510524|formB|t|true||]smartselect2

!option:[empty]loadFormBDetails(formId)Run custom JavaScript

option:[empty]Hide container#formBDetails

HTML
<script type="text/javascript">
 function loadFormBDetails(formId){
   buildHtmlTable('#formBDetailsTable', []);
 }
</script>
ConfiForms (FormView) Registrations Control
formNameformA
typeEmbedded

optiontrue

HTML
<script type="text/javascript">
// based on an answer found at https://stackoverflow.com/questions/5180382/convert-json-data-to-a-html-table

<script type="text/javascript">
// Builds the HTML Table out of myList.
function buildHtmlTable(selector, dataList) {
  var columns = addAllColumnHeaders(myListdataList, selector);

  for (var i = 0; i < myListdataList.length; i++) {
    var row$ = AJS.$('<tr/>');
    for (var colIndex = 0; colIndex < columns.length; colIndex++) {
      var cellValue = myListdataList[i][columns[colIndex]];
      if (cellValue == null) cellValue = "";
      row$.append(AJS.$('<td/>').html(cellValue));
    }
    $(selector).append(row$);
  }
}

// Adds a header row to the table and returns the set of columns.
// Need to do union of keys from all records as some records may not contain
// all records.
function addAllColumnHeaders(myListdataList, selector) {
  var columnSet = [];
  var headerTr$ = AJS.$('<tr/>');

  for (var i = 0; i < myListdataList.length; i++) {
    var rowHash = myListdataList[i];
    for (var key in rowHash) {
      if ($.inArray(key, columnSet) == -1) {
        columnSet.push(key);
        headerTr$.append(AJS.$('<th/>').html(key));
      }
    }
  }
  $(selector).append(headerTr$);

  return columnSet;
}
</script>

...