| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284 |
- <?php
- /* Copyright (C) 2006-2010 Laurent Destailleur <eldy@users.sourceforge.net>
- * Copyright (C) 2010-2017 Regis Houssin <regis.houssin@inodbox.com>
- * Copyright (C) 2015-2021 Frederic France <frederic.france@netlogic.fr>
- * Copyright (C) 2015 Raphaël Doursenaud <rdoursenaud@gpcsolutions.fr>
- *
- * 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 3 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 <https://www.gnu.org/licenses/>.
- * or see https://www.gnu.org/
- */
- /**
- * \file htdocs/core/lib/contact.lib.php
- * \brief Ensemble de fonctions de base pour les contacts
- */
- /**
- * Prepare array with list of tabs
- *
- * @param Contact $object Object related to tabs
- * @return array Array of tabs to show
- */
- function contact_prepare_head(Contact $object)
- {
- global $db, $langs, $conf, $user;
- $tab = 0;
- $head = array();
- $head[$tab][0] = DOL_URL_ROOT.'/contact/card.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Contact");
- $head[$tab][2] = 'card';
- $tab++;
- if ((!empty($conf->ldap->enabled) && !empty($conf->global->LDAP_CONTACT_ACTIVE))
- && (empty($conf->global->MAIN_DISABLE_LDAP_TAB) || !empty($user->admin))) {
- $langs->load("ldap");
- $head[$tab][0] = DOL_URL_ROOT.'/contact/ldap.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("LDAPCard");
- $head[$tab][2] = 'ldap';
- $tab++;
- }
- $head[$tab][0] = DOL_URL_ROOT.'/contact/perso.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("PersonalInformations");
- $head[$tab][2] = 'perso';
- $tab++;
- if (isModEnabled('project') && $user->hasRight('project', 'lire')) {
- $nbProject = 0;
- // Enable caching of thirdrparty count projects
- require_once DOL_DOCUMENT_ROOT.'/core/lib/memory.lib.php';
- $cachekey = 'count_projects_contact_'.$object->id;
- $dataretrieved = dol_getcache($cachekey);
- if (!is_null($dataretrieved)) {
- $nbProject = $dataretrieved;
- } else {
- $sql = 'SELECT COUNT(n.rowid) as nb';
- $sql .= ' FROM '.MAIN_DB_PREFIX.'projet as n';
- $sql .= ' INNER JOIN '.MAIN_DB_PREFIX.'element_contact as cc ON (n.rowid = cc.element_id)';
- $sql .= " WHERE cc.fk_socpeople = ".((int) $object->id);
- $sql .= " AND cc.fk_c_type_contact IN (SELECT rowid FROM ".MAIN_DB_PREFIX."c_type_contact WHERE element='project' AND source='external')";
- $sql .= " AND n.entity IN (".getEntity('project').")";
- $resql = $db->query($sql);
- if ($resql) {
- $obj = $db->fetch_object($resql);
- $nbProject = $obj->nb;
- } else {
- dol_print_error($db);
- }
- dol_setcache($cachekey, $nbProject, 120); // If setting cache fails, this is not a problem, so we do not test result.
- }
- $head[$tab][0] = DOL_URL_ROOT.'/contact/project.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Projects");
- if ($nbProject > 0) {
- $head[$tab][1] .= '<span class="badge marginleftonlyshort">'.$nbProject.'</span>';
- }
- $head[$tab][2] = 'project';
- $tab++;
- }
- // Related items
- if (isModEnabled('commande') || isModEnabled("propal") || isModEnabled('facture') || isModEnabled('ficheinter') || (isModEnabled("fournisseur") && empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD)) || isModEnabled("supplier_order") || isModEnabled("supplier_invoice")) {
- $head[$tab][0] = DOL_URL_ROOT.'/contact/consumption.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Referers");
- $head[$tab][2] = 'consumption';
- $tab++;
- }
- // Show more tabs from modules
- // Entries must be declared in modules descriptor with line
- // $this->tabs = array('entity:+tabname:Title:@mymodule:/mymodule/mypage.php?id=__ID__'); to add new tab
- // $this->tabs = array('entity:-tabname); to remove a tab
- complete_head_from_modules($conf, $langs, $object, $head, $tab, 'contact', 'add', 'core');
- // Notes
- if (empty($conf->global->MAIN_DISABLE_NOTES_TAB)) {
- $nbNote = (empty($object->note_private) ? 0 : 1) + (empty($object->note_public) ? 0 : 1);
- $head[$tab][0] = DOL_URL_ROOT.'/contact/note.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Note");
- if ($nbNote > 0) {
- $head[$tab][1] .= '<span class="badge marginleftonlyshort">'.$nbNote.'</span>';
- }
- $head[$tab][2] = 'note';
- $tab++;
- }
- require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
- require_once DOL_DOCUMENT_ROOT.'/core/class/link.class.php';
- $upload_dir = $conf->societe->dir_output."/contact/".dol_sanitizeFileName($object->ref);
- $nbFiles = count(dol_dir_list($upload_dir, 'files', 0, '', '(\.meta|_preview.*\.png)$'));
- $nbLinks = Link::count($db, $object->element, $object->id);
- $head[$tab][0] = DOL_URL_ROOT.'/contact/document.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Documents");
- if (($nbFiles + $nbLinks) > 0) {
- $head[$tab][1] .= '<span class="badge marginleftonlyshort">'.($nbFiles + $nbLinks).'</span>';
- }
- $head[$tab][2] = 'documents';
- $tab++;
- // Agenda / Events
- $head[$tab][0] = DOL_URL_ROOT.'/contact/agenda.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Events");
- if (isModEnabled('agenda') && (!empty($user->rights->agenda->myactions->read) || !empty($user->rights->agenda->allactions->read))) {
- $head[$tab][1] .= '/';
- $head[$tab][1] .= $langs->trans("Agenda");
- }
- $head[$tab][2] = 'agenda';
- $tab++;
- // Log
- /*
- $head[$tab][0] = DOL_URL_ROOT.'/contact/info.php?id='.$object->id;
- $head[$tab][1] = $langs->trans("Info");
- $head[$tab][2] = 'info';
- $tab++;*/
- complete_head_from_modules($conf, $langs, $object, $head, $tab, 'contact', 'add', 'external');
- complete_head_from_modules($conf, $langs, $object, $head, $tab, 'contact', 'remove');
- return $head;
- }
- /**
- * Show html area for list of projects
- *
- * @param Conf $conf Object conf
- * @param Translate $langs Object langs
- * @param DoliDB $db Database handler
- * @param Object $object Third party object
- * @param string $backtopage Url to go once contact is created
- * @param int $nocreatelink 1=Hide create project link
- * @param string $morehtmlright More html on right of title
- * @return int
- */
- function show_contacts_projects($conf, $langs, $db, $object, $backtopage = '', $nocreatelink = 0, $morehtmlright = '')
- {
- global $user;
- $i = -1;
- if (isModEnabled('project') && $user->rights->projet->lire) {
- $langs->load("projects");
- $newcardbutton = '';
- if (isModEnabled('project') && $user->rights->projet->creer && empty($nocreatelink)) {
- $newcardbutton .= dolGetButtonTitle($langs->trans('AddProject'), '', 'fa fa-plus-circle', DOL_URL_ROOT.'/projet/card.php?socid='.$object->id.'&action=create&backtopage='.urlencode($backtopage));
- }
- print "\n";
- print load_fiche_titre($langs->trans("ProjectsHavingThisContact"), $newcardbutton.$morehtmlright, '');
- print '<div class="div-table-responsive">';
- print "\n".'<table class="noborder" width=100%>';
- $sql = 'SELECT p.rowid as id, p.entity, p.title, p.ref, p.public, p.dateo as do, p.datee as de, p.fk_statut as status, p.fk_opp_status, p.opp_amount, p.opp_percent, p.tms as date_update, p.budget_amount';
- $sql .= ', cls.code as opp_status_code, ctc.libelle';
- $sql .= ' FROM '.MAIN_DB_PREFIX.'projet as p';
- $sql .= ' LEFT JOIN '.MAIN_DB_PREFIX.'c_lead_status as cls on p.fk_opp_status = cls.rowid';
- $sql .= ' INNER JOIN '.MAIN_DB_PREFIX.'element_contact as cc ON (p.rowid = cc.element_id)';
- $sql .= ' INNER JOIN '.MAIN_DB_PREFIX.'c_type_contact as ctc ON (ctc.rowid = cc.fk_c_type_contact)';
- $sql .= " WHERE cc.fk_socpeople = ".((int) $object->id);
- $sql .= " AND ctc.element='project' AND ctc.source='external'";
- $sql .= " AND p.entity IN (".getEntity('project').")";
- $sql .= " ORDER BY p.dateo DESC";
- $result = $db->query($sql);
- if ($result) {
- $num = $db->num_rows($result);
- print '<tr class="liste_titre">';
- print '<td>'.$langs->trans("Ref").'</td>';
- print '<td>'.$langs->trans("Name").'</td>';
- print '<td>'.$langs->trans("ContactType").'</td>';
- print '<td class="center">'.$langs->trans("DateStart").'</td>';
- print '<td class="center">'.$langs->trans("DateEnd").'</td>';
- print '<td class="right">'.$langs->trans("OpportunityAmountShort").'</td>';
- print '<td class="center">'.$langs->trans("OpportunityStatusShort").'</td>';
- print '<td class="right">'.$langs->trans("OpportunityProbabilityShort").'</td>';
- print '<td class="right">'.$langs->trans("Status").'</td>';
- print '</tr>';
- if ($num > 0) {
- require_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
- $projecttmp = new Project($db);
- $i = 0;
- while ($i < $num) {
- $obj = $db->fetch_object($result);
- $projecttmp->fetch($obj->id);
- // To verify role of users
- $userAccess = $projecttmp->restrictedProjectArea($user);
- if ($user->rights->projet->lire && $userAccess > 0) {
- print '<tr class="oddeven">';
- // Ref
- print '<td>';
- print $projecttmp->getNomUrl(1);
- print '</td>';
- // Label
- print '<td>'.$obj->title.'</td>';
- print '<td>'.$obj->libelle.'</td>';
- // Date start
- print '<td class="center">'.dol_print_date($db->jdate($obj->do), "day").'</td>';
- // Date end
- print '<td class="center">'.dol_print_date($db->jdate($obj->de), "day").'</td>';
- // Opp amount
- print '<td class="right">';
- if ($obj->opp_status_code) {
- print price($obj->opp_amount, 1, '', 1, -1, -1, '');
- }
- print '</td>';
- // Opp status
- print '<td class="center">';
- if ($obj->opp_status_code) {
- print $langs->trans("OppStatus".$obj->opp_status_code);
- }
- print '</td>';
- // Opp percent
- print '<td class="right">';
- if ($obj->opp_percent) {
- print price($obj->opp_percent, 1, '', 1, 0).'%';
- }
- print '</td>';
- // Status
- print '<td class="right">'.$projecttmp->getLibStatut(5).'</td>';
- print '</tr>';
- }
- $i++;
- }
- } else {
- print '<tr class="oddeven"><td colspan="8"><span class="opacitymedium">'.$langs->trans("None").'</span></td></tr>';
- }
- $db->free($result);
- } else {
- dol_print_error($db);
- }
- print "</table>";
- print '</div>';
- print "<br>\n";
- }
- return $i;
- }
|