* Copyright (C) 2006-2010 Laurent Destailleur * Copyright (C) 2010 Regis Houssin * * 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. */ /** * \file htdocs/projet/tasks/contact.php * \ingroup project * \brief Actors of a task * \version $Id$ */ require ("../../main.inc.php"); require_once(DOL_DOCUMENT_ROOT."/projet/class/project.class.php"); require_once(DOL_DOCUMENT_ROOT."/projet/class/task.class.php"); require_once(DOL_DOCUMENT_ROOT."/contact/class/contact.class.php"); require_once(DOL_DOCUMENT_ROOT."/lib/project.lib.php"); require_once(DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php'); $langs->load("projects"); $langs->load("companies"); $taskid = isset($_GET["id"])?$_GET["id"]:''; // Security check $socid=0; if ($user->societe_id > 0) $socid = $user->societe_id; //$result = restrictedArea($user, 'projet', $taskid, 'projet_task'); if (!$user->rights->projet->lire) accessforbidden(); /* * Actions */ // Add new contact if ($_POST["action"] == 'addcontact' && $user->rights->projet->creer) { $result = 0; $task = new Task($db); $result = $task->fetch($taskid); if ($result > 0 && $taskid > 0) { $result = $task->add_contact($_POST["contactid"], $_POST["type"], $_POST["source"]); } if ($result >= 0) { Header("Location: contact.php?id=".$task->id); exit; } else { if ($task->error == 'DB_ERROR_RECORD_ALREADY_EXISTS') { $langs->load("errors"); $mesg = '
'.$langs->trans("ErrorThisContactIsAlreadyDefinedAsThisType").'
'; } else { $mesg = '
'.$task->error.'
'; } } } // modification d'un contact. On enregistre le type if ($_POST["action"] == 'updateline' && $user->rights->projet->creer) { $task = new Task($db); if ($task->fetch($taskid)) { $contact = $task->detail_contact($_POST["elrowid"]); $type = $_POST["type"]; $statut = $contact->statut; $result = $task->update_contact($_POST["elrowid"], $statut, $type); if ($result >= 0) { $db->commit(); } else { dol_print_error($db, "result=$result"); $db->rollback(); } } else { dol_print_error($db); } } // bascule du statut d'un contact if ($_GET["action"] == 'swapstatut' && $user->rights->projet->creer) { $task = new Task($db); if ($task->fetch($taskid)) { $contact = $task->detail_contact($_GET["ligne"]); $id_type_contact = $contact->fk_c_type_contact; $statut = ($contact->statut == 4) ? 5 : 4; $result = $task->update_contact($_GET["ligne"], $statut, $id_type_contact); if ($result >= 0) { $db->commit(); } else { dol_print_error($db, "result=$result"); $db->rollback(); } } else { dol_print_error($db); } } // Efface un contact if ($_GET["action"] == 'deleteline' && $user->rights->projet->creer) { $task = new Task($db); $task->fetch($taskid); $result = $task->delete_contact($_GET["lineid"]); if ($result >= 0) { Header("Location: contact.php?id=".$task->id); exit; } else { dol_print_error($db); } } /* * View */ llxHeader('', $langs->trans("Task")); $html = new Form($db); $formcompany = new FormCompany($db); $contactstatic = new Contact($db); $project = new Project($db); /* *************************************************************************** */ /* */ /* Mode vue et edition */ /* */ /* *************************************************************************** */ if (isset($mesg)) print $mesg; $id = $_GET['id']; $ref= $_GET['ref']; if ($id > 0 || ! empty($ref)) { $task = new Task($db); if ( $task->fetch($id,$ref) > 0) { $result=$project->fetch($task->fk_project); if (! empty($project->socid)) $project->societe->fetch($project->socid); // To verify role of users //$userAccess = $projectstatic->restrictedProjectArea($user); // We allow task affected to user even if a not allowed project //$arrayofuseridoftask=$task->getListContactId('internal'); $head = task_prepare_head($task); dol_fiche_head($head, 'contact', $langs->trans("Task"), 0, 'projecttask'); /* * Projet synthese pour rappel */ print ''; //$linkback="".$langs->trans("BackToList").""; // Ref print ''; // Label print ''; // Project print ''; // Customer print ""; print ''; print "
'.$langs->trans('Ref').''; $projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,1); $task->next_prev_filter=" fk_projet in (".$projectsListId.")"; print $html->showrefnav($task,'id','',1,'rowid','ref','',''); print '
'.$langs->trans("Label").''.$task->label.'
'.$langs->trans("Project").''; print $project->getNomUrl(1); print '
".$langs->trans("Company")."'; if ($project->societe->id > 0) print $project->societe->getNomUrl(1); else print ' '; print '
"; print ''; /* * Lignes de contacts */ print '
'; /* * Ajouter une ligne de contact * Non affiche en mode modification de ligne */ if ($_GET["action"] != 'editline' && $user->rights->projet->creer) { print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; $var = false; print ''; print ''; print ''; print ''; print ''; // Ligne ajout pour contact interne print ""; print ''; print ''; print ''; print ''; print ''; print ''; print ''; // Line to add an external contact. Only if project linked to a third party. if ($project->socid) { print ''; print ''; print ''; print ''; print ''; $var=!$var; print ""; print ''; print ''; print ''; print ''; print ''; print ''; print ""; } print ''; } // Liste des contacts lies print ''; print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; $companystatic = new Societe($db); $var = true; foreach(array('internal','external') as $source) { $tab = $task->liste_contact(-1,$source); $num=sizeof($tab); $i = 0; while ($i < $num) { $var = !$var; print ''; // Source print ''; // Societe print ''; // Contact print ''; // Type de contact print ''; // Statut print ''; // Icon update et delete print ''; print "\n"; $i ++; } } print "
'.$langs->trans("Source").''.$langs->trans("Company").''.$langs->trans("ProjectContact").''.$langs->trans("ContactType").' 
'; print img_object('','user').' '.$langs->trans("Users"); print ''; print $conf->global->MAIN_INFO_SOCIETE_NOM; print ''; // On recupere les id des users deja selectionnes $contactsofproject=$project->getListContactId('internal'); $html->select_users($user->id,'contactid',0,'',0,'',$contactsofproject); print ''; $formcompany->selectTypeContact($task, '', 'type','internal','rowid'); print '
'; print img_object('','contact').' '.$langs->trans("ThirdPartyContacts"); print ''; $thirdpartyofproject=$project->getListContactId('thirdparty'); $selectedCompany = isset($_GET["newcompany"])?$_GET["newcompany"]:$project->societe->id; $selectedCompany = $formcompany->selectCompaniesForNewContact($task, 'id', $selectedCompany, 'newcompany',$thirdpartyofproject); print ''; $contactofproject=$project->getListContactId('external'); $nbofcontacts=$html->select_contacts($selectedCompany,'','contactid',0,'',$contactofproject); if ($nbofcontacts == 0) print $langs->trans("NoContactDefined"); print ''; $formcompany->selectTypeContact($task, '', 'type','external','rowid'); print '
 
'.$langs->trans("Source").''.$langs->trans("Company").''.$langs->trans("ProjectContact").''.$langs->trans("ContactType").''.$langs->trans("Status").' 
'; if ($tab[$i]['source']=='internal') print $langs->trans("User"); if ($tab[$i]['source']=='external') print $langs->trans("ThirdPartyContact"); print ''; if ($tab[$i]['socid'] > 0) { $companystatic->fetch($tab[$i]['socid']); print $companystatic->getNomUrl(1); } if ($tab[$i]['socid'] < 0) { print $conf->global->MAIN_INFO_SOCIETE_NOM; } if (! $tab[$i]['socid']) { print ' '; } print ''; if ($tab[$i]['source']=='internal') { print ''; print img_object($langs->trans("ShowUser"),"user").' '.$tab[$i]['nom'].''; } if ($tab[$i]['source']=='external') { print ''; print img_object($langs->trans("ShowContact"),"contact").' '.$tab[$i]['nom'].''; } print ''.$tab[$i]['libelle'].''; // Activation desativation du contact if ($task->statut >= 0) print ''; print $contactstatic->LibStatut($tab[$i]['status'],3); if ($task->statut >= 0) print ''; print ''; if ($user->rights->projet->creer) { print ' '; print ''; print img_delete(); print ''; } print '
"; } else { print "ErrorRecordNotFound"; } } $db->close(); llxFooter('$Date$ - $Revision$'); ?>