summaryrefslogtreecommitdiff
path: root/payments.php
diff options
context:
space:
mode:
author53hornet <atc@53hor.net>2021-09-07 14:23:27 -0400
committer53hornet <atc@53hor.net>2021-09-07 14:23:27 -0400
commit2901cf43bf45ff322fb62286c3bf1594b55c20ee (patch)
tree9c3ce172133e70935f1030524ecf9e460eebf557 /payments.php
parentbfaccc32571df8a02f69518d8864244efba3b5b5 (diff)
download53hor-2901cf43bf45ff322fb62286c3bf1594b55c20ee.tar.xz
53hor-2901cf43bf45ff322fb62286c3bf1594b55c20ee.zip
chore: rename html to php, add donate/payments page, update cv
Diffstat (limited to 'payments.php')
-rw-r--r--payments.php118
1 files changed, 118 insertions, 0 deletions
diff --git a/payments.php b/payments.php
new file mode 100644
index 0000000..2fb35c3
--- /dev/null
+++ b/payments.php
@@ -0,0 +1,118 @@
+<div id="smart-button-container">
+ <div style="text-align: center"><label for="description">Description of services </label><input type="text" name="descriptionInput" id="description" maxlength="127" value=""></div>
+ <p id="descriptionError" style="visibility: hidden; color:red; text-align: center;">Please enter a description</p>
+ <div style="text-align: center"><label for="amount">Amount to be paid </label><input name="amountInput" type="number" id="amount" value=""><span> USD</span></div>
+ <p id="priceLabelError" style="visibility: hidden; color:red; text-align: center;">Please enter a price</p>
+ <div id="invoiceidDiv" style="text-align: center; display: none;"><label for="invoiceid">Invoice ID (if applicable) </label><input name="invoiceid" maxlength="127" type="text" id="invoiceid" value=""></div>
+ <p id="invoiceidError" style="visibility: hidden; color:red; text-align: center;">Please enter an Invoice ID</p>
+ <div style="text-align: center; margin-top: 0.625rem;" id="paypal-button-container"></div>
+</div>
+<script src="https://www.paypal.com/sdk/js?client-id=sb&enable-funding=venmo&currency=USD" data-sdk-integration-source="button-factory"></script>
+<script>
+ function initPayPalButton() {
+ var description = document.querySelector('#smart-button-container #description');
+ var amount = document.querySelector('#smart-button-container #amount');
+ var descriptionError = document.querySelector('#smart-button-container #descriptionError');
+ var priceError = document.querySelector('#smart-button-container #priceLabelError');
+ var invoiceid = document.querySelector('#smart-button-container #invoiceid');
+ var invoiceidError = document.querySelector('#smart-button-container #invoiceidError');
+ var invoiceidDiv = document.querySelector('#smart-button-container #invoiceidDiv');
+
+ var elArr = [description, amount];
+
+ if (invoiceidDiv.firstChild.innerHTML.length > 1) {
+ invoiceidDiv.style.display = "block";
+ }
+
+ var purchase_units = [];
+ purchase_units[0] = {};
+ purchase_units[0].amount = {};
+
+ function validate(event) {
+ return event.value.length > 0;
+ }
+
+ paypal.Buttons({
+ style: {
+ color: 'white',
+ shape: 'pill',
+ label: 'pay',
+ layout: 'vertical',
+
+ },
+
+ onInit: function(data, actions) {
+ actions.disable();
+
+ if (invoiceidDiv.style.display === "block") {
+ elArr.push(invoiceid);
+ }
+
+ elArr.forEach(function(item) {
+ item.addEventListener('keyup', function(event) {
+ var result = elArr.every(validate);
+ if (result) {
+ actions.enable();
+ } else {
+ actions.disable();
+ }
+ });
+ });
+ },
+
+ onClick: function() {
+ if (description.value.length < 1) {
+ descriptionError.style.visibility = "visible";
+ } else {
+ descriptionError.style.visibility = "hidden";
+ }
+
+ if (amount.value.length < 1) {
+ priceError.style.visibility = "visible";
+ } else {
+ priceError.style.visibility = "hidden";
+ }
+
+ if (invoiceid.value.length < 1 && invoiceidDiv.style.display === "block") {
+ invoiceidError.style.visibility = "visible";
+ } else {
+ invoiceidError.style.visibility = "hidden";
+ }
+
+ purchase_units[0].description = description.value;
+ purchase_units[0].amount.value = amount.value;
+
+ if (invoiceid.value !== '') {
+ purchase_units[0].invoice_id = invoiceid.value;
+ }
+ },
+
+ createOrder: function(data, actions) {
+ return actions.order.create({
+ purchase_units: purchase_units,
+ });
+ },
+
+ onApprove: function(data, actions) {
+ return actions.order.capture().then(function(orderData) {
+
+ // Full available details
+ console.log('Capture result', orderData, JSON.stringify(orderData, null, 2));
+
+ // Show a success message within this page, e.g.
+ const element = document.getElementById('paypal-button-container');
+ element.innerHTML = '';
+ element.innerHTML = '<h3>Thank you for your payment!</h3>';
+
+ // Or go to another URL: actions.redirect('thank_you.html');
+
+ });
+ },
+
+ onError: function(err) {
+ console.log(err);
+ }
+ }).render('#paypal-button-container');
+ }
+ initPayPalButton();
+</script>