JavaScript

Parent Previous Next

Get Direct Debit Authorization List



The user will be able to get all the beneficiary list by entering userID and PIN,

then the output will display Beneficiary List for the specific userID.



We will be able to import useful data from these 3 sources, and to call a function and store the user ID and PIN.














getUserID&getPIN



This code required data variable from Jsp, please refer to getUserID&getPIN above.








We will create a function and a header. The header will contain servicename, userID, PIN.


serviceName: getDirectDebitAuthorizationList





setUserID&setPIN



This code required data variable from Jsp, please refer to getUserID&getPIN above.







We will disable Send button









Then we will set some request parameters:


headerObj contains:



Then will use JSON to convert headerObj into var header.





JSP



This code required data variable from Jsp, please refer to Jsp above.







Set up http request.


If xmlHttp is equals to nothing, the web page will display an alert message:"Browser does not support HTTP request."


If xmlHttp is not equal to nothing, the web page will return data from the url and the header."


The timeout will be 5000s.





xmlHttp



This code required data variable xmlHttp from Jsp, please refer to xmlHttp above.



ApiURL



This code required data variable ApiURL from Jsp, please refer to ApiURL above.







Setup http event handlersIf globalerrorID = "010041", return OTP. Else if globalerrorID not = "010000", return error details.





onreadystatechange



This code required data variable onreadystatechange from Jsp, please refer to onreadystatechange above.



xmlHttp



This code required data variable xmlHttp from Jsp, please refer to xmlHttp above.



showOTPModel



This code required data variable showOTPModel from Jsp, please refer to showOTPModel above.



showErrorModal



This code required data variable showErrorModal from Jsp, please refer to showErrorModal above.







I will get all the data from AuthorizationList from -->

--> responseObj.Content.ServiceResponse.AuthorizationList

Then I will create a variable Authorization to store all the data.

Lastly, I will check "AuthorizationList" by using a function "getRecordCount".

Get all the necessary data.










Display all the necessary data.

I will create an empty variable "htmlcode" first.

Then I will use a for loop to display all the data:










We will enable "Send" button.

Once the time is out, it will show error modal: "Timeout invoking API."

Then send the http request.





xmlHttp



This code required data variable xmlHttp from Jsp, please refer to xmlHttp above.



ontimeout



This code required data variable ontimeout from Jsp, please refer to ontimeout above.



showErrorModal



This code required data variable showErrorModal from Jsp, please refer to showErrorModal above.







Button will be disabled when there is an error occurs.









OTP model update button clicked





setOTP



This code required data variable setOTP from Jsp, please refer to setOTP above.







Create a function "getRecordCount"


Lastly, for the “getRecordCount” function, If the length of the AuthorizationList is equal to 0(there is nothing in the AuthorizationList), another function will be called: “showErrorModal”, an error will be displayed “Customer has no accounts”. If the length of the AuthorizationList is equal to undefined, it will return 1 and the length of the Authorization within the AuthorizationList.





showErrorModal



This code required data variable showErrorModal from Jsp, please refer to showErrorModal above.







Overview of getDirectDebitAuthorizationList



<h2 class="page-header" style="color:#937851">List Of Direct Debit Authorization</h2>


<div class="container">

   <div class="col-md-6">

       <div class="row">

           <h3 style="color:#937851">Input</h3>

       </div>

       <form class="form-horizontal well" style="padding-bottom: 0px;">

           <div class="form-group">

               <div class="col-sm-offset-4 col-sm-4">

                   <button id="Send" type="button" class="btn btn-primary">Send</button>

                   <button type="reset" class="btn btn-default">Clear</button>

               </div>

           </div>

           

           <div class="form-group">

               <label for="userID" class="col-sm-4 control-label">User ID</label>

               <div class="col-sm-4">

                   <input id="userID" type="text" class="form-control"/>

               </div>

           </div>

           

           <div class="form-group">

               <label for="PIN" class="col-sm-4 control-label">PIN</label>

               <div class="col-sm-4">

                   <input id="PIN" type="password" class="form-control"/>

               </div>

           </div>

           

       </form>

       <div class="row">

           <div class="col-md-12">

               <hr style="margin-top: 0px; margin-bottom: 20px;">

           </div>

       </div>

   </div>

</div>


<!-- show table

======================================== -->

<div class="container">

   <div class="row">

       <h3 style="color:#937851">Output</h3>

   </div>

   <table class="table table-striped col-md-12 well">

       <thead>

           <tr>

               <th>Customer Account ID</th>

               <th>Billing Org Account ID</th>

               <th>Billing Org Name</th>

               <th>Creation Date</th>

               <th>Direct Debit Authorization ID</th>

               

           </tr>

       </thead>

       <tbody id="Authorization_table">

       </tbody>

   </table>

</div>





<!-- javascript libraries

======================================== -->

<script src="assets/js/jquery.min.js"></script>

<script src="assets/js/jquery-ui.min.js"></script>

<script src="assets/js/bootstrap.min.js"></script>


<script type="text/javascript">


   $(document).ready(function () {

       

       // init user credentials

       document.getElementById("userID").value = getUserID();

       document.getElementById("PIN").value = getPIN();


       /*----------------------------------------

        * [Send] button clicked

        */

       $("#Send").click(function (event) {

           (function() {


               // set service header values

               var serviceName = "getDirectDebitAuthorizationList";

               var userID = document.getElementById("userID").value;

               setUserID(userID);

               var PIN = document.getElementById("PIN").value;

               setPIN(PIN);

                                           


               // disable Send button

               document.getElementById("Send").disabled = true;


               // set request parameters

               var headerObj = {

                   Header: {

                       serviceName: serviceName,

                       userID: userID,

                       PIN: PIN,                        

                       OTP: OTP,

                       

                   }

               };

                                                   

               var header = JSON.stringify(headerObj);

               


               // setup http request

               var xmlHttp = new XMLHttpRequest();

               if (xmlHttp === null){

                   alert("Browser does not support HTTP request.");

                   return;

               }

               xmlHttp.open("POST", getApiURL()+"?Header="+header, true);

               xmlHttp.timeout = 5000;


               // setup http event handlers

               xmlHttp.onreadystatechange = function() {

                   if (xmlHttp.readyState === 4 && xmlHttp.status === 200) {

                       responseObj = JSON.parse(xmlHttp.responseText);

                       serviceRespHeader = responseObj.Content.ServiceResponse.ServiceRespHeader;

                       globalErrorID = serviceRespHeader.GlobalErrorID;

                       if (globalErrorID === "010041"){

                           showOTPModal();

                           return;

                       }

                       else if (globalErrorID !== "010000"){

                           showErrorModal(serviceRespHeader.ErrorDetails);

                           return;

                       }

                       

                       // get data 拿到所有的data

                             AuthorizationList = responseObj.Content.ServiceResponse.AuthorizationList;

                       Authorization = AuthorizationList.Authorization;// data放进这个variable里面

                       var recordCount = getRecordCount(AuthorizationList);//check AuthorizationList

                       

                                                                                       

                       // display data

                       var htmlcode = "";

                       for(var i = 0; i < recordCount; i++){

                           var directDebitAuth = (recordCount===1)?Authorization:Authorization[i];

                           htmlcode += "<tr>";

                           htmlcode += "<td>" + directDebitAuth.CustomerAccountID + "</td>";

                           htmlcode += "<td>" + directDebitAuth.BillingOrgAccountID + "</td>";

                           htmlcode += "<td>" + getBillingOrgName(directDebitAuth.BillingOrgID) + "</td>";

                           htmlcode += "<td>" + directDebitAuth.CreationDate + "</td>";

                           htmlcode += "<td>" + directDebitAuth.DirectDebitAuthorizationID + "</td>";

                           htmlcode += "</tr>";

                       }

                       $("#Authorization_table").html(htmlcode);

                       

                       // enable Send button

                       document.getElementById("Send").disabled = false;

                   }

               };

               xmlHttp.ontimeout = function (e) {

                   showErrorModal("Timeout invoking API.");

                   return;

               };                                        


               // send the http request

               xmlHttp.send();


           })();

       });                              

                       

                       


       /* ----------------------------------------

        * error model close button clicked

        */

       $("#CloseError").click(function (event) {

           (function() {

               document.getElementById("Send").disabled = false;

           })();

       });


       /* ----------------------------------------

        * OTP model update button clicked

        */

       $("#UpdateOTP").click(function (event) {

           (function() {

               var OTP = document.getElementById("OTP").value;

               setOTP(OTP, function() { // ensure OTP set before clicking Send

                   document.getElementById("Send").disabled = false;

                   document.getElementById("Send").click();

               });

           })();

       });


   });

   function getRecordCount(AuthorizationList) {

           if (Object.keys(AuthorizationList).length === 0){

               showErrorModal("Customer has not authorized any organization for direct debit.");

               return 0;

           }

           if (AuthorizationList.Authorization.length === undefined)

               return 1;

           return AuthorizationList.Authorization.length;

       }

   


</script>

   </body>

</html>



You can download the "directDebitAuthorizationList" function below.



directDebitAuthorizationList


Created with the Personal Edition of HelpNDoc: Easily create Web Help sites