26 require_once DOL_DOCUMENT_ROOT.
"/core/boxes/modules_boxes.php";
34 public $boxcode =
"box_last_ticket";
35 public $boximg =
"ticket";
37 public $depends = array(
"ticket");
45 public $info_box_head = array();
46 public $info_box_contents = array();
56 $langs->load(
"boxes");
59 $this->boxlabel = $langs->transnoentitiesnoconv(
"BoxLastTicket");
70 global $conf, $user, $langs;
74 require_once DOL_DOCUMENT_ROOT.
"/ticket/class/ticket.class.php";
76 $text = $langs->trans(
"BoxLastTicketDescription", $max);
77 $this->info_box_head = array(
82 $this->info_box_contents[0][0] = array(
83 'td' =>
'class="left"',
84 'text' => $langs->trans(
"BoxLastTicketContent"),
87 if ($user->hasRight(
'ticket',
'read')) {
88 $sql =
"SELECT t.rowid as id, t.ref, t.track_id, t.fk_soc, t.fk_user_create, t.fk_user_assign, t.subject, t.message, t.fk_statut as status, t.type_code, t.category_code, t.severity_code, t.datec, t.date_read, t.date_close, t.origin_email,";
89 $sql .=
" type.label as type_label, category.label as category_label, severity.label as severity_label,";
90 $sql .=
" s.nom as company_name, s.email as socemail, s.client, s.fournisseur";
91 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
92 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_type as type ON type.code=t.type_code";
93 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_category as category ON category.code=t.category_code";
94 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_severity as severity ON severity.code=t.severity_code";
95 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe as s ON s.rowid=t.fk_soc";
96 $sql .=
" WHERE t.entity IN (".getEntity(
'ticket').
")";
100 $sql .=
" AND t.fk_soc= ".((int) $user->socid);
105 $sql .=
" ORDER BY t.datec DESC, t.rowid DESC ";
106 $sql .= $this->
db->plimit($max, 0);
115 $objp = $this->
db->fetch_object(
$resql);
117 $datec = $this->
db->jdate($objp->datec);
123 $ticket->id = $objp->id;
124 $ticket->track_id = $objp->track_id;
125 $ticket->ref = $objp->ref;
126 $ticket->fk_statut = $objp->status;
127 $ticket->status = $objp->status;
128 $ticket->subject = $objp->subject;
129 if ($objp->fk_soc > 0) {
131 $thirdparty->id = $objp->fk_soc;
132 $thirdparty->email = $objp->socemail;
133 $thirdparty->client = $objp->client;
134 $thirdparty->fournisseur = $objp->fournisseur;
135 $thirdparty->name = $objp->company_name;
136 $link = $thirdparty->getNomUrl(1);
138 $link =
'<span title="'.$objp->origin_email.
'">'.
dol_print_email($objp->origin_email).
'</span>';
144 $this->info_box_contents[$i][$r] = array(
145 'td' =>
'class="nowraponall"',
146 'text' => $ticket->getNomUrl(1),
152 $this->info_box_contents[$i][$r] = array(
153 'td' =>
'class="tdoverflowmax200"',
155 'url' => DOL_URL_ROOT.
"/ticket/card.php?track_id=".urlencode($objp->track_id),
160 $this->info_box_contents[$i][$r] = array(
161 'td' =>
'class="tdoverflowmax100"',
168 $this->info_box_contents[$i][$r] = array(
175 $this->info_box_contents[$i][$r] = array(
176 'td' =>
'class="right nowraponall"',
177 'text' => $ticket->getLibStatut(3),
185 $this->info_box_contents[$i][0] = array(
'td' =>
'',
'text' =>
'<span class="opacitymedium">'.$langs->trans(
"BoxLastTicketNoRecordedTickets").
'</span>');
191 $this->info_box_contents[0][0] = array(
'td' =>
'',
192 'text' =>
'<span class="opacitymedium">'.$langs->trans(
"ReadPermissionNotAllowed").
'</span>');
204 public function showBox($head =
null, $contents =
null, $nooutput = 0)
206 return parent::showBox($this->info_box_head, $this->info_box_contents, $nooutput);
Class to manage third parties objects (customers, suppliers, prospects...)
showBox($head=null, $contents=null, $nooutput=0)
Method to show box.
__construct($db, $param='')
Constructor.
loadBox($max=5)
Load data into info_box_contents array to show array later.
if(isModEnabled('facture') &&!empty($user->rights->facture->lire)) if((isModEnabled('fournisseur') &&empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD) && $user->hasRight("fournisseur", "facture", "lire"))||(isModEnabled('supplier_invoice') && $user->hasRight("supplier_invoice", "lire"))) if(isModEnabled('don') &&!empty($user->rights->don->lire)) if(isModEnabled('tax') &&!empty($user->rights->tax->charges->lire)) if(isModEnabled('facture') &&isModEnabled('commande') && $user->hasRight("commande", "lire") &&empty($conf->global->WORKFLOW_DISABLE_CREATE_INVOICE_FROM_ORDER)) $resql
Social contributions to pay.
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.
dol_print_error($db='', $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
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_email($email, $cid=0, $socid=0, $addlink=0, $max=64, $showinvalid=1, $withpicto=0)
Show EMail link formatted for HTML output.
Class to generate the form for creating a new ticket.
$conf db
API class for accounts.