PayTabs SDK makes the integration with the PayTabs payment gateway very easy by providing a ready-made payment screen that handles the card entry and, billing & shipping information and completes the missing details.


This article is dedicated to walking you through how to initiate the payment/request payload using the configuration options and parameters that have already been clarified in the previous step, "Step 2 - Configure the integration method".


After making sure of configuring this SDK as you wish, you will need to make sure you import/add the SDK package in your package.json file, as shown below: 


"cordova": {
    "plugins": {
      "com.paytabs.cordova.plugin": {}
    }
  }
Generic


Implementing this option will enable you to initiate payments targeted to be paid using the supported types of credit cards such as Visa, MasterCard, Amex, .. etc. To be able to do this, please follow the below instructions:


  1. Configure the billing & shipping information for this payment, noting that the shipping information is optional. To know more about this, please check our 3.1 Cordova  SDK | Manage Shipping and Billing details and 2.1 Cordova SDK | Configuration Options & Parameters solution articles.
         
    let billingDetails = new cordova.plugins.CordovaPaymentPlugin.PaymentSDKBillingDetails(
                   name= "John Smith",
                   email= "email@test.com",
                   phone= "9731111111",
                   addressLine= "address line",
                   city= "Dubai",
                   state= "Dubai",
                   countryCode= "ae", // ISO alpha 2
                   zip= "1234")
    let shippingDetails = new cordova.plugins.CordovaPaymentPlugin. PaymentSDKShippingDetails(
                   name= "John Smith",
                   email= "email@test.com",
                   phone= "9731111111",
                   addressLine= "address line",
                   city= "Dubai",
                   state= "Dubai",
                   countryCode= "ae", // ISO alpha 2
                   zip= "1234")
    Generic



  2. Then create an object from PaymentSDKConfiguration and fill it out with your credentials and payment details. To know more about what is the exact values that should be passed here, please check our 2.1 Cordova SDK | Configuration Options & ParametersCordova and 2.2 Cordova SDK | The PaymentSDKConfiguration Object solution articles.    

    let configuration = new cordova.plugins.CordovaPaymentPlugin.PaymentSDKConfiguration();
        configuration.profileID = "*your profile id*"
        configuration.serverKey= "*server key*"
        configuration.clientKey = "*client key*"
        configuration.cartID = "545454"
        configuration.currency = "AED"
        configuration.cartDescription = "Flowers"
        configuration.merchantCountryCode = "ae"
        configuration.merchantName = "Flowers Store"
        configuration.amount = 20
        configuration.screenTitle = "Pay with Card"
        configuration.billingDetails = billingDetails
        configuration.forceShippingInfo = false
    Generic



  3. Only then you will be ready to start/initiate the payment by passing your PaymentSDKConfiguration object to the startCardPayment function in which the callback event will handle/alter the payment response. To know more about this please check our 2.2 Cordova SDK | The PaymentSDKConfiguration Object and Step 5 - Cordova SDK | Handle the payment response solution articles

    cordova.plugins.CordovaPaymentPlugin.startCardPayment(configuration, function (result) {
            if (result["status"] == "success") {
                // Handle transaction details here.
                var transactionDetails = result["data"];
                console.log("responseCode:" + transactionDetails.paymentResult.responseCode)
                console.log("transactionTime:" + transactionDetails.paymentResult.transactionTime)
                console.log("responseMessage:" + transactionDetails.paymentResult.responseMessage)
                console.log("transactionReference:" + transactionDetails.transactionReference)
                console.log("token:" + transactionDetails.token)
              } else if (result["status"] == "error") {
                // Handle error here the code and message.
              } else if (result["status"] == "event") {
                // Handle events here.
              }
        }, function (error) {
            console.log(error)
        });
    Generic


    This will make the payment behavior would be like the one below, in which your customers will have to provide their full card details.

     








⌂ To get familiar with the whole process and the other steps, kindly navigate to our "The Cordova SDK Integration Manual" solution article. 

 And to navigate to the previous step in the integration process "Step 2 - Configure the integration method" click here

 And to get familiar with the rest of the steps regarding the current step "Step 3 - Initiating the payment" click here.

⇨ Or you can navigate to the next step in the integration process "Step 4 - Accepting the payment" kindly click here.