CCBill API Payment Widget integration guide

Vue

To integrate the CCBill API Payment Widget into your Vue.js application, complete the following steps:

1. Installation and Setup

To use the widget, add a <script> import in the header of the main index.html file.

To view the widget, set up the correct <meta> tag for viewports in the header of the same file.

2. Usage

Add the widget <ccb-payment-widget> element and the required parameters in the template of your component. In this example, the file is called app.vue.

Attributes

PARAMETER
apiKey string
A valid OAuth token generated using the merchant application ID and the secret key asigned to the client account involved in the transaction.
clientAccount string
Merchant account number.
The value must be in the range between 900000 and 999999.
subAccount string
Merchant subaccount number.
The value must be in the range between 0 and 9999.
currency string
Currency used for this transaction.
Accepted values: USD / GBP / EUR / CAD / AUD / JPY
initialPrice string
This is the initial transaction price.
Formatted as a float value up to 2 decimal points, e.g., 5.00
initialPeriod string
The length (in days) of the initial billing.
Formatted as an integer value, e.g., 5
NOTE: Set to 0 in case of a single and non-recurring transaction.
PARAMETER
language string
The language the widget will be rendered in.
Accepted values: en / es / fr / de / it / ja / ko / zh_tw / zh_cn / pt_br / hi / sv / da / no / nl

NOTE: If the language is not supplied or the supplied language is not supported, the widget will try to determine the language from the browser. If that language is not supported, it will default to English.
theme string
The theme the widget will be loaded in.
Accepted values are ccb-light and ccb-dark

NOTE: If the value is not supplied or is invalid, the system will default to ccb-light.
Custom themes are possible; please refer to the theming documentation.
description string
Optional product description to show in the widget.
Up to 500 characters (no HTML/images allowed).
lifeTimeSubscription string
Indicates whether the transaction is a lifetime subscription or not.
Formatted as boolean value 1 or 0
rebills string
Represents a recurring transaction, rebilling the consumer X times according to the value set.
Formatted as an integer value 1 to 99 ("99" being indefinite).

NOTE: When rebills is provided recurringPrice and recurringPeriod become required fields
recurringPrice string
The recurring price in case of a recurring transaction.
Formatted as a float value up to 2 decimal points, e.g., 5.00
It is a required parameter for recurring transactions.
recurringPeriod string
The recurring period in case of a recurring transaction.
Formatted as an integer value, e.g., 5

At this point, your application is consuming the widget. However, the required configuration is still missing.

Define these properties and their values in the script tag within your app.vue component file.

If all the passed parameters are correct, the following screen appears:

A successfully configured CCBill API Payment Widget.

In case of a misconfiguration or if one of the values passed in is not valid, the following screen is displayed:

CCBill Widget misconfiguration message.

3. Create Payment Token

Pressing the Place your order button generates a payment token, which passes into the application as a CustomEvent.

To get the data from the widget and use it in an application, add an event listener for a custom event called tokenCreated, which will give you data in the details property.

When the event is caught, the onGenerateTokenId method is called with data as input, and you can use the payment token.

CCBill Widget successfully configured.

Creating a charge with this payment token will require adding the customer's IP address as an additional payload (ipAddress) or header (X-Origin-IP) parameter.

4. Customize CSS (Optional)

Customize the appearance of the CCBill API Payment Widget through a preset Theme or with CSS variables to modify its appearance.

With CSS variables, the widget easily adapts to match the look and feel of a website. This guide will walk you through the customization process, including preset dark and light themes.

Setting the Viewport Meta Tag

The viewport meta tag sets the initial viewport properties for a web page. It helps control how the web page displays on various devices, ensuring the content fits and scales appropriately.

This is crucial for responsive web design and providing a good user experience on different screen sizes and orientations.

You can set up the correct <meta> tag for viewports in the header of the main index.html file.

Preset Light and Dark Themes

The dark or light themes are standard themes with which the widget is shipped. These themes are ready to use as-is without any additional customization.

1. Define the constant and its value in the my-app.ts file using ccb-dark or ccb-lightas values.
2. Add the theme widget attribute to pass the information to the widget.

Available CSS Variables

You can customize various aspects of the widget using the following CSS variables:

Element Variable
Widget Background --ccb-background
Element Variable
Ribbon - Language Dropdown
Background --ccb-ribbon-background
List - Background --ccb-language-dropdown-background
Text --ccb-language-dropdown-text
Icon - Chevron --ccb-language-dropdown-icon
Header - Price / Product Description
Background --ccb-header-background
Section Divider - Border --ccb-section-divider-border
Price - Text --ccb-header-price-text
Description - Text --ccb-header-description-text
Header - Currency Code - Text --ccb-header-currency-code-text
Section Headers
Header Text --ccb-section-header
Input Field and Dropdown
Background --ccb-input-field-background
Placeholder Text --ccb-input-field-placeholder
Text --ccb-input-field-text
Border --ccb-input-field-border
Border - In Focus --ccb-input-field-border-infocus
Dropdown Country - Divider --ccb-country-dropdown-divider
Dropdown Language - Background --ccb-language-dropdown-background
Links
Text --ccb-link
Text - Hover --ccb-link-hover
Text - Visited --ccb-link-visited
Terms & Conditions
Text --ccb-terms-and-conditions-text
Call to Action - Place your Order Button
Background --ccb-cta-background
Background - Hover --ccb-cta-background-hover
Background - Action --ccb-cta-background-action
Text --ccb-cta-text-color
Text - Hover --ccb-cta-text-color-hover
Footer
Background --ccb-footer-background
Text --ccb-footer-text
Border --ccb-validation-border
Input Field Text --ccb-validation-text
Error Message Text --ccb-validation-error-text
Background --ccb-validation-background
Element Variable
Border --ccb-validation-border
Input Field Text --ccb-validation-text
Error Message Text --ccb-validation-error-text
Background --ccb-validation-background

Feel free to modify these variables according to your website's color scheme and design preferences. Experiment with different values to achieve the desired look for your payment widget.

<!DOCTYPE html>
<html lang="">
  <head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE-edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"/>
<title>DemoVueMerchant</title><link rel="icon" href="<%= BASE_URL %>favicon.ico"/>
<script src="https://js.ccbill.com/payment-widget/v1/index.js"></script>
</head> <body> <noscript> <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong> </noscript> <div id="app"></div> <!--built files will be auto injected--> </body> </html>
<template>
<div>
  <div>
    <h2 v-if="paymentToken">Payment Token Generated</h2>
    <p v-if="paymentToken">{{ paymentToken }}</p>
    <p v-else>No payment token available yet.</p>
  </div>
<ccb-payment-widget :apiKey="apiKey" :language="language" :currency="currency" :initialPrice="initialPrice" :initialPeriod="initialPeriod" :recurringPrice="recurringPrice" :recurringPeriod="recurringPeriod" :rebills="rebills" :lifeTimeSubscription="lifeTimeSubscription" :description="description" :clientAccount="clientAccount" :subAccount="subAccount" :theme="theme" :apiBaseUrl="apiBaseUrl" @tokenCreated="_onGenerateTokenId" ></ccb-payment-widget>
</div> </template> <script>
export default { data: function () { return { paymentToken: '', }; }, props: { apiKey: { type: String, default: 'YOUR_API_KEY' }, language: { type: String, default: 'en' }, currency: { type: String, default: 'USD' }, initialPrice: { type: String, default: '12.22' }, initialPeriod: { type: String, default: '5' }, clientAccount: { type: String, default: '901909' }, subAccount: { type: String, default: '0' }, apiBaseUrl: { type: String, default: 'https://api.dev.ccbill.com/' }, recurringPrice: { type: String, }, recurringPeriod: { type: String, }, rebills: { type: String, }, lifeTimeSubscription: { type: String, }, description: { type: String, },
// Set theme value here. theme: { type: String, default: 'ccb-dark' },
}, methods:{ _onGenerateTokenId(event){ this.paymentToken = event.detail.paymentToken.paymentTokenId; }, },
mounted() { const ccbPaymentWidget = this.$el.querySelector('ccb-payment-widget'); // Manually add an event listener to capture Lit custom events ccbPaymentWidget.addEventListener('tokenCreated', this._onGenerateTokenId); }, beforeUnmount() { const ccbPaymentWidget = this.$el.querySelector('ccb-payment-widget'); // Remove the event listener when the Vue component is unmounted ccbPaymentWidget.removeEventListener('tokenCreated', this._onGenerateTokenId); }, }
</script>
html {
  /* Custom - Background */
  --ccb-background: #280F50;

  /* Custom - Header - Ribbon */
  --ccb-ribbon-background: #62389E;
  --ccb-header-language-dropdown-text: #ffffff;
  --ccb-header-language-dropdown-icon: #ffffff;
  --ccb-header-language-background: #62389E;

  /* Add more customizations here */
}