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 /
speed.bdcloud.fr /
admin /
Delete
Unzip
Name
Size
Permission
Date
Action
backup
[ DIR ]
drwxr-xr-x
2025-11-08 11:17
documents
[ DIR ]
drwxrwxr-x
2025-11-08 11:17
dolistore
[ DIR ]
drwxr-xr-x
2025-11-08 11:17
menus
[ DIR ]
drwxr-xr-x
2025-11-08 11:17
system
[ DIR ]
drwxr-xr-x
2025-11-08 11:17
temp
[ DIR ]
drwxr-xr-x
2025-11-08 11:17
tools
[ DIR ]
drwxr-xr-x
2025-11-08 11:17
accountant.php
9
KB
-rw-r--r--
2020-09-02 15:31
agenda.php
7.11
KB
-rw-r--r--
2020-09-02 15:31
agenda_extrafields.php
4.07
KB
-rw-r--r--
2020-09-02 15:31
agenda_extsites.php
8.36
KB
-rw-r--r--
2020-09-02 15:31
agenda_other.php
14.35
KB
-rw-r--r--
2020-09-02 15:31
agenda_reminder.php
7.75
KB
-rw-r--r--
2020-09-02 15:31
agenda_xcal.php
8.62
KB
-rw-r--r--
2020-09-02 15:31
bank.php
18.42
KB
-rw-r--r--
2020-09-02 15:31
bank_extrafields.php
3.28
KB
-rw-r--r--
2020-09-02 15:31
barcode.php
13.36
KB
-rw-r--r--
2020-09-02 15:31
bom.php
17.08
KB
-rw-r--r--
2020-09-02 15:31
boxes.php
16.64
KB
-rw-r--r--
2020-09-02 15:31
chequereceipts.php
9.17
KB
-rw-r--r--
2020-09-02 15:31
clicktodial.php
5.08
KB
-rw-r--r--
2020-09-02 15:31
commande.php
26.71
KB
-rw-r--r--
2020-09-02 15:31
commande_fournisseur_dispatch_extrafields.php
4.19
KB
-rw-r--r--
2020-09-02 15:31
company.php
39.84
KB
-rw-r--r--
2020-09-02 15:31
compta.php
6.71
KB
-rw-r--r--
2020-09-02 15:31
confexped.php
4.43
KB
-rw-r--r--
2020-09-02 15:31
const.php
10.37
KB
-rw-r--r--
2020-09-02 15:31
contract.php
17.07
KB
-rw-r--r--
2020-09-02 15:31
dav.php
6.21
KB
-rw-r--r--
2020-09-02 15:31
debugbar.php
3.63
KB
-rw-r--r--
2020-09-02 15:31
defaultvalues.php
15.81
KB
-rw-r--r--
2020-09-02 15:31
delais.php
15.48
KB
-rw-r--r--
2020-09-02 15:31
dict.php
103.09
KB
-rw-r--r--
2020-09-02 15:31
ecm.php
2.89
KB
-rw-r--r--
2020-09-02 15:31
emailcollector_card.php
27.68
KB
-rw-r--r--
2020-09-02 15:31
emailcollector_list.php
22.46
KB
-rw-r--r--
2020-09-02 15:31
events.php
4.55
KB
-rw-r--r--
2020-09-02 15:31
expedition.php
17.47
KB
-rw-r--r--
2020-09-02 15:31
expedition_extrafields.php
4.11
KB
-rw-r--r--
2020-09-02 15:31
expeditiondet_extrafields.php
4.2
KB
-rw-r--r--
2020-09-02 15:31
expensereport.php
16.49
KB
-rw-r--r--
2020-09-02 15:31
expensereport_extrafields.php
3.99
KB
-rw-r--r--
2020-09-02 15:31
expensereport_ik.php
6.15
KB
-rw-r--r--
2020-09-02 15:31
expensereport_rules.php
11.11
KB
-rw-r--r--
2020-09-02 15:31
export.php
3.52
KB
-rw-r--r--
2020-09-02 15:31
external_rss.php
10.95
KB
-rw-r--r--
2020-09-02 15:31
facture.php
32.26
KB
-rw-r--r--
2020-09-02 15:31
facture_situation.php
7.96
KB
-rw-r--r--
2020-09-02 15:31
fckeditor.php
8.09
KB
-rw-r--r--
2020-09-02 15:31
fichinter.php
21.22
KB
-rw-r--r--
2020-09-02 15:31
geoipmaxmind.php
5.6
KB
-rw-r--r--
2020-09-02 15:31
holiday.php
17.49
KB
-rw-r--r--
2020-09-02 15:31
holiday_extrafields.php
3.96
KB
-rw-r--r--
2020-09-02 15:31
ihm.php
20.57
KB
-rw-r--r--
2020-09-02 15:31
import.php
3.37
KB
-rw-r--r--
2020-09-02 15:31
index.php
4.83
KB
-rw-r--r--
2020-09-02 15:31
ldap.php
12.79
KB
-rw-r--r--
2020-09-02 15:31
ldap_contacts.php
15.03
KB
-rw-r--r--
2020-09-02 15:31
ldap_groups.php
9.72
KB
-rw-r--r--
2020-09-02 15:31
ldap_members.php
19.98
KB
-rw-r--r--
2020-09-02 15:31
ldap_members_types.php
8.8
KB
-rw-r--r--
2020-09-02 15:31
ldap_users.php
21.81
KB
-rw-r--r--
2020-09-02 15:31
limits.php
14.86
KB
-rw-r--r--
2020-09-02 15:31
livraison.php
16.06
KB
-rw-r--r--
2020-09-02 15:31
livraison_extrafields.php
4.11
KB
-rw-r--r--
2020-09-02 15:31
livraisondet_extrafields.php
4.2
KB
-rw-r--r--
2020-09-02 15:31
loan.php
3.21
KB
-rw-r--r--
2020-09-02 15:31
mailing.php
5.39
KB
-rw-r--r--
2020-09-02 15:31
mailman.php
7.98
KB
-rw-r--r--
2020-09-02 15:31
mails.php
38.72
KB
-rw-r--r--
2020-09-02 15:31
mails_emailing.php
25.54
KB
-rw-r--r--
2020-09-02 15:31
mails_senderprofile_list.php
26.84
KB
-rw-r--r--
2020-09-02 15:31
mails_templates.php
46.64
KB
-rw-r--r--
2020-09-02 15:31
menus.php
8.04
KB
-rw-r--r--
2020-09-02 15:31
modulehelp.php
19.19
KB
-rw-r--r--
2020-09-02 15:31
modules.php
47.32
KB
-rw-r--r--
2020-09-02 15:31
mrp.php
17.18
KB
-rw-r--r--
2020-09-02 15:31
multicurrency.php
12.77
KB
-rw-r--r--
2020-09-02 15:31
notification.php
14.83
KB
-rw-r--r--
2020-09-02 15:31
oauth.php
4.79
KB
-rw-r--r--
2020-09-02 15:31
oauthlogintokens.php
14.72
KB
-rw-r--r--
2020-09-02 15:31
openinghours.php
6.44
KB
-rw-r--r--
2020-09-02 15:31
order_extrafields.php
3.99
KB
-rw-r--r--
2020-09-02 15:31
orderdet_extrafields.php
4.07
KB
-rw-r--r--
2020-09-02 15:31
payment.php
10.11
KB
-rw-r--r--
2020-09-02 15:31
paymentbybanktransfer.php
17.89
KB
-rw-r--r--
2020-09-02 15:31
pdf.php
14.64
KB
-rw-r--r--
2020-09-02 15:31
perms.php
7.88
KB
-rw-r--r--
2020-09-02 15:31
prelevement.php
17.86
KB
-rw-r--r--
2020-09-02 15:31
propal.php
25.87
KB
-rw-r--r--
2020-09-02 15:31
proxy.php
6.7
KB
-rw-r--r--
2020-09-02 15:31
receiptprinter.php
17.78
KB
-rw-r--r--
2020-09-02 15:31
reception_extrafields.php
4.1
KB
-rw-r--r--
2020-09-02 15:31
reception_setup.php
17.21
KB
-rw-r--r--
2020-09-02 15:31
resource.php
4.35
KB
-rw-r--r--
2020-09-02 15:31
resource_extrafields.php
3.98
KB
-rw-r--r--
2020-09-02 15:31
security.php
16.45
KB
-rw-r--r--
2020-09-02 15:31
security_file.php
7.04
KB
-rw-r--r--
2020-09-02 15:31
security_other.php
6.34
KB
-rw-r--r--
2020-09-02 15:31
sms.php
11.46
KB
-rw-r--r--
2020-09-02 15:31
socialnetworks.php
3.22
KB
-rw-r--r--
2020-09-02 15:31
spip.php
5.09
KB
-rw-r--r--
2020-09-02 15:31
stock.php
17.71
KB
-rw-r--r--
2020-09-02 15:31
supplier_invoice.php
18.75
KB
-rw-r--r--
2020-09-02 15:31
supplier_order.php
21.49
KB
-rw-r--r--
2020-09-02 15:31
supplier_payment.php
16.64
KB
-rw-r--r--
2020-09-02 15:31
supplier_proposal.php
20.6
KB
-rw-r--r--
2020-09-02 15:31
supplierinvoice_extrafields.php
4.14
KB
-rw-r--r--
2020-09-02 15:31
supplierinvoicedet_extrafields.php
4.19
KB
-rw-r--r--
2020-09-02 15:31
supplierorder_extrafields.php
4.04
KB
-rw-r--r--
2020-09-02 15:31
supplierorderdet_extrafields.php
4.14
KB
-rw-r--r--
2020-09-02 15:31
syslog.php
10.16
KB
-rw-r--r--
2020-09-02 15:31
taxes.php
8.77
KB
-rw-r--r--
2020-09-02 15:31
ticket.php
14.28
KB
-rw-r--r--
2020-09-02 15:31
ticket_extrafields.php
3.74
KB
-rw-r--r--
2020-09-02 15:31
ticket_public.php
15.61
KB
-rw-r--r--
2020-09-02 15:31
translation.php
23.03
KB
-rw-r--r--
2020-09-02 15:31
triggers.php
2.74
KB
-rw-r--r--
2020-09-02 15:31
user.php
11.86
KB
-rw-r--r--
2020-09-02 15:31
usergroup.php
9.94
KB
-rw-r--r--
2020-09-02 15:31
website.php
23.57
KB
-rw-r--r--
2020-09-02 15:31
website_options.php
4.72
KB
-rw-r--r--
2020-09-02 15:31
workflow.php
7.43
KB
-rw-r--r--
2020-09-02 15:31
Save
Rename
<?php /* Copyright (C) 2007-2012 Laurent Destailleur <eldy@users.sourceforge.net> * Copyright (C) 2009-2018 Regis Houssin <regis.houssin@inodbox.com> * Copyright (C) 2010 Juanjo Menent <jmenent@2byte.es> * * 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/admin/limits.php * \brief Page to setup limits */ require '../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/price.lib.php'; // Load translation files required by the page $langs->loadLangs(array('companies', 'products', 'admin')); if (!$user->admin) accessforbidden(); $action = GETPOST('action', 'alpha'); $currencycode = GETPOST('currencycode', 'alpha'); $mainmaxdecimalsunit = 'MAIN_MAX_DECIMALS_UNIT'.(!empty($currencycode) ? '_'.$currencycode : ''); $mainmaxdecimalstot = 'MAIN_MAX_DECIMALS_TOT'.(!empty($currencycode) ? '_'.$currencycode : ''); $mainmaxdecimalsshown = 'MAIN_MAX_DECIMALS_SHOWN'.(!empty($currencycode) ? '_'.$currencycode : ''); $mainroundingruletot = 'MAIN_ROUNDING_RULE_TOT'.(!empty($currencycode) ? '_'.$currencycode : ''); if ($action == 'update') { $error = 0; $MAXDEC = 8; if ($_POST[$mainmaxdecimalsunit] > $MAXDEC || $_POST[$mainmaxdecimalstot] > $MAXDEC || $_POST[$mainmaxdecimalsshown] > $MAXDEC) { $error++; setEventMessages($langs->trans("ErrorDecimalLargerThanAreForbidden", $MAXDEC), null, 'errors'); } if ($_POST[$mainmaxdecimalsunit].(!empty($currencycode) ? '_'.$currencycode : '') < 0 || $_POST[$mainmaxdecimalstot] < 0 || $_POST[$mainmaxdecimalsshown] < 0) { $langs->load("errors"); $error++; setEventMessages($langs->trans("ErrorNegativeValueNotAllowed"), null, 'errors'); } if ($_POST[$mainroundingruletot]) { if ($_POST[$mainroundingruletot] * pow(10, $_POST[$mainmaxdecimalstot]) < 1) { $langs->load("errors"); $error++; setEventMessages($langs->trans("ErrorMAIN_ROUNDING_RULE_TOTCanMAIN_MAX_DECIMALS_TOT"), null, 'errors'); } } if (!$error) { dolibarr_set_const($db, $mainmaxdecimalsunit, $_POST[$mainmaxdecimalsunit], 'chaine', 0, '', $conf->entity); dolibarr_set_const($db, $mainmaxdecimalstot, $_POST[$mainmaxdecimalstot], 'chaine', 0, '', $conf->entity); dolibarr_set_const($db, $mainmaxdecimalsshown, $_POST[$mainmaxdecimalsshown], 'chaine', 0, '', $conf->entity); dolibarr_set_const($db, $mainroundingruletot, $_POST[$mainroundingruletot], 'chaine', 0, '', $conf->entity); header("Location: ".$_SERVER["PHP_SELF"]."?mainmenu=home&leftmenu=setup".(!empty($currencycode) ? '¤cycode='.$currencycode : '')); exit; } } /* * View */ $form = new Form($db); llxHeader(); print load_fiche_titre($langs->trans("LimitsSetup"), '', 'title_setup'); $currencycode = (!empty($currencycode) ? $currencycode : $conf->currency); $aCurrencies = array($conf->currency); // Default currency always first position if (!empty($conf->multicurrency->enabled) && !empty($conf->global->MULTICURRENCY_USE_LIMIT_BY_CURRENCY)) { require_once DOL_DOCUMENT_ROOT.'/core/lib/multicurrency.lib.php'; $sql = 'SELECT rowid, code FROM '.MAIN_DB_PREFIX.'multicurrency'; $sql .= ' WHERE entity = '.$conf->entity; $sql .= ' AND code != "'.$conf->currency.'"'; // Default currency always first position $resql = $db->query($sql); if ($resql) { while ($obj = $db->fetch_object($resql)) { $aCurrencies[] = $obj->code; } } if (!empty($aCurrencies) && count($aCurrencies) > 1) { $head = multicurrencyLimitPrepareHead($aCurrencies); dol_fiche_head($head, $currencycode, '', -1, "multicurrency"); } } print '<span class="opacitymedium">'.$langs->trans("LimitsDesc")."</span><br>\n"; print "<br>\n"; if ($action == 'edit') { print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'">'; print '<input type="hidden" name="token" value="'.newToken().'">'; print '<input type="hidden" name="action" value="update">'; if (!empty($conf->multicurrency->enabled) && !empty($conf->global->MULTICURRENCY_USE_LIMIT_BY_CURRENCY)) { print '<input type="hidden" name="currencycode" value="'.$currencycode.'">'; } clearstatcache(); print '<table class="noborder centpercent">'; print '<tr class="liste_titre"><td>'.$langs->trans("Parameters").'</td><td>'.$langs->trans("Value").'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_UNIT"), $langs->trans("ParameterActiveForNextInputOnly")); print '</td><td><input class="flat" name="'.$mainmaxdecimalsunit.'" size="3" value="'.(isset($conf->global->$mainmaxdecimalsunit) ? $conf->global->$mainmaxdecimalsunit : $conf->global->MAIN_MAX_DECIMALS_UNIT).'"></td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_TOT"), $langs->trans("ParameterActiveForNextInputOnly")); print '</td><td><input class="flat" name="'.$mainmaxdecimalstot.'" size="3" value="'.(isset($conf->global->$mainmaxdecimalstot) ? $conf->global->$mainmaxdecimalstot : $conf->global->MAIN_MAX_DECIMALS_TOT).'"></td></tr>'; print '<tr class="oddeven"><td>'.$langs->trans("MAIN_MAX_DECIMALS_SHOWN").'</td>'; print '<td><input class="flat" name="'.$mainmaxdecimalsshown.'" size="3" value="'.(isset($conf->global->$mainmaxdecimalsshown) ? $conf->global->$mainmaxdecimalsshown : $conf->global->MAIN_MAX_DECIMALS_SHOWN).'"></td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_ROUNDING_RULE_TOT"), $langs->trans("ParameterActiveForNextInputOnly")); print '</td><td><input class="flat" name="'.$mainroundingruletot.'" size="3" value="'.(isset($conf->global->$mainroundingruletot) ? $conf->global->$mainroundingruletot : $conf->global->MAIN_ROUNDING_RULE_TOT).'"></td></tr>'; print '</table>'; print '<br>'; print '<div class="center">'; print '<input class="button" type="submit" value="'.$langs->trans("Save").'">'; print '</div>'; print '<br>'; print '</form>'; print '<br>'; } else { print '<table class="noborder centpercent">'; print '<tr class="liste_titre"><td>'.$langs->trans("Parameter").'</td><td>'.$langs->trans("Value").'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_UNIT"), $langs->trans("ParameterActiveForNextInputOnly")); print '</td><td align="right">'.(isset($conf->global->$mainmaxdecimalsunit) ? $conf->global->$mainmaxdecimalsunit : $conf->global->MAIN_MAX_DECIMALS_UNIT).'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_TOT"), $langs->trans("ParameterActiveForNextInputOnly")); print '</td><td align="right">'.(isset($conf->global->$mainmaxdecimalstot) ? $conf->global->$mainmaxdecimalstot : $conf->global->MAIN_MAX_DECIMALS_TOT).'</td></tr>'; print '<tr class="oddeven"><td>'.$langs->trans("MAIN_MAX_DECIMALS_SHOWN").'</td>'; print '<td align="right">'.(isset($conf->global->$mainmaxdecimalsshown) ? $conf->global->$mainmaxdecimalsshown : $conf->global->MAIN_MAX_DECIMALS_SHOWN).'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_ROUNDING_RULE_TOT"), $langs->trans("ParameterActiveForNextInputOnly")); print '</td><td align="right">'.(isset($conf->global->$mainroundingruletot) ? $conf->global->$mainroundingruletot : $conf->global->MAIN_ROUNDING_RULE_TOT).'</td></tr>'; print '</table>'; print '<div class="tabsAction">'; print '<a class="butAction" href="'.$_SERVER["PHP_SELF"].'?action=edit'.(!empty($currencycode) ? '¤cycode='.$currencycode : '').'">'.$langs->trans("Modify").'</a>'; print '</div>'; } if (!empty($conf->multicurrency->enabled) && !empty($conf->global->MULTICURRENCY_USE_LIMIT_BY_CURRENCY)) { if (!empty($aCurrencies) && count($aCurrencies) > 1) { dol_fiche_end(); } } if (empty($mysoc->country_code)) { $langs->load("errors"); $warnpicto = img_warning($langs->trans("WarningMandatorySetupNotComplete")); print '<br><a href="'.DOL_URL_ROOT.'/admin/company.php?mainmenu=home">'.$warnpicto.' '.$langs->trans("WarningMandatorySetupNotComplete").'</a>'; } else { // Show examples print load_fiche_titre($langs->trans("ExamplesWithCurrentSetup"), '', ''); print '<span class="opacitymedium">'.$langs->trans("Format").':</span> '.price(price2num(1234.56789, 'MT'), 0, $langs, 1, -1, -1, $currencycode)."<br>\n"; // Always show vat rates with vat 0 $s = 2 / 7; $qty = 1; $vat = 0; $tmparray = calcul_price_total(1, $qty * price2num($s, 'MU'), 0, $vat, 0, 0, 0, 'HT', 0, 0, $mysoc); print '<span class="opacitymedium">'.$langs->trans("UnitPriceOfProduct").":</span> ".price2num($s, 'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print ' -> <span class="opacitymedium">'.$langs->trans("TotalPriceAfterRounding").":</span> ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; $s = 10 / 3; $qty = 1; $vat = 0; $tmparray = calcul_price_total(1, $qty * price2num($s, 'MU'), 0, $vat, 0, 0, 0, 'HT', 0, 0, $mysoc); print '<span class="opacitymedium">'.$langs->trans("UnitPriceOfProduct").":</span> ".price2num($s, 'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print ' -> <span class="opacitymedium">'.$langs->trans("TotalPriceAfterRounding").":</span> ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; $s = 10 / 3; $qty = 2; $vat = 0; $tmparray = calcul_price_total(1, $qty * price2num($s, 'MU'), 0, $vat, 0, 0, 0, 'HT', 0, 0, $mysoc); print '<span class="opacitymedium">'.$langs->trans("UnitPriceOfProduct").":</span> ".price2num($s, 'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print ' -> <span class="opacitymedium">'.$langs->trans("TotalPriceAfterRounding").":</span> ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; // Add vat rates examples specific to country $vat_rates = array(); $sql = "SELECT taux as vat_rate"; $sql .= " FROM ".MAIN_DB_PREFIX."c_tva as t, ".MAIN_DB_PREFIX."c_country as c"; $sql .= " WHERE t.active=1 AND t.fk_pays = c.rowid AND c.code='".$mysoc->country_code."' AND t.taux <> 0"; $sql .= " ORDER BY t.taux ASC"; $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); if ($num) { for ($i = 0; $i < $num; $i++) { $obj = $db->fetch_object($resql); $vat_rates[$i] = $obj->vat_rate; } } } else dol_print_error($db); if (count($vat_rates)) { foreach ($vat_rates as $vat) { for ($qty = 1; $qty <= 2; $qty++) { $s = 10 / 3; $tmparray = calcul_price_total(1, $qty * price2num($s, 'MU'), 0, $vat, 0, 0, 0, 'HT', 0, 0, $mysoc); print '<span class="opacitymedium">'.$langs->trans("UnitPriceOfProduct").":</span> ".price2num($s, 'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print ' -> <span class="opacitymedium">'.$langs->trans("TotalPriceAfterRounding").":</span> ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; } } } else { // More examples if not specific vat rate found // This example must be kept for test purpose with current value because value used (2/7, 10/3, and vat 0, 10) // were calculated to show all possible cases of rounding. If we change this, examples becomes useless or show the same rounding rule. $s = 10 / 3; $qty = 1; $vat = 10; $tmparray = calcul_price_total(1, $qty * price2num($s, 'MU'), 0, $vat, 0, 0, 0, 'HT', 0, 0, $mysoc); print '<span class="opacitymedium">'.$langs->trans("UnitPriceOfProduct").":</span> ".price2num($s, 'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print ' -> <span class="opacitymedium">'.$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; $s = 10 / 3; $qty = 2; $vat = 10; $tmparray = calcul_price_total(1, $qty * price2num($s, 'MU'), 0, $vat, 0, 0, 0, 'HT', 0, 0, $mysoc); print '<span class="opacitymedium">'.$langs->trans("UnitPriceOfProduct").":</span> ".price2num($s, 'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print ' -> <span class="opacitymedium">'.$langs->trans("TotalPriceAfterRounding").":</span> ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; } // Important: can debug rounding, to simulate the rounded total /* print '<br><b>'.$langs->trans("VATRoundedByLine").' ('.$langs->trans("DolibarrDefault").')</b><br>'; foreach($vat_rates as $vat) { for ($qty=1; $qty<=2; $qty++) { $s1=10/3; $s2=2/7; // Round by line $tmparray1=calcul_price_total(1,$qty*price2num($s1,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); $tmparray2=calcul_price_total(1,$qty*price2num($s2,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); $total_ht = $tmparray1[0] + $tmparray2[0]; $total_tva = $tmparray1[1] + $tmparray2[1]; $total_ttc = $tmparray1[2] + $tmparray2[2]; print $langs->trans("UnitPriceOfProduct").": ".(price2num($s1,'MU') + price2num($s2,'MU')); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$total_ht.' / '.$total_tva.' / '.$total_ttc."<br>\n"; } } print '<br><b>'.$langs->trans("VATRoundedOnTotal").'</b><br>'; foreach($vat_rates as $vat) { for ($qty=1; $qty<=2; $qty++) { $s1=10/3; $s2=2/7; // Global round $subtotal_ht = (($qty*price2num($s1,'MU')) + ($qty*price2num($s2,'MU'))); $tmparray3=calcul_price_total(1,$subtotal_ht,0,$vat,0,0,0,'HT',0, 0,$mysoc); $total_ht = $tmparray3[0]; $total_tva = $tmparray3[1]; $total_ttc = $tmparray3[2]; print $langs->trans("UnitPriceOfProduct").": ".price2num($s1+$s2,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$total_ht.' / '.$total_tva.' / '.$total_ttc."<br>\n"; } } */ } // End of page llxFooter(); $db->close();