123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395 |
- <?php
- /* Copyright (C) 2007-2011 Laurent Destailleur <eldy@users.sourceforge.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 2 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 <http://www.gnu.org/licenses/>.
- */
- /**
- * \file htdocs/adherents/fiche_subscription.php
- * \ingroup member
- * \brief Page to add/edit/remove a member subscription
- */
- require("../main.inc.php");
- require_once(DOL_DOCUMENT_ROOT."/lib/member.lib.php");
- require_once(DOL_DOCUMENT_ROOT."/adherents/class/adherent.class.php");
- require_once(DOL_DOCUMENT_ROOT."/adherents/class/cotisation.class.php");
- require_once(DOL_DOCUMENT_ROOT."/compta/bank/class/account.class.php");
- $langs->load("companies");
- $langs->load("bills");
- $langs->load("members");
- $langs->load("users");
- $adh = new Adherent($db);
- $subscription = new Cotisation($db);
- $errmsg='';
- $action=isset($_GET["action"])?$_GET["action"]:$_POST["action"];
- $rowid=isset($_GET["rowid"])?$_GET["rowid"]:$_POST["rowid"];
- $typeid=isset($_GET["typeid"])?$_GET["typeid"]:$_POST["typeid"];
- if (! $user->rights->adherent->cotisation->lire)
- accessforbidden();
- /*
- * Actions
- */
- if ($user->rights->adherent->cotisation->creer && $_REQUEST["action"] == 'update' && ! $_POST["cancel"])
- {
- // Charge objet actuel
- $result=$subscription->fetch($_POST["rowid"]);
- if ($result > 0)
- {
- $db->begin();
- $errmsg='';
- if ($subscription->fk_bank)
- {
- $accountline=new AccountLine($db);
- $result=$accountline->fetch($subscription->fk_bank);
- // If transaction consolidated
- if ($accountline->rappro)
- {
- $errmsg=$langs->trans("SubscriptionLinkedToConciliatedTrnasaction");
- }
- else
- {
- $accountline->datev=dol_mktime($_POST['datesubhour'], $_POST['datesubmin'], 0, $_POST['datesubmonth'], $_POST['datesubday'], $_POST['datesubyear']);
- $accountline->dateo=dol_mktime($_POST['datesubhour'], $_POST['datesubmin'], 0, $_POST['datesubmonth'], $_POST['datesubday'], $_POST['datesubyear']);
- $accountline->amount=$_POST["amount"];
- $result=$accountline->update($user);
- if ($result < 0)
- {
- $errmsg=$accountline->error;
- }
- }
- }
- if (! $errmsg)
- {
- // Modifie valeures
- $subscription->dateh=dol_mktime($_POST['datesubhour'], $_POST['datesubmin'], 0, $_POST['datesubmonth'], $_POST['datesubday'], $_POST['datesubyear']);
- $subscription->datef=dol_mktime($_POST['datesubendhour'], $_POST['datesubendmin'], 0, $_POST['datesubendmonth'], $_POST['datesubendday'], $_POST['datesubendyear']);
- $subscription->note=$_POST["note"];
- $subscription->amount=$_POST["amount"];
- //print 'datef='.$subscription->datef.' '.$_POST['datesubendday'];
- $result=$subscription->update($user);
- if ($result >= 0 && ! sizeof($subscription->errors))
- {
- $db->commit();
- header("Location: fiche_subscription.php?rowid=".$subscription->id);
- exit;
- }
- else
- {
- $db->rollback();
- if ($subscription->error)
- {
- $errmsg=$subscription->error;
- }
- else
- {
- foreach($subscription->errors as $error)
- {
- if ($errmsg) $errmsg.='<br>';
- $errmsg.=$error;
- }
- }
- $action='';
- }
- }
- else
- {
- $db->rollback();
- }
- }
- }
- if ($_REQUEST["action"] == 'confirm_delete' && $_REQUEST["confirm"] == 'yes' && $user->rights->adherent->cotisation->creer)
- {
- $result=$subscription->fetch($rowid);
- $result=$subscription->delete($user);
- if ($result > 0)
- {
- Header("Location: card_subscriptions.php?rowid=".$subscription->fk_adherent);
- exit;
- }
- else
- {
- $mesg=$adh->error;
- }
- }
- /*
- * View
- */
- llxHeader('',$langs->trans("SubscriptionCard"),'EN:Module_Foundations|FR:Module_Adhérents|ES:Módulo_Miembros');
- $form = new Form($db);
- if ($errmsg)
- {
- print '<div class="error">'.$errmsg.'</div>';
- print "\n";
- }
- if ($user->rights->adherent->cotisation->creer && $action == 'edit')
- {
- /********************************************
- *
- * Fiche en mode edition
- *
- ********************************************/
- $subscription->fetch($rowid);
- $result=$adh->fetch($subscription->fk_adherent);
- /*
- * Affichage onglets
- */
- $h = 0;
- $head = array();
- $head[$h][0] = DOL_URL_ROOT.'/adherents/fiche_subscription.php?rowid='.$subscription->id;
- $head[$h][1] = $langs->trans("SubscriptionCard");
- $head[$h][2] = 'general';
- $h++;
- $head[$h][0] = DOL_URL_ROOT.'/adherents/info_subscription.php?rowid='.$subscription->id;
- $head[$h][1] = $langs->trans("Info");
- $head[$h][2] = 'info';
- $h++;
- dol_fiche_head($head, 'general', $langs->trans("Subscription"));
- print "\n";
- print '<form name="update" action="'.$_SERVER["PHP_SELF"].'" method="post">';
- print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
- print "<input type=\"hidden\" name=\"action\" value=\"update\">";
- print "<input type=\"hidden\" name=\"rowid\" value=\"$rowid\">";
- print "<input type=\"hidden\" name=\"fk_bank\" value=\"".$subscription->fk_bank."\">";
- print '<table class="border" width="100%">';
- // Ref
- print '<tr><td width="20%">'.$langs->trans("Ref").'</td><td class="valeur" colspan="2">'.$subscription->ref.' </td></tr>';
- // Member
- $adh->ref=$adh->getFullName($langs);
- print '<tr>';
- print '<td>'.$langs->trans("Member").'</td><td class="valeur" colspan="3">'.$adh->getNomUrl(1,0,'subscription').'</td>';
- print '</tr>';
- // Date start subscription
- print '<tr><td>'.$langs->trans("DateSubscription").'</td><td class="valeur" colspan="2">';
- $form->select_date($subscription->dateh,'datesub',1,1,0,'update',1);
- print '</td>';
- print '</tr>';
- // Date end subscription
- print '<tr><td>'.$langs->trans("DateEndSubscription").'</td><td class="valeur" colspan="2">';
- $form->select_date($subscription->datef,'datesubend',0,0,0,'update',1);
- print '</td>';
- print '</tr>';
- // Amount
- print '<tr><td>'.$langs->trans("Amount").'</td><td class="valeur" colspan="2">';
- print '<input type="text" class="flat" size="10" name="amount" value="'.price($subscription->amount).'"></td></tr>';
- // Label
- print '<tr><td>'.$langs->trans("Label").'</td><td class="valeur" colspan="2">';
- print '<input type="text" class="flat" size="60" name="note" value="'.$subscription->note.'"></td></tr>';
- // Bank line
- if ($conf->banque->enabled)
- {
- if ($conf->global->ADHERENT_BANK_USE || $subscription->fk_bank)
- {
- print '<tr><td>'.$langs->trans("BankTransactionLine").'</td><td class="valeur" colspan="2">';
- if ($subscription->fk_bank)
- {
- $bankline=new AccountLine($db);
- $result=$bankline->fetch($subscription->fk_bank);
- print $bankline->getNomUrl(1,0,'showall');
- }
- else
- {
- print $langs->trans("NoneF");
- }
- print '</td></tr>';
- }
- }
- print '<tr><td colspan="3" align="center">';
- print '<input type="submit" class="button" name="submit" value="'.$langs->trans("Save").'">';
- print ' ';
- print '<input type="submit" class="button" name="cancel" value="'.$langs->trans("Cancel").'">';
- print '</td></tr>';
- print '</table>';
- print '</form>';
- print "\n";
- print '</div>';
- print "\n";
- }
- if ($rowid && $action != 'edit')
- {
- /* ************************************************************************** */
- /* */
- /* Mode affichage */
- /* */
- /* ************************************************************************** */
- $result=$subscription->fetch($rowid);
- $result=$adh->fetch($subscription->fk_adherent);
- /*
- * Affichage onglets
- */
- $h = 0;
- $head = array();
- $head[$h][0] = DOL_URL_ROOT.'/adherents/fiche_subscription.php?rowid='.$subscription->id;
- $head[$h][1] = $langs->trans("SubscriptionCard");
- $head[$h][2] = 'general';
- $h++;
- $head[$h][0] = DOL_URL_ROOT.'/adherents/info_subscription.php?rowid='.$subscription->id;
- $head[$h][1] = $langs->trans("Info");
- $head[$h][2] = 'info';
- $h++;
- dol_fiche_head($head, 'general', $langs->trans("Subscription"), '', 'payment');
- if ($msg) print '<div class="error">'.$msg.'</div>';
- // Confirmation to delete subscription
- if ($action == 'delete')
- {
- //$formquestion=array();
- //$formquestion['text']='<b>'.$langs->trans("ThisWillAlsoDeleteBankRecord").'</b>';
- $text=$langs->trans("ConfirmDeleteSubscription");
- if ($conf->banque->enabled && $conf->global->ADHERENT_BANK_USE) $text.='<br>'.img_warning().' '.$langs->trans("ThisWillAlsoDeleteBankRecord");
- $ret=$form->form_confirm($_SERVER["PHP_SELF"]."?rowid=".$subscription->id,$langs->trans("DeleteSubscription"),$text,"confirm_delete",$formquestion,0,1);
- if ($ret == 'html') print '<br>';
- }
- print '<form action="'.$_SERVER["PHP_SELF"].'" method="post">';
- print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';
- print '<table class="border" width="100%">';
- // Ref
- print '<tr><td width="20%">'.$langs->trans("Ref").'</td>';
- print '<td class="valeur" colspan="3">';
- print $form->showrefnav($subscription,'rowid','',1);
- print '</td></tr>';
- // Member
- $adh->ref=$adh->getFullName($langs);
- print '<tr>';
- print '<td>'.$langs->trans("Member").'</td><td class="valeur" colspan="3">'.$adh->getNomUrl(1,0,'subscription').'</td>';
- print '</tr>';
- // Date subscription
- print '<tr>';
- print '<td>'.$langs->trans("DateSubscription").'</td><td class="valeur" colspan="3">'.dol_print_date($subscription->dateh,'dayhour').'</td>';
- print '</tr>';
- // Date end subscription
- print '<tr>';
- print '<td>'.$langs->trans("DateEndSubscription").'</td><td class="valeur" colspan="3">'.dol_print_date($subscription->datef,'day').'</td>';
- print '</tr>';
- // Amount
- print '<tr><td>'.$langs->trans("Amount").'</td><td class="valeur" colspan="3">'.price($subscription->amount).'</td></tr>';
- // Amount
- print '<tr><td>'.$langs->trans("Label").'</td><td class="valeur" colspan="3">'.$subscription->note.'</td></tr>';
- // Bank line
- if ($conf->banque->enabled)
- {
- if ($conf->global->ADHERENT_BANK_USE || $subscription->fk_bank)
- {
- print '<tr><td>'.$langs->trans("BankTransactionLine").'</td><td class="valeur" colspan="3">';
- if ($subscription->fk_bank)
- {
- $bankline=new AccountLine($db);
- $result=$bankline->fetch($subscription->fk_bank);
- print $bankline->getNomUrl(1,0,'showall');
- }
- else
- {
- print $langs->trans("NoneF");
- }
- print '</td></tr>';
- }
- }
- print "</table>\n";
- print '</form>';
- print "</div>\n";
- /*
- * Barre d'actions
- *
- */
- print '<div class="tabsAction">';
- if ($user->rights->adherent->cotisation->creer)
- {
- if (! $bankline->rappro)
- {
- print "<a class=\"butAction\" href=\"".$_SERVER["PHP_SELF"]."?rowid=".$subscription->id."&action=edit\">".$langs->trans("Modify")."</a>";
- }
- else
- {
- print "<a class=\"butActionRefused\" title=\"".$langs->trans("BankLineConciliated")."\" href=\"#\">".$langs->trans("Modify")."</a>";
- }
- }
- // Supprimer
- if ($user->rights->adherent->cotisation->creer)
- {
- print "<a class=\"butActionDelete\" href=\"".$_SERVER["PHP_SELF"]."?rowid=".$subscription->id."&action=delete\">".$langs->trans("Delete")."</a>\n";
- }
- print '</div>';
- print "<br>\n";
- }
- $db->close();
- llxFooter();
- ?>
|