dolibarr  17.0.4
contact.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2011-2016 Jean-François Ferry <hello@librethic.io>
3  * Copyright (C) 2011 Regis Houssin <regis.houssin@inodbox.com>
4  * Copyright (C) 2016 Christophe Battarel <christophe@altairis.fr>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19  */
20 
27 // Load Dolibarr environment
28 require '../main.inc.php';
29 
30 require_once DOL_DOCUMENT_ROOT.'/ticket/class/ticket.class.php';
31 require_once DOL_DOCUMENT_ROOT.'/core/lib/ticket.lib.php';
32 
33 require_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php';
34 require_once DOL_DOCUMENT_ROOT."/core/lib/company.lib.php";
35 require_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php';
36 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php';
37 if (isModEnabled('project')) {
38  include_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
39  include_once DOL_DOCUMENT_ROOT.'/core/class/html.formprojet.class.php';
40  include_once DOL_DOCUMENT_ROOT.'/core/lib/project.lib.php';
41 }
42 
43 // Load translation files required by the page
44 $langs->loadLangs(array('companies', 'ticket'));
45 
46 // Get parameters
47 $socid = GETPOST("socid", 'int');
48 $action = GETPOST("action", 'alpha');
49 $track_id = GETPOST("track_id", 'alpha');
50 $id = GETPOST("id", 'int');
51 $ref = GETPOST('ref', 'alpha');
52 
53 $type = GETPOST('type', 'alpha');
54 $source = GETPOST('source', 'alpha');
55 
56 $ligne = GETPOST('ligne', 'int');
57 $lineid = GETPOST('lineid', 'int');
58 
59 
60 // Store current page url
61 $url_page_current = DOL_URL_ROOT.'/ticket/contact.php';
62 
63 $object = new Ticket($db);
64 
65 
66 $permissiontoadd = $user->rights->ticket->write;
67 
68 // Security check
69 $id = GETPOST("id", 'int');
70 if ($user->socid > 0) $socid = $user->socid;
71 $result = restrictedArea($user, 'ticket', $object->id, '');
72 
73 // restrict access for externals users
74 if ($user->socid > 0 && ($object->fk_soc != $user->socid)) {
76 }
77 // or for unauthorized internals users
78 if (!$user->socid && (!empty($conf->global->TICKET_LIMIT_VIEW_ASSIGNED_ONLY) && $object->fk_user_assign != $user->id) && !$user->rights->ticket->manage) {
80 }
81 
82 
83 /*
84  * Actions
85  */
86 
87 if ($action == 'addcontact' && $user->rights->ticket->write) {
88  $result = $object->fetch($id, '', $track_id);
89 
90  if ($result > 0 && ($id > 0 || (!empty($track_id)))) {
91  $contactid = (GETPOST('userid', 'int') ? GETPOST('userid', 'int') : GETPOST('contactid', 'int'));
92  $typeid = (GETPOST('typecontact') ? GETPOST('typecontact') : GETPOST('type'));
93 
94  $error = 0;
95 
96  $codecontact = dol_getIdFromCode($db, $typeid, 'c_type_contact', 'rowid', 'code');
97  if ($codecontact=='SUPPORTTEC') {
98  $internal_contacts = $object->listeContact(-1, 'internal', 0, 'SUPPORTTEC');
99  foreach ($internal_contacts as $key => $contact) {
100  if ($contact['id'] !== $contactid) {
101  //print "user à effacer : ".$useroriginassign;
102  $result = $object->delete_contact($contact['rowid']);
103  if ($result<0) {
104  $error ++;
105  setEventMessages($object->error, $object->errors, 'errors');
106  }
107  }
108  }
109  $ret = $object->assignUser($user, $contactid);
110  if ($ret < 0) {
111  $error ++;
112  setEventMessages($object->error, $object->errors, 'errors');
113  }
114  }
115 
116  if (empty($error)) {
117  $result = $object->add_contact($contactid, $typeid, GETPOST("source", 'aZ09'));
118  }
119  }
120 
121  if ($result >= 0) {
122  Header("Location: ".$url_page_current."?id=".$object->id);
123  exit;
124  } else {
125  if ($object->error == 'DB_ERROR_RECORD_ALREADY_EXISTS') {
126  $langs->load("errors");
127  setEventMessages($langs->trans("ErrorThisContactIsAlreadyDefinedAsThisType"), null, 'errors');
128  } else {
129  setEventMessages($object->error, $object->errors, 'errors');
130  }
131  }
132 }
133 
134 // bascule du statut d'un contact
135 if ($action == 'swapstatut' && $user->rights->ticket->write) {
136  if ($object->fetch($id, '', $track_id)) {
137  $result = $object->swapContactStatus($ligne);
138  } else {
139  dol_print_error($db, $object->error);
140  }
141 }
142 
143 // Efface un contact
144 if ($action == 'deletecontact' && $user->rights->ticket->write) {
145  if ($object->fetch($id, '', $track_id)) {
146  $internal_contacts = $object->listeContact(-1, 'internal', 0, 'SUPPORTTEC');
147  foreach ($internal_contacts as $key => $contact) {
148  if ($contact['rowid'] == $lineid && $object->fk_user_assign==$contact['id']) {
149  $ret = $object->assignUser($user, null);
150  if ($ret < 0) {
151  $error ++;
152  setEventMessages($object->error, $object->errors, 'errors');
153  }
154  }
155  }
156  $result = $object->delete_contact($lineid);
157 
158  if ($result >= 0) {
159  Header("Location: ".$url_page_current."?id=".$object->id);
160  exit;
161  }
162  }
163 }
164 
165 
166 
167 /*
168  * View
169  */
170 
171 $help_url = 'FR:DocumentationModuleTicket';
172 llxHeader('', $langs->trans("TicketContacts"), $help_url);
173 
174 $form = new Form($db);
175 $formcompany = new FormCompany($db);
176 $contactstatic = new Contact($db);
177 $userstatic = new User($db);
178 
179 if ($id > 0 || !empty($track_id) || !empty($ref)) {
180  if ($object->fetch($id, $ref, $track_id) > 0) {
181  if ($socid > 0) {
182  $object->fetch_thirdparty();
183  $head = societe_prepare_head($object->thirdparty);
184  print dol_get_fiche_head($head, 'ticket', $langs->trans("ThirdParty"), 0, 'company');
185  dol_banner_tab($object->thirdparty, 'socid', '', ($user->socid ? 0 : 1), 'rowid', 'nom');
186  print dol_get_fiche_end();
187  }
188 
189  if (!$user->socid && !empty($conf->global->TICKET_LIMIT_VIEW_ASSIGNED_ONLY)) {
190  $object->next_prev_filter = "te.fk_user_assign = '".$user->id."'";
191  } elseif ($user->socid > 0) {
192  $object->next_prev_filter = "te.fk_soc = '".$user->socid."'";
193  }
194 
195  $head = ticket_prepare_head($object);
196 
197  print dol_get_fiche_head($head, 'contact', $langs->trans("Ticket"), -1, 'ticket');
198 
199  $morehtmlref = '<div class="refidno">';
200  $morehtmlref .= $object->subject;
201  // Author
202  if ($object->fk_user_create > 0) {
203  $morehtmlref .= '<br>'.$langs->trans("CreatedBy").' : ';
204 
205  $fuser = new User($db);
206  $fuser->fetch($object->fk_user_create);
207  $morehtmlref .= $fuser->getNomUrl(-1);
208  } elseif (!empty($object->email_msgid)) {
209  $morehtmlref .= '<br>'.$langs->trans("CreatedBy").' : ';
210  $morehtmlref .= img_picto('', 'email', 'class="paddingrightonly"');
211  $morehtmlref .= dol_escape_htmltag($object->origin_email).' <small class="hideonsmartphone opacitymedium">('.$form->textwithpicto($langs->trans("CreatedByEmailCollector"), $langs->trans("EmailMsgID").': '.$object->email_msgid).')</small>';
212  } elseif (!empty($object->origin_email)) {
213  $morehtmlref .= '<br>'.$langs->trans("CreatedBy").' : ';
214  $morehtmlref .= img_picto('', 'email', 'class="paddingrightonly"');
215  $morehtmlref .= dol_escape_htmltag($object->origin_email).' <small class="hideonsmartphone opacitymedium">('.$langs->trans("CreatedByPublicPortal").')</small>';
216  }
217 
218  // Thirdparty
219  if (isModEnabled("societe")) {
220  $morehtmlref .= '<br>';
221  $morehtmlref .= img_picto($langs->trans("ThirdParty"), 'company', 'class="pictofixedwidth"');
222  if ($action != 'editcustomer' && 0) {
223  $morehtmlref .= '<a class="editfielda" href="'.$url_page_current.'?action=editcustomer&token='.newToken().'&track_id='.$object->track_id.'">'.img_edit($langs->transnoentitiesnoconv('SetThirdParty'), 0).'</a> ';
224  }
225  $morehtmlref .= $form->form_thirdparty($url_page_current.'?track_id='.$object->track_id, $object->socid, $action == 'editcustomer' ? 'editcustomer' : 'none', '', 1, 0, 0, array(), 1);
226  }
227 
228  // Project
229  if (isModEnabled('project')) {
230  $langs->load("projects");
231  if (0) {
232  $morehtmlref .= '<br>';
233  $morehtmlref .= img_picto($langs->trans("Project"), 'project', 'class="pictofixedwidth"');
234  if ($action != 'classify') {
235  $morehtmlref .= '<a class="editfielda" href="'.$_SERVER['PHP_SELF'].'?action=classify&token='.newToken().'&id='.$object->id.'">'.img_edit($langs->transnoentitiesnoconv('SetProject')).'</a> ';
236  }
237  $morehtmlref .= $form->form_project($_SERVER['PHP_SELF'].'?id='.$object->id, $object->socid, $object->fk_project, ($action == 'classify' ? 'projectid' : 'none'), 0, 0, 0, 1, '', 'maxwidth300');
238  } else {
239  if (!empty($object->fk_project)) {
240  $morehtmlref .= '<br>';
241  $proj = new Project($db);
242  $proj->fetch($object->fk_project);
243  $morehtmlref .= $proj->getNomUrl(1);
244  if ($proj->title) {
245  $morehtmlref .= '<span class="opacitymedium"> - '.dol_escape_htmltag($proj->title).'</span>';
246  }
247  }
248  }
249  }
250 
251  $morehtmlref .= '</div>';
252 
253  $linkback = '<a href="'.dol_buildpath('/ticket/list.php', 1).'"><strong>'.$langs->trans("BackToList").'</strong></a> ';
254 
255  dol_banner_tab($object, 'ref', $linkback, (!empty($user->socid) ? 0 : 1), 'ref', 'ref', $morehtmlref, '', 0, '', '', 1, '');
256 
257  print dol_get_fiche_end();
258 
259  //print '<br>';
260 
261  $permission = $user->rights->ticket->write;
262 
263  // Contacts lines (modules that overwrite templates must declare this into descriptor)
264  $dirtpls = array_merge($conf->modules_parts['tpl'], array('/core/tpl'));
265  foreach ($dirtpls as $reldir) {
266  $res = @include dol_buildpath($reldir.'/contacts.tpl.php');
267  if ($res) {
268  break;
269  }
270  }
271  } else {
272  print "ErrorRecordNotFound";
273  }
274 }
275 
276 // End of page
277 llxFooter();
278 $db->close();
if(GETPOST('button_removefilter_x', 'alpha')||GETPOST('button_removefilter.x', 'alpha')||GETPOST('button_removefilter', 'alpha')) if(GETPOST('button_search_x', 'alpha')||GETPOST('button_search.x', 'alpha')||GETPOST('button_search', 'alpha')) if($action=="save" &&empty($cancel)) $help_url
View.
Definition: agenda.php:118
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
Definition: wrapper.php:56
llxFooter()
Empty footer.
Definition: wrapper.php:70
Class to manage contact/addresses.
Class to build HTML component for third parties management Only common components are here.
Class to manage generation of HTML components Only common components must be here.
Class to manage projects.
Class to manage Dolibarr users.
Definition: user.class.php:47
societe_prepare_head(Societe $object)
Return array of tabs to used on pages for third parties cards.
Definition: company.lib.php:42
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
Definition: card.php:143
dol_banner_tab($object, $paramid, $morehtml='', $shownav=1, $fieldid='rowid', $fieldref='ref', $morehtmlref='', $moreparam='', $nodbprefix=0, $morehtmlleft='', $morehtmlstatus='', $onlybanner=0, $morehtmlright='')
Show tab footer of a card.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='')
Show tabs of a record.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0)
Returns text escaped for inclusion in HTML alt or title tags, or into values of HTML input fields.
dol_print_error($db='', $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_get_fiche_end($notab=0)
Return tab footer of a card.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='')
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
dol_getIdFromCode($db, $key, $tablename, $fieldkey='code', $fieldid='id', $entityfilter=0, $filters='')
Return an id or code from a code or id.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
isModEnabled($module)
Is Dolibarr module enabled.
img_edit($titlealt='default', $float=0, $other='')
Show logo editer/modifier fiche.
Class to generate the form for creating a new ticket.
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.
ticket_prepare_head($object)
Build tabs for a Ticket object.
Definition: ticket.lib.php:83