* Copyright (C) 2005-2006 Destailleur Laurent * * 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/commande/contact.php \ingroup commande \brief Onglet de gestion des contacts de commande \version $Revision$ */ require ("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/commande/commande.class.php"); require_once(DOL_DOCUMENT_ROOT."/contact.class.php"); require_once(DOL_DOCUMENT_ROOT."/lib/order.lib.php"); $langs->load("facture"); $langs->load("orders"); $langs->load("sendings"); $langs->load("companies"); $user->getrights('commande'); if (!$user->rights->commande->lire) accessforbidden(); // les methodes locales /** * \brief Retourne la liste déroulante des sociétés * \param selected Societe présélectionnée * \param htmlname Nom champ formulaire */ function select_societes_for_newconcat($commande, $selected = '', $htmlname = 'newcompany'){ // On recherche les societes $sql = "SELECT s.idp, s.nom FROM"; $sql .= " ".MAIN_DB_PREFIX."societe as s"; // if ($filter) $sql .= " WHERE $filter"; $sql .= " ORDER BY nom ASC"; $resql = $commande->db->query($sql); if ($resql) { $javaScript = "window.location='./contact.php?id=".$commande->id."&".$htmlname."=' + form.".$htmlname.".options[form.".$htmlname.".selectedIndex].value;"; print '\n"; return $firstCompany; } else { dolibarr_print_error($commande->db); } } /** * */ function select_type_contact($commande, $defValue, $htmlname = 'type', $source) { $lesTypes = $commande->liste_type_contact($source); print '\n"; } // Sécurité accés client if ($user->societe_id > 0) { $action = ''; $socid = $user->societe_id; } /* * Ajout d'un nouveau contact */ if ($_POST["action"] == 'addcontact' && $user->rights->commande->creer) { $result = 0; $commande = new Commande($db); $result = $commande->fetch($_GET["id"]); if ($result > 0 && $_GET["id"] > 0) { $result = $commande->add_contact($_POST["contactid"], $_POST["type"], $_POST["source"]); } if ($result >= 0) { Header("Location: contact.php?id=".$commande->id); exit; } else { $mesg = '
'.$commande->error.'
'; } } // modification d'un contact. On enregistre le type if ($_POST["action"] == 'updateligne' && $user->rights->commande->creer) { $commande = new Commande($db); if ($commande->fetch($_GET["id"])) { $contact = $commande->detail_contact($_POST["elrowid"]); $type = $_POST["type"]; $statut = $contact->statut; $result = $commande->update_contact($_POST["elrowid"], $statut, $type); if ($result >= 0) { $db->commit(); } else { dolibarr_print_error($db, "result=$result"); $db->rollback(); } } else { dolibarr_print_error($db); } } // bascule du statut d'un contact if ($_GET["action"] == 'swapstatut' && $user->rights->commande->creer) { $commande = new Commande($db); if ($commande->fetch($_GET["id"])) { $contact = $commande->detail_contact($_GET["ligne"]); $id_type_contact = $contact->fk_c_type_contact; $statut = ($contact->statut == 4) ? 5 : 4; $result = $commande->update_contact($_GET["ligne"], $statut, $id_type_contact); if ($result >= 0) { $db->commit(); } else { dolibarr_print_error($db, "result=$result"); $db->rollback(); } } else { dolibarr_print_error($db); } } // Efface un contact if ($_GET["action"] == 'deleteline' && $user->rights->commande->creer) { $commande = new Commande($db); $commande->fetch($_GET["id"]); $result = $commande->delete_contact($_GET["lineid"]); if ($result >= 0) { Header("Location: contact.php?id=".$commande->id); exit; } else { dolibarr_print_error($db); } } llxHeader('', $langs->trans("Order"), "Commande"); $html = new Form($db); /* *************************************************************************** */ /* */ /* Mode vue et edition */ /* */ /* *************************************************************************** */ if ( isset($mesg)) print $mesg; $id = $_GET["id"]; if ($id > 0) { $langs->trans("OrderCard"); $commande = New Commande($db); if ( $commande->fetch($_GET['id'], $user->societe_id) > 0) { $soc = new Societe($db, $commande->socid); $soc->fetch($commande->socid); $head = commande_prepare_head($commande); dolibarr_fiche_head($head, 'contact', $langs->trans("CustomerOrder")); /* * Facture synthese pour rappel */ print ''; // Ref print '"; // Ref commande client print ''; print ''; // Customer if ( is_null($commande->client) ) $commande->fetch_client(); print ""; print ''; print "
'.$langs->trans("Ref").''; print $commande->ref; print "
'; print ''; print '
'; print $langs->trans('RefCustomer').''; print '
'; print '
'; print $commande->ref_client; print '
".$langs->trans("Company")."'.$commande->client->getNomUrl(1).'
"; print ''; /* * Lignes de contacts */ echo '
'; /* * Ajouter une ligne de contact * Non affiché en mode modification de ligne */ if ($_GET["action"] != 'editline' && $user->rights->facture->creer) { print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; $var = false; print ''; print ''; print ''; print ''; // Ligne ajout pour contact interne print ""; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; // Ligne ajout pour contact externe $var=!$var; print ""; print ''; print ''; print ''; print ''; print ''; print ''; print ""; print ''; } // Liste des contacts liés print ''; print ''; print ''; print ''; print ''; print ''; print ''; print "\n"; $societe = new Societe($db); $var = true; foreach(array('internal','external') as $source) { $tab = $commande->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 ++; } $db->free($result); } print "
'.$langs->trans("Source").''.$langs->trans("Company").''.$langs->trans("Contacts").''.$langs->trans("ContactType").' 
'; print $langs->trans("Internal"); print ''; print $conf->global->MAIN_INFO_SOCIETE_NOM; print ''; $html->select_users($user->id,'contactid'); print ''; select_type_contact($commande, '', 'type','internal'); print '
'; print $langs->trans("External"); print ''; $selectedCompany = isset($_GET["newcompany"])?$_GET["newcompany"]:$commande->client->id; $selectedCompany = select_societes_for_newconcat($commande, $selectedCompany, $htmlname = 'newcompany'); print ''; $html->select_contacts($selectedCompany, $selected = '', $htmlname = 'contactid'); print ''; select_type_contact($commande, '', 'type','external'); print '
 
'.$langs->trans("Source").''.$langs->trans("Company").''.$langs->trans("Contacts").''.$langs->trans("ContactType").''.$langs->trans("Status").' 
'; if ($tab[$i]['source']=='internal') print $langs->trans("Internal"); if ($tab[$i]['source']=='external') print $langs->trans("External"); print ''; if ($tab[$i]['socid'] > 0) { print ''; print img_object($langs->trans("ShowCompany"),"company").' '.$societe->get_nom($tab[$i]['socid']); print ''; } 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 ($commande->statut >= 0) print ''; print img_statut($tab[$i]['status']); if ($commande->statut >= 0) print ''; print ''; if ($commande->statut < 5 && $user->rights->commande->creer) { print ' '; print ''; print img_delete(); print ''; } print '
"; } else { // Contrat non trouv print "Contrat inexistant ou accés refusé"; } } $db->close(); llxFooter('$Date$'); ?>