The Khipu's Web Client offers a comprehensive solution for developers looking to implement a native payment system in Web applications.
Khipu Merchant Account: You must have a merchant account at khipu.com. You can opt for a regular account or a "developer mode" account. Both accounts operate similarly in terms of creation, authorization, and reconciliation of payments, but "developer mode" uses fictional banks and money. It is advisable to use a "developer mode" account during development and testing, and switch to a regular account when going to production.
The kws.js library must be included in the page within the page's <head> tag.
<head>
    ...
    <script src="https://js.khipu.com/v1/kws.js"></script>
    ...
</head>Embedded Khipu can be used in "modal" or "embedded" mode. In both cases, an element must be defined where it will anchor. It is recommended to use a <div> with the id khipu-web-root, but any id can be used.
<div id="khipu-web-root"></div>Below are the parameters necessary to initialize the API.
- modal: BooleanDetermines if the payment process will be presented in a modal window.- true: Activates modal mode.
- false: Deactivates modal mode.
 
- modalOptions: Configures the dimensions of the modal window when modal mode is activated.- maxWidth: The maximum width that the modal window can occupy.
- maxHeight: The maximum height that the modal window can occupy.
 
- options:- style: The graphical style of Khipu Inside Web can be modified with the following parameters:- primaryColor: Main interface color.
 
- skipExitPage: BooleanControls whether to skip the exit page at the end of the payment process.- true: Skips the exit page.
- false: Displays the exit page.
 
 
- style: The graphical style of Khipu Inside Web can be modified with the following parameters:
In the case of Khipu Web, the exit links and buttons are automatically configured with the URLs sent when creating the payment through our API. Special behaviors for modal configuration are also included.
Finally, with a unique payment identifier as explained in payment intent, a payment can be started using Khipu Inside Web.
const callback = (result) => {
  console.log(`calback invoked:`, result);
};
const options = {
  mountElement: document.getElementById('khenshin-web-root'), 
  modal: true, 
  modalOptions: {
    maxWidth: 450,
    maxHeight: 860,
},
  options: {
  style: {
    primaryColor: '#8347AD',
    fontFamily: 'Roboto',
    },
  skipExitPage: false, 
  },
}
const khipu = new Khipu();
khipu.startOperation('Identificador de pago', callback, options);Below are the parameters that the API will return at the end of the process.
- operationId: StringThe unique identifier of the payment intent.
- exitTitle: StringThe title that will be displayed to the user on the exit screen, reflecting the outcome of the operation.
- exitMessage: StringThe message that will be displayed to the user, providing additional details about the outcome of the operation.
- exitUrl: StringThe URL to which the application will return at the end of the process.
- result: StringThe general outcome of the operation, possible values are:- OK: The payment was successfully authorized at the originating bank. The payment is being validated and a notification will be sent by the server once validated. (Test Case)
- ERROR: The payment was not successfully authorized; exitMessage contains the reason to be provided to the client, and failureReason contains the type of error. (Test Case)
- WARNING: The payment has not been completed, but it may occur. For example, the originating bank had an error generating the payment receipt, but the money was sent, or more signatories are needed in a multiple-party transfer. Khipu began the process of monitoring the destination account to validate the payment. (Test Case)
- CONTINUE: The operation needs more steps to complete the payment. For example, payments at Business Banks that need more signatures. (Test Case)
 
- failureReason: String(Optional) Describes the reason for failure if the operation was not successful.
- continueUrl: String(Optional) Available only when the result is "CONTINUE", indicating the URL to follow to continue the operation.
- events: ArrayThe steps taken to generate the payment, with their timestamps.
To close the payment window, for example, when capturing an exit message, simply call the method:
khipu.close();Additionally, for the modal window case, this action will be handled internally via the links:
- Cancel payment and return: Available during the payment process. It triggers the errorHandlercallback with a message type:OPERATION_FAILUREandfailureReason:USER_CANCELED.
- Finish and return: Displayed at the end of the payment process. No further calls to callbacks are made, as a call to the successHandleris sent upon transaction completion.
If you wish to restart the current payment in case of an error or any other issue, you can use the method:
khipu.restart();