A SilverStripe module to integrate Braintree payment forms in Dropin UI.
Currently there're following forms:
When there's no payment method in the vault, the form allows user to add a new payment method:
Both forms (v0.6) allow user to authorize paypal:
Support SilverStripe 4.
Use composer
to install/update:
composer require alext/silverstripe-btpayment
After installing and rebuilding (\dev\build?flush
) go to site admin - Settings and input Braintree settings, see screenshot below:
This module extends SilverStripe member's data to create a Braintree customer for each member and store its customer id in database.
Braintree customer will be created on the fly at the first time using the forms if there's no customer id found.
$BTPaymentForm
in your template of the page.Example:
[SamplePayment.ss]
<!-- BEGIN MAIN CONTENT -->
$BTPaymentForm
<!-- END MAIN CONTENT -->
The page controller must extend BraintreePageController
use AlexT\BTPayment\BraintreePageController;
class SamplePaymentPageController extends BraintreePageController {
}
$BTEditPaymentForm($amount)
in your template, if $amount is not specified 0 (zero) will be put in place.Example (in case we process the payment in the separate page, set the total amount on the fly):
[SamplePaymentManagement.ss]
<!-- BEGIN MAIN CONTENT -->
$BTEditPaymentForm
<!-- END MAIN CONTENT -->
Example if we want to change the total amount on the fly:
[PaymentPage.ss]
<h3>Select a property to purchase:</h3>
<p><p>
<select id="js-select-property">
<option value="0">----- Select property -----</option>
<% loop $FeaturedProperties %>
<option value="{$PricePerNight}">{$Title}</option>
<% end_loop %>
</select>
<hr>
$BTPaymentForm
-----
[scripts.js]
$('#js-select-property').on('change', function (e) {
$('.js-bt-amount').val($('#js-select-property').val());
});
The page controller must extend BraintreeEditPageController
use AlexT\BTPayment\BraintreeEditPageController;
class SamplePaymentManagementPageController extends BraintreeEditPageController {
}
BTPreviousTransactionsForm
in your template.Example:
[SamplePaymentManagement.ss]
<!-- BEGIN MAIN CONTENT -->
$BTPreviousTransactionsForm
<!-- END MAIN CONTENT -->
The page controller must extend BraintreePageController
.
To manually handle the transaction yourself, override function processPayment($session, $form, $nonce, $amount)
to do your own transaction, for example:
public function processPayment($session, $form, $nonce, $amount) {
$gateway = BraintreeExtension::BTGateway();
// make a transaction
$result = $gateway->transaction()->sale([
'amount' => $amount,
'paymentMethodNonce' => $nonce,
'options' => [
'submitForSettlement' => true
]
]);
if ($result->success || !is_null($result->transaction)) {
// clear session if everything is fine
$session->clear("FormData.{$form->getName()}.data");
$form->sessionMessage('A payment of ' . $amount . '$ has been made!', 'Success');
} else {
// ERROR
$errorString = "";
foreach ($result->errors->deepAll() as $error) {
$errorString .= 'Error: ' . $error->code . ": " . $error->message . "\n";
}
$form->sessionError('Unable to make a payment! ' . $errorString, 'Failure');
}
return $this->redirectBack();
}
Module rating system helping users find modules that are well supported. For more on how the rating system works visit Module standards
Score not correct? Let us know there is a problem