25 if (!defined(
'NOREQUIREMENU')) {
26 define(
'NOREQUIREMENU',
'1');
29 if (!defined(
"NOLOGIN")) {
30 define(
"NOLOGIN",
'1');
32 if (!defined(
'NOIPCHECK')) {
33 define(
'NOIPCHECK',
'1');
35 if (!defined(
'NOBROWSERNOTIF')) {
36 define(
'NOBROWSERNOTIF',
'1');
42 $entity = (!empty($_GET[
'entity']) ? (int) $_GET[
'entity'] : (!empty($_POST[
'entity']) ? (int) $_POST[
'entity'] : 1));
43 if (is_numeric($entity)) {
44 define(
"DOLENTITY", $entity);
47 require
'../../main.inc.php';
48 require_once DOL_DOCUMENT_ROOT.
'/ticket/class/actions_ticket.class.php';
49 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formticket.class.php';
50 require_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
51 require_once DOL_DOCUMENT_ROOT.
'/core/lib/ticket.lib.php';
52 require_once DOL_DOCUMENT_ROOT.
'/core/lib/security.lib.php';
53 require_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
54 require_once DOL_DOCUMENT_ROOT.
'/core/lib/payments.lib.php';
57 $langs->loadLangs(array(
"companies",
"other",
"ticket"));
60 $action =
GETPOST(
'action',
'aZ09');
61 $cancel =
GETPOST(
'cancel',
'aZ09');
63 $track_id =
GETPOST(
'track_id',
'alpha');
64 $email =
GETPOST(
'email',
'email');
66 if (
GETPOST(
'btn_view_ticket')) {
67 unset($_SESSION[
'email_customer']);
69 if (isset($_SESSION[
'email_customer'])) {
70 $email = $_SESSION[
'email_customer'];
75 if (empty($conf->ticket->enabled)) {
85 $backtopage = DOL_URL_ROOT.
'/public/ticket/index.php';
87 if (!empty($backtopage)) {
88 header(
"Location: ".$backtopage);
91 $action =
'view_ticket';
94 if ($action ==
"view_ticket" || $action ==
"presend" || $action ==
"close" || $action ==
"confirm_public_close" || $action ==
"add_message") {
96 $display_ticket =
false;
97 if (!strlen($track_id)) {
99 array_push($object->errors, $langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"TicketTrackId")));
102 if (!strlen($email)) {
104 array_push($object->errors, $langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Email")));
109 array_push($object->errors, $langs->trans(
"ErrorEmailInvalid"));
115 $ret = $object->fetch(
'',
'', $track_id);
116 if ($ret && $object->dao->id > 0) {
119 if (strtolower($emailofticket) == strtolower($email)) {
120 $display_ticket =
true;
121 $_SESSION[
'email_customer'] = $email;
124 $contacts = $object->dao->liste_contact(-1,
'external');
125 foreach ($contacts as $contact) {
126 if (strtolower($contact[
'email']) == strtolower($email)) {
127 $display_ticket =
true;
128 $_SESSION[
'email_customer'] = $email;
131 $display_ticket =
false;
136 if ($object->dao->fk_soc > 0 || $object->dao->socid > 0) {
137 $object->dao->fetch_thirdparty();
138 if ($email == $object->dao->thirdparty->email) {
139 $display_ticket =
true;
140 $_SESSION[
'email_customer'] = $email;
144 if ($object->dao->fk_user_create > 0) {
145 $tmpuser =
new User($db);
146 $tmpuser->fetch($object->dao->fk_user_create);
147 if (strtolower($email) == strtolower($tmpuser->email)) {
148 $display_ticket =
true;
149 $_SESSION[
'email_customer'] = $email;
153 if ($object->dao->fk_user_assign > 0 && $object->dao->fk_user_assign != $object->dao->fk_user_create) {
154 $tmpuser =
new User($db);
155 $tmpuser->fetch($object->dao->fk_user_assign);
156 if (strtolower($email) == strtolower($tmpuser->email)) {
157 $display_ticket =
true;
158 $_SESSION[
'email_customer'] = $email;
163 array_push($object->errors, $langs->trans(
"ErrorTicketNotFound", $track_id));
168 if (!$error && $action ==
'confirm_public_close' && $display_ticket) {
169 if ($object->dao->close($user)) {
172 $url =
'view.php?action=view_ticket&track_id='.GETPOST(
'track_id',
'alpha').(!empty($entity) && !empty($conf->multicompany->enabled)?
'&entity='.$entity:
'');
173 header(
"Location: ".$url);
181 if (!$error && $action ==
"add_message" && $display_ticket &&
GETPOSTISSET(
'btn_add_message')) {
183 $ret = $object->dao->newMessage($user, $action, 0, 1);
187 $action =
'view_ticket';
191 if ($error || $errors) {
193 if ($action ==
"add_message") {
204 $triggersendname =
'TICKET_SENTBYMAIL';
206 $autocopy =
'MAIN_MAIL_AUTOCOPY_TICKET_TO';
207 $trackid =
'tic'.$object->id;
208 include DOL_DOCUMENT_ROOT.
'/core/actions_sendmails.inc.php';
219 if (!$conf->global->TICKET_ENABLE_PUBLIC_INTERFACE) {
220 print
'<div class="error">'.$langs->trans(
'TicketPublicInterfaceForbidden').
'</div>';
225 $arrayofjs = array();
226 $arrayofcss = array(
'/ticket/css/styles.css.php');
228 llxHeaderTicket($langs->trans(
"Tickets"),
"", 0, 0, $arrayofjs, $arrayofcss);
230 print
'<div class="ticketpublicarea">';
232 if ($action ==
"view_ticket" || $action ==
"presend" || $action ==
"close" || $action ==
"confirm_public_close") {
233 if ($display_ticket) {
235 if ($action ==
'close') {
236 print
$form->formconfirm($_SERVER[
"PHP_SELF"].
"?track_id=".$track_id.(!empty($entity) && !empty($conf->multicompany->enabled)?
'&entity='.$entity:
''), $langs->trans(
"CloseATicket"), $langs->trans(
"ConfirmCloseAticket"),
"confirm_public_close",
'',
'', 1);
239 print
'<div id="form_view_ticket" class="margintoponly">';
241 print
'<table class="ticketpublictable centpercent tableforfield">';
244 print
'<tr><td class="titlefield">'.$langs->trans(
"Ref").
'</td><td>';
245 print
img_picto(
'',
'ticket',
'class="pictofixedwidth"');
250 print
'<tr><td>'.$langs->trans(
"TicketTrackId").
'</td><td>';
255 print
'<tr><td>'.$langs->trans(
"Subject").
'</td><td>';
256 print
'<span class="bold">';
262 print
'<tr><td>'.$langs->trans(
"Status").
'</td><td>';
263 print $object->dao->getLibStatut(2);
267 print
'<tr><td>'.$langs->trans(
"Type").
'</td><td>';
272 print
'<tr><td>'.$langs->trans(
"Category").
'</td><td>';
273 if ($object->dao->category_label) {
274 print
img_picto(
'',
'category',
'class="pictofixedwidth"');
280 print
'<tr><td>'.$langs->trans(
"Severity").
'</td><td>';
285 print
'<tr><td>'.$langs->trans(
"DateCreation").
'</td><td>';
290 print
'<tr><td>'.$langs->trans(
"Author").
'</td><td>';
291 if ($object->dao->fk_user_create > 0) {
292 $langs->load(
"users");
293 $fuser =
new User($db);
294 $fuser->fetch($object->dao->fk_user_create);
295 print
img_picto(
'',
'user',
'class="pictofixedwidth"');
296 print $fuser->getFullName($langs);
298 print
img_picto(
'',
'email',
'class="pictofixedwidth"');
305 if (!empty($object->dao->date_read)) {
306 print
'<tr><td>'.$langs->trans(
"TicketReadOn").
'</td><td>';
312 if (!empty($object->dao->date_close)) {
313 print
'<tr><td>'.$langs->trans(
"TicketCloseOn").
'</td><td>';
319 print
'<tr><td>'.$langs->trans(
"AssignedTo").
'</td><td>';
320 if ($object->dao->fk_user_assign > 0) {
321 $fuser =
new User($db);
322 $fuser->fetch($object->dao->fk_user_assign);
323 print
img_picto(
'',
'user',
'class="pictofixedwidth"');
324 print $fuser->getFullName($langs, 1);
329 print
'<tr><td>'.$langs->trans(
"Progression").
'</td><td>';
330 print ($object->dao->progress > 0 ?
dol_escape_htmltag($object->dao->progress) :
'0').
'%';
337 print
'<div style="clear: both; margin-top: 1.5em;"></div>';
339 if ($action ==
'presend') {
340 print
load_fiche_titre($langs->trans(
'TicketAddMessage'),
'',
'conversation');
344 $formticket->action =
"add_message";
345 $formticket->track_id = $object->dao->track_id;
346 $formticket->id = $object->dao->id;
348 $formticket->param = array(
'track_id' => $object->dao->track_id,
'fk_user_create' =>
'-1',
349 'returnurl' => DOL_URL_ROOT.
'/public/ticket/view.php'.(!empty($entity) && !empty($conf->multicompany->enabled)?
'?entity='.$entity:
''));
351 $formticket->withfile = 2;
352 $formticket->withcancel = 1;
354 $formticket->showMessageForm(
'100%');
357 if ($action !=
'presend') {
358 print
'<form method="post" id="form_view_ticket_list" name="form_view_ticket_list" action="'.DOL_URL_ROOT.
'/public/ticket/list.php'.(!empty($entity) && !empty($conf->multicompany->enabled)?
'?entity='.$entity:
'').
'">';
359 print
'<input type="hidden" name="token" value="'.newToken().
'">';
360 print
'<input type="hidden" name="action" value="view_ticketlist">';
361 print
'<input type="hidden" name="track_id" value="'.$object->dao->track_id.
'">';
362 print
'<input type="hidden" name="email" value="'.$_SESSION[
'email_customer'].
'">';
366 print
'<div class="tabsAction">';
369 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>';
371 if ($object->dao->fk_statut < Ticket::STATUS_CLOSED) {
373 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) && !empty($conf->multicompany->enabled)?
'&entity='.$entity:
'').
'">'.$langs->trans(
'AddMessage').
'</a></div>';
377 print
'<div class="inline-block divButAction"><a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=close&track_id='.$object->dao->track_id.(!empty($entity) && !empty($conf->multicompany->enabled)?
'&entity='.$entity:
'').
'">'.$langs->trans(
'CloseTicket').
'</a></div>';
385 print
load_fiche_titre($langs->trans(
'TicketMessagesList'),
'',
'conversation');
386 $object->viewTicketMessages(
false,
true, $object->dao);
388 print
'<div class="error">Not Allowed<br><a href="'.$_SERVER[
'PHP_SELF'].
'?track_id='.$object->dao->track_id.(!empty($entity) && !empty($conf->multicompany->enabled)?
'?entity='.$entity:
'').
'" rel="nofollow noopener">'.$langs->trans(
'Back').
'</a></div>';
391 print
'<div class="center opacitymedium margintoponly marginbottomonly">'.$langs->trans(
"TicketPublicMsgViewLogIn").
'</div>';
393 print
'<div id="form_view_ticket">';
394 print
'<form method="post" name="form_view_ticket" action="'.$_SERVER[
'PHP_SELF'].(!empty($entity) && !empty($conf->multicompany->enabled)?
'?entity='.$entity:
'').
'">';
395 print
'<input type="hidden" name="token" value="'.newToken().
'">';
396 print
'<input type="hidden" name="action" value="view_ticket">';
398 print
'<p><label for="track_id" style="display: inline-block; width: 30%; "><span class="fieldrequired">'.$langs->trans(
"TicketTrackId").
'</span></label>';
399 print
'<input size="30" id="track_id" name="track_id" value="'.(GETPOST(
'track_id',
'alpha') ?
GETPOST(
'track_id',
'alpha') :
'').
'" />';
402 print
'<p><label for="email" style="display: inline-block; width: 30%; "><span class="fieldrequired">'.$langs->trans(
'Email').
'</span></label>';
403 print
'<input size="30" id="email" name="email" value="'.(GETPOST(
'email',
'alpha') ?
GETPOST(
'email',
'alpha') : $_SESSION[
'customer_email']).
'" />';
406 print
'<p style="text-align: center; margin-top: 1.5em;">';
407 print
'<input type="submit" class="button" name="btn_view_ticket" value="'.$langs->trans(
'ViewTicket').
'" />';
409 print
'<input type="submit" class="button button-cancel" name="cancel" value="'.$langs->trans(
"Cancel").
'">';
419 htmlPrintOnlinePaymentFooter($mysoc, $langs, 0, $suffix, $object);
GETPOST($paramname, $check= 'alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
if($cancel &&!$id) if($action== 'add'&&!$cancel) if($action== 'delete') if($id) $form
Actions.
Class to manage Dolibarr users.
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...
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
setEventMessages($mesg, $mesgs, $style= 'mesgs', $messagekey= '')
Set event messages in dol_events session object.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname from a POST of a form...
load_fiche_titre($titre, $morehtmlright= '', $picto= 'generic', $pictoisfullpath=0, $id= '', $morecssontable= '', $morehtmlcenter= '')
Load a title with picto.
static getValidAddress($address, $format, $encode=0, $maxnumberofemail=0)
Return a formatted address string for SMTP protocol.
llxHeaderTicket($title, $head="", $disablejs=0, $disablehead=0, $arrayofjs= '', $arrayofcss= '')
Show header for public pages.
img_picto($titlealt, $picto, $moreatt= '', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt= '', $morecss= '', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
accessforbidden($message= '', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program Calling this function terminate execution ...
dol_print_date($time, $format= '', $tzoutput= 'auto', $outputlangs= '', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
Class Actions of the module ticket.
const STATUS_NOT_READ
Status.