dolibarr  x.y.z
card.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2007-2019 Laurent Destailleur <eldy@users.sourceforge.net>
3  * Copyright (C) 2018-2020 Frédéric France <frederic.france@netlogic.fr>
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program. If not, see <https://www.gnu.org/licenses/>.
17  */
18 
25 // Load Dolibarr environment
26 require '../../main.inc.php';
27 require_once DOL_DOCUMENT_ROOT.'/core/lib/member.lib.php';
28 require_once DOL_DOCUMENT_ROOT.'/adherents/class/adherent.class.php';
29 require_once DOL_DOCUMENT_ROOT.'/adherents/class/adherent_type.class.php';
30 require_once DOL_DOCUMENT_ROOT.'/adherents/class/subscription.class.php';
31 if (isModEnabled("banque")) {
32  require_once DOL_DOCUMENT_ROOT.'/compta/bank/class/account.class.php';
33 }
34 
35 // Load translation files required by the page
36 $langs->loadLangs(array("companies", "members", "bills", "users"));
37 
38 $adh = new Adherent($db);
39 $adht = new AdherentType($db);
40 $object = new Subscription($db);
41 $errmsg = '';
42 
43 $action = GETPOST("action", 'alpha');
44 $rowid = GETPOST("rowid", "int") ? GETPOST("rowid", "int") : GETPOST("id", "int");
45 $typeid = GETPOST("typeid", "int");
46 $cancel = GETPOST('cancel', 'alpha');
47 $confirm = GETPOST('confirm');
48 $note = GETPOST('note', 'alpha');
49 $typeid = (int) GETPOST('typeid', 'int');
50 $amount = price2num(GETPOST('amount', 'alpha'), 'MT');
51 
52 if (!$user->hasRight('adherent', 'cotisation', 'lire')) {
54 }
55 
56 $permissionnote = $user->hasRight('adherent', 'cotisation', 'creer'); // Used by the include of actions_setnotes.inc.php
57 $permissiondellink = $user->hasRight('adherent', 'cotisation', 'creer'); // Used by the include of actions_dellink.inc.php
58 $permissiontoedit = $user->hasRight('adherent', 'cotisation', 'creer'); // Used by the include of actions_lineupdonw.inc.php
59 
60 $hookmanager->initHooks(array('subscriptioncard', 'globalcard'));
61 
62 // Security check
63 $result = restrictedArea($user, 'subscription', 0); // TODO Check on object id
64 
65 
66 /*
67  * Actions
68  */
69 
70 if ($cancel) {
71  $action = '';
72 }
73 
74 //include DOL_DOCUMENT_ROOT.'/core/actions_setnotes.inc.php'; // Must be include, not include_once
75 
76 include DOL_DOCUMENT_ROOT.'/core/actions_dellink.inc.php'; // Must be include, not include_once
77 
78 //include DOL_DOCUMENT_ROOT.'/core/actions_lineupdown.inc.php'; // Must be include, not include_once
79 
80 
81 if ($user->hasRight('adherent', 'cotisation', 'creer') && $action == 'update' && !$cancel) {
82  // Load current object
83  $result = $object->fetch($rowid);
84  if ($result > 0) {
85  $db->begin();
86 
87  $errmsg = '';
88 
89  if ($object->fk_bank) {
90  $accountline = new AccountLine($db);
91  $result = $accountline->fetch($object->fk_bank);
92 
93  // If transaction consolidated
94  if ($accountline->rappro) {
95  $errmsg = $langs->trans("SubscriptionLinkedToConciliatedTransaction");
96  } else {
97  $accountline->datev = dol_mktime(GETPOST('datesubhour', 'int'), GETPOST('datesubmin', 'int'), 0, GETPOST('datesubmonth', 'int'), GETPOST('datesubday', 'int'), GETPOST('datesubyear', 'int'));
98  $accountline->dateo = dol_mktime(GETPOST('datesubhour', 'int'), GETPOST('datesubmin', 'int'), 0, GETPOST('datesubmonth', 'int'), GETPOST('datesubday', 'int'), GETPOST('datesubyear', 'int'));
99  $accountline->amount = $amount;
100  $result = $accountline->update($user);
101  if ($result < 0) {
102  $errmsg = $accountline->error;
103  }
104  }
105  }
106 
107  if (!$errmsg) {
108  // Modify values
109  $object->dateh = dol_mktime(GETPOST('datesubhour', 'int'), GETPOST('datesubmin', 'int'), 0, GETPOST('datesubmonth', 'int'), GETPOST('datesubday', 'int'), GETPOST('datesubyear', 'int'));
110  $object->datef = dol_mktime(GETPOST('datesubendhour', 'int'), GETPOST('datesubendmin', 'int'), 0, GETPOST('datesubendmonth', 'int'), GETPOST('datesubendday', 'int'), GETPOST('datesubendyear', 'int'));
111  $object->fk_type = $typeid;
112  $object->note_public = $note;
113  $object->note_private = $note;
114 
115  $object->amount = $amount;
116 
117  $result = $object->update($user);
118  if ($result >= 0 && !count($object->errors)) {
119  $db->commit();
120 
121  header("Location: card.php?rowid=".$object->id);
122  exit;
123  } else {
124  $db->rollback();
125 
126  if ($object->error) {
127  $errmsg = $object->error;
128  } else {
129  foreach ($object->errors as $error) {
130  if ($errmsg) {
131  $errmsg .= '<br>';
132  }
133  $errmsg .= $error;
134  }
135  }
136  $action = '';
137  }
138  } else {
139  $db->rollback();
140  }
141  }
142 }
143 
144 if ($action == 'confirm_delete' && $confirm == 'yes' && $user->hasRight('adherent', 'cotisation', 'creer')) {
145  $result = $object->fetch($rowid);
146  $result = $object->delete($user);
147  if ($result > 0) {
148  header("Location: ".DOL_URL_ROOT."/adherents/card.php?rowid=".$object->fk_adherent);
149  exit;
150  } else {
151  $mesg = $adh->error;
152  }
153 }
154 
155 
156 
157 /*
158  * View
159  */
160 
161 $form = new Form($db);
162 
163 $help_url = 'EN:Module_Foundations|FR:Module_Adh&eacute;rents|ES:M&oacute;dulo_Miembros';
164 llxHeader('', $langs->trans("SubscriptionCard"), $help_url);
165 
166 
167 dol_htmloutput_errors($errmsg);
168 
169 
170 if ($user->hasRight('adherent', 'cotisation', 'creer') && $action == 'edit') {
171  /********************************************
172  *
173  * Subscription card in edit mode
174  *
175  ********************************************/
176 
177  $object->fetch($rowid);
178  $result = $adh->fetch($object->fk_adherent);
179 
180  $head = subscription_prepare_head($object);
181 
182  print '<form name="update" action="'.$_SERVER["PHP_SELF"].'" method="post">';
183  print '<input type="hidden" name="token" value="'.newToken().'">';
184  print "<input type=\"hidden\" name=\"action\" value=\"update\">";
185  print "<input type=\"hidden\" name=\"rowid\" value=\"$rowid\">";
186  print "<input type=\"hidden\" name=\"fk_bank\" value=\"".$object->fk_bank."\">";
187 
188  print dol_get_fiche_head($head, 'general', $langs->trans("Subscription"), 0, 'payment');
189 
190  $linkback = '<a href="'.DOL_URL_ROOT.'/adherents/subscription/list.php?restore_lastsearch_values=1">'.$langs->trans("BackToList").'</a>';
191 
192  print "\n";
193  print '<table class="border centpercent">';
194 
195  // Ref
196  print '<tr><td class="titlefieldcreate">'.$langs->trans("Ref").'</td>';
197  print '<td class="valeur" colspan="3">';
198  print $form->showrefnav($object, 'rowid', $linkback, 1);
199  print '</td></tr>';
200 
201  // Member
202  $adh->ref = $adh->getFullName($langs);
203  print '<tr>';
204  print '<td>'.$langs->trans("Member").'</td><td class="valeur" colspan="3">'.$adh->getNomUrl(1, 0, 'subscription').'</td>';
205  print '</tr>';
206 
207  // Type
208  print '<tr>';
209  print '<td>'.$langs->trans("Type").'</td><td class="valeur" colspan="3">';
210  print $form->selectarray("typeid", $adht->liste_array(), (GETPOSTISSET("typeid") ? GETPOST("typeid") : $object->fk_type));
211  print'</td></tr>';
212 
213  // Date start subscription
214  print '<tr><td>'.$langs->trans("DateSubscription").'</td><td class="valeur" colspan="2">';
215  print $form->selectDate($object->dateh, 'datesub', 1, 1, 0, 'update', 1);
216  print '</td>';
217  print '</tr>';
218 
219  // Date end subscription
220  print '<tr><td>'.$langs->trans("DateEndSubscription").'</td><td class="valeur" colspan="2">';
221  print $form->selectDate($object->datef, 'datesubend', 0, 0, 0, 'update', 1);
222  print '</td>';
223  print '</tr>';
224 
225  // Amount
226  print '<tr><td>'.$langs->trans("Amount").'</td><td class="valeur" colspan="2">';
227  print '<input type="text" class="flat" size="10" name="amount" value="'.price($object->amount).'"></td></tr>';
228 
229  // Label
230  print '<tr><td>'.$langs->trans("Label").'</td><td class="valeur" colspan="2">';
231  print '<input type="text" class="flat" size="60" name="note" value="'.$object->note.'"></td></tr>';
232 
233  // Bank line
234  if (isModEnabled("banque") && (!empty($conf->global->ADHERENT_BANK_USE) || $object->fk_bank)) {
235  print '<tr><td>'.$langs->trans("BankTransactionLine").'</td><td class="valeur" colspan="2">';
236  if ($object->fk_bank) {
237  $bankline = new AccountLine($db);
238  $result = $bankline->fetch($object->fk_bank);
239  print $bankline->getNomUrl(1, 0, 'showall');
240  } else {
241  print $langs->trans("NoneF");
242  }
243  print '</td></tr>';
244  }
245 
246  print '</table>';
247 
248  print dol_get_fiche_end();
249 
250  print $form->buttonsSaveCancel();
251 
252  print '</form>';
253  print "\n";
254 }
255 
256 if ($rowid && $action != 'edit') {
257  /********************************************
258  *
259  * Subscription card in view mode
260  *
261  ********************************************/
262 
263  $result = $object->fetch($rowid);
264  $result = $adh->fetch($object->fk_adherent);
265 
266  $head = subscription_prepare_head($object);
267 
268  print dol_get_fiche_head($head, 'general', $langs->trans("Subscription"), -1, 'payment');
269 
270  // Confirmation to delete subscription
271  if ($action == 'delete') {
272  $formquestion=array();
273  //$formquestion['text']='<b>'.$langs->trans("ThisWillAlsoDeleteBankRecord").'</b>';
274  $text = $langs->trans("ConfirmDeleteSubscription");
275  if (isModEnabled("banque") && !empty($conf->global->ADHERENT_BANK_USE)) {
276  $text .= '<br>'.img_warning().' '.$langs->trans("ThisWillAlsoDeleteBankRecord");
277  }
278  print $form->formconfirm($_SERVER["PHP_SELF"]."?rowid=".$object->id, $langs->trans("DeleteSubscription"), $text, "confirm_delete", $formquestion, 0, 1);
279  }
280 
281  print '<form action="'.$_SERVER["PHP_SELF"].'" method="post">';
282  print '<input type="hidden" name="token" value="'.newToken().'">';
283 
284  $linkback = '<a href="'.DOL_URL_ROOT.'/adherents/subscription/list.php?restore_lastsearch_values=1">'.$langs->trans("BackToList").'</a>';
285 
286  dol_banner_tab($object, 'rowid', $linkback, 1);
287 
288  print '<div class="fichecenter">';
289 
290  print '<div class="underbanner clearboth"></div>';
291 
292  print '<table class="border centpercent tableforfield">';
293 
294  // Member
295  $adh->ref = $adh->getFullName($langs);
296  print '<tr>';
297  print '<td class="titlefield">'.$langs->trans("Member").'</td><td class="valeur">'.$adh->getNomUrl(1, 0, 'subscription').'</td>';
298  print '</tr>';
299 
300  // Type
301  print '<tr>';
302  print '<td class="titlefield">'.$langs->trans("Type").'</td>';
303  print '<td class="valeur">';
304  if ($object->fk_type > 0 || $adh->typeid > 0) {
305  $typeid = ($object->fk_type > 0 ? $object->fk_type : $adh->typeid);
306  $adht->fetch($typeid);
307  print $adht->getNomUrl(1);
308  } else {
309  print $langs->trans("NoType");
310  }
311  print '</td></tr>';
312 
313  // Date subscription
314  print '<tr>';
315  print '<td>'.$langs->trans("DateSubscription").'</td><td class="valeur">'.dol_print_date($object->dateh, 'day').'</td>';
316  print '</tr>';
317 
318  // Date end subscription
319  print '<tr>';
320  print '<td>'.$langs->trans("DateEndSubscription").'</td><td class="valeur">'.dol_print_date($object->datef, 'day').'</td>';
321  print '</tr>';
322 
323  // Amount
324  print '<tr><td>'.$langs->trans("Amount").'</td><td class="valeur"><span class="amount">'.price($object->amount).'</span></td></tr>';
325 
326  // Label
327  print '<tr><td>'.$langs->trans("Label").'</td><td class="valeur">'.$object->note.'</td></tr>';
328 
329  // Bank line
330  if (isModEnabled("banque") && (!empty($conf->global->ADHERENT_BANK_USE) || $object->fk_bank)) {
331  print '<tr><td>'.$langs->trans("BankTransactionLine").'</td><td class="valeur">';
332  if ($object->fk_bank) {
333  $bankline = new AccountLine($db);
334  $result = $bankline->fetch($object->fk_bank);
335  print $bankline->getNomUrl(1, 0, 'showall');
336  } else {
337  print $langs->trans("NoneF");
338  }
339  print '</td></tr>';
340  }
341 
342  print "</table>\n";
343  print '</div>';
344 
345  print '</form>';
346 
347  print dol_get_fiche_end();
348 
349  /*
350  * Action bar
351  */
352  print '<div class="tabsAction">';
353 
354  if ($user->hasRight('adherent', 'cotisation', 'creer')) {
355  if (!empty($bankline->rappro)) {
356  print '<div class="inline-block divButAction"><a class="butAction" href="'.$_SERVER["PHP_SELF"]."?rowid=".$object->id.'&action=edit&token='.newToken().'">'.$langs->trans("Modify")."</a></div>";
357  } else {
358  print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" title="'.$langs->trans("BankLineConciliated")."\" href=\"#\">".$langs->trans("Modify")."</a></div>";
359  }
360  }
361 
362  // Delete
363  if ($user->hasRight('adherent', 'cotisation', 'creer')) {
364  print '<div class="inline-block divButAction"><a class="butActionDelete" href="'.$_SERVER["PHP_SELF"]."?rowid=".$object->id.'&action=delete&token='.newToken().'">'.$langs->trans("Delete")."</a></div>\n";
365  }
366 
367  print '</div>';
368 
369 
370  print '<div class="fichecenter"><div class="fichehalfleft">';
371  print '<a name="builddoc"></a>'; // ancre
372 
373  // Generated documents
374  /*
375  $filename = dol_sanitizeFileName($object->ref);
376  $filedir = $conf->facture->dir_output . '/' . dol_sanitizeFileName($object->ref);
377  $urlsource = $_SERVER['PHP_SELF'] . '?facid=' . $object->id;
378  $genallowed = $user->rights->facture->lire;
379  $delallowed = $user->rights->facture->creer;
380 
381  print $formfile->showdocuments('facture', $filename, $filedir, $urlsource, $genallowed, $delallowed, $object->model_pdf, 1, 0, 0, 28, 0, '', '', '', $soc->default_lang);
382  $somethingshown = $formfile->numoffiles;
383  */
384  // Show links to link elements
385  //$linktoelem = $form->showLinkToObjectBlock($object, null, array('subscription'));
386  $somethingshown = $form->showLinkedObjectBlock($object, '');
387 
388  // Show links to link elements
389  /*$linktoelem = $form->showLinkToObjectBlock($object,array('order'));
390  if ($linktoelem) print ($somethingshown?'':'<br>').$linktoelem;
391  */
392 
393  print '</div><div class="fichehalfright">';
394 
395  // List of actions on element
396  /*
397  include_once DOL_DOCUMENT_ROOT . '/core/class/html.formactions.class.php';
398  $formactions = new FormActions($db);
399  $somethingshown = $formactions->showactions($object, $object->element, $socid, 1);
400  */
401 
402  print '</div></div>';
403 }
404 
405 // End of page
406 llxFooter();
407 $db->close();
if(GETPOST('button_removefilter_x', 'alpha')||GETPOST('button_removefilter.x', 'alpha')||GETPOST('button_removefilter', 'alpha')) if(GETPOST('button_search_x', 'alpha')||GETPOST('button_search.x', 'alpha')||GETPOST('button_search', 'alpha')) if($action=="save" &&empty($cancel)) $help_url
View.
Definition: agenda.php:118
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
Definition: wrapper.php:56
llxFooter()
Empty footer.
Definition: wrapper.php:70
Class to manage bank transaction lines.
Class to manage members of a foundation.
Class to manage members type.
Class to manage generation of HTML components Only common components must be here.
Class to manage subscriptions of foundation members.
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
Definition: card.php:143
dol_banner_tab($object, $paramid, $morehtml='', $shownav=1, $fieldid='rowid', $fieldref='ref', $morehtmlref='', $moreparam='', $nodbprefix=0, $morehtmlleft='', $morehtmlstatus='', $onlybanner=0, $morehtmlright='')
Show tab footer of a card.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed informations (by default a local PHP server timestamp) Re...
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='')
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.
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.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs='', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
newToken()
Return the value of token currently saved into session with name 'newtoken'.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname from a POST of a form.
isModEnabled($module)
Is Dolibarr module enabled.
dol_htmloutput_errors($mesgstring='', $mesgarray=array(), $keepembedded=0)
Print formated error messages to output (Used to show messages on html output).
subscription_prepare_head(Subscription $object)
Return array head with list of tabs to view object informations.
Definition: member.lib.php:315
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.