28require
'../main.inc.php';
29require_once DOL_DOCUMENT_ROOT.
'/core/class/dolgraph.class.php';
30require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formother.class.php';
31require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
32require_once DOL_DOCUMENT_ROOT.
'/ticket/class/actions_ticket.class.php';
33require_once DOL_DOCUMENT_ROOT.
'/ticket/class/ticketstats.class.php';
45$hookmanager->initHooks(array(
'ticketsindex'));
48$langs->loadLangs(array(
'companies',
'other',
'ticket'));
57$action =
GETPOST(
'action',
'aZ09');
61 $socid = $user->socid;
66$nowyear = $nowarray[
'year'];
76if (!$user->hasRight(
'ticket',
'read') && !$user->hasRight(
'knowledgemanagement',
'knowledgerecord',
'read')) {
82$permissiontomanage = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'ticket',
'write')) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'expedition',
'ticket',
'manage_advance')));
100llxHeader(
'', $langs->trans(
'TicketsIndex'), $help_url,
'', 0, 0,
'',
'',
'',
'mod-ticket page-dashboard');
103print
load_fiche_titre($langs->trans(
'TicketsIndex'), $resultboxes[
'selectboxlist'],
'ticket');
108$filenamenb = $dir.
"/".$prefix.
"ticketinyear-".$endyear.
".png";
109$fileurlnb = DOL_URL_ROOT.
'/viewimage.php?modulepart=ticket&file=ticketinyear-'.$endyear.
'.png';
112$param_year =
'DOLUSERCOOKIE_ticket_by_status_year';
113$param_shownb =
'DOLUSERCOOKIE_ticket_by_status_shownb';
114$param_showtot =
'DOLUSERCOOKIE_ticket_by_status_showtot';
115$autosetarray = preg_split(
"/[,;:]+/",
GETPOST(
'DOL_AUTOSET_COOKIE'));
118if (in_array(
'DOLUSERCOOKIE_ticket_by_status', $autosetarray)) {
120 $shownb =
GETPOST($param_shownb,
'alpha');
121 $showtot =
GETPOST($param_showtot,
'alpha');
122} elseif (!empty($_COOKIE[
'DOLUSERCOOKIE_ticket_by_status'])) {
123 $tmparray = json_decode($_COOKIE[
'DOLUSERCOOKIE_ticket_by_status'],
true);
124 $endyear = $tmparray[
'year'];
125 $shownb = empty($tmparray[
'shownb']) ? 0 : $tmparray[
'shownb'];
126 $showtot = empty($tmparray[
'showtot']) ? 0 : $tmparray[
'showtot'];
128if (empty($shownb) && empty($showtot)) {
133if (empty($endyear)) {
134 $endyear = $nowarray[
'year'];
137$startyear = $endyear - 1;
140$WIDTH = (($shownb && $showtot) || !empty(
$conf->dol_optimize_smallscreen)) ?
'100%' :
'80%';
141if (empty(
$conf->dol_optimize_smallscreen)) {
147print
'<div class="clearboth"></div>';
148print
'<div class="fichecenter fichecenterbis">';
150print
'<div class="twocolumns">';
152print
'<div class="firstcolumn fichehalfleft boxhalfleft" id="boxhalfleft">';
170$sql =
"SELECT t.fk_statut, COUNT(t.fk_statut) as nb";
171$sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
172if (!$user->hasRight(
'societe',
'client',
'voir')) {
173 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
175$sql .=
' WHERE t.entity IN ('.getEntity(
'ticket').
')';
178if (!$user->hasRight(
'societe',
'client',
'voir')) {
179 $sql .=
" AND t.fk_soc = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
183if ($user->socid > 0) {
184 $sql .=
" AND t.fk_soc= ".((int) $user->socid);
188 $sql .=
" AND t.fk_user_assign = ".((int) $user->id);
191$sql .=
" GROUP BY t.fk_statut";
193$dataseries = array();
194$result =
$db->query($sql);
196 while ($objp =
$db->fetch_object($result)) {
198 if ($objp->fk_statut == Ticket::STATUS_NOT_READ) {
199 $tick[
'unread'] = $objp->nb;
201 if ($objp->fk_statut == Ticket::STATUS_READ) {
202 $tick[
'read'] = $objp->nb;
204 if ($objp->fk_statut == Ticket::STATUS_NEED_MORE_INFO) {
205 $tick[
'needmoreinfo'] = $objp->nb;
207 if ($objp->fk_statut == Ticket::STATUS_ASSIGNED) {
208 $tick[
'assigned'] = $objp->nb;
210 if ($objp->fk_statut == Ticket::STATUS_IN_PROGRESS) {
211 $tick[
'inprogress'] = $objp->nb;
213 if ($objp->fk_statut == Ticket::STATUS_WAITING) {
214 $tick[
'waiting'] = $objp->nb;
216 if ($objp->fk_statut == Ticket::STATUS_CLOSED) {
217 $tick[
'closed'] = $objp->nb;
219 if ($objp->fk_statut == Ticket::STATUS_CANCELED) {
220 $tick[
'canceled'] = $objp->nb;
234 include DOL_DOCUMENT_ROOT.
'/theme/'.
$conf->theme.
'/theme_vars.inc.php';
236 $colorseries = array();
238 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_NOT_READ]),
'data' => round($tick[
'unread']));
240 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_READ]),
'data' => round($tick[
'read']));
241 $colorseries[Ticket::STATUS_READ] = $badgeStatus1;
242 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_ASSIGNED]),
'data' => round($tick[
'assigned']));
243 $colorseries[Ticket::STATUS_ASSIGNED] = $badgeStatus3;
244 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_IN_PROGRESS]),
'data' => round($tick[
'inprogress']));
245 $colorseries[Ticket::STATUS_IN_PROGRESS] = $badgeStatus4;
247 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_WAITING]),
'data' => round($tick[
'waiting']));
248 $colorseries[Ticket::STATUS_WAITING] =
'-'.$badgeStatus4;
250 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_NEED_MORE_INFO]),
'data' => round($tick[
'needmoreinfo']));
251 $colorseries[Ticket::STATUS_NEED_MORE_INFO] =
'-'.$badgeStatus3;
252 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_CANCELED]),
'data' => round($tick[
'canceled']));
253 $colorseries[Ticket::STATUS_CANCELED] = $badgeStatus9;
254 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv(
$object->labelStatusShort[Ticket::STATUS_CLOSED]),
'data' => round($tick[
'closed']));
255 $colorseries[Ticket::STATUS_CLOSED] = $badgeStatus6;
260$stringtoshow =
'<script type="text/javascript">
261 jQuery(document).ready(function() {
262 jQuery("#idsubimgDOLUSERCOOKIE_ticket_by_status").click(function() {
263 jQuery("#idfilterDOLUSERCOOKIE_ticket_by_status").toggle();
267$stringtoshow .=
'<div class="center hideobject" id="idfilterDOLUSERCOOKIE_ticket_by_status">';
268$stringtoshow .=
'<form class="flat formboxfilter" method="POST" action="'.dolBuildUrl($_SERVER[
"PHP_SELF"]).
'">';
269$stringtoshow .=
'<input type="hidden" name="token" value="'.newToken().
'">';
270$stringtoshow .=
'<input type="hidden" name="action" value="refresh">';
271$stringtoshow .=
'<input type="hidden" name="DOL_AUTOSET_COOKIE" value="DOLUSERCOOKIE_ticket_by_status:year,shownb,showtot">';
272$stringtoshow .= $langs->trans(
"Year").
' <input class="flat" size="4" type="text" name="'.$param_year.
'" value="'.$endyear.
'">';
273$stringtoshow .=
'<input type="image" alt="'.$langs->trans(
"Refresh").
'" src="'.
img_picto($langs->trans(
"Refresh"),
'refresh.png',
'', 0, 1).
'">';
274$stringtoshow .=
'</form>';
275$stringtoshow .=
'</div>';
277if ($user->hasRight(
'ticket',
'read')) {
278 print
'<div class="div-table-responsive-no-min">';
279 print
'<table class="noborder centpercent">';
280 print
'<tr class="liste_titre"><th colspan=2>'.$langs->trans(
"Statistics").
' '.$endyear.
' '.
img_picto(
'',
'filter.png',
'id="idsubimgDOLUSERCOOKIE_ticket_by_status" class="linkobject"').
'</th></tr>';
282 print
'<tr><td class="center" colspan=2>';
287 if (!empty($dataseries) && count($dataseries) > 1) {
288 foreach ($dataseries as $key => $value) {
289 $totalnb += $value[
'data'];
293 foreach ($dataseries as $key => $value) {
294 $data[] = array($value[
'label'], $value[
'data']);
297 $mesg = $px1->isGraphKo();
299 $px1->SetData($data);
300 $px1->SetDataColor(array_values($colorseries));
305 while ($i <= $endyear) {
309 $px1->setShowLegend(2);
310 $px1->SetType(array(
'pie'));
311 $px1->SetLegend($legend);
312 $px1->SetMaxValue($px1->GetCeilMaxValue());
314 $px1->SetHeight($HEIGHT);
315 $px1->SetYLabel($langs->trans(
"TicketStatByStatus"));
317 $px1->SetHorizTickIncrement(1);
318 $px1->SetCssPrefix(
"cssboxes");
319 $px1->mode =
'depth';
322 $px1->draw($filenamenb, $fileurlnb);
323 print $px1->show($totalnb ? 0 : 1);
327 print
'<tr class="liste_total"><td>'.$langs->trans(
"Total").
'</td><td class="right">'.$totalnb.
'</td></tr>';
332if ($user->hasRight(
'ticket',
'read')) {
334 $data = $stats->getNbByMonthWithPrevYear($endyear, $startyear);
339print $resultboxes[
'boxlista'];
343print
'<div class="secondcolumn fichehalfright boxhalfright" id="boxhalfright">';
345if ($user->hasRight(
'ticket',
'read')) {
350 $sql =
"SELECT t.rowid, t.ref, t.track_id, t.datec, t.subject, t.type_code, t.category_code, t.severity_code, t.fk_statut as status, t.progress,";
351 $sql .=
" type.code as type_code, type.label as type_label,";
352 $sql .=
" category.code as category_code, category.label as category_label,";
353 $sql .=
" severity.code as severity_code, severity.label as severity_label";
354 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
355 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_type as type ON type.code = t.type_code AND type.entity = t.entity";
356 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_category as category ON category.code = t.category_code AND category.entity = t.entity";
357 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_severity as severity ON severity.code = t.severity_code AND severity.entity = t.entity";
358 if (!$user->hasRight(
'societe',
'client',
'voir')) {
359 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
362 $sql .=
' WHERE t.entity IN ('.getEntity(
'ticket').
')';
363 $sql .=
" AND t.fk_statut = 0";
364 if (!$user->hasRight(
'societe',
'client',
'voir')) {
365 $sql .=
" AND t.fk_soc = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
368 if ($user->socid > 0) {
369 $sql .=
" AND t.fk_soc= ".((int) $user->socid);
373 $sql .=
" AND t.fk_user_assign = ".((int) $user->id);
376 $sql .=
$db->order(
"t.datec",
"DESC");
377 $sql .=
$db->plimit($max, 0);
380 $result =
$db->query($sql);
382 $num =
$db->num_rows($result);
386 $tmpmax =
getDolGlobalInt(
'MAIN_SIZE_SHORTLIST_LIMIT_LAST_MODIFIED_TICKETS', $max);
387 $transRecordedType = $langs->trans(
"LatestNewTickets", $tmpmax);
389 print
'<div class="div-table-responsive-no-min">';
390 print
'<table class="noborder centpercent">';
391 print
'<tr class="liste_titre"><th colspan="5">'.$transRecordedType;
392 print
'<a href="'.DOL_URL_ROOT.
'/ticket/list.php?search_fk_statut[]='.
Ticket::STATUS_NOT_READ.
'" title="'.$langs->trans(
"FullList").
'">';
393 print
'<span class="badge marginleftonlyshort">...</span>';
404 $objp =
$db->fetch_object($result);
408 $object->track_id = $objp->track_id;
409 $object->status = $objp->status;
410 $object->progress = $objp->progress;
411 $object->subject = $objp->subject;
413 print
'<tr class="oddeven">';
416 print
'<td class="nowraponall">';
421 print
'<td class="center nowraponall">';
426 print
'<td class="nowrap tdoverflowmax150">';
431 print
'<td class="nowrap tdoverflowmax100">';
432 $s = $langs->getLabelFromKey(
$db,
'TicketTypeShort'.$objp->type_code,
'c_ticket_type',
'code',
'label', $objp->type_code);
433 print
'<span title="'.dol_escape_htmltag($s).
'">'.$s.
'</span>';
437 print
'<td class="nowrap">';
438 if (!empty($objp->category_code)) {
439 $s = $langs->getLabelFromKey(
$db,
'TicketCategoryShort'.$objp->category_code,
'c_ticket_category',
'code',
'label', $objp->category_code);
440 print
'<span title="'.dol_escape_htmltag($s).
'">'.$s.
'</span>';
446 print
'<td class="nowrap" title="'.$langs->trans(
"Priority").
'">';
447 $s = $langs->getLabelFromKey(
$db,
'TicketSeverityShort'.$objp->severity_code,
'c_ticket_severity',
'code',
'label', $objp->severity_code);
448 print
'<span title="'.dol_escape_htmltag($s).
'">'.$s.
'</span>';
452 print
'<td class="nowraponall right">';
453 print
$object->getLibStatut(5);
462 print
'<tr><td colspan="7"><span class="opacitymedium">'.$langs->trans(
'NoUnreadTicketsFound').
'</span></td></tr>';
474print $resultboxes[
'boxlistb'];
481print
'<div class="clearboth"></div>';
483$parameters = array(
'user' => $user);
484$reshook = $hookmanager->executeHooks(
'dashboardTickets', $parameters, $object);
$id
Support class for third parties, contacts, members, users or resources.
if(! $sortfield) if(! $sortorder) $object
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
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.
static getDefaultGraphSizeForStats($direction, $defaultsize='')
getDefaultGraphSizeForStats
const STATUS_NOT_READ
Status.
Class to manage the ticket stats.
dolSqlDateFilter($datefield, $day_date, $month_date, $year_date, $excludefirstand=0, $gm=false)
Generate a SQL string to make a filter into a range (for second of date until last second of date).
dol_now($mode='gmt')
Return date for now.
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.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dolPrintHTMLForAttribute($s, $escapeonlyhtmltags=0, $allowothertags=array())
Return a string ready to be output into an HTML attribute (alt, title, data-html, ....
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).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
dol_trunc($string, $size=40, $trunc='right', $stringencoding='UTF-8', $nodot=0, $display=0)
Truncate a string to a particular length adding '…' if string larger than length.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
Class to generate the form for creating a new ticket.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.