Skip to main content

Get started with payment widget

The payment widget provides a seamless way to accept payments, allowing customers to complete transactions without leaving your website. Integrated directly into your webpage, the widget eliminates the need for PCI DSS certification. Thus, the payment process using the payment widget occurs seamlessly on your website, avoiding redirection to a hosted checkout page.

Interaction format:

Interaction format

Features

  • Functions seamlessly on both desktop and mobile devices.
  • Supports diverse payment methods, including card payments, Apple Pay, and Google Pay.
  • Accommodates both one-step and two-step payment processes.
  • It allows initiating recurring payments.
  • Integrates seamlessly with taxation using the SBCR feature.
  • Offers two display modes on your website:
    • popup - a pop-up window featuring the payment widget.
    • embedded - an integrated window with the payment widget.
caution

Explore the functionalities of both display modes and test the payment widget's features by following this link.

To introduce the payment widget, you need to integrate its library and invoke the initialization function.

Example of how to connect the library and initialize the widget:

<script src="https://gcdn.tranzzo.com/widget/payment-widget.js"></script>
<script>
PaymentWidget.init({
apiKey: 'YOUR_API_KEY',
mode: 'popup',
payment: {
type: 'pay',
amount: 1.99,
currency: 'UAH'
}
});
</script>

When utilizing the mode:'embedded' it is essential to include the selector parameter. This parameter enables you to specify the HTML element on the page where the widget will be presented.

Example of widget initialization with mode:'embedded':

<div id="widget"></div>
<script>
const widget = PaymentWidget.init({
apiKey: 'YOUR_API_KEY',
mode: 'embedded',
selector: '#widget',
payment: {
type: 'pay',
amount: 1.99,
currency: 'UAH'
}
});
</script>

When using a one-step payment process, the type: 'pay' must be passed in the payment widget initialization request.

When using a two-step payment process with pre-authorization (holding) of funds on the customer's bank account, it is necessary to pass the type: 'hold' in the request to initialize the payment widget.

Request example for two-step payment process:

<script>
const widget = PaymentWidget.init({
apiKey: 'YOUR_API_KEY',
mode: 'popup',
payment: {
type: 'hold',
amount: 1.99,
currency: 'UAH'
}
});
</script>

To capture the payment or void the pre-authorization in the two-step payment process through the widget, you can utilize the corresponding API requests or leverage the functionalities provided in the merchant portal.