mirror of
https://github.com/Dolibarr/dolibarr.git
synced 2025-12-20 08:21:29 +01:00
1004 lines
32 KiB
PHP
1004 lines
32 KiB
PHP
<?php
|
|
/* Copyright (C) 2001-2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
|
* Copyright (C) 2002-2003 Jean-Louis Bergamo <jlb@j1b.org>
|
|
* Copyright (C) 2004-2007 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, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
* $Id$
|
|
* $Source$
|
|
*/
|
|
|
|
/**
|
|
\file htdocs/adherents/fiche.php
|
|
\ingroup adherent
|
|
\brief Page d'ajout, edition, suppression d'une fiche adhérent
|
|
\version $Revision$
|
|
*/
|
|
|
|
require("./pre.inc.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/lib/member.lib.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/adherents/adherent.class.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/adherents/adherent_type.class.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/adherents/adherent_options.class.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/adherents/cotisation.class.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/compta/bank/account.class.php");
|
|
require_once(DOL_DOCUMENT_ROOT."/includes/xmlrpc/xmlrpc.php");
|
|
|
|
$langs->load("companies");
|
|
$langs->load("bills");
|
|
$langs->load("members");
|
|
$langs->load("users");
|
|
|
|
$user->getrights('adherent');
|
|
|
|
$adh = new Adherent($db);
|
|
$adho = new AdherentOptions($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"];
|
|
|
|
|
|
|
|
/*
|
|
* Actions
|
|
*/
|
|
|
|
if ($_POST["action"] == 'confirm_sendinfo' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id = $rowid;
|
|
$adh->fetch($rowid);
|
|
|
|
if ($adh->email)
|
|
{
|
|
$result=$adh->send_an_email($adh->email,"Voici le contenu de votre fiche\n\n%INFOS%\n\n","Contenu de votre fiche adherent");
|
|
}
|
|
}
|
|
|
|
if ($_REQUEST["action"] == 'update' && ! $_POST["cancel"])
|
|
{
|
|
$datenaiss='';
|
|
if (isset($_POST["naissday"]) && $_POST["naissday"]
|
|
&& isset($_POST["naissmonth"]) && $_POST["naissmonth"]
|
|
&& isset($_POST["naissyear"]) && $_POST["naissyear"])
|
|
{
|
|
$datenaiss=dolibarr_mktime(12, 0, 0, $_POST["naissmonth"], $_POST["naissday"], $_POST["naissyear"]);
|
|
}
|
|
|
|
$adh->id = $_POST["rowid"];
|
|
$adh->prenom = $_POST["prenom"];
|
|
$adh->nom = $_POST["nom"];
|
|
$adh->fullname = trim($adh->prenom.' '.$adh->nom);
|
|
$adh->login = $_POST["login"];
|
|
$adh->pass = $_POST["pass"];
|
|
|
|
$adh->societe = $_POST["societe"];
|
|
$adh->adresse = $_POST["adresse"];
|
|
$adh->cp = $_POST["cp"];
|
|
$adh->ville = $_POST["ville"];
|
|
$adh->pays_id = $_POST["pays"];
|
|
|
|
$adh->phone = $_POST["phone"];
|
|
$adh->phone_perso = $_POST["phone_perso"];
|
|
$adh->phone_mobile= $_POST["phone_mobile"];
|
|
$adh->email = $_POST["email"];
|
|
$adh->naiss = $datenaiss;
|
|
$adh->photo = $_POST["photo"];
|
|
|
|
$adh->typeid = $_POST["type"];
|
|
$adh->commentaire = $_POST["comment"];
|
|
$adh->morphy = $_POST["morphy"];
|
|
|
|
$adh->amount = $_POST["amount"];
|
|
|
|
// recuperation du statut et public
|
|
$adh->statut = $_POST["statut"];
|
|
$adh->public = $_POST["public"];
|
|
|
|
foreach($_POST as $key => $value)
|
|
{
|
|
if (ereg("^options_",$key))
|
|
{
|
|
//escape values from POST, at least with addslashes, to avoid obvious SQL injections
|
|
//(array_options is directly input in the DB in adherent.class.php::update())
|
|
$adh->array_options[$key]=addslashes($_POST[$key]);
|
|
}
|
|
}
|
|
$result=$adh->update($user,0);
|
|
if ($result >= 0 && ! sizeof($adh->errors))
|
|
{
|
|
if (isset($_POST["password"]) && $_POST["password"] !='')
|
|
{
|
|
$ret=$edituser->password($user,$password,$conf->password_encrypted,0);
|
|
if ($ret < 0)
|
|
{
|
|
$message.='<div class="error">'.$edituser->error.'</div>';
|
|
}
|
|
}
|
|
|
|
Header("Location: fiche.php?rowid=".$adh->id);
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
if ($adh->error)
|
|
{
|
|
$errmsg=$adh->error;
|
|
}
|
|
else
|
|
{
|
|
foreach($adh->errors as $error)
|
|
{
|
|
if ($errmsg) $errmsg.='<br>';
|
|
$errmsg.=$error;
|
|
}
|
|
}
|
|
$action='';
|
|
}
|
|
}
|
|
|
|
if ($_POST["action"] == 'add')
|
|
{
|
|
$datenaiss='';
|
|
if (isset($_POST["naissday"]) && $_POST["naissday"]
|
|
&& isset($_POST["naissmonth"]) && $_POST["naissmonth"]
|
|
&& isset($_POST["naissyear"]) && $_POST["naissyear"])
|
|
{
|
|
$datenaiss=dolibarr_mktime(12, 0, 0, $_POST["naissmonth"], $_POST["naissday"], $_POST["naissyear"]);
|
|
}
|
|
$datecotisation='';
|
|
if (isset($_POST["reday"]) && isset($_POST["remonth"]) && isset($_POST["reyear"]))
|
|
{
|
|
$datecotisation=dolibarr_mktime(12, 0 , 0, $_POST["remonth"], $_POST["reday"], $_POST["reyear"]);
|
|
}
|
|
|
|
$type=$_POST["type"];
|
|
$nom=$_POST["nom"];
|
|
$prenom=$_POST["prenom"];
|
|
$societe=$_POST["societe"];
|
|
$adresse=$_POST["adresse"];
|
|
$cp=$_POST["cp"];
|
|
$ville=$_POST["ville"];
|
|
$pays_id=$_POST["pays_id"];
|
|
|
|
$phone=$_POST["phone"];
|
|
$phone_perso=$_POST["phone_perso"];
|
|
$phone_mobile=$_POST["phone_mobile"];
|
|
$email=$_POST["member_email"];
|
|
$login=$_POST["member_login"];
|
|
$pass=$_POST["password"];
|
|
$photo=$_POST["photo"];
|
|
$comment=$_POST["comment"];
|
|
$morphy=$_POST["morphy"];
|
|
$cotisation=$_POST["cotisation"];
|
|
|
|
$adh->prenom = $prenom;
|
|
$adh->nom = $nom;
|
|
$adh->societe = $societe;
|
|
$adh->adresse = $adresse;
|
|
$adh->cp = $cp;
|
|
$adh->ville = $ville;
|
|
$adh->pays_id = $pays_id;
|
|
$adh->phone = $phone;
|
|
$adh->phone_perso = $phone_perso;
|
|
$adh->phone_mobile= $phone_mobile;
|
|
$adh->email = $email;
|
|
$adh->login = $login;
|
|
$adh->pass = $pass;
|
|
$adh->naiss = $datenaiss;
|
|
$adh->photo = $photo;
|
|
$adh->typeid = $type;
|
|
$adh->commentaire = $comment;
|
|
$adh->morphy = $morphy;
|
|
foreach($_POST as $key => $value){
|
|
if (ereg("^options_",$key)){
|
|
//escape values from POST, at least with addslashes, to avoid obvious SQL injections
|
|
//(array_options is directly input in the DB in adherent.class.php::update())
|
|
$adh->array_options[$key]=addslashes($_POST[$key]);
|
|
}
|
|
}
|
|
|
|
// Test validite des paramètres
|
|
if(!isset($type) || $type==''){
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorMemberTypeNotDefined")."<br>\n";
|
|
}
|
|
// Test si le login existe deja
|
|
if(!isset($login) || $login==''){
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorFieldRequired",$langs->trans("Login"))."<br>\n";
|
|
}
|
|
else {
|
|
$sql = "SELECT login FROM ".MAIN_DB_PREFIX."adherent WHERE login='".$login."'";
|
|
$result = $db->query($sql);
|
|
if ($result) {
|
|
$num = $db->num_rows($result);
|
|
}
|
|
if ($num) {
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorLoginAlreadyExists",$login)."<br>\n";
|
|
}
|
|
}
|
|
if (!isset($nom) || $nom=='') {
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorFieldRequired",$langs->transnoentities("Lastname"))."<br>\n";
|
|
}
|
|
if (!isset($prenom) || $prenom=='') {
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorFieldRequired",$langs->transnoentities("Firstname"))."<br>\n";
|
|
}
|
|
if ($conf->global->ADHERENT_MAIL_REQUIRED && ! ValidEMail($email)) {
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorBadEMail",$email)."<br>\n";
|
|
}
|
|
if (!isset($pass) || $pass == '' ) {
|
|
$error++;
|
|
$errmsg .= $langs->trans("ErrorFieldRequired",$langs->transnoentities("Password"))."<br>\n";
|
|
}
|
|
$public=0;
|
|
if (isset($public)) $public=1;
|
|
|
|
if (! $error)
|
|
{
|
|
$db->begin();
|
|
|
|
// Email a peu pres correct et le login n'existe pas
|
|
$result=$adh->create($user);
|
|
if ($result > 0)
|
|
{
|
|
if (isset($_POST['password']) && trim($_POST['password']))
|
|
{
|
|
$adh->password($user,trim($_POST['password']),0);
|
|
}
|
|
|
|
if ($cotisation > 0)
|
|
{
|
|
$crowid=$adh->cotisation($datecotisation, $cotisation);
|
|
|
|
// insertion dans la gestion banquaire si configure pour
|
|
if ($global->conf->ADHERENT_BANK_USE)
|
|
{
|
|
$dateop=time();
|
|
$amount=$cotisation;
|
|
$acct=new Account($db,$_POST["accountid"]);
|
|
$insertid=$acct->addline($dateop, $_POST["operation"], $_POST["label"], $amount, $_POST["num_chq"], '', $user);
|
|
if ($insertid == '')
|
|
{
|
|
dolibarr_print_error($db);
|
|
}
|
|
else
|
|
{
|
|
// met a jour la table cotisation
|
|
$sql ="UPDATE ".MAIN_DB_PREFIX."cotisation";
|
|
$sql.=" SET fk_bank=$insertid WHERE rowid=$crowid ";
|
|
$result = $db->query($sql);
|
|
if ($result)
|
|
{
|
|
//Header("Location: fiche.php");
|
|
}
|
|
else
|
|
{
|
|
dolibarr_print_error($db);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$db->commit();
|
|
|
|
Header("Location: liste.php?statut=-1");
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
$db->rollback();
|
|
|
|
if ($adh->error) $errmsg=$adh->error;
|
|
else $errmsg=$adh->errors[0];
|
|
|
|
$action = 'create';
|
|
}
|
|
}
|
|
else {
|
|
$action = 'create';
|
|
}
|
|
}
|
|
|
|
if ($_POST["action"] == 'confirm_delete' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$result=$adh->delete($rowid);
|
|
if ($result > 0)
|
|
{
|
|
Header("Location: liste.php");
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
$mesg=$adh->error;
|
|
}
|
|
}
|
|
|
|
|
|
if ($_POST["action"] == 'confirm_valid' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id=$rowid;
|
|
$adh->fetch($rowid);
|
|
|
|
$adht = new AdherentType($db);
|
|
$adht->fetch($adh->typeid);
|
|
|
|
$result=$adh->validate($user);
|
|
if ($result >= 0 && ! sizeof($adh->errors))
|
|
{
|
|
|
|
}
|
|
else
|
|
{
|
|
if ($adh->error)
|
|
{
|
|
$errmsg=$adh->error;
|
|
}
|
|
else
|
|
{
|
|
foreach($adh->errors as $error)
|
|
{
|
|
if ($errmsg) $errmsg.='<br>';
|
|
$errmsg.=$error;
|
|
}
|
|
}
|
|
$action='';
|
|
}
|
|
|
|
// Envoi mail validation (selon param du type adherent sinon generique)
|
|
if ($adh->email)
|
|
{
|
|
if (isset($adht->mail_valid) && $adht->mail_valid)
|
|
{
|
|
$result=$adh->send_an_email($adh->email,$adht->mail_valid,$conf->adherent->email_valid_subject);
|
|
}
|
|
else
|
|
{
|
|
$result=$adh->send_an_email($adh->email,$conf->global->ADHERENT_MAIL_VALID,$conf->global->ADHERENT_MAIL_VALID_SUBJECT);
|
|
}
|
|
if ($result < 0)
|
|
{
|
|
$errmsg.=$adh->error;
|
|
}
|
|
}
|
|
|
|
// Rajoute l'utilisateur dans les divers abonnements (mailman, spip, etc...)
|
|
if ($adh->add_to_abo($adht) < 0)
|
|
{
|
|
// error
|
|
$errmsg.="Echec du rajout de l'utilisateur aux abonnements: ".$adh->error."<BR>\n";
|
|
}
|
|
|
|
}
|
|
|
|
if ($_POST["action"] == 'confirm_resign' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id=$rowid;
|
|
$adh->resiliate($user->id);
|
|
$adh->fetch($rowid);
|
|
|
|
$adht = new AdherentType($db);
|
|
$adht->fetch($adh->typeid);
|
|
|
|
if ($adh->email)
|
|
{
|
|
$result=$adh->send_an_email($adh->email,$conf->adherent->email_resil,$conf->adherent->email_resil_subject);
|
|
}
|
|
|
|
// supprime l'utilisateur des divers abonnements ..
|
|
if (! $adh->del_to_abo($adht))
|
|
{
|
|
// error
|
|
$errmsg.="echec de la suppression de l'utilisateur aux abonnements: ".$adh->error."<BR>\n";
|
|
}
|
|
}
|
|
|
|
if ($_POST["action"] == 'confirm_add_glasnost' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id=$rowid;
|
|
$adh->fetch($rowid);
|
|
$adht = new AdherentType($db);
|
|
$adht->fetch($adh->typeid);
|
|
if ($adht->vote == 'yes'){
|
|
define("XMLRPC_DEBUG", 1);
|
|
if (!$adh->add_to_glasnost()){
|
|
$errmsg.="Echec du rajout de l'utilisateur dans glasnost: ".$adh->error."<BR>\n";
|
|
}
|
|
XMLRPC_debug_print();
|
|
}
|
|
}
|
|
|
|
if ($_POST["action"] == 'confirm_del_glasnost' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id=$rowid;
|
|
$adh->fetch($rowid);
|
|
$adht = new AdherentType($db);
|
|
$adht->fetch($adh->typeid);
|
|
if ($adht->vote == 'yes'){
|
|
define("XMLRPC_DEBUG", 1);
|
|
if(!$adh->del_to_glasnost()){
|
|
$errmsg.="Echec de la suppression de l'utilisateur dans glasnost: ".$adh->error."<BR>\n";
|
|
}
|
|
XMLRPC_debug_print();
|
|
}
|
|
}
|
|
|
|
if ($_POST["action"] == 'confirm_del_spip' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id=$rowid;
|
|
$adh->fetch($rowid);
|
|
if(!$adh->del_to_spip()){
|
|
$errmsg.="Echec de la suppression de l'utilisateur dans spip: ".$adh->error."<BR>\n";
|
|
}
|
|
}
|
|
|
|
if ($_POST["action"] == 'confirm_add_spip' && $_POST["confirm"] == 'yes')
|
|
{
|
|
$adh->id=$rowid;
|
|
$adh->fetch($rowid);
|
|
if (!$adh->add_to_spip())
|
|
{
|
|
$errmsg.="Echec du rajout de l'utilisateur dans spip: ".$adh->error."<BR>\n";
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
*
|
|
*/
|
|
|
|
llxHeader();
|
|
|
|
|
|
if ($errmsg)
|
|
{
|
|
print '<div class="error">'.$errmsg.'</div>';
|
|
print "\n";
|
|
}
|
|
|
|
// fetch optionals attributes and labels
|
|
$adho->fetch_optionals();
|
|
|
|
|
|
if ($action == 'edit')
|
|
{
|
|
/********************************************
|
|
*
|
|
* Fiche en mode edition
|
|
*
|
|
********************************************/
|
|
|
|
$adho = new AdherentOptions($db);
|
|
$adh = new Adherent($db);
|
|
$adh->id = $rowid;
|
|
$adh->fetch($rowid);
|
|
// fetch optionals value
|
|
$adh->fetch_optionals($rowid);
|
|
// fetch optionals attributes and labels
|
|
$adho->fetch_optionals();
|
|
|
|
$adht = new AdherentType($db);
|
|
|
|
|
|
/*
|
|
* Affichage onglets
|
|
*/
|
|
$head = member_prepare_head($adh);
|
|
|
|
dolibarr_fiche_head($head, 'general', $langs->trans("Member"));
|
|
|
|
|
|
print '<form name="update" action="'.$_SERVER["PHP_SELF"].'" method="post">';
|
|
print "<input type=\"hidden\" name=\"action\" value=\"update\">";
|
|
print "<input type=\"hidden\" name=\"rowid\" value=\"$rowid\">";
|
|
print "<input type=\"hidden\" name=\"statut\" value=\"".$adh->statut."\">";
|
|
|
|
print '<table class="border" width="100%">';
|
|
|
|
$htmls = new Form($db);
|
|
|
|
// Ref
|
|
print '<tr><td>'.$langs->trans("Ref").'</td><td class="valeur" colspan="2">'.$adh->id.' </td></tr>';
|
|
|
|
// Nom
|
|
print '<tr><td>'.$langs->trans("Lastname").'</td><td><input type="text" name="nom" size="40" value="'.$adh->nom.'"></td>';
|
|
// Notes
|
|
print '<td valign="top" width="50%">'.$langs->trans("Notes").'</td></tr>';
|
|
|
|
// Prenom
|
|
print '<tr><td width="15%">'.$langs->trans("Firstname").'</td><td width="35%"><input type="text" name="prenom" size="40" value="'.$adh->prenom.'"></td>';
|
|
$rowspan=16;
|
|
$rowspan+=sizeof($adho->attribute_label);
|
|
print '<td rowspan="'.$rowspan.'" valign="top">';
|
|
print '<textarea name="comment" wrap="soft" cols="70" rows="16">'.$adh->commentaire.'</textarea></td></tr>';
|
|
|
|
// Login
|
|
print '<tr><td>'.$langs->trans("Login").'</td><td><input type="text" name="login" size="40" value="'.$adh->login.'"></td></tr>';
|
|
|
|
// Password
|
|
print '<tr><td>'.$langs->trans("Password").'</td><td><input type="password" name="pass" size="40" value="'.$adh->pass.'"></td></tr>';
|
|
|
|
// Type
|
|
print '<tr><td>'.$langs->trans("Type").'</td><td>';
|
|
$htmls->select_array("type", $adht->liste_array(), $adh->typeid);
|
|
print "</td></tr>";
|
|
|
|
// Physique-Moral
|
|
$morphys["phy"] = $langs->trans("Physical");
|
|
$morphys["mor"] = $langs->trans("Morale");
|
|
print "<tr><td>".$langs->trans("Person")."</td><td>";
|
|
$htmls->select_array("morphy", $morphys, $adh->morphy);
|
|
print "</td></tr>";
|
|
|
|
// Société
|
|
print '<tr><td>'.$langs->trans("Company").'</td><td><input type="text" name="societe" size="40" value="'.$adh->societe.'"></td></tr>';
|
|
|
|
// Adresse
|
|
print '<tr><td>'.$langs->trans("Address").'</td><td>';
|
|
print '<textarea name="adresse" wrap="soft" cols="40" rows="2">'.$adh->adresse.'</textarea></td></tr>';
|
|
|
|
// Cp
|
|
print '<tr><td>'.$langs->trans("Zip").'/'.$langs->trans("Town").'</td><td><input type="text" name="cp" size="6" value="'.$adh->cp.'"> <input type="text" name="ville" size="32" value="'.$adh->ville.'"></td></tr>';
|
|
|
|
// Pays
|
|
print '<tr><td>'.$langs->trans("Country").'</td><td>';
|
|
$htmls->select_pays($adh->pays_code?$adh->pays_code:$mysoc->pays_code,'pays');
|
|
print '</td></tr>';
|
|
|
|
// Tel
|
|
print '<tr><td>'.$langs->trans("PhonePro").'</td><td><input type="text" name="phone" size="20" value="'.$adh->phone.'"></td></tr>';
|
|
|
|
// Tel perso
|
|
print '<tr><td>'.$langs->trans("PhonePerso").'</td><td><input type="text" name="phone_perso" size="20" value="'.$adh->phone_perso.'"></td></tr>';
|
|
|
|
// Tel mobile
|
|
print '<tr><td>'.$langs->trans("PhoneMobile").'</td><td><input type="text" name="phone_mobile" size="20" value="'.$adh->phone_mobile.'"></td></tr>';
|
|
|
|
// EMail
|
|
print '<tr><td>'.$langs->trans("EMail").($conf->global->ADHERENT_MAIL_REQUIRED?'*':'').'</td><td><input type="text" name="email" size="40" value="'.$adh->email.'"></td></tr>';
|
|
|
|
// Date naissance
|
|
print "<tr><td>".$langs->trans("Birthday")."</td><td>\n";
|
|
$htmls->select_date(($adh->naiss ? $adh->naiss : -1),'naiss','','',1,'update');
|
|
print "</td></tr>\n";
|
|
|
|
// Url photo
|
|
print '<tr><td>URL photo</td><td><input type="text" name="photo" size="40" value="'.$adh->photo.'"></td></tr>';
|
|
|
|
// Profil public
|
|
print "<tr><td>".$langs->trans("Public")."</td><td>\n";
|
|
$htmls->select_YesNo($adh->public,"public");
|
|
print "</td></tr>\n";
|
|
|
|
// Attributs supplémentaires
|
|
foreach($adho->attribute_label as $key=>$value)
|
|
{
|
|
print "<tr><td>$value</td><td><input type=\"text\" name=\"options_$key\" size=\"40\" value=\"".$adh->array_options["options_$key"]."\"></td></tr>\n";
|
|
}
|
|
|
|
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 '</div>';
|
|
}
|
|
|
|
if ($action == 'create')
|
|
{
|
|
/* ************************************************************************** */
|
|
/* */
|
|
/* Fiche création */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
$htmls = new Form($db);
|
|
$adht = new AdherentType($db);
|
|
|
|
print_titre($langs->trans("NewMember"));
|
|
|
|
print "<form name='add' action=\"fiche.php\" method=\"post\">\n";
|
|
print '<input type="hidden" name="action" value="add">';
|
|
|
|
print '<table class="border" width="100%">';
|
|
|
|
// Nom
|
|
print '<tr><td>'.$langs->trans("Lastname").'*</td><td><input type="text" name="nom" value="'.$adh->nom.'" size="40"></td>';
|
|
print '<td width="50%" valign="top">'.$langs->trans("Notes").' :</td></tr>';
|
|
|
|
// Prenom
|
|
print '<tr><td>'.$langs->trans("Firstname").'*</td><td><input type="text" name="prenom" size="40" value="'.$adh->prenom.'"></td>';
|
|
$rowspan=16;
|
|
print '<td valign="top" rowspan="'.$rowspan.'"><textarea name="comment" wrap="soft" cols="70" rows="14">'.$adh->commantaire.'</textarea></td></tr>';
|
|
|
|
// Login
|
|
print '<tr><td>'.$langs->trans("Login").'*</td><td><input type="text" name="member_login" size="40" value="'.$adh->login.'"></td></tr>';
|
|
|
|
// Mot de passe
|
|
$generated_password='';
|
|
if ($conf->global->USER_PASSWORD_GENERATED)
|
|
{
|
|
$nomclass="modGeneratePass".ucfirst($conf->global->USER_PASSWORD_GENERATED);
|
|
$nomfichier=$nomclass.".class.php";
|
|
//print DOL_DOCUMENT_ROOT."/includes/modules/security/generate/".$nomclass;
|
|
require_once(DOL_DOCUMENT_ROOT."/includes/modules/security/generate/".$nomfichier);
|
|
$genhandler=new $nomclass($db,$conf,$lang,$user);
|
|
$generated_password=$genhandler->getNewGeneratedPassword();
|
|
}
|
|
print '<tr><td>'.$langs->trans("Password").'*</td><td>';
|
|
print '<input size="30" maxsize="32" type="text" name="password" value="'.$generated_password.'">';
|
|
print '</td></tr>';
|
|
|
|
// Type
|
|
print '<tr><td>'.$langs->trans("MemberType").'*</td><td>';
|
|
$listetype=$adht->liste_array();
|
|
if (sizeof($listetype))
|
|
{
|
|
$htmls->select_array("type", $listetype, $typeid);
|
|
} else {
|
|
print '<font class="error">'.$langs->trans("NoTypeDefinedGoToSetup").'</font>';
|
|
}
|
|
print "</td>\n";
|
|
|
|
|
|
// Moral-Physique
|
|
$morphys["phy"] = "Physique";
|
|
$morphys["mor"] = "Morale";
|
|
print "<tr><td>".$langs->trans("Person")."*</td><td>\n";
|
|
$htmls->select_array("morphy", $morphys);
|
|
print "</td>\n";
|
|
|
|
print '<tr><td>'.$langs->trans("Company").'</td><td><input type="text" name="societe" size="40" value="'.$adh->societe.'"></td></tr>';
|
|
|
|
// Adresse
|
|
print '<tr><td valign="top">'.$langs->trans("Address").'</td><td>';
|
|
print '<textarea name="adresse" wrap="soft" cols="40" rows="2">'.$adh->adresse.'</textarea></td></tr>';
|
|
|
|
// CP / Ville
|
|
print '<tr><td>'.$langs->trans("Zip").' / '.$langs->trans("Town").'</td><td><input type="text" name="cp" size="8"> <input type="text" name="ville" size="32" value="'.$adh->ville.'"></td></tr>';
|
|
|
|
// Pays
|
|
print '<tr><td>'.$langs->trans("Country").'</td><td>';
|
|
$htmls->select_pays($adh->pays_id ? $adh->pays_id : $mysoc->pays_id,'pays_id');
|
|
print '</td></tr>';
|
|
|
|
// Tel pro
|
|
print '<tr><td>'.$langs->trans("PhonePro").'</td><td><input type="text" name="phone" size="20" value="'.$adh->phone.'"></td></tr>';
|
|
|
|
// Tel perso
|
|
print '<tr><td>'.$langs->trans("PhonePerso").'</td><td><input type="text" name="phone_perso" size="20" value="'.$adh->phone_perso.'"></td></tr>';
|
|
|
|
// Tel mobile
|
|
print '<tr><td>'.$langs->trans("PhoneMobile").'</td><td><input type="text" name="phone_mobile" size="20" value="'.$adh->phone_mobile.'"></td></tr>';
|
|
|
|
// EMail
|
|
print '<tr><td>'.$langs->trans("EMail").($conf->global->ADHERENT_MAIL_REQUIRED?'*':'').'</td><td><input type="text" name="member_email" size="40" value="'.$adh->email.'"></td></tr>';
|
|
|
|
// Date naissance
|
|
print "<tr><td>".$langs->trans("Birthday")."</td><td>\n";
|
|
$htmls->select_date(($adh->naiss ? $adh->naiss : -1),'naiss','','',1,'add');
|
|
print "</td></tr>\n";
|
|
|
|
// Url photo
|
|
print '<tr><td>Url photo</td><td><input type="text" name="photo" size="40"></td></tr>';
|
|
foreach($adho->attribute_label as $key=>$value)
|
|
{
|
|
print "<tr><td>$value</td><td><input type=\"text\" name=\"options_$key\" size=\"40\"></td></tr>\n";
|
|
}
|
|
|
|
// Profil public
|
|
print "<tr><td>".$langs->trans("Public")."</td><td>\n";
|
|
$htmls->select_YesNo($adh->public,"public");
|
|
print "</td></tr>\n";
|
|
|
|
|
|
print "</table>\n";
|
|
print '<br>';
|
|
|
|
print '<center><input type="submit" class="button" value="'.$langs->trans("AddMember").'"></center>';
|
|
|
|
print "</form>\n";
|
|
|
|
}
|
|
|
|
if ($rowid && $action != 'edit')
|
|
{
|
|
/* ************************************************************************** */
|
|
/* */
|
|
/* Mode affichage */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
$adh = new Adherent($db);
|
|
$adh->id = $rowid;
|
|
$adh->fetch($rowid);
|
|
$adh->fetch_optionals($rowid);
|
|
|
|
$adht = new AdherentType($db);
|
|
$adht->fetch($adh->typeid);
|
|
|
|
$html = new Form($db);
|
|
|
|
|
|
/*
|
|
* Affichage onglets
|
|
*/
|
|
$head = member_prepare_head($adh);
|
|
|
|
dolibarr_fiche_head($head, 'general', $langs->trans("Member"));
|
|
|
|
|
|
$result=$adh->load_previous_next_id($adh->next_prev_filter);
|
|
if ($result < 0) dolibarr_print_error($db,$adh->error);
|
|
$previous_id = $adh->id_previous?'<a href="'.$_SERVER["PHP_SELF"].'?rowid='.urlencode($adh->id_previous).'">'.img_previous().'</a>':'';
|
|
$next_id = $adh->id_next?'<a href="'.$_SERVER["PHP_SELF"].'?rowid='.urlencode($adh->id_next).'">'.img_next().'</a>':'';
|
|
|
|
// Confirmation de la suppression de l'adhérent
|
|
if ($action == 'delete')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid",$langs->trans("DeleteMember"),$langs->trans("ConfirmDeleteMember"),"confirm_delete");
|
|
print '<br>';
|
|
}
|
|
|
|
// Confirmation de la validation
|
|
if ($action == 'valid')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid",$langs->trans("ValidateMember"),$langs->trans("ConfirmValidateMember"),"confirm_valid");
|
|
print '<br>';
|
|
}
|
|
|
|
// Confirmation de l'envoi fiche par mail
|
|
if ($action == 'sendinfo')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid",$langs->trans("SendCardByMail"),$langs->trans("ConfirmSendCardByMail"),"confirm_sendinfo");
|
|
print '<br>';
|
|
}
|
|
|
|
// Confirmation de la Résiliation
|
|
if ($action == 'resign')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid",$langs->trans("ResiliateMember"),$langs->trans("ConfirmResiliateMember"),"confirm_resign");
|
|
print '<br>';
|
|
}
|
|
|
|
/*
|
|
* Confirmation de l'ajout dans glasnost
|
|
*/
|
|
if ($action == 'add_glasnost')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid","Ajouter dans glasnost","Etes-vous sur de vouloir ajouter cet adhérent dans glasnost ? (serveur : ".ADHERENT_GLASNOST_SERVEUR.")","confirm_add_glasnost");
|
|
print '<br>';
|
|
}
|
|
|
|
/*
|
|
* Confirmation de la suppression dans glasnost
|
|
*/
|
|
if ($action == 'del_glasnost')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid","Supprimer dans glasnost","Etes-vous sur de vouloir effacer cet adhérent dans glasnost ? (serveur : ".ADHERENT_GLASNOST_SERVEUR.")","confirm_del_glasnost");
|
|
print '<br>';
|
|
}
|
|
|
|
/*
|
|
* Confirmation de l'ajout dans spip
|
|
*/
|
|
if ($action == 'add_spip')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid","Ajouter dans spip","Etes-vous sur de vouloir ajouter cet adhérent dans spip ? (serveur : ".ADHERENT_SPIP_SERVEUR.")","confirm_add_spip");
|
|
print '<br>';
|
|
}
|
|
|
|
/*
|
|
* Confirmation de la suppression dans spip
|
|
*/
|
|
if ($action == 'del_spip')
|
|
{
|
|
$html->form_confirm("fiche.php?rowid=$rowid","Supprimer dans spip","Etes-vous sur de vouloir effacer cet adhérent dans spip ? (serveur : ".ADHERENT_SPIP_SERVEUR.")","confirm_del_spip");
|
|
$html->form_confirm("fiche.php?rowid=$rowid","Ajouter dans glasnost","Etes-vous sur de vouloir ajouter cet adhérent dans glasnost ? (serveur : ".ADHERENT_GLASNOST_SERVEUR.")","confirm_del_spip");
|
|
print '<br>';
|
|
}
|
|
|
|
|
|
print '<form action="fiche.php" method="post">';
|
|
print '<table class="border" width="100%">';
|
|
|
|
// Ref
|
|
print '<tr><td width="20%">'.$langs->trans("Ref").'</td>';
|
|
print '<td class="valeur" colspan="3">';
|
|
if ($previous_id || $next_id) print '<table class="nobordernopadding" width="100%"><tr class="nobordernopadding"><td class="nobordernopadding">';
|
|
print $adh->id;
|
|
if ($previous_id || $next_id) print '</td><td class="nobordernopadding" align="center" width="20">'.$previous_id.'</td><td class="nobordernopadding" align="center" width="20">'.$next_id.'</td></tr></table>';
|
|
print '</td></tr>';
|
|
|
|
// Nom
|
|
print '<tr><td>'.$langs->trans("Lastname").'</td><td class="valeur">'.$adh->nom.' </td>';
|
|
print '<td valign="top" width="50%">'.$langs->trans("Notes").'</td></tr>';
|
|
|
|
// Prenom
|
|
print '<tr><td>'.$langs->trans("Firstname").'</td><td class="valeur">'.$adh->prenom.' </td>';
|
|
print '<td rowspan="'.(13+count($adh->array_options)).'" valign="top" width="50%">';
|
|
print nl2br($adh->commentaire).' </td></tr>';
|
|
|
|
// Login
|
|
print '<tr><td>'.$langs->trans("Login").'</td><td class="valeur">'.$adh->login.' </td></tr>';
|
|
|
|
// Password
|
|
print '<tr><td>'.$langs->trans("Password").'</td><td>'.eregi_replace('.','*',$adh->pass).'</td></tr>';
|
|
|
|
// Type
|
|
print '<tr><td>'.$langs->trans("Type").'</td><td class="valeur">'.$adht->getNomUrl(1)."</td></tr>\n";
|
|
|
|
// Morphy
|
|
print '<tr><td>'.$langs->trans("Person").'</td><td class="valeur">'.$adh->getmorphylib().'</td></tr>';
|
|
|
|
// Tiers
|
|
print '<tr><td>'.$langs->trans("Company").'</td><td class="valeur">'.$adh->societe.' </td></tr>';
|
|
|
|
// Adresse
|
|
print '<tr><td>'.$langs->trans("Address").'</td><td class="valeur">'.nl2br($adh->adresse).' </td></tr>';
|
|
|
|
// CP / Ville
|
|
print '<tr><td>'.$langs->trans("Zip").' / '.$langs->trans("Town").'</td><td class="valeur">'.$adh->cp.' '.$adh->ville.' </td></tr>';
|
|
|
|
// Pays
|
|
print '<tr><td>'.$langs->trans("Country").'</td><td class="valeur">'.$html->pays_name($adh->pays_id).'</td></tr>';
|
|
|
|
// Tel pro.
|
|
print '<tr><td>'.$langs->trans("PhonePro").'</td><td class="valeur">'.$adh->phone.'</td></tr>';
|
|
|
|
// Tel perso
|
|
print '<tr><td>'.$langs->trans("PhonePerso").'</td><td class="valeur">'.$adh->phone_perso.'</td></tr>';
|
|
|
|
// Tel mobile
|
|
print '<tr><td>'.$langs->trans("PhoneMobile").'</td><td class="valeur">'.$adh->phone_mobile.'</td></tr>';
|
|
|
|
// EMail
|
|
print '<tr><td>'.$langs->trans("EMail").($conf->global->ADHERENT_MAIL_REQUIRED?'*':'').'</td><td class="valeur">'.$adh->email.' </td></tr>';
|
|
|
|
// Date naissance
|
|
print '<tr><td>'.$langs->trans("Birthday").'</td><td class="valeur">'.dolibarr_print_date($adh->naiss,'day').' </td></tr>';
|
|
|
|
// URL
|
|
print '<tr><td>URL Photo</td><td class="valeur">'.$adh->photo.' </td></tr>';
|
|
|
|
// Public
|
|
print '<tr><td>'.$langs->trans("Public").'</td><td class="valeur">'.yn($adh->public).'</td></tr>';
|
|
|
|
// Status
|
|
print '<tr><td>'.$langs->trans("Status").'</td><td class="valeur">'.$adh->getLibStatut(4).'</td></tr>';
|
|
|
|
// Autres attributs
|
|
foreach($adho->attribute_label as $key=>$value){
|
|
print "<tr><td>$value</td><td>".$adh->array_options["options_$key"]." </td></tr>\n";
|
|
}
|
|
|
|
print "</table>\n";
|
|
print '</form>';
|
|
|
|
print "</div>\n";
|
|
|
|
|
|
/*
|
|
* Barre d'actions
|
|
*
|
|
*/
|
|
print '<div class="tabsAction">';
|
|
|
|
|
|
print "<a class=\"butAction\" href=\"fiche.php?rowid=$rowid&action=edit\">".$langs->trans("Edit")."</a>";
|
|
|
|
// Valider
|
|
if ($adh->statut == -1)
|
|
{
|
|
print "<a class=\"butAction\" href=\"fiche.php?rowid=$rowid&action=valid\">".$langs->trans("Validate")."</a>\n";
|
|
}
|
|
|
|
// Réactiver
|
|
if ($adh->statut == 0)
|
|
{
|
|
print "<a class=\"butAction\" href=\"fiche.php?rowid=$rowid&action=valid\">".$langs->trans("Reenable")."</a>\n";
|
|
}
|
|
|
|
// Envoi fiche par mail
|
|
if ($adh->statut >= 1 && $adh->email)
|
|
{
|
|
print "<a class=\"butAction\" href=\"fiche.php?rowid=$adh->id&action=sendinfo\">".$langs->trans("SendCardByMail")."</a>\n";
|
|
}
|
|
|
|
// Résilier
|
|
if ($adh->statut == 1)
|
|
{
|
|
print "<a class=\"butAction\" href=\"fiche.php?rowid=$rowid&action=resign\">".$langs->trans("Resiliate")."</a>\n";
|
|
}
|
|
|
|
// Supprimer
|
|
if ($user->rights->adherent->supprimer)
|
|
{
|
|
print "<a class=\"butActionDelete\" href=\"fiche.php?rowid=$adh->id&action=delete\">".$langs->trans("Delete")."</a>\n";
|
|
}
|
|
|
|
// Action Glasnost
|
|
if ($adht->vote == 'yes' && $conf->global->ADHERENT_USE_GLASNOST)
|
|
{
|
|
define("XMLRPC_DEBUG", 1);
|
|
$isinglasnost=$adh->is_in_glasnost();
|
|
if ($isinglasnost == 1)
|
|
{
|
|
print "<a class=\"tabAction\" href=\"fiche.php?rowid=$adh->id&action=del_glasnost\">Suppression dans Glasnost</a>\n";
|
|
}
|
|
if ($isinglasnost == 0) {
|
|
print "<a class=\"tabAction\" href=\"fiche.php?rowid=$adh->id&action=add_glasnost\">Ajout dans Glasnost</a>\n";
|
|
}
|
|
if ($isinglasnost == -1) {
|
|
print '<br><font class="error">Failed to connect to SPIP: '.$adh->error.'</font>';
|
|
}
|
|
}
|
|
|
|
// Action SPIP
|
|
if ($conf->global->ADHERENT_USE_SPIP)
|
|
{
|
|
$isinspip=$adh->is_in_spip();
|
|
if ($isinspip == 1)
|
|
{
|
|
print "<a class=\"tabAction\" href=\"fiche.php?rowid=$adh->id&action=del_spip\">Suppression dans Spip</a>\n";
|
|
}
|
|
if ($isinspip == 0)
|
|
{
|
|
print "<a class=\"tabAction\" href=\"fiche.php?rowid=$adh->id&action=add_spip\">Ajout dans Spip</a>\n";
|
|
}
|
|
if ($isinspip == -1) {
|
|
print '<br><font class="error">Failed to connect to SPIP: '.$adh->error.'</font>';
|
|
}
|
|
}
|
|
|
|
print '</div>';
|
|
print "<br>\n";
|
|
|
|
|
|
|
|
/*
|
|
* Bandeau des cotisations
|
|
*
|
|
*/
|
|
|
|
print '<table border=0 width="100%">';
|
|
|
|
print '<tr>';
|
|
print '<td valign="top" width="50%">';
|
|
|
|
print '</td><td valign="top">';
|
|
|
|
print '</td></tr>';
|
|
print '</table>';
|
|
|
|
}
|
|
|
|
|
|
$db->close();
|
|
|
|
llxFooter('$Date$ - $Revision$');
|
|
?>
|