Linux vps-61133.fhnet.fr 4.9.0-19-amd64 #1 SMP Debian 4.9.320-2 (2022-06-30) x86_64
Apache/2.4.25 (Debian)
Server IP : 93.113.207.21 & Your IP : 216.73.216.35
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
var /
www /
html /
bdc.bdcloud.fr /
takepos /
Delete
Unzip
Name
Size
Permission
Date
Action
admin
[ DIR ]
drwxr-x---
2025-11-08 11:17
ajax
[ DIR ]
drwxr-x---
2025-11-08 11:17
css
[ DIR ]
drwxr-x---
2025-11-08 11:17
genimg
[ DIR ]
drwxr-x---
2025-11-08 11:17
img
[ DIR ]
drwxr-x---
2025-11-08 11:17
js
[ DIR ]
drwxr-x---
2025-11-08 11:17
public
[ DIR ]
drwxr-x---
2025-11-08 11:17
sql
[ DIR ]
drwxr-x---
2025-11-08 11:17
README.md
162
B
-rwxr-x---
2023-04-04 15:51
floors.php
7.65
KB
-rwxr-x---
2023-04-04 15:51
freezone.php
4.77
KB
-rwxr-x---
2023-04-04 15:51
index.php
56.5
KB
-rwxr-x---
2023-04-04 15:51
invoice.php
72.48
KB
-rwxr-x---
2023-04-04 15:51
modulebuilder.txt
242
B
-rwxr-x---
2023-04-04 15:51
pay.php
28.4
KB
-rwxr-x---
2023-04-04 15:51
phone.php
13.83
KB
-rwxr-x---
2023-04-04 15:51
printbox.php
3.2
KB
-rwxr-x---
2023-04-04 15:51
receipt.php
10.89
KB
-rwxr-x---
2023-04-04 15:51
reduction.php
7.93
KB
-rwxr-x---
2023-04-04 15:51
send.php
3.95
KB
-rwxr-x---
2023-04-04 15:51
smpcb.php
2.01
KB
-rwxr-x---
2023-04-04 15:51
split.php
7.13
KB
-rwxr-x---
2023-04-04 15:51
Save
Rename
<?php /* Copyright (C) 2018 Andreu Bisquerra <jove@bisquerra.com> * Copyright (C) 2021-2022 Thibault FOUCART <support@ptibogxiv.net> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <https://www.gnu.org/licenses/>. */ /** * \file htdocs/takepos/pay.php * \ingroup takepos * \brief Page with the content of the popup to enter payments */ // if (! defined('NOREQUIREUSER')) define('NOREQUIREUSER', '1'); // Not disabled cause need to load personalized language // if (! defined('NOREQUIREDB')) define('NOREQUIREDB', '1'); // Not disabled cause need to load personalized language // if (! defined('NOREQUIRESOC')) define('NOREQUIRESOC', '1'); // if (! defined('NOREQUIRETRAN')) define('NOREQUIRETRAN', '1'); if (!defined('NOTOKENRENEWAL')) { define('NOTOKENRENEWAL', '1'); } if (!defined('NOREQUIREMENU')) { define('NOREQUIREMENU', '1'); } if (!defined('NOREQUIREHTML')) { define('NOREQUIREHTML', '1'); } // Load Dolibarr environment require '../main.inc.php'; // Load $user and permissions require_once DOL_DOCUMENT_ROOT.'/compta/facture/class/facture.class.php'; require_once DOL_DOCUMENT_ROOT.'/stripe/class/stripe.class.php'; // Load translation files required by the page $langs->loadLangs(array("main", "bills", "cashdesk", "banks")); $place = (GETPOST('place', 'aZ09') ? GETPOST('place', 'aZ09') : '0'); // $place is id of table for Bar or Restaurant $invoiceid = GETPOST('invoiceid', 'int'); $hookmanager->initHooks(array('takepospay')); if (empty($user->rights->takepos->run)) { accessforbidden(); } /* * View */ $arrayofcss = array('/takepos/css/pos.css.php'); $arrayofjs = array(); $head = ''; $title = ''; $disablejs = 0; $disablehead = 0; $head='<link rel="stylesheet" href="css/pos.css.php">'; if (getDolGlobalInt('TAKEPOS_COLOR_THEME') == 1) { $head .= '<link rel="stylesheet" href="css/colorful.css">'; } top_htmlhead($head, $title, $disablejs, $disablehead, $arrayofjs, $arrayofcss); ?> <body> <?php if (isModEnabled('stripe')) { $service = 'StripeTest'; $servicestatus = 0; if (!empty($conf->global->STRIPE_LIVE) && !GETPOST('forcesandbox', 'alpha')) { $service = 'StripeLive'; $servicestatus = 1; } // Force to use the correct API key global $stripearrayofkeysbyenv; $site_account = $stripearrayofkeysbyenv[$servicestatus]['publishable_key']; $stripe = new Stripe($db); $stripeacc = $stripe->getStripeAccount($service); // Get Stripe OAuth connect account (no remote access to Stripe here) $stripecu = $stripe->getStripeCustomerAccount($object->id, $servicestatus, $site_account); // Get remote Stripe customer 'cus_...' (no remote access to Stripe here) $keyforstripeterminalbank = "CASHDESK_ID_BANKACCOUNT_STRIPETERMINAL".$_SESSION["takeposterminal"]; ?> <script src="https://js.stripe.com/terminal/v1/"></script> <script> var terminal = StripeTerminal.create({ onFetchConnectionToken: fetchConnectionToken, onUnexpectedReaderDisconnect: unexpectedDisconnect, }); function unexpectedDisconnect() { // In this function, your app should notify the user that the reader disconnected. // You can also include a way to attempt to reconnect to a reader. console.log("Disconnected from reader") } function fetchConnectionToken() { <?php $urlconnexiontoken = DOL_URL_ROOT.'/stripe/ajax/ajax.php?action=getConnexionToken&token='.newToken().'&servicestatus='.urlencode($servicestatus); if (!empty($conf->global->STRIPE_LOCATION)) { $urlconnexiontoken .= '&location='.urlencode($conf->global->STRIPE_LOCATION); } if (!empty($stripeacc)) { $urlconnexiontoken .= '&stripeacc='.urlencode($stripeacc); } ?> // Do not cache or hardcode the ConnectionToken. The SDK manages the ConnectionToken's lifecycle. return fetch('<?php echo $urlconnexiontoken; ?>', { method: "POST" }) .then(function(response) { return response.json(); }) .then(function(data) { return data.secret; }); } </script> <?php } if (isModEnabled('stripe') && isset($keyforstripeterminalbank) && (empty($conf->global->STRIPE_LIVE) || GETPOST('forcesandbox', 'alpha'))) { dol_htmloutput_mesg($langs->trans('YouAreCurrentlyInSandboxMode', 'Stripe'), '', 'warning', 1); } $invoice = new Facture($db); if ($invoiceid > 0) { $invoice->fetch($invoiceid); } else { $sql = "SELECT rowid FROM ".MAIN_DB_PREFIX."facture where ref='(PROV-POS".$_SESSION["takeposterminal"]."-".$place.")'"; $resql = $db->query($sql); $obj = $db->fetch_object($resql); if ($obj) { $invoiceid = $obj->rowid; } if (!$invoiceid) { $invoiceid = 0; // Invoice does not exist yet } else { $invoice->fetch($invoiceid); } } ?> <script> <?php if ($invoice->type != $invoice::TYPE_CREDIT_NOTE) { if (empty($conf->global->$keyforstripeterminalbank)) { ?> const config = {simulated: <?php if (empty($servicestatus) && !empty($conf->global->STRIPE_TERMINAL_SIMULATED)) { ?> true <?php } else { ?> false <?php } ?> <?php if (!empty($conf->global->STRIPE_LOCATION)) { ?>, location: '<?php echo $conf->global->STRIPE_LOCATION; ?>'<?php } ?>} terminal.discoverReaders(config).then(function(discoverResult) { if (discoverResult.error) { console.log('Failed to discover: ', discoverResult.error); } else if (discoverResult.discoveredReaders.length === 0) { console.log('No available readers.'); } else { // You should show the list of discoveredReaders to the // cashier here and let them select which to connect to (see below). selectedReader = discoverResult.discoveredReaders[0]; //console.log('terminal.discoverReaders', selectedReader); // only active for development terminal.connectReader(selectedReader).then(function(connectResult) { if (connectResult.error) { document.getElementById("card-present-alert").innerHTML = '<div class="error">'+connectResult.error.message+'</div>'; console.log('Failed to connect: ', connectResult.error); } else { document.getElementById("card-present-alert").innerHTML = ''; console.log('Connected to reader: ', connectResult.reader.label); if (document.getElementById("StripeTerminal")) { document.getElementById("StripeTerminal").innerHTML = '<button type="button" class="calcbutton2" onclick="ValidateStripeTerminal();"><span class="fa fa-2x fa-credit-card iconwithlabel"></span><br>'+connectResult.reader.label+'</button>'; } } }); } }); <?php } else { ?> terminal.connectReader(<?php echo json_encode($stripe->getSelectedReader($conf->global->$keyforstripeterminalbank, $stripeacc, $servicestatus)); ?>).then(function(connectResult) { if (connectResult.error) { document.getElementById("card-present-alert").innerHTML = '<div class="error clearboth">'+connectResult.error.message+'</div>'; console.log('Failed to connect: ', connectResult.error); } else { document.getElementById("card-present-alert").innerHTML = ''; console.log('Connected to reader: ', connectResult.reader.label); if (document.getElementById("StripeTerminal")) { document.getElementById("StripeTerminal").innerHTML = '<button type="button" class="calcbutton2" onclick="ValidateStripeTerminal();"><span class="fa fa-2x fa-credit-card iconwithlabel"></span><br>'+connectResult.reader.label+'</button>'; } } }); <?php } } ?> </script> <?php // Define list of possible payments $arrayOfValidPaymentModes = array(); $arrayOfValidBankAccount = array(); $sql = "SELECT code, libelle as label FROM ".MAIN_DB_PREFIX."c_paiement"; $sql .= " WHERE entity IN (".getEntity('c_paiement').")"; $sql .= " AND active = 1"; $sql .= " ORDER BY libelle"; $resql = $db->query($sql); if ($resql) { while ($obj = $db->fetch_object($resql)) { $paycode = $obj->code; if ($paycode == 'LIQ') { $paycode = 'CASH'; } if ($paycode == 'CB') { $paycode = 'CB'; } if ($paycode == 'CHQ') { $paycode = 'CHEQUE'; } $accountname = "CASHDESK_ID_BANKACCOUNT_".$paycode.$_SESSION["takeposterminal"]; if (!empty($conf->global->$accountname) && $conf->global->$accountname > 0) { $arrayOfValidBankAccount[$conf->global->$accountname] = $conf->global->$accountname; $arrayOfValidPaymentModes[] = $obj; } if (!isModEnabled('banque')) { if ($paycode == 'CASH' || $paycode == 'CB') $arrayOfValidPaymentModes[] = $obj; } } } ?> <script> <?php $remaintopay = 0; if ($invoice->id > 0) { $remaintopay = $invoice->getRemainToPay(); } $alreadypayed = (is_object($invoice) ? ($invoice->total_ttc - $remaintopay) : 0); if ($conf->global->TAKEPOS_NUMPAD == 0) { print "var received='';"; } else { print "var received=0;"; } ?> var alreadypayed = <?php echo $alreadypayed ?>; function addreceived(price) { <?php if (empty($conf->global->TAKEPOS_NUMPAD)) { print 'received+=String(price);'."\n"; } else { print 'received+=parseFloat(price);'."\n"; } ?> $('.change1').html(pricejs(parseFloat(received), 'MT')); $('.change1').val(parseFloat(received)); alreadypaydplusreceived=price2numjs(alreadypayed + parseFloat(received)); //console.log("already+received = "+alreadypaydplusreceived); //console.log("total_ttc = "+<?php echo $invoice->total_ttc; ?>); if (alreadypaydplusreceived > <?php echo $invoice->total_ttc; ?>) { var change=parseFloat(alreadypayed + parseFloat(received) - <?php echo $invoice->total_ttc; ?>); $('.change2').html(pricejs(change, 'MT')); $('.change2').val(change); $('.change1').removeClass('colorred'); $('.change1').addClass('colorgreen'); $('.change2').removeClass('colorwhite'); $('.change2').addClass('colorred'); } else { $('.change2').html(pricejs(0, 'MT')); $('.change2').val(0); if (alreadypaydplusreceived == <?php echo $invoice->total_ttc; ?>) { $('.change1').removeClass('colorred'); $('.change1').addClass('colorgreen'); $('.change2').removeClass('colorred'); $('.change2').addClass('colorwhite'); } else { $('.change1').removeClass('colorgreen'); $('.change1').addClass('colorred'); $('.change2').removeClass('colorred'); $('.change2').addClass('colorwhite'); } } } function reset() { received=0; $('.change1').html(pricejs(received, 'MT')); $('.change1').val(price2numjs(received)); $('.change2').html(pricejs(received, 'MT')); $('.change2').val(price2numjs(received)); $('.change1').removeClass('colorgreen'); $('.change1').addClass('colorred'); $('.change2').removeClass('colorred'); $('.change2').addClass('colorwhite'); } function Validate(payment) { var invoiceid = <?php echo ($invoiceid > 0 ? $invoiceid : 0); ?>; var accountid = $("#selectaccountid").val(); var amountpayed = $("#change1").val(); var excess = $("#change2").val(); if (amountpayed > <?php echo $invoice->total_ttc; ?>) { amountpayed = <?php echo $invoice->total_ttc; ?>; } console.log("We click on the payment mode to pay amount = "+amountpayed); parent.$("#poslines").load("invoice.php?place=<?php echo $place; ?>&action=valid&token=<?php echo newToken(); ?>&pay="+payment+"&amount="+amountpayed+"&excess="+excess+"&invoiceid="+invoiceid+"&accountid="+accountid, function() { if (amountpayed > <?php echo $remaintopay; ?> || amountpayed == <?php echo $remaintopay; ?> || amountpayed==0 ) { console.log("Close popup"); parent.$.colorbox.close(); } else { console.log("Amount is not comple, so we do NOT close popup and reload it."); location.reload(); } }); } function fetchPaymentIntentClientSecret(amount, invoiceid) { const bodyContent = JSON.stringify({ amount : amount, invoiceid : invoiceid }); <?php $urlpaymentintent = DOL_URL_ROOT.'/stripe/ajax/ajax.php?action=createPaymentIntent&token='.newToken().'&servicestatus='.$servicestatus; if (!empty($stripeacc)) $urlpaymentintent .= '&stripeacc='.$stripeacc; ?> return fetch('<?php echo $urlpaymentintent; ?>', { method: "POST", headers: { 'Content-Type': 'application/json' }, body: bodyContent }) .then(function(response) { return response.json(); }) .then(function(data) { return data.client_secret; }); } function capturePaymentIntent(paymentIntentId) { const bodyContent = JSON.stringify({"id": paymentIntentId}) <?php $urlpaymentintent = DOL_URL_ROOT.'/stripe/ajax/ajax.php?action=capturePaymentIntent&token='.newToken().'&servicestatus='.urlencode($servicestatus); if (!empty($stripeacc)) { $urlpaymentintent .= '&stripeacc='.urlencode($stripeacc); } ?> return fetch('<?php echo $urlpaymentintent; ?>', { method: "POST", headers: { 'Content-Type': 'application/json' }, body: bodyContent }) .then(function(response) { return response.json(); }) .then(function(data) { return data.client_secret; }); } function ValidateStripeTerminal() { console.log("Launch ValidateStripeTerminal"); var invoiceid = <?php echo($invoiceid > 0 ? $invoiceid : 0); ?>; var accountid = $("#selectaccountid").val(); var amountpayed = $("#change1").val(); var excess = $("#change2").val(); if (amountpayed > <?php echo $invoice->getRemainToPay(); ?>) { amountpayed = <?php echo $invoice->getRemainToPay(); ?>; } if (amountpayed == 0) { amountpayed = <?php echo $invoice->getRemainToPay(); ?>; } console.log("Pay with terminal ", amountpayed); fetchPaymentIntentClientSecret(amountpayed, invoiceid).then(function(client_secret) { <?php if (empty($servicestatus) && !empty($conf->global->STRIPE_TERMINAL_SIMULATED)) { ?> terminal.setSimulatorConfiguration({testCardNumber: '<?php echo $conf->global->STRIPE_TERMINAL_SIMULATED; ?>'}); <?php } ?> document.getElementById("card-present-alert").innerHTML = '<div class="warning clearboth"><?php echo $langs->trans('PaymentSendToStripeTerminal'); ?></div>'; terminal.collectPaymentMethod(client_secret).then(function(result) { if (result.error) { // Placeholder for handling result.error document.getElementById("card-present-alert").innerHTML = '<div class="error clearboth">'+result.error.message+'</div>'; } else { document.getElementById("card-present-alert").innerHTML = '<div class="warning clearboth"><?php echo $langs->trans('PaymentBeingProcessed'); ?></div>'; console.log('terminal.collectPaymentMethod', result.paymentIntent); terminal.processPayment(result.paymentIntent).then(function(result) { if (result.error) { document.getElementById("card-present-alert").innerHTML = '<div class="error clearboth">'+result.error.message+'</div>'; console.log(result.error) } else if (result.paymentIntent) { paymentIntentId = result.paymentIntent.id; console.log('terminal.processPayment', result.paymentIntent); capturePaymentIntent(paymentIntentId).then(function(client_secret) { if (result.error) { // Placeholder for handling result.error document.getElementById("card-present-alert").innerHTML = '<div class="error clearboth">'+result.error.message+'</div>'; console.log("error when capturing paymentIntent", result.error); } else { document.getElementById("card-present-alert").innerHTML = '<div class="warning clearboth"><?php echo $langs->trans('PaymentValidated'); ?></div>'; console.log("Capture paymentIntent successfull "+paymentIntentId); parent.$("#poslines").load("invoice.php?place=<?php echo $place; ?>&action=valid&token=<?php echo newToken(); ?>&pay=CB&amount="+amountpayed+"&excess="+excess+"&invoiceid="+invoiceid+"&accountid="+accountid, function() { if (amountpayed > <?php echo $remaintopay; ?> || amountpayed == <?php echo $remaintopay; ?> || amountpayed==0 ) { console.log("Close popup"); parent.$.colorbox.close(); } else { console.log("Amount is not comple, so we do NOT close popup and reload it."); location.reload(); } }); } }); } }); } }); }); } function ValidateSumup() { console.log("Launch ValidateSumup"); <?php $_SESSION['SMP_CURRENT_PAYMENT'] = "NEW" ?> var invoiceid = <?php echo($invoiceid > 0 ? $invoiceid : 0); ?>; var amountpayed = $("#change1").val(); if (amountpayed > <?php echo $invoice->total_ttc; ?>) { amountpayed = <?php echo $invoice->total_ttc; ?>; } // Starting sumup app window.open('sumupmerchant://pay/1.0?affiliate-key=<?php echo $conf->global->TAKEPOS_SUMUP_AFFILIATE ?>&app-id=<?php echo $conf->global->TAKEPOS_SUMUP_APPID ?>&total=' + amountpayed + '¤cy=EUR&title=' + invoiceid + '&callback=<?php echo DOL_MAIN_URL_ROOT ?>/takepos/smpcb.php'); var loop = window.setInterval(function () { $.ajax({ method: 'POST', data: { token: '<?php echo currentToken(); ?>' }, url: '<?php echo DOL_URL_ROOT ?>/takepos/smpcb.php?status' }).done(function (data) { console.log(data); if (data === "SUCCESS") { parent.$("#poslines").load("invoice.php?place=<?php echo $place; ?>&action=valid&token=<?php echo newToken(); ?>&pay=CB&amount=" + amountpayed + "&invoiceid=" + invoiceid, function () { //parent.$("#poslines").scrollTop(parent.$("#poslines")[0].scrollHeight); parent.$.colorbox.close(); //parent.setFocusOnSearchField(); // This does not have effect }); clearInterval(loop); } else if (data === "FAILED") { parent.$.colorbox.close(); clearInterval(loop); } }); }, 2500); } <?php if (!empty($conf->global->TAKEPOS_CUSTOMER_DISPLAY)) { echo "var line1='".$langs->trans('TotalTTC')."'.substring(0,20);"; echo "line1=line1.padEnd(20);"; echo "var line2='".price($invoice->total_ttc, 1, '', 1, -1, -1)."'.substring(0,20);"; echo "line2=line2.padEnd(20);"; echo "$.ajax({ type: 'GET', data: { text: line1+line2 }, url: '".getDolGlobalString('TAKEPOS_PRINT_SERVER')."/display/index.php', });"; } ?> </script> <div style="position:relative; padding-top: 20px; left:5%; height:140px; width:90%;"> <div class="paymentbordline paymentbordlinetotal center"> <span class="takepospay colorwhite"><?php echo $langs->trans('TotalTTC'); ?>: <span id="totaldisplay" class="colorwhite"><?php echo price($invoice->total_ttc, 1, '', 1, -1, -1, $invoice->multicurrency_code); ?></span></span> </div> <?php if ($remaintopay != $invoice->total_ttc) { ?> <div class="paymentbordline paymentbordlineremain center"> <span class="takepospay colorwhite"><?php echo $langs->trans('RemainToPay'); ?>: <span id="remaintopaydisplay" class="colorwhite"><?php echo price($remaintopay, 1, '', 1, -1, -1, $invoice->multicurrency_code); ?></span></span> </div> <?php } ?> <div class="paymentbordline paymentbordlinereceived center"> <span class="takepospay colorwhite"><?php echo $langs->trans("Received"); ?>: <span class="change1 colorred"><?php echo price(0, 1, '', 1, -1, -1, $invoice->multicurrency_code); ?></span><input type="hidden" id="change1" class="change1" value="0"></span> </div> <div class="paymentbordline paymentbordlinechange center"> <span class="takepospay colorwhite"><?php echo $langs->trans("Change"); ?>: <span class="change2 colorwhite"><?php echo price(0, 1, '', 1, -1, -1, $invoice->multicurrency_code); ?></span><input type="hidden" id="change2" class="change2" value="0"></span> </div> <?php if (!empty($conf->global->TAKEPOS_CAN_FORCE_BANK_ACCOUNT_DURING_PAYMENT)) { require_once DOL_DOCUMENT_ROOT.'/core/class/html.form.class.php'; print '<div class="paymentbordline paddingtop paddingbottom center">'; $filter = ''; $form = new Form($db); print '<span class="takepospay colorwhite">'.$langs->trans("BankAccount").': </span>'; $form->select_comptes(0, 'accountid', 0, $filter, 1, ''); print ajax_combobox('selectaccountid'); print '</div>'; } ?> </div> <div style="position:absolute; left:5%; height:52%; width:90%;"> <?php $action_buttons = array( array( "function" =>"reset()", "span" => "style='font-size: 150%;'", "text" => "C", "class" => "poscolorblue" ), array( "function" => "parent.$.colorbox.close();", "span" => "id='printtext' style='font-weight: bold; font-size: 18pt;'", "text" => "X", "class" => "poscolordelete" ), ); $numpad = $conf->global->TAKEPOS_NUMPAD; if (isModEnabled('stripe') && isset($keyforstripeterminalbank) && !empty($conf->global->STRIPE_CARD_PRESENT)) { print '<span id="card-present-alert">'; dol_htmloutput_mesg($langs->trans('ConnectingToStripeTerminal', 'Stripe'), '', 'warning', 1); print '</span>'; } print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '7' : '10').');">'.($numpad == 0 ? '7' : '10').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '8' : '20').');">'.($numpad == 0 ? '8' : '20').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '9' : '50').');">'.($numpad == 0 ? '9' : '50').'</button>'; ?> <?php if (count($arrayOfValidPaymentModes) > 0) { $paycode = $arrayOfValidPaymentModes[0]->code; $payIcon = ''; if ($paycode == 'LIQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'coins'; } } elseif ($paycode == 'CB') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'credit-card'; } } elseif ($paycode == 'CHQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'money-check'; } } print '<button type="button" class="calcbutton2" onclick="Validate(\''.dol_escape_js($paycode).'\');">'.(!empty($payIcon) ? '<span class="fa fa-2x fa-'.$payIcon.' iconwithlabel"></span><span class="hideonsmartphone"><br>'.$langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[0]->code) : $langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[0]->code)).'</span></button>'; } else { print '<button type="button" class="calcbutton2">'.$langs->trans("NoPaimementModesDefined").'</button>'; } print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '4' : '1').');">'.($numpad == 0 ? '4' : '1').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '5' : '2').');">'.($numpad == 0 ? '5' : '2').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '6' : '5').');">'.($numpad == 0 ? '6' : '5').'</button>'; ?> <?php if (count($arrayOfValidPaymentModes) > 1) { $paycode = $arrayOfValidPaymentModes[1]->code; $payIcon = ''; if ($paycode == 'LIQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'coins'; } } elseif ($paycode == 'CB') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'credit-card'; } } elseif ($paycode == 'CHQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'money-check'; } } print '<button type="button" class="calcbutton2" onclick="Validate(\''.dol_escape_js($paycode).'\');">'.(!empty($payIcon) ? '<span class="fa fa-2x fa-'.$payIcon.' iconwithlabel"></span><br> '.$langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[1]->code) : $langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[1]->code)).'</button>'; } else { $button = array_pop($action_buttons); print '<button type="button" class="calcbutton2" onclick="'.$button["function"].'"><span '.$button["span"].'>'.$button["text"].'</span></button>'; } print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '1' : '0.10').');">'.($numpad == 0 ? '1' : '0.10').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '2' : '0.20').');">'.($numpad == 0 ? '2' : '0.20').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '3' : '0.50').');">'.($numpad == 0 ? '3' : '0.50').'</button>'; ?> <?php if (count($arrayOfValidPaymentModes) > 2) { $paycode = $arrayOfValidPaymentModes[2]->code; $payIcon = ''; if ($paycode == 'LIQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'coins'; } } elseif ($paycode == 'CB') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'credit-card'; } } elseif ($paycode == 'CHQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'money-check'; } } print '<button type="button" class="calcbutton2" onclick="Validate(\''.dol_escape_js($paycode).'\');">'.(!empty($payIcon) ? '<span class="fa fa-2x fa-'.$payIcon.' iconwithlabel"></span><br>'.$langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[2]->code) : $langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[2]->code)).'</button>'; } else { $button = array_pop($action_buttons); print '<button type="button" class="calcbutton2" onclick="'.$button["function"].'"><span '.$button["span"].'>'.$button["text"].'</span></button>'; } print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '0' : '0.01').');">'.($numpad == 0 ? '0' : '0.01').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '\'000\'' : '0.02').');">'.($numpad == 0 ? '000' : '0.02').'</button>'; print '<button type="button" class="calcbutton" onclick="addreceived('.($numpad == 0 ? '\'.\'' : '0.05').');">'.($numpad == 0 ? '.' : '0.05').'</button>'; $i = 3; while ($i < count($arrayOfValidPaymentModes)) { $paycode = $arrayOfValidPaymentModes[$i]->code; $payIcon = ''; if ($paycode == 'LIQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'coins'; } } elseif ($paycode == 'CB') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'credit-card'; } } elseif ($paycode == 'CHQ') { if (!isset($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON) || !empty($conf->global->TAKEPOS_NUMPAD_USE_PAYMENT_ICON)) { $payIcon = 'money-check'; } } print '<button type="button" class="calcbutton2" onclick="Validate(\''.dol_escape_js($paycode).'\');">'.(!empty($payIcon) ? '<span class="fa fa-2x fa-'.$payIcon.' iconwithlabel"></span><br>'.$langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[$i]->code) : $langs->trans("PaymentTypeShort".$arrayOfValidPaymentModes[$i]->code)).'</button>'; $i = $i + 1; } if (isModEnabled('stripe') && isset($keyforstripeterminalbank) && !empty($conf->global->STRIPE_CARD_PRESENT)) { $keyforstripeterminalbank = "CASHDESK_ID_BANKACCOUNT_STRIPETERMINAL".$_SESSION["takeposterminal"]; print '<span id="StripeTerminal"></span>'; if (!empty($conf->global->$keyforstripeterminalbank)) { } else { $langs->loadLangs(array("errors", "admin")); //print '<button type="button" class="calcbutton2 disabled" title="'.$langs->trans("SetupNotComplete").'">TerminalOff</button>'; } } $keyforsumupbank = "CASHDESK_ID_BANKACCOUNT_SUMUP".$_SESSION["takeposterminal"]; if (getDolGlobalInt('TAKEPOS_ENABLE_SUMUP')) { if (!empty($conf->global->$keyforsumupbank)) { print '<button type="button" class="calcbutton2" onclick="ValidateSumup();">Sumup</button>'; } else { $langs->loadLangs(array("errors", "admin")); print '<button type="button" class="calcbutton2 disabled" title="'.$langs->trans("SetupNotComplete").'">Sumup</button>'; } } $parameters = array(); $reshook = $hookmanager->executeHooks('addMoreActionsButtons', $parameters, $invoice, $action); // Note that $action and $object may have been modified by hook if ($reshook < 0) setEventMessages($hookmanager->error, $hookmanager->errors, 'errors'); $class = ($i == 3) ? "calcbutton3" : "calcbutton2"; foreach ($action_buttons as $button) { $newclass = $class.($button["class"] ? " ".$button["class"] : ""); print '<button type="button" class="'.$newclass.'" onclick="'.$button["function"].'"><span '.$button["span"].'>'.$button["text"].'</span></button>'; } if ($conf->global->TAKEPOS_DELAYED_PAYMENT) { print '<button type="button" class="calcbutton2" onclick="Validate(\'delayed\');">'.$langs->trans("Reported").'</button>'; } ?> <?php // Add code from hooks $parameters=array(); $hookmanager->executeHooks('completePayment', $parameters, $invoice); print $hookmanager->resPrint; ?> </div> </body> </html>