dolibarr 21.0.0-beta
ajaxpayment.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2011 Auguria <anthony.poiret@auguria.net>
3 * Copyright (C) 2024 MDW <mdeweerd@users.noreply.github.com>
4 * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <https://www.gnu.org/licenses/>.
18 */
19
25if (!defined('NOREQUIRESOC')) {
26 define('NOREQUIRESOC', '1');
27}
28if (!defined('NOTOKENRENEWAL')) {
29 define('NOTOKENRENEWAL', '1');
30}
31if (!defined('NOREQUIREMENU')) {
32 define('NOREQUIREMENU', '1'); // If there is no menu to show
33}
34if (!defined('NOREQUIREHTML')) {
35 define('NOREQUIREHTML', '1'); // If we don't need to load the html.form.class.php
36}
37
38// Load Dolibarr environment
39require '../main.inc.php';
40
49$langs->load('compta');
50
51// No permission check. This is just a formatting data service.
52
53
54/*
55 * View
56 */
57
58//init var
59$invoice_type = GETPOSTINT('invoice_type');
60$amountPayment = GETPOST('amountPayment');
61$amounts = GETPOST('amounts'); // from text inputs : invoice amount payment (check required)
62$remains = GETPOST('remains'); // from dolibarr's object (no need to check)
63$currentInvId = GETPOST('imgClicked'); // from DOM elements : imgId (equals invoice id)
64
65// Getting the posted keys=>values, sanitize the ones who are from text inputs
66$amountPayment = $amountPayment != '' ? (is_numeric(price2num($amountPayment)) ? price2num($amountPayment) : '') : ''; // keep void if not a valid entry
67
68// Clean checkamounts
69if (is_array($amounts)) {
70 foreach ($amounts as $key => $value) {
71 $value = price2num($value);
72 $amounts[$key] = $value;
73 if (empty($value)) {
74 unset($amounts[$key]);
75 }
76 }
77}
78// Clean remains
79if (is_array($remains)) {
80 foreach ($remains as $key => $value) {
81 $value = price2num($value);
82 $remains[$key] = ($invoice_type == 2 ? -1 : 1) * (float) $value;
83 if (empty($value)) {
84 unset($remains[$key]);
85 }
86 }
87} elseif ($remains) {
88 $remains = array(price2num($remains));
89} else {
90 $remains = array();
91}
92
93// Treatment
94$result = ($amountPayment != '') ? ((float) $amountPayment - array_sum($amounts)) : array_sum($amounts); // Remaining amountPayment
95$toJsonArray = array();
96$totalRemaining = price2num(array_sum($remains));
97$toJsonArray['label'] = $amountPayment == '' ? '' : $langs->transnoentities('RemainingAmountPayment');
98if ($currentInvId) { // Here to breakdown
99 // Get the current amount (from form) and the corresponding remainToPay (from invoice)
100 $currentAmount = $amounts['amount_'.$currentInvId];
101 $currentRemain = $remains['remain_'.$currentInvId];
102
103 // If amountPayment isn't filled, breakdown invoice amount, else breakdown from amountPayment
104 if ($amountPayment == '') {
105 // Check if current amount exists in amounts
106 $amountExists = array_key_exists('amount_'.$currentInvId, $amounts);
107 if ($amountExists) {
108 $remainAmount = $currentRemain - $currentAmount; // To keep value between curRemain and curAmount
109 $result += $remainAmount; // result must be deduced by
110 $currentAmount += $remainAmount; // curAmount put to curRemain
111 } else {
112 $currentAmount = $currentRemain;
113 $result += $currentRemain;
114 }
115 } else {
116 // Reset the subtraction for this amount
117 $result += price2num($currentAmount);
118 $currentAmount = 0;
119
120 if ($result >= 0) { // then we need to calculate the amount to breakdown
121 $amountToBreakdown = ($result - $currentRemain >= 0 ?
122 $currentRemain : // Remain can be fully paid
123 $currentRemain + ($result - $currentRemain)); // Remain can only partially be paid
124 $currentAmount = $amountToBreakdown; // In both cases, amount will take breakdown value
125 $result -= $amountToBreakdown; // And canceled subtraction has been replaced by breakdown
126 } // else there's no need to calc anything, just reset the field (result is still < 0)
127 }
128 $toJsonArray['amount_'.$currentInvId] = price2num($currentAmount); // Param will exist only if an img has been clicked
129}
130
131$toJsonArray['makeRed'] = ($totalRemaining < price2num($result) || price2num($result) < 0);
132$toJsonArray['result'] = price($result); // Return value to user format
133$toJsonArray['resultnum'] = price2num($result); // Return value to numeric format
134
135// Encode to JSON to return
136echo json_encode($toJsonArray); // Printing the call's result
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
price($amount, $form=0, $outlangs='', $trunc=1, $rounding=-1, $forcerounding=-1, $currency_code='')
Function to format a value into an amount for visual output Function used into PDF and HTML pages.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.