dolibarr 21.0.0-beta
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 * Copyright (C) 2024 MDW <mdeweerd@users.noreply.github.com>
6 * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 3 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
21 */
22
29// Load Dolibarr environment
30require '../main.inc.php';
31
32require_once DOL_DOCUMENT_ROOT.'/ticket/class/ticket.class.php';
33require_once DOL_DOCUMENT_ROOT.'/core/lib/ticket.lib.php';
34
35require_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php';
36require_once DOL_DOCUMENT_ROOT."/core/lib/company.lib.php";
37require_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php';
38require_once DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php';
39if (isModEnabled('project')) {
40 include_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
41 include_once DOL_DOCUMENT_ROOT.'/core/class/html.formprojet.class.php';
42 include_once DOL_DOCUMENT_ROOT.'/core/lib/project.lib.php';
43}
44
53// Load translation files required by the page
54$langs->loadLangs(array('companies', 'ticket'));
55
56// Get parameters
57$socid = GETPOSTINT("socid");
58$action = GETPOST("action", 'alpha');
59$track_id = GETPOST("track_id", 'alpha');
60$id = GETPOSTINT("id");
61$ref = GETPOST('ref', 'alpha');
62
63$type = GETPOST('type', 'alpha');
64$source = GETPOST('source', 'alpha');
65
66$ligne = GETPOSTINT('ligne');
67$lineid = GETPOSTINT('lineid');
68
69
70// Store current page url
71$url_page_current = DOL_URL_ROOT.'/ticket/contact.php';
72
73$hookmanager->initHooks(array('contactticketcard', 'globalcard'));
74$object = new Ticket($db);
75if ($id > 0 || $ref || $track_id) {
76 $result = $object->fetch($id, $ref, $track_id);
77}
78
79// Security check
80$id = GETPOSTINT("id");
81if ($user->socid > 0) {
82 $socid = $user->socid;
83}
84$result = restrictedArea($user, 'ticket', $object->id, '');
85
86// restrict access for externals users
87if ($user->socid > 0 && ($object->fk_soc != $user->socid)) {
89}
90// or for unauthorized internals users
91if (!$user->socid && (getDolGlobalString('TICKET_LIMIT_VIEW_ASSIGNED_ONLY') && $object->fk_user_assign != $user->id) && !$user->hasRight('ticket', 'manage')) {
93}
94
95$permissiontoadd = $user->hasRight('ticket', 'write');
96
97
98/*
99 * Actions
100 */
101$error = 0;
102$parameters = array();
103$reshook = $hookmanager->executeHooks('doActions', $parameters, $object, $action); // Note that $action and $object may have been modified by some hooks
104if ($reshook < 0) {
105 setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
106}
107
108if ($action == 'addcontact' && $user->hasRight('ticket', 'write')) {
109 $result = $object->fetch($id, '', $track_id);
110
111 if ($result > 0 && ($id > 0 || (!empty($track_id)))) {
112 $contactid = (GETPOSTINT('userid') ? GETPOSTINT('userid') : GETPOSTINT('contactid'));
113 $typeid = (GETPOST('typecontact') ? GETPOST('typecontact') : GETPOST('type'));
114
115 $codecontact = dol_getIdFromCode($db, $typeid, 'c_type_contact', 'rowid', 'code');
116 if ($codecontact == 'SUPPORTTEC') {
117 $internal_contacts = $object->listeContact(-1, 'internal', 0, 'SUPPORTTEC');
118 foreach ($internal_contacts as $key => $contact) {
119 if ($contact['id'] !== $contactid) {
120 //print "user à effacer : ".$useroriginassign;
121 $result = $object->delete_contact($contact['rowid']);
122 if ($result < 0) {
123 $error++;
124 setEventMessages($object->error, $object->errors, 'errors');
125 }
126 }
127 }
128 $ret = $object->assignUser($user, $contactid);
129 if ($ret < 0) {
130 $error++;
131 setEventMessages($object->error, $object->errors, 'errors');
132 }
133 }
134
135 if (empty($error)) {
136 $result = $object->add_contact($contactid, $typeid, GETPOST("source", 'aZ09'));
137 }
138 }
139
140 if ($result >= 0) {
141 header("Location: ".$url_page_current."?id=".$object->id);
142 exit;
143 } else {
144 if ($object->error == 'DB_ERROR_RECORD_ALREADY_EXISTS') {
145 $langs->load("errors");
146 setEventMessages($langs->trans("ErrorThisContactIsAlreadyDefinedAsThisType"), null, 'errors');
147 } else {
148 setEventMessages($object->error, $object->errors, 'errors');
149 }
150 }
151}
152
153// bascule du statut d'un contact
154if ($action == 'swapstatut' && $user->hasRight('ticket', 'write')) {
155 if ($object->fetch($id, '', $track_id)) {
156 $result = $object->swapContactStatus($ligne);
157 } else {
158 dol_print_error($db, $object->error);
159 }
160}
161
162// Efface un contact
163if ($action == 'deletecontact' && $user->hasRight('ticket', 'write')) {
164 if ($object->fetch($id, '', $track_id)) {
165 $internal_contacts = $object->listeContact(-1, 'internal', 0, 'SUPPORTTEC');
166 foreach ($internal_contacts as $key => $contact) {
167 if ($contact['rowid'] == $lineid && $object->fk_user_assign == $contact['id']) {
168 $ret = $object->assignUser($user, 0);
169 if ($ret < 0) {
170 $error++;
171 setEventMessages($object->error, $object->errors, 'errors');
172 }
173 }
174 }
175 $result = $object->delete_contact($lineid);
176
177 if ($result >= 0) {
178 header("Location: ".$url_page_current."?id=".$object->id);
179 exit;
180 }
181 }
182}
183
184// Set parent company
185if ($action == 'set_thirdparty' && $user->hasRight('ticket', 'write')) {
186 if ($object->fetch(GETPOSTINT('id'), '', GETPOST('track_id', 'alpha')) >= 0) {
187 $result = $object->setCustomer(GETPOSTINT('editcustomer'));
188 $url = $_SERVER["PHP_SELF"].'?track_id='.GETPOST('track_id', 'alpha');
189 header("Location: ".$url);
190 exit();
191 }
192}
193
194
195/*
196 * View
197 */
198
199$help_url = 'FR:DocumentationModuleTicket';
200llxHeader('', $langs->trans("TicketContacts"), $help_url, '', 0, 0, '', '', '', 'mod-ticket page-card_contacts');
201
202$form = new Form($db);
203$formcompany = new FormCompany($db);
204$contactstatic = new Contact($db);
205$userstatic = new User($db);
206
207if ($id > 0 || !empty($track_id) || !empty($ref)) {
208 if ($object->fetch($id, $ref, $track_id) > 0) {
209 if ($socid > 0) {
210 $object->fetch_thirdparty();
211 $head = societe_prepare_head($object->thirdparty);
212 print dol_get_fiche_head($head, 'ticket', $langs->trans("ThirdParty"), 0, 'company');
213 dol_banner_tab($object->thirdparty, 'socid', '', ($user->socid ? 0 : 1), 'rowid', 'nom');
214 print dol_get_fiche_end();
215 }
216
217 if (!$user->socid && getDolGlobalString('TICKET_LIMIT_VIEW_ASSIGNED_ONLY')) {
218 $object->next_prev_filter = "te.fk_user_assign:=:'".((int) $user->id);
219 } elseif ($user->socid > 0) {
220 $object->next_prev_filter = "te.fk_soc:=:".((int) $user->socid);
221 }
222
223 $head = ticket_prepare_head($object);
224
225 print dol_get_fiche_head($head, 'contact', $langs->trans("Ticket"), -1, 'ticket');
226
227 $morehtmlref = '<div class="refidno">';
228 $morehtmlref .= $object->subject;
229 // Author
230 if ($object->fk_user_create > 0) {
231 $morehtmlref .= '<br>'.$langs->trans("CreatedBy").' : ';
232
233 $fuser = new User($db);
234 $fuser->fetch($object->fk_user_create);
235 $morehtmlref .= $fuser->getNomUrl(-1);
236 } elseif (!empty($object->email_msgid)) {
237 $morehtmlref .= '<br>'.$langs->trans("CreatedBy").' : ';
238 $morehtmlref .= img_picto('', 'email', 'class="paddingrightonly"');
239 $morehtmlref .= dol_escape_htmltag($object->origin_email).' <small class="hideonsmartphone opacitymedium">('.$form->textwithpicto($langs->trans("CreatedByEmailCollector"), $langs->trans("EmailMsgID").': '.$object->email_msgid).')</small>';
240 } elseif (!empty($object->origin_email)) {
241 $morehtmlref .= '<br>'.$langs->trans("CreatedBy").' : ';
242 $morehtmlref .= img_picto('', 'email', 'class="paddingrightonly"');
243 $morehtmlref .= dol_escape_htmltag($object->origin_email).' <small class="hideonsmartphone opacitymedium">('.$langs->trans("CreatedByPublicPortal").')</small>';
244 }
245
246 // Thirdparty
247 if (isModEnabled("societe")) {
248 $morehtmlref .= '<br>';
249 $morehtmlref .= img_picto($langs->trans("ThirdParty"), 'company', 'class="pictofixedwidth"');
250 if ($action != 'editcustomer' && $permissiontoadd) {
251 $morehtmlref .= '<a class="editfielda" href="'.$url_page_current.'?action=editcustomer&token='.newToken().'&track_id='.$object->track_id.'">'.img_edit($langs->transnoentitiesnoconv('SetThirdParty'), 0).'</a> ';
252 }
253 $morehtmlref .= $form->form_thirdparty($url_page_current.'?track_id='.$object->track_id, $object->socid, $action == 'editcustomer' ? 'editcustomer' : 'none', '', 1, 0, 0, array(), 1);
254 }
255
256 // Project
257 if (isModEnabled('project')) {
258 $langs->load("projects");
259 if (0) {
260 $morehtmlref .= '<br>';
261 $morehtmlref .= img_picto($langs->trans("Project"), 'project', 'class="pictofixedwidth"');
262 if ($action != 'classify') {
263 $morehtmlref .= '<a class="editfielda" href="'.$_SERVER['PHP_SELF'].'?action=classify&token='.newToken().'&id='.$object->id.'">'.img_edit($langs->transnoentitiesnoconv('SetProject')).'</a> ';
264 }
265 $morehtmlref .= $form->form_project($_SERVER['PHP_SELF'].'?id='.$object->id, $object->socid, $object->fk_project, ($action == 'classify' ? 'projectid' : 'none'), 0, 0, 0, 1, '', 'maxwidth300');
266 } else {
267 if (!empty($object->fk_project)) {
268 $morehtmlref .= '<br>';
269 $proj = new Project($db);
270 $proj->fetch($object->fk_project);
271 $morehtmlref .= $proj->getNomUrl(1);
272 if ($proj->title) {
273 $morehtmlref .= '<span class="opacitymedium"> - '.dol_escape_htmltag($proj->title).'</span>';
274 }
275 }
276 }
277 }
278
279 $morehtmlref .= '</div>';
280
281 $linkback = '<a href="'.dol_buildpath('/ticket/list.php', 1).'"><strong>'.$langs->trans("BackToList").'</strong></a> ';
282
283 dol_banner_tab($object, 'ref', $linkback, (empty($user->socid) ? 1 : 0), 'ref', 'ref', $morehtmlref, '', 0, '', '', 1, '');
284
285 print dol_get_fiche_end();
286
287 //print '<br>';
288
289 $permission = $user->hasRight('ticket', 'write');
290
291 // Contacts lines (modules that overwrite templates must declare this into descriptor)
292 $dirtpls = array_merge($conf->modules_parts['tpl'], array('/core/tpl'));
293 foreach ($dirtpls as $reldir) {
294 $res = @include dol_buildpath($reldir.'/contacts.tpl.php');
295 if ($res) {
296 break;
297 }
298 }
299 } else {
300 print "ErrorRecordNotFound";
301 }
302}
303
304// End of page
305llxFooter();
306$db->close();
$id
Definition account.php:48
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
Definition card.php:66
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Definition wrapper.php:71
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.
societe_prepare_head(Societe $object)
Return array of tabs to used on pages for third parties cards.
llxFooter()
Footer empty.
Definition document.php:107
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
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.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
img_edit($titlealt='default', $float=0, $other='')
Show logo edit/modify fiche.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
Definition member.php:79
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.