28if (!defined(
'NOREQUIREMENU')) {
29 define(
'NOREQUIREMENU',
'1');
32if (!defined(
"NOLOGIN")) {
33 define(
"NOLOGIN",
'1');
35if (!defined(
'NOIPCHECK')) {
36 define(
'NOIPCHECK',
'1');
38if (!defined(
'NOBROWSERNOTIF')) {
39 define(
'NOBROWSERNOTIF',
'1');
46$entity = (!empty($_GET[
'entity']) ? (int) $_GET[
'entity'] : (!empty($_POST[
'entity']) ? (int) $_POST[
'entity'] : 1));
47if (is_numeric($entity)) {
48 define(
"DOLENTITY", $entity);
52require
'../../main.inc.php';
53require_once DOL_DOCUMENT_ROOT.
'/ticket/class/actions_ticket.class.php';
54require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formticket.class.php';
55require_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
56require_once DOL_DOCUMENT_ROOT.
'/core/lib/ticket.lib.php';
57require_once DOL_DOCUMENT_ROOT.
'/core/lib/security.lib.php';
58require_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
59require_once DOL_DOCUMENT_ROOT.
'/core/lib/payments.lib.php';
70$langs->loadLangs(array(
"companies",
"other",
"ticket"));
73$action =
GETPOST(
'action',
'aZ09');
76$track_id =
GETPOST(
'track_id',
'alpha');
77$email =
GETPOST(
'email',
'email');
80if (
GETPOST(
'btn_view_ticket')) {
81 unset($_SESSION[
'email_customer']);
83if (isset($_SESSION[
'email_customer'])) {
84 $email = $_SESSION[
'email_customer'];
99 $backtopage =
getDolGlobalString(
'TICKET_URL_PUBLIC_INTERFACE', DOL_URL_ROOT.
'/public/ticket/');
101 if (!empty($backtopage)) {
102 header(
"Location: ".$backtopage);
105 $action =
'view_ticket';
108$display_ticket =
false;
109if (in_array($action, array(
"view_ticket",
"presend",
"close",
"confirm_public_close",
"add_message",
"add_contact"))) {
111 if (!strlen($track_id)) {
113 array_push(
$object->errors, $langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"TicketTrackId")));
116 if (!strlen($email)) {
118 array_push(
$object->errors, $langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Email")));
123 array_push(
$object->errors, $langs->trans(
"ErrorEmailInvalid"));
129 $ret =
$object->fetch(0,
'', $track_id);
130 if ($ret &&
$object->dao->id > 0) {
133 if (strtolower($emailofticket) == strtolower($email)) {
134 $display_ticket =
true;
135 $_SESSION[
'email_customer'] = $email;
138 $contacts =
$object->dao->liste_contact(-1,
'external');
139 foreach ($contacts as $contact) {
140 if (strtolower($contact[
'email']) == strtolower($email)) {
141 $display_ticket =
true;
142 $_SESSION[
'email_customer'] = $email;
145 $display_ticket =
false;
151 $object->dao->fetch_thirdparty();
152 if ($email ==
$object->dao->thirdparty->email) {
153 $display_ticket =
true;
154 $_SESSION[
'email_customer'] = $email;
158 if (
$object->dao->fk_user_create > 0) {
160 $tmpuser->fetch(
$object->dao->fk_user_create);
161 if (strtolower($email) == strtolower($tmpuser->email)) {
162 $display_ticket =
true;
163 $_SESSION[
'email_customer'] = $email;
167 if (
$object->dao->fk_user_assign > 0 &&
$object->dao->fk_user_assign !=
$object->dao->fk_user_create) {
169 $tmpuser->fetch(
$object->dao->fk_user_assign);
170 if (strtolower($email) == strtolower($tmpuser->email)) {
171 $display_ticket =
true;
172 $_SESSION[
'email_customer'] = $email;
177 array_push(
$object->errors, $langs->trans(
"ErrorTicketNotFound", $track_id));
182 if (!$error && $action ==
'confirm_public_close' && $display_ticket) {
183 if (
$object->dao->close($user)) {
186 $url =
'view.php?action=view_ticket&track_id='.GETPOST(
'track_id',
'alpha').(!empty($entity) &&
isModEnabled(
'multicompany') ?
'&entity='.$entity :
'').
'&token='.newToken();
187 header(
"Location: ".$url);
195 if (!$error && $action ==
"add_message" && $display_ticket && GETPOSTISSET(
'btn_add_message')) {
196 $ret =
$object->dao->newMessage($user, $action, 0, 1);
199 $action =
'view_ticket';
204 if (!$error && $action ==
"add_contact" && $display_ticket && GETPOSTISSET(
'btn_add_contact')) {
208 $action =
'view_ticket';
212 if ($error || !empty(
$object->errors)) {
214 if ($action ==
"add_message") {
224$triggersendname =
'TICKET_SENTBYMAIL';
226$autocopy =
'MAIN_MAIL_AUTOCOPY_TICKET_TO';
228 $trackid =
'tic'.$object->dao->id;
230include DOL_DOCUMENT_ROOT.
'/core/actions_sendmails.inc.php';
242$hookmanager->initHooks(array(
'ticketpublicview',
'globalcard'));
245 print
'<div class="error">'.$langs->trans(
'TicketPublicInterfaceForbidden').
'</div>';
251$arrayofcss = array(
getDolGlobalString(
'TICKET_URL_PUBLIC_INTERFACE',
'/public/ticket/').
'css/styles.css.php');
253llxHeaderTicket($langs->trans(
"Tickets"),
"", 0, 0, $arrayofjs, $arrayofcss);
256if ($action ==
"view_ticket" || $action ==
"presend" || $action ==
"close" || $action ==
"confirm_public_close") {
257 if ($display_ticket) {
258 print
'<!-- public view ticket if if -->';
259 print
'<div class="ticketpublicarea ticketlargemargin">';
262 if ($action ==
'close') {
263 print $form->formconfirm($_SERVER[
"PHP_SELF"].
"?track_id=".$track_id.(!empty($entity) &&
isModEnabled(
'multicompany') ?
'&entity='.$entity :
''), $langs->trans(
"CloseATicket"), $langs->trans(
"ConfirmCloseAticket"),
"confirm_public_close",
'',
'', 1);
266 print
'<div id="form_view_ticket" class="margintoponly">';
268 print
'<table class="ticketpublictable centpercent tableforfield">';
271 print
'<tr><td class="titlefield">'.$langs->trans(
"Ref").
' / '.$langs->trans(
"TicketTrackId").
'</td><td>';
272 print
img_picto(
'',
'ticket',
'class="pictofixedwidth"');
274 print
'<span class="opacitylow"> / '.dolPrintHTML(
$object->dao->track_id).
'</span>';
278 print
'<tr><td>'.$langs->trans(
"Subject").
'</td><td>';
279 print
'<span class="bold large">';
285 print
'<tr><td>'.$langs->trans(
"Status").
'</td><td>';
286 print
$object->dao->getLibStatut(2);
290 print
'<tr><td>'.$langs->trans(
"Type").
'</td><td>';
295 print
'<tr><td>'.$langs->trans(
"Category").
'</td><td>';
296 if (
$object->dao->category_label) {
297 print
img_picto(
'',
'category',
'class="pictofixedwidth"');
303 print
'<tr><td>'.$langs->trans(
"Severity").
'</td><td>';
308 print
'<tr><td>'.$langs->trans(
"DateCreation").
'</td><td>';
309 print
img_picto(
'',
'calendar',
'class="pictofixedwidth"');
314 print
'<tr><td>'.$langs->trans(
"Author").
'</td><td>';
315 if (
$object->dao->fk_user_create > 0) {
316 $langs->load(
"users");
318 $fuser->fetch(
$object->dao->fk_user_create);
319 print
img_picto(
'',
'user',
'class="pictofixedwidth"');
320 print $fuser->getFullName($langs);
322 print
img_picto(
'',
'email',
'class="pictofixedwidth"');
329 if (!empty(
$object->dao->date_read)) {
330 print
'<tr><td>'.$langs->trans(
"TicketReadOn").
'</td><td>';
336 if (!empty(
$object->dao->date_close)) {
337 print
'<tr><td>'.$langs->trans(
"TicketCloseOn").
'</td><td>';
343 if (
$object->dao->fk_user_assign > 0) {
344 print
'<tr><td>'.$langs->trans(
"AssignedTo").
'aaaa</td><td>';
346 $fuser->fetch(
$object->dao->fk_user_assign);
347 print
img_picto(
'',
'user',
'class="pictofixedwidth"');
348 print $fuser->getFullName($langs, 0);
354 print
'<tr><td>'.$langs->trans(
"ExternalContributors").
'</td><td>';
356 $contactlist =
$object->dao->liste_contact(-1,
'external');
357 foreach ($contactlist as $externalContributor) {
358 print
img_picto(
'',
'contact',
'class="pictofixedwidth"');
359 print $externalContributor[
"lastname"].
" ".$externalContributor[
"firstname"].
"<br>";
367 print
'<form method="post" id="form_view_add_contact" name="form_view_add_contact" action="'.$_SERVER[
'PHP_SELF'].
'?track_id='.
$object->dao->track_id.
'">';
368 print
'<input type="hidden" name="token" value="'.newToken().
'">';
369 print
'<input type="hidden" name="action" value="add_contact">';
370 print
'<input type="hidden" name="email" value="'.$_SESSION[
'email_customer'].
'">';
371 print
'<tr><td>'.$langs->trans(
"AddContributor").
'</td><td>';
373 print $form->select_contact(
$object->dao->fk_soc,
'',
'contactid', 3,
'',
'', 1,
'minwidth100imp widthcentpercentminusxx maxwidth400',
true);
374 print
'<input type="submit" class="button smallpaddingimp reposition" name="btn_add_contact" value="'.$langs->trans(
'Add').
'" />';
375 print
'</td></tr></form>';
380 print
'<tr><td>'.$langs->trans(
"Progression").
'</td><td>';
386 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_view.tpl.php';
392 print
'<div style="clear: both; margin-top: 1.5em;"></div>';
394 if ($action ==
'presend') {
396 print
load_fiche_titre($langs->trans(
'TicketAddMessage'),
'',
'conversation');
400 $formticket->action =
"add_message";
401 $formticket->track_id =
$object->dao->track_id;
402 $formticket->trackid =
'tic'.$object->dao->id;
404 $baseurl =
getDolGlobalString(
'TICKET_URL_PUBLIC_INTERFACE', DOL_URL_ROOT.
'/public/ticket/');
406 $formticket->param = array(
'track_id' =>
$object->dao->track_id,
'fk_user_create' =>
'-1',
407 'returnurl' => $baseurl.
'view.php'.(!empty($entity) &&
isModEnabled(
'multicompany') ?
'?entity='.$entity :
''));
409 $formticket->withfile = 2;
410 $formticket->withcancel = 1;
411 $formticket->withtitletopic = 1;
413 $formticket->showMessageForm(
'100%', 1);
416 if ($action !=
'presend') {
417 $baseurl =
getDolGlobalString(
'TICKET_URL_PUBLIC_INTERFACE', DOL_URL_ROOT.
'/public/ticket/');
419 print
'<form method="POST" id="form_view_ticket_list" name="form_view_ticket_list" action="'.$baseurl.
'list.php'.(!empty($entity) &&
isModEnabled(
'multicompany') ?
'?entity='.$entity :
'').
'">';
420 print
'<input type="hidden" name="token" value="'.newToken().
'">';
421 print
'<input type="hidden" name="action" value="view_ticketlist">';
422 print
'<input type="hidden" name="track_id" value="'.$object->dao->track_id.
'">';
423 print
'<input type="hidden" name="email" value="'.$_SESSION[
'email_customer'].
'">';
427 print
'<div class="tabsAction">';
430 print
'<div class="inline-block divButAction"><a class="left" style="padding-right: 50px" href="javascript:$(\'#form_view_ticket_list\').submit();">'.$langs->trans(
'ViewMyTicketList').
'</a></div>';
432 if (
$object->dao->status < Ticket::STATUS_CLOSED) {
434 print
'<div class="inline-block divButAction"><a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=presend&mode=init&track_id='.
$object->dao->track_id.(!empty($entity) &&
isModEnabled(
'multicompany') ?
'&entity='.$entity :
'').
'&token='.newToken().
'">'.$langs->trans(
'TicketAddMessage').
'</a></div>';
437 if (
$object->dao->status >= Ticket::STATUS_NOT_READ &&
$object->dao->status < Ticket::STATUS_CLOSED) {
438 print
'<div class="inline-block divButAction"><a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=close&track_id='.
$object->dao->track_id.(!empty($entity) &&
isModEnabled(
'multicompany') ?
'&entity='.$entity :
'').
'&token='.newToken().
'">'.$langs->trans(
'CloseTicket').
'</a></div>';
448 print
'<div class="ticketpublicarea ticketlargemargin">';
450 print
load_fiche_titre($langs->trans(
'TicketMessagesList'),
'',
'conversation');
458 print
'<!-- public view ticket if else -->';
459 print
'<div class="ticketpublicarea ticketlargemargin">';
461 print
'<div class="error">Not Allowed<br><a href="'.$_SERVER[
'PHP_SELF'].
'?track_id='.
$object->dao->track_id.(!empty($entity) &&
isModEnabled(
'multicompany') ?
'?entity='.$entity :
'').
'" rel="nofollow noopener">'.$langs->trans(
"GoBack").
'</a></div>';
466 print
'<!-- public view ticket else -->';
467 print
'<div class="ticketpublicarea ticketlargemargin">';
469 print
'<div class="center opacitymedium margintoponly marginbottomonly ticketlargemargin">'.$langs->trans(
"TicketPublicMsgViewLogIn").
'</div>';
471 print
'<div id="form_view_ticket">';
472 print
'<form method="POST" class="maxwidth1000 center" name="form_view_ticket" action="'.$_SERVER[
'PHP_SELF'].(!empty($entity) &&
isModEnabled(
'multicompany') ?
'?entity='.$entity :
'').
'">';
474 print
'<input type="hidden" name="token" value="'.newToken().
'">';
475 print
'<input type="hidden" name="action" value="view_ticket">';
477 print
'<p><label for="track_id" style="display: inline-block;" class="titlefieldcreate left"><span class="fieldrequired">';
478 print
img_picto($langs->trans(
"TicketTrackId"),
'generic',
'class="pictofixedwidth"');
479 print $langs->trans(
"TicketTrackId").
'</span></label>';
480 print
'<br class="showonsmartphone hidden">';
481 print
'<input class="minwidth100" id="track_id" name="track_id" value="'.(GETPOST(
'track_id',
'alpha') ?
GETPOST(
'track_id',
'alpha') :
'').
'" />';
484 print
'<p><label for="email" style="display: inline-block;" class="titlefieldcreate left"><span class="fieldrequired">';
485 print
img_picto($langs->trans(
"Email"),
'email',
'class="pictofixedwidth"');
486 print $langs->trans(
'Email').
'</span></label>';
487 print
'<br class="showonsmartphone hidden">';
488 print
'<input class="minwidth100" id="email" name="email" value="'.(GETPOST(
'email',
'alpha') ?
GETPOST(
'email',
'alpha') : (!empty($_SESSION[
'customer_email']) ? $_SESSION[
'customer_email'] :
"")).
'" />';
491 print
'<p style="text-align: center; margin-top: 1.5em;">';
492 print
'<input type="submit" class="button" name="btn_view_ticket" value="'.$langs->trans(
'ViewTicket').
'" />';
494 print
'<input type="submit" class="button button-cancel" name="cancel" value="'.$langs->trans(
"Cancel").
'">';
if(! $sortfield) if(! $sortorder) $object
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
Class Actions of the module ticket.
static getValidAddress($address, $format, $encode=0, $maxnumberofemail=0)
Return a formatted address string for SMTP protocol.
Class to manage Dolibarr users.
htmlPrintOnlineFooter($fromcompany, $langs, $addformmessage=0, $suffix='', $object=null)
Show footer of company in HTML public pages.
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, $allowothertags=array())
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.
dolPrintHTML($s, $allowiframe=0, $moreallowedtags=array())
Return a string (that can be on several lines) ready to be output on a HTML page.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
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...
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.