Платежные интеграции CloudPayments
Если нет времени и желания разбираться самостоятельно – обращайтесь
Платежные виджеты CloudPayments
Разовый платеж
Подключаем платежный виджет
в файле functions.php
wp_enqueue_script( 'cloudpayments',
https://widget.cloudpayments.ru/bundles/cloudpayments.js' );
// cloudpaymentslocal.js - подключение на сайте, подключаем в футер
wp_enqueue_script( 'cloudpaymentslocal',
get_template_directory_uri() . '/js/cloudpaymentslocal.js', null, null, true );
в файле /js/cloudpaymentslocal.js
const cloudpaymentsOncePaymentButton = document.querySelector( '.cloudpayments-once-payment' );
let options = {
// publicId: 'test_api_00000000000000000000001', //id из личного кабинета - тестовый (лого смайлик)
// publicId: 'test_api_00000000000000000000002', //id из личного кабинета - тестовый (лого CloudPayments круглый)
publicId: 'test_api_00000000000000000000003', //id из личного кабинета - тестовый (лого CloudPayments облако)
email: 'my@email.ru',
};
if ( cloudpaymentsOncePaymentButton ) {
cloudpaymentsOncePaymentButton.addEventListener( 'click', ( e ) => {
e.preventDefault();
options.requireEmail = false;
options.description = 'Разовый платеж';
pay( options );
} );
}
// ------------------------------------------------------------------------------------------------ Разовый платеж
this.pay = function ( {
publicId = 'test_api_00000000000000000000001',
description = 'Платеж',
email = 'user@example.com',
requireEmail = false
} ) {
var widget = new cp.CloudPayments( );
widget.pay( 'charge', // или 'auth'
{ //options
publicId: publicId, //id из личного кабинета
description: description, // назначение платежа
amount: 1, //сумма
currency: 'RUB', //валюта
requireEmail: requireEmail,
email: email, //email плательщика
},
{
onSuccess: function (options) { // success
//действие при успешной оплате
},
onFail: function (reason, options) { // fail
//действие при неуспешной оплате
},
onComplete: function (paymentResult, options) { //Вызывается как только виджет получает от api.cloudpayments ответ с результатом транзакции.
//например вызов вашей аналитики Facebook Pixel
}
}
)
};
Рекуррентный платеж
Рекуррентные платежи — это повторяющиеся переводы денег с карты на счет. Еще их называют автоплатежами. Например, эта модель оплаты подходит бизнесу, который предлагает сервисы по подписке.
Рекуррентные платежи – возможность выполнять регулярные списания денег с банковской карты покупателя без повторного ввода реквизитов карты и без участия плательщика для инициации очередного платежа.
в файле /js/cloudpaymentslocal.js
const cloudpaymentsRecurrentButton = document.querySelector( '.cloudpayments-recurrent-payment' );
if ( cloudpaymentsRecurrentButton ) {
cloudpaymentsRecurrentButton.addEventListener( 'click', ( e ) => {
e.preventDefault();
options.description = 'Подписка на автоплатеж,\n первый платеж 1 руб.,\n ежемесячно 100 руб.'; //назначение
options.requireEmail = true;
recurrent( options );
} );
}
this.recurrent = function ( {
publicId = 'test_api_00000000000000000000001',
description = 'Платеж',
email = 'user@example.com',
requireEmail = false
} ) {
var widget = new cp.CloudPayments();
var accountId = email;
var data = {};
data.CloudPayments = {
recurrent: {
amount: 100, // ежемесячно платеж на 100 руб
interval: 'Month',
period: 1,
}
}; //создание ежемесячной подписки
widget.charge( { // options
publicId: publicId, //id из личного кабинета
description: description, //назначение
amount: 1, //сумма
currency: 'RUB', //валюта
requireEmail: requireEmail,
email: email, //email плательщика
accountId: accountId, //идентификатор плательщика (обязательно для создания подписки)
data: data
},
function (options) { // success
//действие при успешной оплате
},
function (reason, options) { // fail
//действие при неуспешной оплате
});
};
Документация – https://developers.cloudpayments.ru/#demo-widget
Если нет времени и желания разбираться самостоятельно – обращайтесь