27require
'../main.inc.php';
28require_once DOL_DOCUMENT_ROOT.
'/compta/sociales/class/chargesociales.class.php';
29require_once DOL_DOCUMENT_ROOT.
'/compta/sociales/class/paymentsocialcontribution.class.php';
30require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/account.class.php';
33$langs->loadLangs(array(
"banks",
"bills",
"compta"));
36$action =
GETPOST(
'action',
'aZ09');
43if ($user->socid > 0) {
44 $socid = $user->socid;
54if ($action ==
'add_payment' || ($action ==
'confirm_paiement' && $confirm ==
'yes')) {
58 $loc = DOL_URL_ROOT.
'/compta/sociales/card.php?id='.$chid;
59 header(
"Location: ".$loc);
65 if (!(
GETPOST(
"paiementtype") > 0)) {
66 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"PaymentMode")),
null,
'errors');
70 if ($datepaye ==
'') {
71 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Date")),
null,
'errors');
75 if (isModEnabled(
"bank") && !(
GETPOST(
"accountid") > 0)) {
76 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"AccountToCredit")),
null,
'errors');
85 foreach ($_POST as $key => $value) {
86 if (substr($key, 0, 7) ==
'amount_') {
87 $other_chid = substr($key, 7);
92 if (count($amounts) <= 0) {
103 $paiement->chid = $chid;
104 $paiement->datepaye = $datepaye;
105 $paiement->amounts = $amounts;
106 $paiement->paiementtype =
GETPOST(
"paiementtype",
'alphanohtml');
107 $paiement->num_payment =
GETPOST(
"num_payment",
'alphanohtml');
108 $paiement->note =
GETPOST(
"note",
'restricthtml');
109 $paiement->note_private =
GETPOST(
"note",
'restricthtml');
112 $paymentid = $paiement->create($user, (
GETPOST(
'closepaidcontrib') ==
'on' ? 1 : 0));
113 if ($paymentid < 0) {
121 $result = $paiement->addPaymentToBank($user,
'payment_sc',
'(SocialContributionPayment)',
GETPOSTINT(
'accountid'),
'',
'');
122 if (!($result > 0)) {
131 $loc = DOL_URL_ROOT.
'/compta/sociales/card.php?id='.$chid;
132 header(
'Location: '.$loc);
148$form =
new Form($db);
152if ($action ==
'create') {
153 $charge->fetch($chid);
154 $charge->accountid = $charge->fk_account ? $charge->fk_account : $charge->accountid;
155 $charge->paiementtype = $charge->mode_reglement_id ? $charge->mode_reglement_id : $charge->paiementtype;
157 $total = $charge->amount;
158 if (!empty($conf->use_javascript_ajax)) {
159 print
"\n".
'<script type="text/javascript">';
162 print
' $(document).ready(function () {';
163 print
' $(".AutoFillAmount").on(\'click touchstart\', function() {
164 console.log("Click on .AutoFillAmount");
165 var amount = $(this).data("value");
166 document.getElementById($(this).data(\'rowid\')).value = amount ;
170 print
' </script>'.
"\n";
175 print
'<form name="add_payment" action="'.$_SERVER[
'PHP_SELF'].
'" method="POST">';
176 print
'<input type="hidden" name="token" value="'.newToken().
'">';
177 print
'<input type="hidden" name="id" value="'.$chid.
'">';
178 print
'<input type="hidden" name="chid" value="'.$chid.
'">';
179 print
'<input type="hidden" name="action" value="add_payment">';
183 print
'<table class="border centpercent">';
185 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"Ref").
'</td><td><a href="'.DOL_URL_ROOT.
'/compta/sociales/card.php?id='.$chid.
'">'.$chid.
'</a></td></tr>';
186 print
'<tr><td>'.$langs->trans(
"Label").
'</td><td>'.$charge->label.
"</td></tr>\n";
187 print
'<tr><td>'.$langs->trans(
"Type").
"</td><td>".$charge->type_label.
"</td></tr>\n";
188 print
'<tr><td>'.$langs->trans(
"Period").
"</td><td>".
dol_print_date($charge->periode,
'day').
"</td></tr>\n";
192 $sql =
"SELECT sum(p.amount) as total";
193 $sql .=
" FROM ".MAIN_DB_PREFIX.
"paiementcharge as p";
194 $sql .=
" WHERE p.fk_charge = ".((int) $chid);
195 $resql = $db->query($sql);
197 $obj = $db->fetch_object($resql);
198 $sumpaid = $obj->total;
204 print
'<tr><td class="fieldrequired">'.$langs->trans(
"Date").
'</td><td>';
206 $datepayment = !
getDolGlobalString(
'MAIN_AUTOFILL_DATE') ? (GETPOSTISSET(
"remonth") ? $datepaye : -1) :
'';
207 print $form->selectDate($datepayment,
'', 0, 0, 0,
"add_payment", 1, 1, 0,
'',
'', $charge->date_ech,
'', 1, $langs->trans(
"DateOfSocialContribution"));
211 print
'<tr><td class="fieldrequired">'.$langs->trans(
"PaymentMode").
'</td><td>';
212 print
img_picto(
'',
'bank',
'class="pictofixedwidth"');
213 print $form->select_types_paiements(GETPOSTISSET(
"paiementtype") ?
GETPOST(
"paiementtype") : $charge->paiementtype,
"paiementtype",
'', 0, 1, 0, 0, 1,
'maxwidth500 widthcentpercentminusxx', 1);
218 print
'<td class="fieldrequired">'.$langs->trans(
'AccountToDebit').
'</td>';
220 print
img_picto(
'',
'bank_account',
'class="pictofixedwidth"');
221 print $form->select_comptes(GETPOSTISSET(
"accountid") ?
GETPOSTINT(
"accountid") : $charge->accountid,
"accountid", 0,
'', 2,
'', 0,
'maxwidth500 widthcentpercentminusx', 1);
225 print
'<tr><td>'.$langs->trans(
'Numero');
226 if (empty($conf->dol_optimize_smallscreen)) {
227 print
' <em>('.$langs->trans(
"ChequeOrTransferNumber").
')</em>';
230 print
'<td><input name="num_payment" class="width100" type="text" value="'.GETPOST(
'num_payment',
'alphanohtml').
'"></td></tr>'.
"\n";
233 print
'<td class="tdtop">'.$langs->trans(
"Comments").
'</td>';
234 print
'<td class="tdtop"><textarea class="quatrevingtpercent" name="note" wrap="soft" rows="'.ROWS_3.
'">'.
GETPOST(
'note',
'alphanohtml').
'</textarea></td>';
247 print
'<div class="div-table-responsive-no-min">';
248 print
'<table class="noborder centpercent">';
249 print
'<tr class="liste_titre">';
251 print
'<td class="left">'.$langs->trans(
"DateDue").
'</td>';
252 print
'<td class="right">'.$langs->trans(
"Amount").
'</td>';
253 print
'<td class="right">'.$langs->trans(
"AlreadyPaid").
'</td>';
254 print
'<td class="right">'.$langs->trans(
"RemainderToPay").
'</td>';
255 print
'<td class="center">'.$langs->trans(
"Amount").
'</td>';
265 print
'<tr class="oddeven">';
267 if ($objp->date_ech > 0) {
268 print
'<td class="left">'.dol_print_date($objp->date_ech,
'day').
'</td>'.
"\n";
270 print
"<td align=\"center\"><b>!!!</b></td>\n";
273 print
'<td class="right nowraponall"><span class="amount">'.price($objp->amount).
"</span></td>";
275 print
'<td class="right nowraponall"><span class="amount">'.price($sumpaid).
"</span></td>";
277 print
'<td class="right nowraponall"><span class="amount">'.price($objp->amount - $sumpaid).
"</span></td>";
279 print
'<td class="center nowraponall">';
280 if ($sumpaid < $objp->amount) {
281 $namef =
"amount_".$objp->id;
282 $nameRemain =
"remain_".$objp->id;
283 if (!empty($conf->use_javascript_ajax)) {
284 print
img_picto(
"Auto fill",
'rightarrow',
"class='AutoFillAmount' data-rowid='".$namef.
"' data-value='".($objp->amount - $sumpaid).
"'");
286 $remaintopay = $objp->amount - $sumpaid;
287 print
'<input type=hidden class="sum_remain" name="'.$nameRemain.
'" value="'.$remaintopay.
'">';
288 print
'<input type="text" size="8" name="'.$namef.
'" id="'.$namef.
'" value="'.
GETPOST(
'amount_'.$objp->id,
'alpha').
'">';
295 $total += $objp->total;
296 $total_ttc += $objp->total_ttc;
297 $totalrecu += $objp->amount;
302 print
'<tr class="oddeven">';
303 print
'<td colspan="2" class="left">'.$langs->trans(
"Total").
':</td>';
304 print
'<td class="right"><b>'.price($total_ttc).
'</b></td>';
305 print
'<td class="right"><b>'.price($totalrecu).
'</b></td>';
306 print
'<td class="right"><b>'.price($total_ttc - $totalrecu).
'</b></td>';
307 print
'<td align="center"> </td>';
315 print
'<br><div class="center"><input type="checkbox" checked name="closepaidcontrib"> '.$langs->trans(
"ClosePaidContributionsAutomatically");
316 print
'<br><input type="submit" class="button" name="save" value="'.$langs->trans(
'ToMakePayment').
'">';
317 print
' ';
318 print
'<input type="submit" class="button button-cancel" name="cancel" value="'.$langs->trans(
"Cancel").
'">';
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader()
Empty header.
Class for managing the social charges.
Class to manage payments of social contributions.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0)
Set event messages in dol_events session object.
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.