dolibarr 22.0.5
list.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2013-2016 Jean-François FERRY <jfefe@aternatik.fr>
3 * Copyright (C) 2024-2025 MDW <mdeweerd@users.noreply.github.com>
4 * Copyright (C) 2024 Frédéric France <frederic.france@free.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, see <https://www.gnu.org/licenses/>.
18 */
19
26if (!defined('NOREQUIREMENU')) {
27 define('NOREQUIREMENU', '1');
28}
29// If there is no need to load and show top and left menu
30if (!defined("NOLOGIN")) {
31 define("NOLOGIN", '1');
32}
33if (!defined('NOIPCHECK')) {
34 define('NOIPCHECK', '1'); // Do not check IP defined into conf $dolibarr_main_restrict_ip
35}
36if (!defined('NOBROWSERNOTIF')) {
37 define('NOBROWSERNOTIF', '1');
38}
39// If this page is public (can be called outside logged session)
40
41// For MultiCompany module.
42// Do not use GETPOST here, function is not defined and define must be done before including main.inc.php
43// Because 2 entities can have the same ref.
44$entity = (!empty($_GET['entity']) ? (int) $_GET['entity'] : (!empty($_POST['entity']) ? (int) $_POST['entity'] : 1));
45if (is_numeric($entity)) {
46 define("DOLENTITY", $entity);
47}
48
49// Load Dolibarr environment
50require '../../main.inc.php';
51require_once DOL_DOCUMENT_ROOT.'/ticket/class/actions_ticket.class.php';
52require_once DOL_DOCUMENT_ROOT.'/core/class/html.formticket.class.php';
53require_once DOL_DOCUMENT_ROOT.'/core/class/CMailFile.class.php';
54require_once DOL_DOCUMENT_ROOT.'/core/lib/ticket.lib.php';
55require_once DOL_DOCUMENT_ROOT.'/core/lib/security.lib.php';
56require_once DOL_DOCUMENT_ROOT.'/core/lib/company.lib.php';
57require_once DOL_DOCUMENT_ROOT.'/core/lib/payments.lib.php';
58
67// Load translation files required by the page
68$langs->loadLangs(array("companies", "other", "ticket"));
69
70// Get parameters
71$action = GETPOST('action', 'aZ09');
72$cancel = GETPOST('cancel');
73
74$track_id = GETPOST('track_id', 'alpha');
75$email = strtolower(GETPOST('email', 'alpha'));
76$suffix = "";
77$moreforfilter = "";
78
79if (GETPOST('btn_view_ticket_list')) {
80 unset($_SESSION['track_id_customer']);
81 unset($_SESSION['email_customer']);
82}
83if (empty($track_id) && isset($_SESSION['track_id_customer'])) {
84 $track_id = $_SESSION['track_id_customer'];
85}
86if (empty($email) && isset($_SESSION['email_customer'])) {
87 $email = strtolower($_SESSION['email_customer']);
88}
89
90$object = new Ticket($db);
91
92// Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context
93$hookmanager->initHooks(array('ticketpubliclist', 'globalcard'));
94
95if (!isModEnabled('ticket')) {
96 httponly_accessforbidden('Module Ticket not enabled');
97}
98
99
100/*
101 * Actions
102 */
103
104if ($cancel) {
105 $backtopage = getDolGlobalString('TICKET_URL_PUBLIC_INTERFACE', DOL_URL_ROOT.'/public/ticket/');
106
107 header("Location: ".$backtopage);
108 exit;
109}
110
111
112/*
113 * View
114 */
115
116$form = new Form($db);
117$user_assign = new User($db);
118$user_create = new User($db);
119$formTicket = new FormTicket($db);
120
121if (!getDolGlobalString('TICKET_ENABLE_PUBLIC_INTERFACE')) {
122 print '<div class="error">'.$langs->trans('TicketPublicInterfaceForbidden').'</div>';
123 $db->close();
124 exit();
125}
126
127$arrayofjs = array();
128$arrayofcss = array(getDolGlobalString('TICKET_URL_PUBLIC_INTERFACE', '/public/ticket/').'css/styles.css.php');
129
130llxHeaderTicket($langs->trans("Tickets"), "", 0, 0, $arrayofjs, $arrayofcss);
131
132$display_ticket_list = false;
133
134// Load the ticket from track_id
135if ($action == "view_ticketlist") {
136 $error = 0;
137 if (!strlen($track_id)) {
138 $error++;
139 array_push($object->errors, $langs->trans("ErrorFieldRequired", $langs->transnoentities("TicketTrackId")));
140 $action = '';
141 }
142
143 if (!strlen($email)) {
144 $error++;
145 array_push($object->errors, $langs->trans("ErrorFieldRequired", $langs->transnoentities("Email")));
146 $action = '';
147 } else {
148 if (!isValidEmail($email)) {
149 $error++;
150 array_push($object->errors, $langs->trans("ErrorEmailOrTrackingInvalid"));
151 $action = '';
152 }
153 }
154
155 if (!$error) {
156 $ret = $object->fetch(0, '', $track_id);
157
158 if ($ret && $object->id > 0) {
159 // vérifie si l'adresse email est bien dans les contacts du ticket
160 $contacts = $object->liste_contact(-1, 'external');
161 foreach ($contacts as $contact) {
162 if (strtolower($contact['email']) == $email) {
163 $display_ticket_list = true;
164 $_SESSION['email_customer'] = $email;
165 $_SESSION['track_id_customer'] = $track_id;
166 break;
167 } else {
168 $display_ticket_list = false;
169 }
170 }
171 if ($object->fk_soc > 0) {
172 $object->fetch_thirdparty();
173 if ($email == strtolower($object->thirdparty->email)) {
174 $display_ticket_list = true;
175 $_SESSION['email_customer'] = $email;
176 $_SESSION['track_id_customer'] = $track_id;
177 }
178 }
179 if ($object->fk_user_create > 0) {
180 $tmpuser = new User($db);
181 $tmpuser->fetch($object->fk_user_create);
182 if ($email == strtolower($tmpuser->email)) {
183 $display_ticket_list = true;
184 $_SESSION['email_customer'] = $email;
185 $_SESSION['track_id_customer'] = $track_id;
186 }
187 }
188
189 $emailorigin = strtolower(CMailFile::getValidAddress($object->origin_email, 2));
190 if ($email == $emailorigin) {
191 $display_ticket_list = true;
192 $_SESSION['email_customer'] = $email;
193 $_SESSION['track_id_customer'] = $track_id;
194 }
195 } else {
196 $error++;
197 array_push($object->errors, $langs->trans("ErrorTicketNotFound", $track_id));
198 $action = '';
199 }
200 }
201
202 if ($error) {
203 setEventMessages($object->error, $object->errors, 'errors');
204 $action = '';
205 }
206}
207
208
209if ($action == "view_ticketlist") {
210 print '<div class="ticketpublicarealist ticketlargemargin">';
211
212 print '<br>';
213 if ($display_ticket_list) {
214 // Filters
215 $search_fk_status = GETPOST("search_fk_status", 'alpha');
216 $search_subject = GETPOST("search_subject", 'alpha');
217 $search_type = GETPOST("search_type", 'alpha');
218 $search_category = GETPOST("search_category", 'alpha');
219 $search_severity = GETPOST("search_severity", 'alpha');
220 $search_fk_user_create = GETPOST("search_fk_user_create", "intcomma");
221 $search_fk_user_assign = GETPOST("search_fk_user_assign", "intcomma");
222
223 // Store current page url
224 $url_page_current = dol_buildpath('/public/ticket/list.php', 1);
225 $contextpage = $url_page_current;
226
227 // Do we click on purge search criteria ?
228 if (GETPOST("button_removefilter_x")) {
229 $search_fk_status = '';
230 $search_subject = '';
231 $search_type = '';
232 $search_category = '';
233 $search_severity = '';
234 $search_fk_user_create = '';
235 $search_fk_user_assign = '';
236 }
237
238 // fetch optionals attributes and labels
239 $extrafields = new ExtraFields($db);
240 $extrafields->fetch_name_optionals_label($object->table_element);
241
242 $search_array_options = $extrafields->getOptionalsFromPost($object->table_element, '', 'search_');
243
244 $filter = array();
245
246 $param = '&action=view_ticketlist';
247 if (!empty($entity) && isModEnabled('multicompany')) {
248 $param .= '&entity='.((int) $entity);
249 }
250
251 $param .= '&token='.newToken();
252
253 // Definition of fields for list
254 $arrayfields = array(
255 't.datec' => array('label' => $langs->trans("Date"), 'checked' => '1'),
256 't.date_read' => array('label' => $langs->trans("TicketReadOn"), 'checked' => '0'),
257 't.date_close' => array('label' => $langs->trans("TicketCloseOn"), 'checked' => '0'),
258 't.ref' => array('label' => $langs->trans("Ref"), 'checked' => '1'),
259 //'t.track_id' => array('label' => $langs->trans("IDTracking"), 'checked' => '0'),
260 't.fk_statut' => array('label' => $langs->trans("Status"), 'checked' => '1'),
261 't.subject' => array('label' => $langs->trans("Subject"), 'checked' => '1'),
262 'type.code' => array('label' => $langs->trans("Type"), 'checked' => '1'),
263 'category.code' => array('label' => $langs->trans("Category"), 'checked' => '1'),
264 'severity.code' => array('label' => $langs->trans("Severity"), 'checked' => '1'),
265 't.progress' => array('label' => $langs->trans("Progression"), 'checked' => '0'),
266 //'t.fk_contract' => array('label' => $langs->trans("Contract"), 'checked' => '0'),
267 't.fk_user_create' => array('label' => $langs->trans("Author"), 'checked' => '1'),
268 't.fk_user_assign' => array('label' => $langs->trans("AssignedTo"), 'checked' => '0'),
269
270 //'t.entity'=>array('label'=>$langs->trans("Entity"), 'checked' => '1', 'enabled'=>(isModEnabled('multicompany') && empty($conf->multicompany->transverse_mode))),
271 //'t.datec' => array('label' => $langs->trans("DateCreation"), 'checked' => '0', 'position' => 500),
272 //'t.tms' => array('label' => $langs->trans("DateModificationShort"), 'checked' => '0', 'position' => 2)
273 //'t.statut'=>array('label'=>$langs->trans("Status"), 'checked' => '1', 'position'=>1000),
274 );
275
276 if (!getDolGlobalString('TICKET_SHOW_PROGRESSION')) {
277 unset($arrayfields['t.progress']);
278 }
279
280 // Extra fields
281 include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_array_fields.tpl.php';
282
283 if (!empty($search_subject)) {
284 $filter['t.subject'] = $search_subject;
285 $param .= '&search_subject='.urlencode($search_subject);
286 }
287 if (!empty($search_type)) {
288 $filter['t.type_code'] = $search_type;
289 $param .= '&search_type='.urlencode($search_type);
290 }
291 if (!empty($search_category)) {
292 $filter['t.category_code'] = $search_category;
293 $param .= '&search_category='.urlencode($search_category);
294 }
295 if (!empty($search_severity)) {
296 $filter['t.severity_code'] = $search_severity;
297 $param .= '&search_severity='.urlencode($search_severity);
298 }
299 if (!empty($search_fk_user_assign)) {
300 // -1 value = all so no filter
301 if ($search_fk_user_assign > 0) {
302 $filter['t.fk_user_assign'] = $search_fk_user_assign;
303 $param .= '&search_fk_user_assign='.urlencode((string) ($search_fk_user_assign));
304 }
305 }
306 if (!empty($search_fk_user_create)) {
307 // -1 value = all so no filter
308 if ($search_fk_user_create > 0) {
309 $filter['t.fk_user_create'] = $search_fk_user_create;
310 $param .= '&search_fk_user_create='.urlencode((string) ($search_fk_user_create));
311 }
312 }
313 if ((isset($search_fk_status) && $search_fk_status != '') && $search_fk_status != '-1' && $search_fk_status != 'non_closed') {
314 $filter['t.fk_statut'] = $search_fk_status;
315 $param .= '&search_fk_status='.urlencode($search_fk_status);
316 }
317 if (isset($search_fk_status) && $search_fk_status == 'non_closed') {
318 $filter['t.fk_statut'] = array(0, 1, 3, 4, 5, 6);
319 $param .= '&search_fk_statut=openall';
320 }
321
322 require DOL_DOCUMENT_ROOT.'/core/actions_changeselectedfields.inc.php';
323
324 $sortfield = GETPOST('sortfield', 'aZ09comma');
325 $sortorder = GETPOST('sortorder', 'aZ09comma');
326
327 if (!$sortfield) {
328 $sortfield = 't.datec';
329 }
330 if (!$sortorder) {
331 $sortorder = 'DESC';
332 }
333
334 $limit = $conf->liste_limit;
335
336 $page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page");
337 if (empty($page) || $page == -1) {
338 $page = 0;
339 } // If $page is not defined, or '' or -1
340 $offset = $limit * $page;
341 $pageprev = $page - 1;
342 $pagenext = $page + 1;
343
344 // Request SQL
345 $sql = "SELECT DISTINCT";
346 $sql .= " t.rowid,";
347 $sql .= " t.ref,";
348 $sql .= " t.track_id,";
349 $sql .= " t.fk_soc,";
350 $sql .= " t.fk_project,";
351 $sql .= " t.origin_email,";
352 $sql .= " t.fk_user_create, uc.lastname as user_create_lastname, uc.firstname as user_create_firstname,";
353 $sql .= " t.fk_user_assign, ua.lastname as user_assign_lastname, ua.firstname as user_assign_firstname,";
354 $sql .= " t.subject,";
355 $sql .= " t.message,";
356 $sql .= " t.fk_statut,";
357 $sql .= " t.resolution,";
358 if (getDolGlobalString('TICKET_SHOW_PROGRESSION')) {
359 $sql .= " t.progress,";
360 }
361 $sql .= " t.timing,";
362 $sql .= " t.type_code,";
363 $sql .= " t.category_code,";
364 $sql .= " t.severity_code,";
365 $sql .= " t.datec,";
366 $sql .= " t.date_read,";
367 $sql .= " t.date_close,";
368 $sql .= " t.tms,";
369 $sql .= " type.label as type_label, category.label as category_label, severity.label as severity_label";
370 // Add fields for extrafields
371 if (isset($extrafields->attributes[$object->table_element]['label']) && is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) {
372 foreach ($extrafields->attributes[$object->table_element]['label'] as $key => $val) {
373 $sql .= ($extrafields->attributes[$object->table_element]['type'][$key] != 'separate' ? ", ef.".$key." as options_".$key : '');
374 }
375 }
376 $sql .= " FROM ".MAIN_DB_PREFIX."ticket as t";
377 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."c_ticket_type as type ON type.code = t.type_code";
378 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."c_ticket_category as category ON category.code = t.category_code";
379 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."c_ticket_severity as severity ON severity.code = t.severity_code";
380 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."societe as s ON s.rowid = t.fk_soc";
381 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."user as uc ON uc.rowid = t.fk_user_create";
382 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."user as ua ON ua.rowid = t.fk_user_assign";
383 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."element_contact as ec ON ec.element_id = t.rowid";
384 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."c_type_contact as tc ON ec.fk_c_type_contact = tc.rowid";
385 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."socpeople sp ON ec.fk_socpeople = sp.rowid";
386 if (isset($extrafields->attributes[$object->table_element]['label']) && is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) {
387 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."ticket_extrafields as ef on (t.rowid = ef.fk_object)";
388 }
389 $sql .= " WHERE t.entity IN (".getEntity('ticket').")";
390 $sql .= " AND ((tc.source = 'external'";
391 $sql .= " AND tc.element = '".$db->escape($object->element)."'";
392 $sql .= " AND tc.active = 1";
393 $sql .= " AND sp.email = '".$db->escape($_SESSION['email_customer'])."')"; // email found into an external contact
394 $sql .= " OR s.email = '".$db->escape($_SESSION['email_customer'])."'"; // or email of the linked company
395 $sql .= " OR t.origin_email = '".$db->escape($_SESSION['email_customer'])."')"; // or email of the requester
396 // Manage filter
397 if (!empty($filter)) {
398 foreach ($filter as $key => $value) {
399 if (strpos($key, 'date')) { // To allow $filter['YEAR(s.dated)']=>$year
400 $sql .= " AND ".$db->sanitize($key)." = '".$db->escape($value)."'";
401 } elseif (($key == 't.fk_user_assign') || ($key == 't.type_code') || ($key == 't.category_code') || ($key == 't.severity_code')) {
402 $sql .= " AND ".$db->sanitize($key)." = '".$db->escape($value)."'";
403 } elseif ($key == 't.fk_statut') {
404 if (is_array($value) && count($value) > 0) {
405 $sql .= " AND ".$db->sanitize($key)." IN (".$db->sanitize(implode(',', $value)).")";
406 } else {
407 $sql .= " AND ".$db->sanitize($key)." = ".((int) $value);
408 }
409 } else {
410 $sql .= " AND ".$db->sanitize($key)." LIKE '%".$db->escape($value)."%'";
411 }
412 }
413 }
414 //$sql .= " GROUP BY t.track_id";
415 $sql .= $db->order($sortfield, $sortorder);
416
417 $resql = $db->query($sql);
418 if ($resql) {
419 $num_total = $db->num_rows($resql);
420 if (!empty($limit)) {
421 $sql .= $db->plimit($limit + 1, $offset);
422 }
423
424 $resql = $db->query($sql);
425 if ($resql) {
426 $num = $db->num_rows($resql);
427
428 $baseurl = getDolGlobalString('TICKET_URL_PUBLIC_INTERFACE', DOL_URL_ROOT.'/public/ticket/');
429
430 $newcardbutton = '<a class="marginrightonly" href="'.$baseurl . 'create_ticket.php?action=create'.(!empty($entity) && isModEnabled('multicompany') ? '&entity='.$entity : '').'&token='.newToken().'" rel="nofollow noopener"><span class="fa fa-15 fa-plus-circle valignmiddle btnTitle-icon" title="'.dol_escape_htmltag($langs->trans("CreateTicket")).'"></span></a>';
431
432 print_barre_liste($langs->trans('TicketList'), $page, 'list.php', $param, $sortfield, $sortorder, '', $num, $num_total, 'ticket', 0, $newcardbutton);
433
434 // Search bar
435 print '<form method="POST" action="'.$_SERVER['PHP_SELF'].(!empty($entity) && isModEnabled('multicompany') ? '?entity='.$entity : '').'" id="searchFormList" >'."\n";
436 print '<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">';
437 print '<input type="hidden" name="token" value="'.newToken().'">';
438 print '<input type="hidden" name="action" value="view_ticketlist">';
439 print '<input type="hidden" name="sortfield" value="'.$sortfield.'">';
440 print '<input type="hidden" name="sortorder" value="'.$sortorder.'">';
441
442 $varpage = empty($contextpage) ? $url_page_current : $contextpage;
443 $selectedfields = $form->multiSelectArrayWithCheckbox('selectedfields', $arrayfields, $varpage); // This also change content of $arrayfields
444
445 // allow to display information before list
446 $parameters = array('arrayfields' => $arrayfields);
447 $reshook = $hookmanager->executeHooks('printFieldListHeader', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
448 print $hookmanager->resPrint;
449
450 print '<div class="div-table-responsive">';
451 print '<table class="liste '.($moreforfilter ? "listwithfilterbefore" : "").'">';
452
453 // Filter bar
454 print '<tr class="liste_titre">';
455
456 if (!empty($arrayfields['t.datec']['checked'])) {
457 print '<td class="liste_titre"></td>';
458 }
459
460 if (!empty($arrayfields['t.date_read']['checked'])) {
461 print '<td class="liste_titre"></td>';
462 }
463 if (!empty($arrayfields['t.date_close']['checked'])) {
464 print '<td class="liste_titre"></td>';
465 }
466
467 if (!empty($arrayfields['t.ref']['checked'])) {
468 print '<td class="liste_titre"></td>';
469 }
470
471 if (!empty($arrayfields['t.subject']['checked'])) {
472 print '<td class="liste_titre">';
473 print '<input type="text" class="flat maxwidth100" name="search_subject" value="'.$search_subject.'">';
474 print '</td>';
475 }
476
477 if (!empty($arrayfields['type.code']['checked'])) {
478 print '<td class="liste_titre">';
479 $formTicket->selectTypesTickets($search_type, 'search_type', '', 2, 1, 1, 0, 'maxwidth150');
480 print '</td>';
481 }
482
483 if (!empty($arrayfields['category.code']['checked'])) {
484 print '<td class="liste_titre">';
485 $formTicket->selectGroupTickets($search_category, 'search_category', '(public:=:1)', 2, 1, 1, 0, 'maxwidth150');
486 print '</td>';
487 }
488
489 if (!empty($arrayfields['severity.code']['checked'])) {
490 print '<td class="liste_titre">';
491 $formTicket->selectSeveritiesTickets($search_severity, 'search_severity', '', 2, 1, 1, 0, 'maxwidth150');
492 print '</td>';
493 }
494
495 if (getDolGlobalString('TICKET_SHOW_PROGRESSION') && !empty($arrayfields['t.progress']['checked'])) {
496 print '<td class="liste_titre"></td>';
497 }
498
499 if (!empty($arrayfields['t.fk_user_create']['checked'])) {
500 print '<td class="liste_titre"></td>';
501 }
502
503 if (!empty($arrayfields['t.fk_user_assign']['checked'])) {
504 print '<td class="liste_titre"></td>';
505 }
506
507 if (!empty($arrayfields['t.tms']['checked'])) {
508 print '<td class="liste_titre"></td>';
509 }
510
511 // Extra fields
512 include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_input.tpl.php';
513
514 // Fields from hook
515 $parameters = array('arrayfields' => $arrayfields);
516 $reshook = $hookmanager->executeHooks('printFieldListOption', $parameters, $object); // Note that $action and $object may have been modified by hook
517 print $hookmanager->resPrint;
518
519 // Status ticket
520 if (!empty($arrayfields['t.fk_statut']['checked'])) {
521 print '<td class="liste_titre">';
522 $selected = ($search_fk_status != "non_closed" ? $search_fk_status : '');
523 //$object->printSelectStatus($selected);
524 print '</td>';
525 }
526
527 // Action column
528 print '<td class="liste_titre maxwidthsearch">';
529 $searchpicto = $form->showFilterButtons();
530 print $searchpicto;
531 print '</td>';
532 print '</tr>';
533
534 // Field title
535 print '<tr class="liste_titre">';
536 if (!empty($arrayfields['t.datec']['checked'])) {
537 print_liste_field_titre($arrayfields['t.datec']['label'], $url_page_current, 't.datec', '', $param, '', $sortfield, $sortorder);
538 }
539 if (!empty($arrayfields['t.date_read']['checked'])) {
540 print_liste_field_titre($arrayfields['t.date_read']['label'], $url_page_current, 't.date_read', '', $param, '', $sortfield, $sortorder);
541 }
542 if (!empty($arrayfields['t.date_close']['checked'])) {
543 print_liste_field_titre($arrayfields['t.date_close']['label'], $url_page_current, 't.date_close', '', $param, '', $sortfield, $sortorder);
544 }
545 if (!empty($arrayfields['t.ref']['checked'])) {
546 print_liste_field_titre($arrayfields['t.ref']['label'], $url_page_current, 't.ref', '', $param, '', $sortfield, $sortorder);
547 }
548 if (!empty($arrayfields['t.subject']['checked'])) {
549 print_liste_field_titre($arrayfields['t.subject']['label']);
550 }
551 if (!empty($arrayfields['type.code']['checked'])) {
552 print_liste_field_titre($arrayfields['type.code']['label'], $url_page_current, 'type.code', '', $param, '', $sortfield, $sortorder);
553 }
554 if (!empty($arrayfields['category.code']['checked'])) {
555 print_liste_field_titre($arrayfields['category.code']['label'], $url_page_current, 'category.code', '', $param, '', $sortfield, $sortorder);
556 }
557 if (!empty($arrayfields['severity.code']['checked'])) {
558 print_liste_field_titre($arrayfields['severity.code']['label'], $url_page_current, 'severity.code', '', $param, '', $sortfield, $sortorder);
559 }
560 if (getDolGlobalString('TICKET_SHOW_PROGRESSION') && !empty($arrayfields['t.progress']['checked'])) {
561 print_liste_field_titre($arrayfields['t.progress']['label'], $url_page_current, 't.progress', '', $param, '', $sortfield, $sortorder);
562 }
563 if (!empty($arrayfields['t.fk_user_create']['checked'])) {
564 print_liste_field_titre($arrayfields['t.fk_user_create']['label'], $url_page_current, 't.fk_user_create', '', $param, '', $sortfield, $sortorder);
565 }
566 if (!empty($arrayfields['t.fk_user_assign']['checked'])) {
567 print_liste_field_titre($arrayfields['t.fk_user_assign']['label'], $url_page_current, 't.fk_user_assign', '', $param, '', $sortfield, $sortorder);
568 }
569 if (!empty($arrayfields['t.tms']['checked'])) {
570 print_liste_field_titre($arrayfields['t.tms']['label'], $url_page_current, 't.tms', '', $param, '', $sortfield, $sortorder);
571 }
572
573 // Extra fields
574 include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_title.tpl.php';
575
576 // Hook fields
577 $parameters = array('arrayfields' => $arrayfields, 'param' => $param, 'sortfield' => $sortfield, 'sortorder' => $sortorder);
578 $reshook = $hookmanager->executeHooks('printFieldListTitle', $parameters, $object); // Note that $action and $object may have been modified by hook
579 print $hookmanager->resPrint;
580
581 if (!empty($arrayfields['t.fk_statut']['checked'])) {
582 print_liste_field_titre($arrayfields['t.fk_statut']['label'], $url_page_current, 't.fk_statut', '', $param, '', $sortfield, $sortorder);
583 }
584 print_liste_field_titre($selectedfields, $url_page_current, "", '', '', 'align="right"', $sortfield, $sortorder, 'center maxwidthsearch ');
585 print '</tr>';
586
587 while ($obj = $db->fetch_object($resql)) {
588 print '<tr class="oddeven">';
589
590 // Date ticket
591 if (!empty($arrayfields['t.datec']['checked'])) {
592 print '<td>';
593 print dol_print_date($db->jdate($obj->datec), 'dayhour', 'tzuserrel');
594 print '</td>';
595 }
596
597 // Date read
598 if (!empty($arrayfields['t.date_read']['checked'])) {
599 print '<td>';
600 print dol_print_date($db->jdate($obj->date_read), 'dayhour', 'tzuserrel');
601 print '</td>';
602 }
603
604 // Date close
605 if (!empty($arrayfields['t.date_close']['checked'])) {
606 print '<td>';
607 print dol_print_date($db->jdate($obj->date_close), 'dayhour', 'tzuserrel');
608 print '</td>';
609 }
610
611 // Ref
612 if (!empty($arrayfields['t.ref']['checked'])) {
613 print '<td class="nowraponall">';
614 print '<a rel="nofollow" href="javascript:viewticket(\''.dol_escape_js($obj->track_id).'\',\''.dol_escape_js($_SESSION['email_customer']).'\');">';
615 print img_picto('', 'ticket', 'class="paddingrightonly"');
616 print $obj->ref;
617 print '</a>';
618 print '</td>';
619 }
620
621 // Subject
622 if (!empty($arrayfields['t.subject']['checked'])) {
623 print '<td>';
624 print '<a rel="nofollow" href="javascript:viewticket(\''.dol_escape_js($obj->track_id).'\',\''.dol_escape_js($_SESSION['email_customer']).'\');">';
625 print $obj->subject;
626 print '</a>';
627 print '</td>';
628 }
629
630 // Type
631 if (!empty($arrayfields['type.code']['checked'])) {
632 print '<td>';
633 print $obj->type_label;
634 print '</td>';
635 }
636
637 // Category
638 if (!empty($arrayfields['category.code']['checked'])) {
639 print '<td>';
640 print $obj->category_label;
641 print '</td>';
642 }
643
644 // Severity
645 if (!empty($arrayfields['severity.code']['checked'])) {
646 print '<td>';
647 print $obj->severity_label;
648 print '</td>';
649 }
650
651 // Progression
652 if (getDolGlobalString('TICKET_SHOW_PROGRESSION') && !empty($arrayfields['t.progress']['checked'])) {
653 print '<td>';
654 print $obj->progress;
655 print '</td>';
656 }
657
658 // Message author
659 if (!empty($arrayfields['t.fk_user_create']['checked'])) {
660 print '<td title="'.dol_escape_htmltag($obj->origin_email).'">';
661 if ($obj->fk_user_create > 0) {
662 $user_create->firstname = (!empty($obj->user_create_firstname) ? $obj->user_create_firstname : '');
663 $user_create->name = (!empty($obj->user_create_lastname) ? $obj->user_create_lastname : '');
664 $user_create->id = (!empty($obj->fk_user_create) ? $obj->fk_user_create : '');
665 print $user_create->getFullName($langs);
666 } else {
667 print img_picto('', 'email', 'class="paddingrightonly"');
668 print $langs->trans('Email');
669 }
670 print '</td>';
671 }
672
673 // Assigned author
674 if (!empty($arrayfields['t.fk_user_assign']['checked'])) {
675 print '<td>';
676 if ($obj->fk_user_assign > 0) {
677 $user_assign->firstname = (!empty($obj->user_assign_firstname) ? $obj->user_assign_firstname : '');
678 $user_assign->lastname = (!empty($obj->user_assign_lastname) ? $obj->user_assign_lastname : '');
679 $user_assign->id = (!empty($obj->fk_user_assign) ? $obj->fk_user_assign : '');
680 print img_picto('', 'user', 'class="paddingrightonly"');
681 print $user_assign->getFullName($langs);
682 }
683 print '</td>';
684 }
685
686 if (!empty($arrayfields['t.tms']['checked'])) {
687 print '<td>'.dol_print_date($db->jdate($obj->tms), 'dayhour').'</td>';
688 }
689
690 // Extra fields
691 if (isset($extrafields->attributes[$object->table_element]['label']) && is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) {
692 foreach ($extrafields->attributes[$object->table_element]['label'] as $key => $val) {
693 if (!empty($arrayfields["ef.".$key]['checked'])) {
694 print '<td';
695 $cssstring = $extrafields->getCSSClass($key, $object->table_element, 'csslist');
696 if ($cssstring) {
697 print ' class="'.$cssstring.'"';
698 }
699 print '>';
700 $tmpkey = 'options_'.$key;
701 print $extrafields->showOutputField($key, $obj->$tmpkey, '', $object->table_element);
702 print '</td>';
703 }
704 }
705 }
706
707 // Statut
708 if (!empty($arrayfields['t.fk_statut']['checked'])) {
709 print '<td class="nowraponall">';
710 $object->status = $obj->fk_statut;
711 if (getDolGlobalString('TICKET_SHOW_PROGRESSION')) {
712 $object->progress = $obj->progress;
713 }
714 print $object->getLibStatut(2);
715 print '</td>';
716 }
717
718 print '<td></td>';
719
720 $i++;
721 print '</tr>';
722 }
723
724 print '</table>';
725 print '</div>';
726
727 print '</form>';
728
729 $url_public_ticket = getDolGlobalString('TICKET_URL_PUBLIC_INTERFACE', dol_buildpath('/public/ticket/', 1));
730
731 print '<form method="POST" id="form_view_ticket" name="form_view_ticket" action="'.$url_public_ticket.'view.php'.(!empty($entity) && isModEnabled('multicompany') ? '?entity='.$entity : '').'" style="display:none;">';
732 print '<input type="hidden" name="token" value="'.newToken().'">';
733 print '<input type="hidden" name="action" value="view_ticket">';
734 print '<input type="hidden" name="btn_view_ticket_list" value="1">';
735 print '<input type="hidden" name="track_id" value="">';
736 print '<input type="hidden" name="email" value="">';
737 print "</form>";
738 print '<script type="text/javascript">
739 function viewticket(ticket_id, email) {
740 var form = $("#form_view_ticket");
741 form.find("input[name=\\"track_id\\"]").val(ticket_id);
742 form.find("input[name=\\"email\\"]").val(email);
743 form.submit();
744 }
745 </script>';
746 }
747 } else {
748 dol_print_error($db);
749 }
750 } else {
751 print '<div class="error">Not Allowed<br><a href="'.$_SERVER['PHP_SELF'].'?track_id='.$object->track_id.'">'.$langs->trans('Back').'</a></div>';
752 }
753
754 print '</div>';
755} else {
756 print '<div class="ticketpublicarea ticketlargemargin">';
757
758 print '<p class="center opacitymedium">'.$langs->trans("TicketPublicMsgViewLogIn").'</p>';
759 print '<br>';
760
761 print '<div id="form_view_ticket">';
762 print '<form method="POST" class="maxwidth1000 center" name="form_view_ticketlist" action="'.$_SERVER['PHP_SELF'].(!empty($entity) && isModEnabled('multicompany') ? '?entity='.$entity : '').'">';
763 print '<input type="hidden" name="token" value="'.newToken().'">';
764 print '<input type="hidden" name="action" value="view_ticketlist">';
765 //print '<input type="hidden" name="search_fk_status" value="non_closed">';
766
767 print '<p><label for="track_id" style="display: inline-block" class="titlefieldcreate left"><span class="fieldrequired">';
768 print img_picto($langs->trans("TicketTrackId"), 'generic', 'class="pictofixedwidth"');
769 print $langs->trans("OneOfTicketTrackId");
770 print '</span></label>';
771 print '<br class="showonsmartphone hidden">';
772 print '<input class="minwidth100" id="track_id" name="track_id" value="'.(GETPOST('track_id', 'alpha') ? GETPOST('track_id', 'alpha') : '').'" />';
773 print '</p>';
774
775 print '<p><label for="email" style="display: inline-block" class="titlefieldcreate left"><span class="fieldrequired">';
776 print img_picto($langs->trans("Email"), 'email', 'class="pictofixedwidth"');
777 print $langs->trans('Email').'</span></label>';
778 print '<br class="showonsmartphone hidden">';
779 print '<input class="minwidth100" id="email" name="email" value="'.(GETPOST('email', 'alpha') ? GETPOST('email', 'alpha') : (!empty($_SESSION['customer_email']) ? $_SESSION['customer_email'] : "")).'" />';
780 print '</p>';
781
782 print '<p style="text-align: center; margin-top: 1.5em;">';
783 print '<input type="submit" class="button button-select" name="btn_view_ticket_list" value="'.$langs->trans('ViewMyTicketList').'" />';
784 print ' &nbsp; ';
785 print '<input type="submit" class="button button-cancel" name="cancel" value="'.$langs->trans("Cancel").'">';
786 print "</p>\n";
787
788 print "</form>\n";
789 print "</div>\n";
790
791 print "</div>";
792}
793
794if (getDolGlobalInt('TICKET_SHOW_COMPANY_FOOTER')) {
795 // End of page
796 htmlPrintOnlineFooter($mysoc, $langs, 0, $suffix, $object);
797}
798
799llxFooter('', 'public');
800
801$db->close();
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
Definition card.php:67
static getValidAddress($address, $format, $encode=0, $maxnumberofemail=0)
Return a formatted address string for SMTP protocol.
Class to manage standard extra fields.
Class to manage generation of HTML components Only common components must be here.
Class to manage Dolibarr users.
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as p label as s rowid as s nom as s email
Sender: Who sends the email ("Sender" has sent emails on behalf of "From").
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
print_liste_field_titre($name, $file="", $field="", $begin="", $param="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
print_barre_liste($title, $page, $file, $options='', $sortfield='', $sortorder='', $morehtmlcenter='', $num=-1, $totalnboflines='', $picto='generic', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limit=-1, $selectlimitsuffix=0, $hidenavigation=0, $pagenavastextinput=0, $morehtmlrightbeforearrow='')
Print a title with navigation controls for pagination.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_escape_js($stringtoescape, $mode=0, $noescapebackslashn=0)
Returns text escaped for inclusion into javascript code.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
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.
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
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...
ui state ui widget content ui state ui widget header ui state a ui button
0 = Do not include form tag and submit button -1 = Do not include form tag but include submit button
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.
$conf db name
Only used if Module[ID]Name translation string is not found.
Definition repair.php:161
httponly_accessforbidden($message='1', $http_response_code=403, $stringalreadysanitized=0)
Show a message to say access is forbidden and stop program.
llxHeaderTicket($title, $head="", $disablejs=0, $disablehead=0, $arrayofjs=[], $arrayofcss=[])
Show http header, open body tag and show HTML header banner for public pages for tickets.