Skip to content

Advanced widget customization

For an advanced widget customization you can add the style parameter section to an API request body. The section should contain the CSS styles that you'd like to apply to the widget. Please note, the submitted customization parameters override the basic widget customization settings made in the back office.

General scheme of parameters available for an advanced widget customization

Widget customization parameters

Widget styles

Info

Note that secureInfo element is placed in the header of the payment page and in the footer of the widget. If you need to customize this element for both the payment page and the widget, add secureInfo object to both footer{} and header{}.

Parameter Description
style
widget A section of general widget customization settings.
backgroundColor An HEX code of the widget background color.
buttonsColor An HEX code of the widget buttons and background type color. Applicable to button elements, if no relevant CSS properties are set in the button.card, button.brands, and button.pay sections.
backgroundType A widget background type.
Possible values:
0 or none - no image;
1- random;
2- shards;
4- rhombus;
8- ovals;
16- triangles.
backgroundCustomLeft An image embedded as a background left to the widget.
Possible values:
none – no image;
{base64-encoded image file} – a string with a base64-encoded SVG file. The file size must not exceed 1 MB.
backgroundCustomRight An image embedded as a background right to the widget.
Possible values:
none – no image;
{base64-encoded image file} – a string with a base64-encoded SVG file. The file size must not exceed 1 MB.
extra CSS properties Additional CSS properties that you can customize, if needed. See the property list here. Applicable to button elements, if no relevant CSS properties are set in the button.card, button.brands, and button.pay sections.
header A section of customization settings of the widget header.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
shop A shop name. Shown as a URL or a shop name set in the system back office.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
margin Element margins. Set as a string of values in the {margin-top} {margin-right} {margin-bottom} {margin-left} format.
close A close-iFrame widget element.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
margin Element margins. Set as a string of values in the {margin-top} {margin-right} {margin-bottom} {margin-left} format.
secureInfo An element that stands for the text about the security of the payment. If not customized, contains a link to Horizonpay.
On the payment page, the element is placed in the header. If the text also needs to be customized for the widget, it is necessary to add secureInfo object to the footer {}.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
margin Element margins. Set as a string of values in the {margin-top} {margin-right} {margin-bottom} {margin-left} format.
text Text to be displayed. Can contain a link. For example, "text": "Secure payment is provided by [clickable text](url)".
price A price display element.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
margin Element margins. Set as a string of values in the {margin-top} {margin-right} {margin-bottom} {margin-left} format.
description A payment description element.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
margin Element margins. Set as a string of values in the {margin-top} {margin-right} {margin-bottom} {margin-left} format.
button A section of widget customization settings applicable to the Pay by card, Pay by alternative payment methods, Pay button, and Payment result button elements.
borderRadius A button border radius. Applicable to button elements, if no relevant CSS properties are set in the buttons.card, buttons.brands, and buttons.pay sections.
backgroundColor An HEX-code of the element background color. Applicable to button elements, if no relevant CSS properties are set in the button.card, button.brands, and button.pay sections.
card A section of widget customization settings applicable to the Pay by card button element.
borderRadius A button border radius.
backgroundColor An HEX code of the element background color.
text A text shown on the Pay by card button. Use the {amount} placeholder to show the payment amount on the button.
extra CSS properties Additional CSS properties that you can customize, if needed.
brands A section of widget customization settings applicable to the Pay by alternative payment methods button element.
borderRadius A button border radius.
backgroundColor An HEX code of the element background color.
text A text shown on the Pay by alternative payment methods button. Use the {amount} placeholder to show the payment amount on the button.
extra CSS properties Additional CSS properties that you can customize, if needed.
pay A section of widget customization settings applicable to the Pay and Payment result button elements.
borderRadius A button border radius.
backgroundColor An HEX code of the element background color.
text A text shown on the Pay button. Use the {amount} placeholder to show the payment amount on the button.
extra CSS properties Additional CSS properties that you can customize, if needed.
inputs A section of customization settings for the element of input fields for customer details for a payment by a card or an alternative payment method.
backgroundColor An HEX code of the element background color.
holder An element of a cardholder input field.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
backgroundColor An HEX code of the element background color.
cvc An element of cvc input field.
type Possible value: password. If sent, the input cvc value will be masked.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
backgroundColor An HEX code of the element background color.
cardFace An element of a card-face background.
backgroundColor An HEX code of the element background color.
backgroundImage A base64-encoded file. SVG, PNG, and JPG formats and a size of up to 1 MB are supported.
backgroundPosition An embedded card-face image position.
Possible values:
top;
bottom;
left;
right;
center;
a string of percent values, for example 25% 75%;
a string of position measurements, for example 1cm 2cm.
backgroundSize An embedded card-face image size.
Possible values:
cover;
contain;
a string of the image width and height, for example 50% auto.
backgroundRepeat An image repeat on the widget background.
Possible values:
repeat-x;
repeat-y;
repeat;
space;
round;
no-repeat.
footer A widget footer element.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
logo A payment service provider's logo element.
secureInfo An element that stands for the text about the security of the payment. If not customized, contains a link to Horizonpay.
For the widget, this text is placed in the footer. If the text needs to be customized for the payment page, it is necessary to add secureInfo object to the header {}.
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
margin Element margins. Set as a string of values in the {margin-top} {margin-right} {margin-bottom} {margin-left} format.
text Text to be displayed. Can contain a link. For example, "text": "Secure payment is provided by [clickable text](url)".
display An option to remove the widget element.
Possible value:
none – do not show.
By default, if "display": "none" is not sent in the request, the element is displayed.
additional_logos An array containing file(s) with additional logos for the payment page. Each file is represented by a base64-encoded string. The additional merchant logos will be displayed after Horizonpay logo from left to right. The number of additional logo files is unlimited.

Extra CSS properties

Here you can find a list of additional CSS properties supported for button.card, button.brands, and button.pay elements. If you want to customize the element, submit the property key and value in the relevant request section. Otherwise, the system applies general widget customization settings.

CSS property Description
fontFamily A text font style.
color An HEX code of the text font color.
fontSize A text font size.
fontSmooth A property of anti-aliasing when the element font is rendered.
fontStyle A text font style.
fontVariant A property to render a text in small-caps font.
fontWeight A text weight meaning.
lineHeight A vertical distance between two lines of text.
letterSpacing A horizontal spacing between text symbols.
textAlign A property of text alignment.
textDecoration A property of applying decorative lines on text.
textShadow A property of text shadowing.
textTransform A property of text capitalization.
Example of widget customization
<script type='text/javascript'>
            this.payment = function() {
                var params ={
                    checkout_url: 'https://checkout.horizonpay.kz',
                    checkout: {
                        iframe: true,
                        test: true,
                        transaction_type: 'payment',
                        public_key: 'your_shop_public_key',
                        order: {
                            amount: 999,
                            currency: 'EUR',
                            description: 'Payment description',
                            tracking_id: 'your_transaction_id'
                        }
                    },
                    settings: {
                        widget_version: 2,
                        require: [],
                        customer: {},
                        success_url: 'http://127.0.0.1:4567/success',
                        fail_url: 'http://127.0.0.1:4567/fail',
                        decline_url: 'http://127.0.0.1:4567/decline',
                        notification_url: 'http://your_shop.com/notification',
                        verification_url: null,
                        cancel_url: 'http://127.0.0.1:4567/cancel',
                        return_url: 'http://127.0.0.1:4567/return',
                        language: 'ru',
                        customer_fields: {
                            visible: [
                                'city'
                            ],
                            read_only: []
                        },
                        credit_card_fields: {
                            read_only: [
                                'holder'
                            ]
                        },
                        save_card_toggle: {
                            display: true,
                            customer_contract: true,
                            text: 'save_card_toggle text',
                            hint: 'save_card_toggle hint'
                        },
                        style: {
                            widget: {
                                backgroundColor: '#dbc21f',
                                buttonsColor: '#fcf400',
                                backgroundType: '4',
                                backgroundCustomLeft: 'PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pgo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDIwMDEwOTA0Ly9FTiIKICJodHRwOi8vd3d3LnczLm9...',                   
                                fontFamily: 'fantasy',
                                color: '#ff0000',
                                fontSize: '',
                                fontSmooth: '',
                                fontStyle: '',
                                fontVariant: '',
                                fontWeight: '',
                                lineHeight: '',
                                letterSpacing: '',
                                textAlign: '',
                                textDecoration: '',
                                textShadow: '',
                                textTransform: ''
                            },
                            header: {
                                shop: {
                                    margin: ''
                                },
                                close: {
                                    margin: ''
                                }
                            },
                            price: {
                                margin: ''
                            },
                            description: {
                                margin: ''
                            },
                            button: {
                                borderRadius: '22px',
                                backgroundColor: '#03b3ff',
                                card: {
                                    borderRadius: '22px',
                                    backgroundColor: '#ffffff',
                                    text: 'Pay with card {amount}',
                                    fontFamily: 'roboto',
                                    color: '#6f7d79',
                                    fontSize: '',
                                    fontSmooth: '',
                                    fontStyle: '',
                                    fontVariant: '',
                                    fontWeight: '',
                                    lineHeight: '',
                                    letterSpacing: '',
                                    textAlign: '',
                                    textDecoration: '',
                                    textShadow: '',
                                    textTransform: ''
                                },
                                brands: {
                                    borderRadius: '22px',
                                    backgroundColor: '#cf8608',
                                    text: 'Pay {amount}',
                                    fontFamily: 'consolas',
                                    color: '#2f2cd1',
                                    fontSize: '',
                                    fontSmooth: '',
                                    fontStyle: '',
                                    fontVariant: '',
                                    fontWeight: '',
                                    lineHeight: '',
                                    letterSpacing: '',
                                    textAlign: '',
                                    textDecoration: '',
                                    textShadow: '',
                                    textTransform: ''
                                },
                                pay: {
                                    borderRadius: '22px',
                                    backgroundColor: '#24ff03',
                                    text: 'Pay pay final button {amount}',
                                    fontFamily: 'calibry',
                                    color: '#bc4ce5',
                                    fontSize: '',
                                    fontSmooth: '',
                                    fontStyle: '',
                                    fontVariant: '',
                                    fontWeight: '',
                                    lineHeight: '',
                                    letterSpacing: '',
                                    textAlign: '',
                                    textDecoration: '',
                                    textShadow: '',
                                    textTransform: ''
                                }
                            },
                            inputs: {
                                backgroundColor: '',
                                holder: {
                                    backgroundColor: ''
                                }
                            },
                            cardFace: {
                                backgroundColor: '',
                                backgroundImage: '',
                                backgroundPosition: '',
                                backgroundSize: '',
                                backgroundRepeat: ''
                            },
                            footer: {
                                logo: {}
                            }
                        }
                    }
                }

                new BeGateway(params).createWidget();
            };
</script>
Example of a payment token request with widget customization parameters
{
    "checkout": {
        "test": true,
        "transaction_type": "payment",
        "payment_method": {
            "types": []
        },
        "attempts": 3,
        "order": {
            "currency": "USD",
            "amount": 1000,
            "description": "Order description"
        },
        "settings": {
            "widget_version": 2,
            "require": [],
            "customer": {},
            "success_url": "http://your_shop.com/success",
            "fail_url": "http://your_shop.com/fail",
            "decline_url": "http://your_shop.com/decline",
            "notification_url": "http://your_shop.com/notification",
            "verification_url": null,
            "cancel_url": "http://your_shop.com/cancel",
            "return_url": "http://your_shop.com/return",
            "language": "ru",
            "customer_fields": {
                "visible": [
                    "city"
                ],
                "read_only": []
            },
            "credit_card_fields": {
                "read_only": [
                    "holder"
                ]
            },
            "save_card_toggle": {
                "display": true,
                "customer_contract": true,
                "text": "save_card_toggle text",
                "hint": "save_card_toggle hint"
            },
            "style": {
                "widget": {
                    "backgroundColor": "#dbc21f",
                    "buttonsColor": "#fcf400",
                    "backgroundType": "4",
                    "backgroundCustomLeft": "PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pgo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDIwMDEwOTA0Ly9FTiIKICJodHRwOi8vd3d3LnczLm9...",
                    "fontFamily": "fantasy",
                    "color": "#ff0000",
                    "fontSize": "",
                    "fontSmooth": "",
                    "fontStyle": "",
                    "fontVariant": "",
                    "fontWeight": "",
                    "lineHeight": "",
                    "letterSpacing": "",
                    "textAlign": "",
                    "textDecoration": "",
                    "textShadow": "",
                    "textTransform": ""
                },
                "header": {                        
                    "shop": {                            
                        "margin": "0px 0px 0px 0px"
                    },
                    "close": {                            
                        "margin": "0px 0px 0px 0px"
                    },
                    "secureInfo": {                          
                      "margin": "0px 0px 0px 0px",
                      "text": "Secure payment is provided by [Horizonpay](https://example.com/terms)" 
                    }
                },
                "price": {                        
                    "margin": "0px 0px 0px 0px"
                },
                "description": {                        
                    "margin": "0px 0px 0px 0px"
                },
                "button": {
                    "borderRadius": "22px",
                    "backgroundColor": "#03b3ff",
                    "card": {
                        "borderRadius": "22px",
                        "backgroundColor": "#ffffff",
                        "text": "Pay with card {amount}",
                        "fontFamily": "roboto",
                        "color": "#6f7d79",
                        "fontSize": "",
                        "fontSmooth": "",
                        "fontStyle": "",
                        "fontVariant": "",
                        "fontWeight": "",
                        "lineHeight": "",
                        "letterSpacing": "",
                        "textAlign": "",
                        "textDecoration": "",
                        "textShadow": "",
                        "textTransform": ""
                    },
                    "brands": {
                        "borderRadius": "22px",
                        "backgroundColor": "#cf8608",
                        "text": "Pay {amount}",
                        "fontFamily": "consolas",
                        "color": "#2f2cd1",
                        "fontSize": "",
                        "fontSmooth": "",
                        "fontStyle": "",
                        "fontVariant": "",
                        "fontWeight": "",
                        "lineHeight": "",
                        "letterSpacing": "",
                        "textAlign": "",
                        "textDecoration": "",
                        "textShadow": "",
                        "textTransform": ""
                    },
                    "pay": {
                        "borderRadius": "22px",
                        "backgroundColor": "#24ff03",
                        "text": "Pay {amount}",
                        "fontFamily": "calibri",
                        "color": "#bc4ce5",
                        "fontSize": "",
                        "fontSmooth": "",
                        "fontStyle": "",
                        "fontVariant": "",
                        "fontWeight": "",
                        "lineHeight": "",
                        "letterSpacing": "",
                        "textAlign": "",
                        "textDecoration": "",
                        "textShadow": "",
                        "textTransform": ""
                    }
                },
                "inputs": {
                    "backgroundColor": "",
                    "holder": {                            
                        "backgroundColor": ""
                    },
                    "cvc": {
                        "type": "password",                            
                        "backgroundColor": ""
                    }
                },
                "cardFace": {
                    "backgroundColor": "",
                    "backgroundImage": "PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pgo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDIwMDEwOTA0Ly9FTiIKICJodHRwOi8vd3d3LnczLm9yZy9UUi8yMDAxL1JFQy1TVkctMjAwMTA5MDQvRFREL3N2ZzEwLmR0ZCI...",
                    "backgroundPosition": "center",
                    "backgroundSize": "400px 300px",
                    "backgroundRepeat": "repeat"
                },
                "footer": {                        
                    "logo": {},
                    "secureInfo": {
                      "margin": "0px 0px 0px 0px",
                      "text": "Secure payment is provided by [Horizonpay](https://example.com/terms)" 
                    },
                    "additional_logos": [
                        "iVBORw0KGgoAAAANSUhEUgAADwAAAAhwCAYAAACQvstyAAAACXBIWXMAABYlAAAWJQFJUiTwAAAAAXNSR0IArs4c6QAARnQU1BAACxjwv8YQU...",
                        "iVBORw0KGgoAAAANSUhEUgAAAMgAAABkCAYAAADDhn8LAAAACXBIWXMAsTAAALEwEA..."
                    ]
                }
            }
        }
    }
}