Checkout – Web
This guide helps you get started with the Checkout SDK on web browsers.
Prerequisite
- A Mangopay ClientId and API key (get a Sandbox API key for free)
- A User and their associated Wallet to complete the pay-in
- A card to register or payment method setup (see Testing - Payment methods for testing information)
Supported browsers: Chrome 117, Firefox 118, Safari 16, or higher
Installation
You can install the Mangopay Checkout SDK using npm or yarn.
npm install --save @mangopay/checkout-sdk
yarn add @mangopay/checkout-sdk
Install via CDN
If you are using script tags to load files, include the Mangopay SDK script in your HTML:
<script src="https://checkout.mangopay.com/sdk/checkout-sdk.min.js"></script>
Warning – Load script from Mangopay Checkout domain
To maintain PCI compliance, the script must be loaded directly from the Mangopay Checkout domain:
http://checkout.mangopay.com
The script must not be bundled or hosted on other domains. You must reference it directly from our domain.
Content Security Policy (CSP)
Caution - Allow policies if using CSP
If your web page is using the Content-Security-Policy response header, you need to allow the policies below.
Policy | URLs |
---|---|
script-src | *.google.com |
connect-src | api.mangopay.com api.sandbox.mangopay.com *.payline.com |
Initialization
Initialize the SDK and specify the configuration options.
import { CheckoutSdk } from '@mangopay/checkout-sdk';
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk(elementOrSelector, options);
Initialization parameters
Property | Type | Description |
---|---|---|
elementOrSelector | HTMLElement | String REQUIRED | The container element or the selector of the container element. |
options | Object | The options of the Checkout SDK configuration. |
options
The child parameters of the options
object parameter:
Property | Type | Description |
---|---|---|
clientId | String REQUIRED | The unique identifier associated with the Mangopay API key, giving access to the Mangopay API. |
environment | String | The Mangopay environment. |
profilingMerchantId | String REQUIRED | The unique identifier associated with your fraud protection package. Contact Mangopay to obtain this value. |
amount | String REQUIRED | Information about the debited funds. The currency (ISO_4217 format) and value (expressed in minor units) of the debited funds. |
paymentMethods | Array REQUIRED | The payment methods presented to the user. Array of objects detailing the |
branding | Object | The custom branding of the payment page (see Customization section below). |
locale | String | Object | The language for the payment page. Specify one of the built-in languages (en , fr ) or send an object with custom messages (see Customization section below). |
tenantId | String | The Mangopay tenant being used by the platform. Platforms that have contracted with Mangopay’s UK entity must set the value to Allowed values: |
Configuration
Configure the MangopayCheckout parameters and delegates.
Example - Vanilla JS
<body>
<div id="checkoutForm">
<div id="container"></div>
</div>
<script src="/index.js"></script>
</body>
window.addEventListener('load', async () => {
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk('#container', options);
if (!mangopaySdk) {
throw new Error('Failed to load MangopayCheckoutSdk');
}
mangopaySdk.on('error', (event: CustomEvent<ErrorEventDetails>) => console.error(event.detail));
mangopaySdk.on('tokenizationComplete', (event: CustomEvent<TokenizationCompleteEventDetails>) => {
// handle tokenization complete
});
mangopaySdk.on('paymentComplete', (event: CustomEvent<PaymentCompleteEventDetails>) => {
// handle payment complete
});
});
Example - ReactJS
import { MangopayCheckout } from '@mangopay/checkout-sdk-react';
const sdkRef = useRef(null);
const onTokenizationComplete = () => {
/* Handle Card/GooglePay/ApplePay token here
e.g charge customer card using CardId
*/
};
const onPaymentComplete = () => {
/* Handle Card/PayPal payment complete */
};
<MangopayCheckout
ref={sdkRef}
options={options}
disabled={disabled}
onError={onError}
onLoaded={onLoaded}
onChange={onChange}
onTokenizationComplete={onTokenizationComplete}
onPaymentComplete={onPaymentComplete}
/>
MangopayCheckout parameters
Property | Type | Description |
---|---|---|
ref | React.RefObject<MangopayCheckoutForwardedRef> | React reference object: import { MangopayCheckoutForwardedRef } from '@mangopay/checkout-sdk-react'; |
onPaymentComplete | Function(event) | Triggered when the transaction is completed, whatever the outcome (whether successful or failed). |
options | Object | Checkout SDK configuration options |
disabled | Boolean | Applies a disabled state to the Checkout component such that user input is not accepted. |
onError | Function(event) | Triggered when an internal SDK error has occurred. |
onLoaded | Function(event) | Triggered when the Checkout SDK is loaded. |
onChange | Function(event) | Triggered when data exposed by the Checkout SDK is changed. |
onTokenizationComplete | Function(event) | Triggered when:
|
onPaymentComplete | Function(event) | Triggered when the transaction is completed, whatever the outcome (whether successful or failed). |
Handling redirection
Warning – Use Mangopay Checkout domain as return URL
When making the pay-in request from your backend, use the Mangopay Checkout URL as the SecureModeReturnURL
or ReturnURL
(depending on the payment method):
http://checkout.mangopay.com
The user must be returned to this URL after redirection.
Some payment methods (card, Google Pay, PayPal) require or may require the user to be redirected to authorize or complete a transaction.
The Checkout SDK allows you to manage the entire payment flow seamlessly while retaining control over transaction logic in your backend. Once a payment method is selected and payment details are provided, use the options.onCreatePayment
function to request the transaction from your backend.
Subsequently, and when necessary for the transaction type, the Checkout SDK seamlessly manages additional redirect actions for 3DS authorization or otherwise validating the payment.
To manage transaction redirects effectively with the SDK:
-
In your
paymentMethods
configurations, define anoptions.onCreatePayment
attribute as a function. -
Within your function:
- Request a transaction from your server and subsequently, Mangopay.
- Return the unaltered transaction response object to the SDK.
- The SDK:
- Redirects the user to the payment authentication page when necessary.
- Manages payment provider redirects back to the SDK.
- Triggers the
onPaymentComplete
event with the ID and status of the transaction. - Confirms the redirect result on your server by invoking the corresponding GET API of the transaction.
- Presents the payment result to the user.
paymentMethods: [
{
type: 'card | paypal | googlepay',
onCreatePayment: function (event) {
// 1. implement server-side call to request a transaction.
// 2. return the card transaction object.
}
}
]
Configuring card payments
To configure the card payment method, specify card
as the type
of the paymentMethods
object. For the options
, use the following configuration parameters.
options
Property | Type | Description |
---|---|---|
options.supportedCardBrands | Array REQUIRED | The card brands supported. |
options.onCreateCardRegistration | Function REQUIRED | Use this attribute to request and return a Card Registration. |
options.onCreatePayment | Function REQUIRED | To handle 3DS redirects for card payments, use this attribute to request and return a pay-in. |
Card configuration example
const options = {
clientId: 'MANGOPAY_CLIENT_ID',
environment: 'SANDBOX | PRODUCTION',
amount: {
value: 1000,
currency: "EUR"
},
paymentMethods: [
{
type: 'card',
onCreateCardRegistration: function (event) {
// 1. implement server-side call to create a card registration.
// 2. return the card registration.
},
onCreatePayment: function (event: paymentMethod) {
// 1. implement server-side call to request a card transaction.
// 2. return the card transaction object.
// 3. the SDK handles 3DS redirect for you.
}
}
]
};
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk(elementOrSelector, options);
Card tokenization
In the options
for the card payment method, create a function to handle creation of Card Registration event handler in the paymentMethods
object:
- Your
onCreateCardRegistration
function calls your server, and passes it the card brand of the user. - Your server makes a request to Create a Card Registration.
- In response, your server receives a Card Registration object.
- In your
onCreateCardRegistration
function, return the unmodified Card Registration object to the SDK. - The SDK tokenizes the card and updates the Card Registration object to create the
CardId
which is used for payment.
// Vanilla JS
mangopaySdk.on('tokenizationComplete', (event: CustomEvent<TokenizationCompleteEventDetails>) => {
// handle tokenization complete
});
mangopaySdk.on('paymentComplete', (event: CustomEvent<PaymentCompleteEventDetails>) => {
// handle payment complete
});
// React.js
const onTokenizationComplete = () => {
// handle tokenization complete
};
const onPaymentComplete = () => {
// handle payment complete
};
<MangopayCheckout
ref={sdkRef}
options={options}
onTokenizationComplete={onTokenizationComplete}
onPaymentComplete={onPaymentComplete}
/>
tokenizationComplete output
{
"Id": "cardreg_m_01HQ0J6GB3JFZ1NC5EGCJBE4PB",
"Tag": null,
"CreationDate": 1708342329,
"UserId": "user_m_01HP6ZG0XXZ89V34GRZEY9HQCE",
"AccessKey": "1X0m87dmM2LiwFgxPLBJ",
"PreregistrationData": "YkgVxL1yNY4ZOfKtqEew_Zj34Eg4_H3r-UyvrLWB_MHYF1OqkWAtDMwDMZ0pSZfliRF4hvSrtJCvT7-9XAi0Xsj7Q1OS-vT4lpHzEztZoLs",
"RegistrationData": "data=iN_eoipU7i2AEuTss7wuoPRZYTuNVHlTvhc4dEXHczhSWquUg8N2vrbXU91rCDepo0Fw6rcqxRBK8KMWk8xhHGOBEuIr9_d-Xo64K6cr5w-lY2yXbTUOs7e-S6CpTShm",
"CardId": "card_m_01HQ0J6H02QXH3HATEYW0FMJKP",
"CardType": "CB_VISA_MASTERCARD",
"CardRegistrationURL": "https://pci.sandbox.mangopay.com/api/mangopay/vault/tokenize/eyJjbGllbnQiOiJjbGllbnRJZCIsInRva2VuIjoidW5xaXVlVG9rZW4ifQ==",
"ResultCode": "000000",
"ResultMessage": "Success",
"Currency": "EUR",
"Status": "VALIDATED"
"ProfilingAttemptReference": "25e5c450-7f00-4805-af04-4330e4dc0cee"
}
Managing cards
You can use the following endpoints to manage cards:
- View a Card provides key information about the card, including its Fingerprint which can be used as an anti-fraud tool
- Deactivate or edit a Card allows you to irreversibly set the card as inactive
Warning - End user’s approval needed to save card details
Under no circumstances should card information be kept without the end user’s approval.
If you don’t have the end user’s approval, you need to deactivate the card systematically after use in your implementation.
Requesting card payments
You can use a registered card (CardId
) for requests with the following objects. In your request, ensure that the SecureModeReturnURL
parameter is set to https://checkout.mangopay.com
.
- The Card Validation object, to validate a card without debit
- The Direct Card PayIn object, for one-shot card payments
- The Recurring PayIn Registration object, for recurring card payments
- The Preauthorization object, for 7-day preauthorized card payments
- The Deposit Preauthorization object, for 30-day preauthorized card payments
Configuring Apple Pay
Note - Apple Pay integration required
Offering Apple Pay requires additional setup by the platform, including certification and integration. For more information, see the How to process an Apple Pay payment tutorial.
Caution - Apple Pay on the Web availability
Apple Pay on the Web, using the JavaScript Checkout SDK, is only available on Mac and iOS devices. Apple Pay on the Web also requires additional certification.
To configure the Apple Pay payment method, specify apple_pay
as the type
of the paymentMethods
object. For the options
, use the following configuration parameters.
Apple Pay configuration options
Property | Type | Description |
---|---|---|
paymentRequest | Object REQUIRED | The specifications of the payment request. |
onCreatePayment | Function REQUIRED | Function called after the user has successfully authenticated a card for payment from the Apple Pay sheet. Use this attribute to implement backend creation of the Apple Pay PayIn from your server. After creating the pay-in, return the pay-in object to the SDK. |
paymentRequest
Property | Type | Description |
---|---|---|
countryCode | String REQUIRED | The platform’s two-letter ISO 3166 country code. |
currencyCode | String REQUIRED | The three-letter ISO 4217 code (EUR, GBP, etc) of a supported currency (depends on feature, contract, and activation settings). |
merchantCapabilities | Array REQUIRED | Information about the card types and authentication protocols you support (see Apple Pay documentation). |
supportedNetworks | Array REQUIRED | The card networks supported by mangopay Allowed values: VISA, MASTERCARD |
total | Object REQUIRED | The line item total for the payment (see Apple Pay documentation). |
merchantIdentifier | String REQUIRED | Your platform’s Apple Pay Merchant ID. |
merchantName | String REQUIRED | The name of your platform. |
onValidateMerchant | Function REQUIRED | Use this attribute to request and return a ApplePay session. Function called when the SDK receives an onvalidatemerchant merchant event from the Apple Pay sheet. The assigned function should implement backend creation of the merchant session object from your server. After creating the session object, return the session object to the SDK. |
requiredBillingContactFields | Array REQUIRED | The billing information to fulfill the order (see Apple Pay documentation). |
Requesting the merchant session from your server
Displaying the Apple Pay payment sheet using the Mangopay Checkout SDK works as follows:
- You generate the merchant session from your server
- The SDK’s
onValidateMerchant
function calls your server and passes it the static hostnameapple-pay-gateway.apple.com
as the validation URL. In the China region, usecn-apple-pay-gateway.apple.com
. - Your server uses the validation URL to request a session from the Apple Pay server, as described in Requesting an Apple Pay Payment Session.
- In the response, your server receives an opaque merchant session object:
MerchantSession
. - You pass the merchant session object to the
completeMerchantValidation
method of the SDK (see Apple Pay documentation for more information on this method).
//Define ApplePay Merchant session delegate
const validateApplePayMerchant = (validationURL: string): Promise<ApplePayMerchantSession> => {
return fetch(
'https://backend-api-url/get-apple-pay-session',
method: 'POST',
body: JSON.stringify({
validationURL,
merchantIdentifier: 'merchant.com.example.mystore',
displayName: 'MyStore',
initiative: 'web',
initiativeContext: 'mystore.example.com'
})
);
};
Requesting Apple Pay pay-in
To request the payment, use the Create an Apple Pay PayIn endpoint and include the Apple Pay PaymentData
.
- Set up payment delegate – Assign a delegate function to the
onCreatePayment
attribute in your Apple Pay options. - Handle payment authorization – After the shopper successfully authorizes a card for payment through the Apple Pay sheet, the SDK will call your
onCreatePayment
function and pass thePaymentData
to it. - Create pay-in – Implement the backend creation of the Apple Pay PayIn on your server using the
PaymentData
provided. - Return pay-in object – After creating the pay-in, return the pay-in object to the SDK.
interface CreateApplePayPaymentData {
PaymentData: {
transactionId: string;
network: string;
tokenData: string;
};
ProfilingAttemptReference?: string;
}
//Define ApplePay PayIn delegate
const handleCreateApplePayPayIn = (data: CreateApplePayPaymentData): Promise<CreateApplePayPayInResult> => {
return fetch(
'https://backend-api-url/create-applepay-payin',
method: 'POST',
body: JSON.stringify(data)
);
};
Apple Pay configuration example
const options = {
clientId: 'MANGOPAY_CLIENT_ID',
environment: 'SANDBOX | PRODUCTION',
paymentMethods: [
{
type: 'apple_pay',
options: {
paymentRequest: {
countryCode: 'IE',
currencyCode: 'EUR',
merchantCapabilities: ['supports3DS'],
supportedNetworks: ['visa', 'masterCard'],
total: {
label: 'Demo (Card is not charged)',
type: 'final',
amount: '20.00',
},
merchantIdentifier: 'merchant.com.example.mystore',
merchantName: 'MyStore',
onValidateMerchant: validateApplePayMerchant,
requiredBillingContactFields: ['email']
},
onCreatePayment: handleCreateApplePayPayIn
},
}
]
};
// Vanilla JS
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk(elementOrSelector, options);
// React.js
<MangopayCheckout ref={sdkRef} options={options} />
Configuring Google Pay
Note - Google Pay setup required
Offering Google Pay requires additional setup by the platform. For more information, see the How to process a Google Pay payment tutorial.
Caution - Add Mangopay Checkout to your Google Console
You need to add checkout.mangopay.com
along with your domain to the authorized list in the Google Business Console to view the Google Pay payment popup.
This allows the Checkout SDK to ensure the Google Pay experience is presented appropriately to your shoppers. Not following this guidance may impact your payment acceptance on Google Pay.
To configure the Google Pay payment method, specify google_pay
as the type
of the paymentMethods
object. For the options
, use the following configuration parameters.
Google Pay configuration options
Property | Type | Description |
---|---|---|
merchantInfo.merchantId | String REQUIRED | Your Mangopay ClientId . |
merchantInfo.merchantName | String REQUIRED | The name of your platform. If a merchant is recognized, the message displayed in the payment sheet is “Pay Unverified Merchant”. For more information, see the Google Pay documentation. |
gateway | String REQUIRED | The orchestration used: in this case, whenthen. |
cardParameters.allowedAuthMethods | Array REQUIRED | The supported authentication methods: PAN_ONLY, meaning the card is registered in the user’s Google account and requires additional authentication; CRYPTOGRAM_3DS, meaning the card is enrolled in the customer’s Google Wallet and authentication is handled by Google, with no 3DS redirection and no liability for the platform. |
cardParameters.allowedCardNetworks | Array REQUIRED | The card networks supported by Mangopay. Allowed values: VISA, MASTERCARD |
transactionInfo | Object REQUIRED | Information about the transaction and its authorization, such as whether the user agrees to the transaction, the total price and price status. For more information on this object parameter, see the Google Pay documentation. |
onCreatePayment | Function REQUIRED | Function called after the user has successfully authorized a card for payment from the Google Pay sheet. The assigned function should implement backend creation of the Google Pay PayIn from your server. After creating the pay-in, return the pay-in object to the SDK. |
buttonColor | String | The color of the button. Default value: default Allowed values:
|
buttonType | String | The type of the button, determining the text to display. Default value: buy Allowed values:
|
buttonLocale | String | The ISO 639-1 code representing the desired button language. Default value: The browser or operating system language settings. Allowed values: en, ar, bg, ca, cs, da, de, el, es, et, fi, fr, hr, id, it, ja, ko, ms, nl, no, pl, pt, ru, sk, sl, sr, sv, th, tr, uk, and zh. |
Handling Google Pay authorization
The onTokenizationComplete
function is called after the user approves the payment on the Google Pay form. The output contains the paymentData
object (see Google Pay documentation) which is needed to request the Google Pay payment via the API from your backend.
Requesting Google Pay pay-in
To request the payment, use the Create a Google Pay PayIn endpoint. Include the Google Pay PaymentData
and ensure that the SecureModeReturnURL
parameter is set to https://checkout.mangopay.com
.
- Set up payment delegate – Assign a delegate function to the
onCreatePayment
attribute in your Google Pay options. - Handle payment authorization – After the shopper successfully authorizes a card for payment through the Google Pay sheet, the SDK will call your
onCreatePayment
function and pass thePaymentData
to it. - Create pay-in – Implement the backend creation of the Google Pay PayIn on your server using the
PaymentData
provided. - Return pay-in object – After creating the pay-in, return the pay-in object to the SDK.
interface CreateGooglePayPaymentData {
PaymentData: string;
ProfilingAttemptReference: string;
}
//Define GooglePay PayIn delegate
const handleCreateGooglePayPayIn = (data: CreateGooglePayPaymentData): Promise<CreateGooglePayPayInResult> => {
return fetch(
'https://your-backend-api-url/create-googlepay-payin',
method: 'POST',
body: JSON.stringify(data)
);
};
Google Pay configuration example
const options = {
clientId: 'MANGOPAY_CLIENT_ID',
environment: 'SANDBOX | PRODUCTION',
paymentMethods: [
{
type: 'google_pay',
options: {
merchantInfo: {
merchantId: 'test',
merchantName: 'Test',
},
gateway: 'whenthen',
cardParameters: {
allowedAuthMethods: ['PAN_ONLY', 'CRYPTOGRAM_3DS'],
allowedCardNetworks: ['VISA', 'MASTERCARD'],
},
transactionInfo: {
totalPrice: '20.00',
totalPriceStatus: 'FINAL',
currencyCode: 'EUR',
countryCode: 'DE', // required for EEA only
transactionId: '123456789',
totalPriceLabel: '20.00', // required if displayItems is provided
displayItems: [
{
label: 'PS5',
type: 'SUBTOTAL',
price: '20.00',
},
],
},
paymentData: {
emailRequired: true,
},
onCreatePayment: (paymentData) => handleCreateGooglePayPayIn(paymentData)
},
}
]
};
// Vanilla JS
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk(elementOrSelector, options);
// React.js
<MangopayCheckout ref={sdkRef} options={options} />
Configuring PayPal
Note – PayPal setup required
Offering PayPal requires approval from PayPal and activation. For more information, see the PayPal article.
PayPal configuration options
To configure PayPal, specify paypal
as the type
of the paymentMethods
object. For the options
, use the following configuration parameters.
Property | Type | Description |
---|---|---|
options.onCreatePayment | Function REQUIRED | Use this attribute to request and return a PayPal pay-in. The assigned function should implement backend creation of the PayPal pay-in from your server. |
PayPal configuration example
//Define PayPal PayIn delegate
const createPayPalPayIn = (profilingAttemptReference: string): Promise<CreatePayPalPayInResult> => {
return fetch(
'https://your-backend-api-url/create-paypal-payin',
body: JSON.stringify({ProfilingAttemptReference: profilingAttemptReference})
);
};
const options = {
clientId: 'MANGOPAY_CLIENT_ID',
environment: 'SANDBOX | PRODUCTION',
amount: {
value: 1000,
currency: "EUR"
},
paymentMethods: [
{
type: "paypal",
options: {
//define delegate to call when Paypal button is clicked
onCreatePayment: (data) => createPayPalPayIn(data)
}
}
]
};
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk(elementOrSelector, options);
//this event is triggered when redirect/payment is completed
mangopaySdk.on('paymentComplete', (event: CustomEvent<PaymentCompleteEventDetails>) => {
// verify payment result
// unmount checkout and present payment result.
});
Requesting PayPal pay-in
To request the payment, use the Create a PayPal PayIn endpoint. Ensure that the ReturnURL
parameter is set to https://checkout.mangopay.com
.
Obtaining browser info for a pay-in
The browserInfo
object is required when submitting a pay-in request. To get the required values for the transaction, use the getBrowserInfo
function from the Checkout SDK instance. Pass on the values to your server.
//Using checkout-sdk or checkout-sdk-react package from npm.
import { getBrowserInfo } from '@mangopay/checkout-sdk'
//alternatively, if you are using the cdn script
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk('#container', options);
const browserInfo = mangopaySdk.getBrowserInfo();
const payInRequestObj =
{
...
browserInfo : {
"AcceptHeader" : browserInfo.AcceptHeader,
"JavaEnabled" : browserInfo.JavaEnabled,
"Language" : browserInfo.Language,
"ColorDepth" : browserInfo.ColorDepth,
"ScreenHeight" : browserInfo.ScreenHeight,
"ScreenWidth" : browserInfo.ScreenWidth,
"TimeZoneOffset": browserInfo.TimeZoneOffset,
"UserAgent" : browserInfo.UserAgent,
"JavascriptEnabled": browserInfo.JavascriptEnabled
}
};
Verifying the payment result
Once the onPaymentComplete
event is triggered, verify the status of the relevant Mangopay API object:
Caution – Check payment result from backend
You should confirm the transaction result returned by the Checkout SDK by calling the Mangopay API from your backend.
//This event is triggerd by the SDK when a full payment cycle is complete.
mangopaySdk.on('paymentComplete', (event: CustomEvent<PaymentCompleteEventDetails>) => {
const { id } = event.details
// 1. Verify payment result using the transaction Id.
// 2. Present payment result to user.
});
Showing and dismissing the loading spinner
When processing a token request, the SDK shows a loading spinner and retains it until the loading state is set to false
. This provides a temporary state for the user until the full payment is complete, including calls from your platform’s backend.
The setLoading
method handles the loading state for displaying and dismissing the spinner.
import { CheckoutSdk } from '@mangopay/checkout-sdk';
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk('#container', options);
// dismiss the loader spinner
mangopaySdk.setLoading(false);
Using Card Element
Card Element is a ready-made component that allows you to create your own card payment experience and tokenize card payment details. With Card Element, you can incorporate a custom pay button and have control over the tokenization process.
When using Card Element, you still benefit from card data validation, and the ability to customize the payment form.
Initialize the cardFormElement
with your ClientId
and select your environment (Sandbox or Production).
import MangopaySdkLoader from '@mangopay/sdk-loader';
const cardFormElement = await MangopaySdkLoader.loadCardFormElement(elementOrSelector, options);
cardFormElement-specific options
Property | Type | Description |
---|---|---|
paymentMethod | Object | The payment method used with the card form element. Only 'card’ is supported. See payment methods for more details.
Allowed values: ‘card’ |
Vanilla JS usage example
<body>
<form novalidate id="checkoutForm">
<div id="container"></div>
<button type="submit" id="submitButton">Pay now</button>
</form>
<script src="/index.js"></script>
</body>
window.addEventListener('load', async () => {
const cardFormElement = await MangopaySdkLoader.loadCardFormElement('#container', options);
if (!cardFormElement) {
throw new Error('Failed to load MangopayCardFormElement');
}
const submitButton = document.querySelector('#submitButton');
if (!submitButton) {
throw new Error('Submit button is missing.');
}
submitButton.addEventListener('click', async (event) => {
event.preventDefault();
cardFormElement.disable();
try {
cardFormElement.completePayment();
} finally {
cardFormElement.enable();
}
});
cardFormElement.on('error', (event: CustomEvent<ErrorEventDetails>) => console.error(event.detail));
cardFormElement.on('tokenizationComplete', (event: CustomEvent<TokenizationCompleteEventDetails>) => {
// handle tokenization complete
});
});
ReactJS usage example
import { CardFormElement } from '@mangopay/checkout-sdk-react';
const sdkRef = useRef(null);
const onTokenizationComplete = () => {
/* Handle Card token here
e.g charge customer card using CardId
*/
};
<>
<form noValidate>
<CardFormElement
ref={sdkRef}
options={options}
disabled={disabled}
onError={onError}
onLoaded={onLoaded}
onChange={onChange}
onTokenizationComplete={onTokenizationComplete}
/>
</form>
<button onClick={handleCompletePayment} className="btn pay-btn">
Pay now
</button>
</>
Branding
You can customize the appearance of the checkout using the branding
object.
const options = {
branding: {
fontFamily: 'Helvetica Neue',
fontSize: {
primary: '14px',
secondary: '12px',
},
borderType: 'square', // 'square' | 'round' | 'bottom'
colors: {
primary: '#000000',
secondary: '#545A61',
accent: '#4E40EF',
accentContrast: '#FFFFFF',
border: '#E6E9EC',
borderFocused: '#000000',
error: '#EC0B43',
},
borderRadius: '0',
backgroundColor: '#ffffff',
textColor: '#000000',
lineHeight: '48px',
variables: undefined,
rules: undefined,
},
},
};
// Vanilla JS
const mangopaySdk = await MangopaySdkLoader.loadCheckoutSdk('#container', options);
// React.js
<MangopayCheckout ref={sdkRef} options={options} />
Theme variables and rules
You can use the rules
and variables
objects for further customization.
Variables
Variables are CSS variables that you can declare and use in your theme rules.
{
theme: {
...,
variables: {
primaryColor: "#1D3557"
secondaryColor: "#457B9D"
}
rules: {
PayButton: `
backgroundColor: var(--primaryColor);
`
}
}
}
Rules
Rules allows you to apply CSS styles to Checkout SDK components. To do so, target components by class names, with or without the CSS class selector prefix (FieldContainer
or .FieldContainer
), and specify the styles to apply. The feature supports all native CSS properties and nesting.
{
theme: {
...,
variables: {
primaryColor: "#1D3557"
secondaryColor: "#457B9D"
}
rules: {
'.FieldContainer': `
height: 40px;
border-radius: 8px;
backgroundColor: var(--primaryColor);
&:hover {
backgroundColor: var(--secondaryColor);
}
`
}
}
}
Localization
Mangopay Checkout SDK has built-in localization support for: DE, EN, ES, FR, NL, PT
const options = {
locale: 'en', // 'en' | 'fr' | 'es' | 'de' | 'pt' | 'nl' | Object
};
// Vanilla JS
const mangopaySdk = await MangopaySdkLoader.loadCheckoutSdk('#container', options);
// React.js
<MangopayCheckout ref={sdkRef} options={options} />
You can customize labels, placeholder and success and error messages by providing a customLanguage
object.
const customLanguage = {
"card-information.header.label": "Card information",
"card.number.placeholder": "1234 1234 1234 1234",
"card.number.aria-label": "Card number",
"card.number.errors.required": "Card number is required",
"card.number.errors.min-length": "Minimum number of digits is 13",
"card.number.errors.invalid-number": "Invalid card number",
"card.psp.legal.notice": "Processed with Mangopay",
"card.psp.legal.privacy": "Privacy.",
"card.save.label": "Save payment details for future use",
"card.saved-cards.choose-card.label": "Choose card",
"card.saved-cards.clear-card.label": "Clear",
"card.saved-cards.saved-card.aria-label": "The card ending in",
"card.billing-name.placeholder": "Name on card",
"card.billing-name.aria-label": "Name on card",
"card.billing-name.errors.required": "Full name is required",
"card.expiry.placeholder": "MM / YY",
"card.expiry.aria-label": "Card expiration",
"card.expiry.errors.required": "Expiration date is required",
"card.expiry.errors.pattern": "Expiration date format is not valid (MM/YY)",
"card.expiry.errors.expired": "Your card is expired",
"card.cvc.placeholder": "CVC",
"card.cvc.aria-label": "Card CVC",
"card.cvc.errors.required": "Security code is required",
"card.cvc.errors.min-length": "Security code is too short",
"card.cvc.errors.max-length": "Security code is too long",
"pay-button.label": "Pay",
"pay-button.aria-label": "Pay",
"payment-methods.card.label": "Card",
"payment-methods.show-less.label": "Show less",
"payment-methods.show-more.label": "Show more",
"payment-methods.applepay.label": "Apple Pay",
"payment-methods.applepay.aria-label": "Pay with Apple Pay",
"payment-methods.googlepay.label": "Google Pay",
"payment-methods.googlepay.aria-label": "Pay with Google Pay",
"payment-methods.paypal.label": "PayPal",
"payment-methods.paypal.aria-label": "Pay with PayPal",
"payment-methods.paypal.overlay.message": "Don’t see the secure paypal browser? We’ll help you re-launch the window to complete your purchase",
"payment-methods.paypal.overlay.continue": "Click to Continue",
"payment-success-state.label": "Payment Succeeded",
"redirect-note.label": "After submitting your order, you will be securely redirected to complete your purchase.",
"loading.label": "Processing your payment",
//errors
"error.invalid_cvc": "Invalid CVC",
"error.authorization_required": "Authorization Required",
"error.contact_card_issuer": "Contact Card Issuer",
"error.unsupported_card": "Unsupported Card",
"error.insufficient_funds": "Insufficient Funds",
"error.unsupported_currency": "Unsupported Currency",
"error.card_rejected": "Card Rejected",
"error.expired_card": "Expired Card",
"error.suspected_fraud": "Suspected Fraud",
"error.general_decline": "General Decline",
"error.incorrect_number": "Incorrect Number",
"error.incorrect_pin": "Incorrect Pin",
"error.invalid_address": "Invalid Address",
"error.invalid_card_or_account": "Invalid Card or Account",
"error.invalid_amount": "Invalid Amount",
"error.invalid_date": "Invalid Date",
"error.lost_restricted_or_stolen_card": "Lost, Restricted or Stolen Card",
"error.blocked_list": "Blocked List",
"error.not_permitted": "Not Permitted",
"error.offline_or_online_pin_required": "Offline or Online Pin Required",
"error.pin_retry_exceeded": "Pin Retry Exceeded",
"error.processing_error": "Processing Error",
"error.withdrawal_count_limit_exceeded": "Withdrawal Count Limit Exceeded",
"error.unknown": "Unknown error",
"error.fraud": "Fraud",
"error.three_d_secure": "3DS Failed",
"error.custom_rule": "Custom Rule",
"error.payment_cancelled": "Try making your payment again or select a different bank to continue",
"error.payment_rejected": "The payment was rejected by the institution. Try again, or select another account or institution",
"error.internal_server_error": "An unexpected error occurred",
"error.institution_not_responding": "This financial institution is not currently responding to requests. We apologize for the inconvenience",
"error.authorize.payment-already-authorized": "This payment has been already authorized",
"error.param_error": "One or several required parameters are missing or incorrect",
"error.payment_restart": "The payment wasn't successful, please try again",
"error.ressource_not_found": "The resource does not exist"
};
const options = {
locale: customLanguage
};
// Vanilla JS
const mangopaySdk = await CheckoutSdk.loadCheckoutSdk('#container', options);
// React.js
<MangopayCheckout ref={sdkRef} options={options} />