24 require
'../main.inc.php';
25 require_once DOL_DOCUMENT_ROOT.
'/ticket/class/actions_ticket.class.php';
26 require_once DOL_DOCUMENT_ROOT.
'/ticket/class/ticketstats.class.php';
27 require_once DOL_DOCUMENT_ROOT.
'/core/class/dolgraph.class.php';
28 require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
33 $hookmanager->initHooks(array(
'ticketsindex'));
36 $langs->loadLangs(array(
'companies',
'other',
'ticket'));
43 $msg_id =
GETPOST(
'msg_id',
'int');
45 $action =
GETPOST(
'action',
'aZ09');
48 $socid = $user->socid;
54 $nowyear = strftime(
"%Y",
dol_now());
57 $startyear = $year - 1;
74 $form =
new Form($db);
75 $tickesupstatic =
new Ticket($db);
77 llxHeader(
'', $langs->trans(
'TicketsIndex'),
'');
84 $filenamenb = $dir.
"/".$prefix.
"ticketinyear-".$endyear.
".png";
85 $fileurlnb = DOL_URL_ROOT.
'/viewimage.php?modulepart=ticket&file=ticketinyear-'.$endyear.
'.png';
88 $param_year =
'DOLUSERCOOKIE_ticket_by_status_year';
89 $param_shownb =
'DOLUSERCOOKIE_ticket_by_status_shownb';
90 $param_showtot =
'DOLUSERCOOKIE_ticket_by_status_showtot';
91 $autosetarray = preg_split(
"/[,;:]+/",
GETPOST(
'DOL_AUTOSET_COOKIE'));
92 if (in_array(
'DOLUSERCOOKIE_ticket_by_status', $autosetarray)) {
93 $endyear =
GETPOST($param_year,
'int');
94 $shownb =
GETPOST($param_shownb,
'alpha');
95 $showtot =
GETPOST($param_showtot,
'alpha');
97 $tmparray = json_decode($_COOKIE[
'DOLUSERCOOKIE_ticket_by_status'],
true);
98 $endyear = $tmparray[
'year'];
99 $shownb = $tmparray[
'shownb'];
100 $showtot = $tmparray[
'showtot'];
102 if (empty($shownb) && empty($showtot)) {
107 if (empty($endyear)) {
108 $endyear = $nowarray[
'year'];
111 $startyear = $endyear - 1;
112 $WIDTH = (($shownb && $showtot) || !empty($conf->dol_optimize_smallscreen)) ?
'100%' :
'80%';
115 print '<div class="fichecenter"><div class="fichethirdleft">';
131 $sql =
"SELECT t.fk_statut, COUNT(t.fk_statut) as nb";
132 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
133 if (!$user->rights->societe->client->voir && !$socid) {
134 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
136 $sql .=
' WHERE t.entity IN ('.getEntity(
'ticket').
')';
139 if (!$user->rights->societe->client->voir && !$socid) {
140 $sql .=
" AND t.fk_soc = sc.fk_soc AND sc.fk_user = ".$user->id;
144 if ($user->socid > 0) {
145 $sql .=
" AND t.fk_soc= ".((int) $user->socid);
148 if (!empty($conf->global->TICKET_LIMIT_VIEW_ASSIGNED_ONLY) && !$user->rights->ticket->manage) {
149 $sql .=
" AND t.fk_user_assign = ".$user->id;
152 $sql .=
" GROUP BY t.fk_statut";
154 $result = $db->query($sql);
156 while ($objp = $db->fetch_object($result)) {
159 $tick[
'unread'] = $objp->nb;
161 if ($objp->fk_statut == Ticket::STATUS_READ) {
162 $tick[
'read'] = $objp->nb;
164 if ($objp->fk_statut == Ticket::STATUS_NEED_MORE_INFO) {
165 $tick[
'needmoreinfo'] = $objp->nb;
167 if ($objp->fk_statut == Ticket::STATUS_ASSIGNED) {
168 $tick[
'assigned'] = $objp->nb;
170 if ($objp->fk_statut == Ticket::STATUS_IN_PROGRESS) {
171 $tick[
'inprogress'] = $objp->nb;
173 if ($objp->fk_statut == Ticket::STATUS_WAITING) {
174 $tick[
'waiting'] = $objp->nb;
176 if ($objp->fk_statut == Ticket::STATUS_CLOSED) {
177 $tick[
'closed'] = $objp->nb;
179 if ($objp->fk_statut == Ticket::STATUS_CANCELED) {
180 $tick[
'canceled'] = $objp->nb;
184 include_once DOL_DOCUMENT_ROOT.
'/theme/'.$conf->theme.
'/theme_vars.inc.php';
186 $dataseries = array();
187 $colorseries = array();
189 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[
Ticket::STATUS_NOT_READ]),
'data' => round($tick[
'unread']));
191 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_READ]),
'data' => round($tick[
'read']));
192 $colorseries[Ticket::STATUS_READ] = $badgeStatus1;
193 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_ASSIGNED]),
'data' => round($tick[
'assigned']));
194 $colorseries[Ticket::STATUS_ASSIGNED] = $badgeStatus3;
195 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_IN_PROGRESS]),
'data' => round($tick[
'inprogress']));
196 $colorseries[Ticket::STATUS_IN_PROGRESS] = $badgeStatus4;
197 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_WAITING]),
'data' => round($tick[
'waiting']));
198 $colorseries[Ticket::STATUS_WAITING] =
'-'.$badgeStatus4;
199 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_NEED_MORE_INFO]),
'data' => round($tick[
'needmoreinfo']));
200 $colorseries[Ticket::STATUS_NEED_MORE_INFO] =
'-'.$badgeStatus3;
201 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_CANCELED]),
'data' => round($tick[
'canceled']));
202 $colorseries[Ticket::STATUS_CANCELED] = $badgeStatus9;
203 $dataseries[] = array(
'label' => $langs->transnoentitiesnoconv($tickesupstatic->statuts_short[Ticket::STATUS_CLOSED]),
'data' => round($tick[
'closed']));
204 $colorseries[Ticket::STATUS_CLOSED] = $badgeStatus6;
209 $stringtoshow =
'<script type="text/javascript" language="javascript">
210 jQuery(document).ready(function() {
211 jQuery("#idsubimgDOLUSERCOOKIE_ticket_by_status").click(function() {
212 jQuery("#idfilterDOLUSERCOOKIE_ticket_by_status").toggle();
216 $stringtoshow .=
'<div class="center hideobject" id="idfilterDOLUSERCOOKIE_ticket_by_status">';
217 $stringtoshow .=
'<form class="flat formboxfilter" method="POST" action="'.$_SERVER[
"PHP_SELF"].
'">';
218 $stringtoshow .=
'<input type="hidden" name="token" value="'.newToken().
'">';
219 $stringtoshow .=
'<input type="hidden" name="action" value="refresh">';
220 $stringtoshow .=
'<input type="hidden" name="DOL_AUTOSET_COOKIE" value="DOLUSERCOOKIE_ticket_by_status:year,shownb,showtot">';
221 $stringtoshow .= $langs->trans(
"Year").
' <input class="flat" size="4" type="text" name="'.$param_year.
'" value="'.$endyear.
'">';
222 $stringtoshow .=
'<input type="image" alt="'.$langs->trans(
"Refresh").
'" src="'.
img_picto($langs->trans(
"Refresh"),
'refresh.png',
'',
'', 1).
'">';
223 $stringtoshow .=
'</form>';
224 $stringtoshow .=
'</div>';
226 print '<div class="div-table-responsive-no-min">';
227 print '<table class="noborder centpercent">';
228 print '<tr class="liste_titre"><th >'.$langs->trans(
"Statistics").
' '.$endyear.
' '.
img_picto(
'',
'filter.png',
'id="idsubimgDOLUSERCOOKIE_ticket_by_status" class="linkobject"').
'</th></tr>';
230 print '<tr><td class="center">';
234 if (!empty($dataseries) && count($dataseries) > 1) {
236 foreach ($dataseries as $key => $value) {
237 $totalnb += $value[
'data'];
241 foreach ($dataseries as $key => $value) {
242 $data[] = array($value[
'label'], $value[
'data']);
245 $mesg = $px1->isGraphKo();
247 $px1->SetData($data);
248 $px1->SetDataColor(array_values($colorseries));
253 while ($i <= $endyear) {
257 $px1->setShowLegend(2);
258 $px1->SetType(array(
'pie'));
259 $px1->SetLegend($legend);
260 $px1->SetMaxValue($px1->GetCeilMaxValue());
262 $px1->SetHeight($HEIGHT);
263 $px1->SetYLabel($langs->trans(
"TicketStatByStatus"));
265 $px1->SetHorizTickIncrement(1);
266 $px1->SetCssPrefix(
"cssboxes");
267 $px1->mode =
'depth';
270 $px1->draw($filenamenb, $fileurlnb);
271 print $px1->show($totalnb ? 0 : 1);
280 $data = $stats->getNbByMonthWithPrevYear($endyear, $startyear);
282 print '</div><div class="fichetwothirdright"><div class="ficheaddleft">';
291 $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, t.progress,";
292 $sql .=
" type.code as type_code, type.label as type_label,";
293 $sql .=
" category.code as category_code, category.label as category_label,";
294 $sql .=
" severity.code as severity_code, severity.label as severity_label";
295 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
296 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_type as type ON type.code=t.type_code";
297 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_category as category ON category.code=t.category_code";
298 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_severity as severity ON severity.code=t.severity_code";
299 if (!$user->rights->societe->client->voir && !$socid) {
300 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
303 $sql .=
' WHERE t.entity IN ('.getEntity(
'ticket').
')';
304 $sql .=
" AND t.fk_statut=0";
305 if (!$user->rights->societe->client->voir && !$socid) {
306 $sql .=
" AND t.fk_soc = sc.fk_soc AND sc.fk_user = ".$user->id;
309 if ($user->socid > 0) {
310 $sql .=
" AND t.fk_soc= ".((int) $user->socid);
313 if ($conf->global->TICKET_LIMIT_VIEW_ASSIGNED_ONLY && !$user->rights->ticket->manage) {
314 $sql .=
" AND t.fk_user_assign=".$user->id;
317 $sql .= $db->order(
"t.datec",
"DESC");
318 $sql .= $db->plimit($max, 0);
321 $result = $db->query($sql);
323 $num = $db->num_rows($result);
327 $transRecordedType = $langs->trans(
"LatestNewTickets", $max);
329 print '<div class="div-table-responsive-no-min">';
330 print '<table class="noborder centpercent">';
331 print '<tr class="liste_titre"><th colspan="5">'.$transRecordedType.
'</th>';
332 print '<th class="right" colspan="2"><a href="'.DOL_URL_ROOT.
'/ticket/list.php?search_fk_statut[]='.
Ticket::STATUS_NOT_READ.
'">'.$langs->trans(
"FullList").
'</th>';
336 $objp = $db->fetch_object($result);
338 $tickesupstatic->id = $objp->rowid;
339 $tickesupstatic->ref = $objp->ref;
340 $tickesupstatic->track_id = $objp->track_id;
341 $tickesupstatic->fk_statut = $objp->fk_statut;
342 $tickesupstatic->progress = $objp->progress;
343 $tickesupstatic->subject = $objp->subject;
345 print '<tr class="oddeven">';
348 print '<td class="nowraponall">';
349 print $tickesupstatic->getNomUrl(1);
353 print '<td class="left">';
358 print
'<td class="nowrap">';
359 print
'<a href="card.php?track_id='.$objp->track_id.
'">'.
dol_trunc($objp->subject, 30).
'</a>';
363 print
'<td class="nowrap tdoverflowmax100">';
364 $s = $langs->getLabelFromKey($db,
'TicketTypeShort'.$objp->type_code,
'c_ticket_type',
'code',
'label', $objp->type_code);
365 print
'<span title="'.dol_escape_htmltag($s).
'">'.$s.
'</span>';
369 print
'<td class="nowrap">';
370 $s = $langs->getLabelFromKey($db,
'TicketCategoryShort'.$objp->category_code,
'c_ticket_category',
'code',
'label', $objp->category_code);
371 print
'<span title="'.dol_escape_htmltag($s).
'">'.$s.
'</span>';
376 print
'<td class="nowrap">';
377 $s = $langs->getLabelFromKey($db,
'TicketSeverityShort'.$objp->severity_code,
'c_ticket_severity',
'code',
'label', $objp->severity_code);
378 print
'<span title="'.dol_escape_htmltag($s).
'">'.$s.
'</span>';
382 print
'<td class="nowraponall right">';
383 print $tickesupstatic->getLibStatut(5);
392 print
'<tr><td colspan="6" class="opacitymedium">'.$langs->trans(
'NoUnreadTicketsFound').
'</td></tr>';
401 print
'</div></div></div>';
402 print
'<div style="clear:both"></div>';
404 $parameters = array(
'user' => $user);
405 $reshook = $hookmanager->executeHooks(
'dashboardTickets', $parameters, $object);
GETPOST($paramname, $check= 'alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
Classe permettant la gestion des stats des deplacements et notes de frais.
dol_now($mode= 'auto')
Return date for now.
load_fiche_titre($titre, $morehtmlright= '', $picto= 'generic', $pictoisfullpath=0, $id= '', $morecssontable= '', $morehtmlcenter= '')
Load a title with picto.
img_picto($titlealt, $picto, $moreatt= '', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt= '', $morecss= '', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
dol_getdate($timestamp, $fast=false, $forcetimezone= '')
Return an array with locale date info.
restrictedArea($user, $features, $objectid=0, $tableandshare= '', $feature2= '', $dbt_keyfield= 'fk_soc', $dbt_select= 'rowid', $isdraft=0)
Check permissions of a user to show a page and an object.
dolSqlDateFilter($datefield, $day_date, $month_date, $year_date, $excludefirstand=0)
Generate a SQL string to make a filter into a range (for second of date until last second of date) ...
print
Draft customers invoices.
dol_print_date($time, $format= '', $tzoutput= 'auto', $outputlangs= '', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db= '', $error= '', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
static getDefaultGraphSizeForStats($direction, $defaultsize= '')
getDefaultGraphSizeForStats
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.
const STATUS_NOT_READ
Status.