Payment Web Component [BETA]

Learn how to integrate Monite's Payment component into your apps to provide smooth payment experience for your users.

Overview

Monite provides an embeddable Payment component that allows our partners to build a custom invoice payment and BillPay experience into their applications or websites. The Payment component is an alternative to hosted payment pages, and allows users (entities or their counterparts) to make payments without leaving your application.

From an integration perspective, using the Payment component requires:

  • Server side: to generate a payment link ID, receive webhooks about the payment status, and (optionally) customize the look and feel of the Payment component.
  • Client side: the Payment component handles all necessary payment-related requests and validates the inputs.
Monite Payment component
Monite Payment component

Payment methods

The payment methods displayed by the component are configured when you generate a payment link ID for this component, as explained below.

Additionally, the entity that will receive or make the payment:

Usage

Embedding the Payment component into your web page requires just two lines of code.

First, import the Payment component’s module:

1<!-- Production only -->
2<script type="module" src="https://pay.monite.com/drop-in/index.js"></script>
3
4<!-- Sandbox only -->
5<script type="module" src="https://pay.sandbox.monite.com/drop-in/index.js"></script>

Then initialize the Payment component:

1<monite-payment link-id="PAYMENT_LINK_ID" />

The PAYMENT_LINK_ID must be generated in advance by calling POST /payment_links with your partner access token. Payment links can be created for Accounts Payable invoices (entity pays), Accounts Receivable invoices (entity gets paid), or arbitrary monetary amounts (entity pays or gets paid). For more information, see Payment links.

In the body of the POST /payment_links request, specify the payment methods you want to display in the component (assuming these methods are already enabled for the entity).

The following example creates a payment link ID for an external invoice that an entity issued to its counterpart. The counterpart is supposed to use your payment page to make the payment to the entity.

1curl -X POST 'https://api.sandbox.monite.com/v1/payment_links' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'Authorization: Bearer YOUR_PARTNER_TOKEN' \
4 -H 'Content-Type: application/json' \
5 -d '{
6 "payment_methods": [
7 "card",
8 "eps",
9 "ideal",
10 "sepa_credit",
11 "sepa_debit"
12 ],
13 "recipient": {
14 "id": "e575bbe2-38ef-48a4-b21a-b72801bd9d17",
15 "type": "entity"
16 },
17 "return_url": "https://return.url.com",
18 "amount": 1250,
19 "currency": "EUR",
20 "payment_reference": "Inv 102",
21 "invoice": {
22 "issue_date": "2024-04-18",
23 "due_date": "2024-05-18"
24 }
25 }'

The response from POST /payment_links contains a unique id. This is the ID you need to pass to the Monite Payment component via the <monite-payment link-id="PAYMENT_LINK_ID" /> tag on your payment page.

1{
2 "id": "8a3b5037-ae70-42c3-8cf1-c10b44e07a8c",
3 "amount": 1250,
4 "currency": "EUR",
5 ...
6}

Customization

The look and feel of the payment component can be customized to match your branding. The colors and other styling options are controlled by the partner setting payments.payment_page_theme, which you can change by calling PATCH /settings. For details, see Payment page customization.