Multiple payment methods

This topic describes how to combine and use multiple payment methods in the one checkout form.

If you have not used FramePay previously, before you complete this tutorial, add FramePay to a form with one payment method in isolation. For tutorials, see Get started with FramePay.

For most payment methods, input mounting is not required, you only provide the method name when creating the token. However, some payment methods, such as: payment card and bank account, require inputs that must be mounted in your checkout form.

This topic describes how to set up your FramePay form to support the following payment methods:

  • Express method.
  • Payment card (requires input mounting).
  • Bank account (requires input mounting).
  • Any other alternative payment method (does not require input mounting).

1. Obtain IDs and a publishable API key

When you first log in to Rebilly, you create an organization as part of the setup process. A default website is created when a new organization is created. For more information, see Organizations and websites.

  1. Log in or sign up to Rebilly.
  2. Obtain your organization ID and website ID:
    1. In the left navigation bar, press Settings .
    2. In the Management section, press My organization & websites.
    3. In the Organization details section, note the ID value.
    4. In the Website section, note the ID value.
  3. Obtain your publishable API key:
    1. In the left navigation bar, press Automations .
    2. In the Development section, press API keys.
    3. Optionally, if you have not created a publishable key:
      1. In top right of the screen, press Create API key.
      2. In the API key type section, select Publishable.
      3. Optionally, in the Organizations dropdown, select the organizations that can use the API key.
      4. Optionally, in the Allowed IPs field, enter the IP addresses that are permitted to use the API key.
      5. Press Save API key.
      6. Go to the API keys page.
    4. Select a publishable key and copy the Key value.

2. Set up multiple payment methods using FramePay

1

Initial set up

Set up the library and provide the HTML.

Include the FramePay stylesheet

This adds default styles to FramePay elements on the page.

example.html

Include the FramePay script

This exposes FramePay in the global JS scope as Framepay.

example.html

Create your checkout form

FramePay automatically gathers data from your checkout form.

To enable this, you must use data-rebilly attributes on your input fields.

example.html

Add mounting points to your form

Add an empty placeholder div with a unique ID for the following payment methods:

  • Express methods (Paypal in this example).
  • Methods that require input elements (payment card and bank account in this case).
example.html
2

Configure FramePay

This step describes the basic setup for mounting.

Initialize

Initialize FramePay with a configuration object.

For more information, see FramePay configuration reference.

client.js

Rebilly data

To connect with the Rebilly API, in your configuration object, provide your: publishable API key, organization ID, and website ID.

client.js

Transaction data

Provide the transaction data in your configuration object.

client.js

Optional: Style FramePay inputs

Customize the card payment and bank account fields to match the look and feel of the rest of your form.

To customize, add the style property in your configuration object.

For all available properties, see Style reference.

client.js

Mount the (pre-)selected payment method

After initialization, mount the pre-selected payment method (either card payment or bank account) in their container. Keep track of the current element instances with a cache. This example uses a mountedFrames array as a cache.

Also mount the express methods element in their container.

client.js

Handle change when a customer selects a different payment method

Note: This step is not necessary for express methods.

When a customer selects a different payment method, destroy the element instances by invoking the .destroy() method.

Then, re-mount the FramePay element for the payment method that was selected by the customer.

client.js
3

Get the payment token

Generate a payment token using FramePay.

Express methods

For express methods, when a customer completes the flow, Rebilly creates a payment token.

To retrieve it, listen to the token-ready event.

For more information, see Framepay.on('token-ready', ...).

client.js

Non-express methods

For non-express methods, to send the form data to FramePay, call Framepay.createToken().

  • If the collected form data is valid, you receive a successful result with a new payment token.
  • If the collected form data is not valid, you receive an error explaining why.

For more information, see Framepay.createToken(form).

To specify the payment method selected by the customer, when creating the payment token, pass its value as the method property in extraData. This example includes:

  • method: 'payment-card' for card payment.
  • method: 'ach' for bank account.
  • method: 'China UnionPay' for China UnionPay.

For a full list of supported methods, see the method payload of the Create payment token operation.

client.js

Basic set up complete

To learn more about FramePay, see:

Copy to clipboard
  • example.html
  • client.js
  • style.css
1<!DOCTYPE html>
2 <html>
3 <head>
4 <link href="https://framepay.rebilly.com/framepay.css" rel="stylesheet" />
5 <script src="https://framepay.rebilly.com/framepay.js"></script>
6 <script src="./client.js" defer></script>
7 <link href="./style.css" rel="stylesheet" />
8 </head>
9
10 <body>
11 <div class="container mm-example">
12 <div id="paypal-mount"></div>
13
14 <div class="divider"></div>
15
16 <form id="payment-form">
17 <div class="field">
18 <input data-rebilly="firstName" placeholder="First name" />
19 </div>
20 <div class="field">
21 <input data-rebilly="lastName" placeholder="Last name" />
22 </div>
23 <div class="field">
24 <input data-rebilly="emails" placeholder="Email address" />
25 </div>
26
27 <div class="payment-methods">
28 <div class="tabs">
29 <div class="tab">
30 <input type="radio" id="card" name="paymentMethod" value="payment-card" checked />
31 <label class="tab-label" for="card">Payment Card</label>
32 <div class="tab-content">
33 <div id="mounting-point"></div>
34 </div>
35 </div>
36
37 <div class="tab">
38 <input type="radio" id="ach" name="paymentMethod" value="ach" />
39 <label class="tab-label" for="ach">Bank account</label>
40 <div class="tab-content">
41 <div>
42 <div class="field">
43 <label class="label">Account type</label>
44 <div id="bank-account-type"></div>
45 </div>
46 <div class="field">
47 <label class="label">Account number</label>
48 <div id="bank-account-number"></div>
49 </div>
50 <div class="field">
51 <label class="label">Routing number</label>
52 <div id="bank-routing-number"></div>
53 </div>
54 </div>
55 </div>
56 </div>
57
58 <div class="tab">
59 <input type="radio" id="cn-u-pay" name="paymentMethod" value="China UnionPay" />
60 <label class="tab-label" for="cn-u-pay">
61 China UnionPay
62 </label>
63 <div class="tab-content">
64 <div class="flex align-items-center">
65 <div class="text-grey">
66 After submitting your order, you will be redirected to securely complete your purchase.
67 </div>
68 </div>
69 </div>
70 </div>
71 </div>
72 </div>
73
74 <button id="pay-now">Make payment</button>
75 </form>
76 </div>
77 </body>
78 </html>

Interactive example

This is an interactive example of a basic checkout form which uses FramePay to tokenize payments from multiple methods

View console.log messages in a new window.