All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ui.scripts.docs.js Maven / Gradle / Ivy

/*
 * Licensed to The Apereo Foundation under one or more contributor license
 * agreements. See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 *
 *
 * The Apereo Foundation licenses this file to you under the Educational
 * Community License, Version 2.0 (the "License"); you may not use this file
 * except in compliance with the License. You may obtain a copy of the License
 * at:
 *
 *   http://opensource.org/licenses/ecl2.txt
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
 * License for the specific language governing permissions and limitations under
 * the License.
 *
 */

/* TODO: We don't want alerts but we are stuck with them for now: */
/* eslint-disable no-alert */
/* global $ */

/**
 * Try to prettify JSON data. In case it fails, just return the original data.
 */
function tryPretty(data) {
  try {
    var obj = JSON.parse(data);
    return JSON.stringify(obj, undefined, 2).toString();
  } catch(err) {
    return data;
  }
}

/**
 * Takes a path and integrates the pathParams values into it
 * @param {String} path the path with keys (e.g. /my/{thing}/{stuff})
 * @param {Array} params the params to put into the path (e.g. {'thing':'apple'})
 */
function updatePath(path, params) {
  var newPath = path;
  for (var key in params) {
    if (Object.prototype.hasOwnProperty.call(params, key)) {
      var value = params[key];
      if (value !== undefined && value !== null && value !== '') {
        // The Regex here handles syntax like /episode.{format:xml|json}.
        // In this case, the {format:xml|json} part is extracted, then
        // the xml|json part is used as the second regex to verify user's input.
        // If the input is valid, the path /episode.{format:xml|json} would be
        // replaced by /episode.xml for example.
        var regex = new RegExp( '{' + key + '(:[^}]*|)}', '');
        if (regex.test(newPath))
        {
          var pat = regex.exec(newPath)[1].substring(1);
          var regex2 = new RegExp(pat, '');
          if (regex2.test(value))
          {
            newPath = newPath.replace(regex, value);
          } else
          {
            alert('The value for ' + key + ' is invalid.');
          }
        } else
        {
          alert('wrong syntax');
        }
      }
    }
  }
  return newPath;
}

function checkPath($form) {
  var params = [];
  $form.find('.form_param_path').each( function() {
    var $param = $(this);
    params[$param.attr('name')] = $param.val();
  });
  var form_path = $form.find('input.form_action_holder').val();
  var path = updatePath(form_path, params);
  // update form and display
  $form.attr('action', path);
  $form.find('.form_path').html(path);
  return path.indexOf('{') < 0 && path.indexOf('}') < 0;
}

function checkRequired($form) {
  // check all required items
  var $required = $form.find('.form_param_required');
  var total = $required.length;
  var counter = 0;
  $required.each( function() {
    var $this = $(this);
    if ($this.val() !== null && $this.val() !== '') {
      counter++;
    }
  });
  var $formInputs = $form.find('div.form_submit input');
  if (counter >= total) {
    // submit is ok
    $formInputs.removeAttr('disabled');
    return true;
  } else {
    // disable form submit until required options at set
    $formInputs.attr('disabled', 'disabled');
    return false;
  }
}

$(document).ready(function() {

  $('a.show_form_link').click(
    function() {
      var $this = $(this);
      var $form = $this.parent().find('div.hidden_form');
      var $hidectrl = $this.parent().find('a.hide_form_link');
      $form.toggle(400);
      $hidectrl.show();
      $this.parent().find('div.form_submit input[type=\'button\']').click(
        function() {
          $form.hide(200);
          $this.show();
        }
      );
      $this.hide();
      return false;
    }
  );

  $('a.hide_form_link').click(
    function() {
      var $this = $(this);
      var $form = $this.parent().find('div.hidden_form');
      var $show_form_ctrl = $this.parent().find('a.show_form_link');
      $form.hide(200);
      $show_form_ctrl.show();
      $this.hide();
      return false;
    }
  );

  // do operation on all testing forms
  $('form.form_test_form').each( function() {
    var $form = $(this);
    if ($form.find('input.form_action_holder').length >= 1) {
      // now find and put the event handler on all path params
      $form.find('.form_param_path').change( function() {
        checkPath($form);
      });
      // run the checkPath method
      checkPath($form);
      var $reqParams = $form.find('.form_param_required');
      if ($reqParams.length > 0) {
        // add required options checks
        $reqParams.change( function(){
          checkRequired($form);
        }).keyup( function(){
          checkRequired($form);
        });
      }
      // run the check required
      checkRequired($form);
      // handle the ajax submissions
      if ($form.find('input.form_ajax_submit').length >= 1) {
        // the form will use ajax submit
        //var form_key = $form.find("input.form_endpoint_name").val();
        // add an event handler to the form submit
        $form.bind('submit', function() {
          if ( checkRequired($form) ) {
            var submitParams = {};
            $form.find('.form_param_submit').each( function() {
              var $param = $(this);
              var $value = $param.val();
              if (this.type == 'checkbox' && !this.checked) {
                $value = 'false';
              }
              submitParams[$param.attr('name')] = $value;
            });
            var method = $form.find('.form_method').val();
            var url = $form.attr('action');
            $form.parent().find('.test_form_working').show();
            $form.parent().find('.test_form_response input').click(function(){
              $(this).parent.hide();
            });

            // clear previous responses
            var responseBody = $form.parent().find('.test_form_response');
            responseBody.hide();
            responseBody.find('pre').text('');

            var queryString = '';
            if (method === 'DELETE') {
              queryString = $.param(submitParams);
            }

            if (queryString !== '') {
              url = url + '?' + queryString;
            }

            var request = {
              type: method,
              url: url,
              processData: true,
              dataType: 'text',
              success: function(data, textStatus, request) {
                $form.parent().find('.test_form_working').hide();
                var responseBody = $form.parent().find('.test_form_response');
                data = tryPretty(data);
                responseBody.show();
                var msg = 'Status: ' + request.status + ' (' + request.statusText + ')\n\n' + data;
                responseBody.find('pre').text(msg);
              },
              error: function(request) {
                $form.parent().find('.test_form_working').hide();
                var responseBody = $form.parent().find('.test_form_response');
                var msg = 'Status: ' + request.status + ' (' + request.statusText + ')';
                responseBody.show();
                responseBody.find('pre').text(msg);
              }
            };

            if (method !== 'DELETE') {
              request.data = submitParams;
            }

            // make the request
            $.ajax(request);
          } else {
            alert('Fill out all required fields first');
          }
          return false;
        });
      }
    }
  });
});




© 2015 - 2025 Weber Informatics LLC | Privacy Policy