29require
'../main.inc.php';
30require_once DOL_DOCUMENT_ROOT.
'/recruitment/class/recruitmentjobposition.class.php';
31require_once DOL_DOCUMENT_ROOT.
'/recruitment/class/recruitmentcandidature.class.php';
32require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
43$langs->loadLangs(array(
"recruitment",
"boxes"));
45$action =
GETPOST(
'action',
'aZ09');
52if (!empty($user->socid) && $user->socid > 0) {
54 $socid = $user->socid;
63restrictedArea($user,
'recruitment', 0,
'recruitment_recruitmentjobposition',
'recruitmentjobposition',
'',
'rowid');
82llxHeader(
"", $langs->trans(
"RecruitmentArea"));
84print
load_fiche_titre($langs->trans(
"RecruitmentArea"),
'',
'object_recruitmentjobposition');
86print
'<div class="fichecenter"><div class="fichethirdleft">';
93if (
$conf->use_javascript_ajax) {
94 $sql =
"SELECT COUNT(t.rowid) as nb, status";
95 $sql .=
" FROM ".MAIN_DB_PREFIX.
"recruitment_recruitmentjobposition as t";
96 $sql .=
" GROUP BY t.status";
97 $sql .=
" ORDER BY t.status ASC";
98 $resql =
$db->query($sql);
109 include DOL_DOCUMENT_ROOT.
'/theme/'.
$conf->theme.
'/theme_vars.inc.php';
111 $num =
$db->num_rows($resql);
115 $dataseries = array();
116 $colorseries = array();
121 $obj =
$db->fetch_object($resql);
123 $vals[$obj->status] = $obj->nb;
125 $totalnb += $obj->nb;
131 print
'<div class="div-table-responsive-no-min">';
132 print
'<table class="noborder nohover centpercent">';
133 print
'<tr class="liste_titre"><th colspan="2">'.$langs->trans(
"Statistics").
' - '.$langs->trans(
"JobPositions").
'</th></tr>'.
"\n";
134 $listofstatus = array(0, 1, 3, 9);
135 foreach ($listofstatus as $status) {
136 $dataseries[] = array(
dol_html_entity_decode($staticrecruitmentjobposition->LibStatut($status, 1), ENT_QUOTES | ENT_HTML5), (isset($vals[$status]) ? (
int) $vals[$status] : 0));
138 $colorseries[$status] =
'-'.$badgeStatus0;
141 $colorseries[$status] = $badgeStatus4;
144 $colorseries[$status] = $badgeStatus6;
147 $colorseries[$status] = $badgeStatus9;
150 if (empty(
$conf->use_javascript_ajax)) {
151 print
'<tr class="oddeven">';
152 print
'<td>'.$staticrecruitmentjobposition->LibStatut($status, 0).
'</td>';
153 print
'<td class="right"><a href="list.php?statut='.$status.
'">'.(isset($vals[$status]) ? $vals[$status] : 0).
'</a></td>';
157 print
'<tr><td class="center" colspan="2">';
159 include_once DOL_DOCUMENT_ROOT.
'/core/class/dolgraph.class.php';
161 $dolgraph->SetData($dataseries);
162 $dolgraph->SetDataColor(array_values($colorseries));
163 $dolgraph->setShowLegend(2);
164 $dolgraph->setShowPercent(1);
165 $dolgraph->SetType(array(
'pie'));
166 $dolgraph->SetHeight(
'200');
167 $dolgraph->draw(
'idgraphstatus');
168 print $dolgraph->show($totalnb ? 0 : 1);
179 $sql =
"SELECT COUNT(t.rowid) as nb, status";
180 $sql .=
" FROM ".MAIN_DB_PREFIX.
"recruitment_recruitmentcandidature as t";
181 $sql .=
" GROUP BY t.status";
182 $sql .=
" ORDER BY t.status ASC";
183 $resql =
$db->query($sql);
186 $num =
$db->num_rows($resql);
190 $dataseries = array();
191 $colorseries = array();
195 $obj =
$db->fetch_object($resql);
197 $vals[$obj->status] = $obj->nb;
199 $totalnb += $obj->nb;
205 print
'<div class="div-table-responsive-no-min">';
206 print
'<table class="noborder nohover centpercent">';
207 print
'<tr class="liste_titre"><th colspan="2">'.$langs->trans(
"Statistics").
' - '.$langs->trans(
"RecruitmentCandidatures").
'</th></tr>'.
"\n";
208 $listofstatus = array(0, 1, 3, 5, 8, 9);
209 foreach ($listofstatus as $status) {
210 $dataseries[] = array(
dol_html_entity_decode($staticrecruitmentcandidature->LibStatut($status, 1), ENT_QUOTES | ENT_HTML5), (isset($vals[$status]) ? (
int) $vals[$status] : 0));
211 if ($status == RecruitmentCandidature::STATUS_DRAFT) {
212 $colorseries[$status] =
'-'.$badgeStatus0;
214 if ($status == RecruitmentCandidature::STATUS_VALIDATED) {
215 $colorseries[$status] = $badgeStatus1;
217 if ($status == RecruitmentCandidature::STATUS_CONTRACT_PROPOSED) {
218 $colorseries[$status] = $badgeStatus4;
220 if ($status == RecruitmentCandidature::STATUS_CONTRACT_SIGNED) {
221 $colorseries[$status] = $badgeStatus5;
223 if ($status == RecruitmentCandidature::STATUS_REFUSED) {
224 $colorseries[$status] = $badgeStatus9;
226 if ($status == RecruitmentCandidature::STATUS_CANCELED) {
227 $colorseries[$status] = $badgeStatus9;
230 if (empty(
$conf->use_javascript_ajax)) {
231 print
'<tr class="oddeven">';
232 print
'<td>'.$staticrecruitmentcandidature->LibStatut($status, 0).
'</td>';
233 print
'<td class="right"><a href="list.php?statut='.$status.
'">'.(isset($vals[$status]) ? $vals[$status] : 0).
'</a></td>';
237 print
'<tr><td class="center" colspan="2">';
239 include_once DOL_DOCUMENT_ROOT.
'/core/class/dolgraph.class.php';
241 $dolgraph->SetData($dataseries);
242 $dolgraph->SetDataColor(array_values($colorseries));
243 $dolgraph->setShowLegend(2);
244 $dolgraph->setShowPercent(1);
245 $dolgraph->SetType(array(
'pie'));
246 $dolgraph->SetHeight(
'200');
247 $dolgraph->draw(
'idgraphstatuscandidature');
248 print $dolgraph->show($totalnb ? 0 : 1);
341print
'</div><div class="fichetwothirdright">';
345if (
isModEnabled(
'recruitment') && $user->hasRight(
'recruitment',
'recruitmentjobposition',
'read')) {
346 $sql =
"SELECT s.rowid, s.ref, s.label, s.date_creation, s.tms, s.status, COUNT(rc.rowid) as nbapplications";
347 $sql .=
" FROM ".MAIN_DB_PREFIX.
"recruitment_recruitmentjobposition as s";
348 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"recruitment_recruitmentcandidature as rc ON rc.fk_recruitmentjobposition = s.rowid";
349 if (
isModEnabled(
'societe') && !$user->hasRight(
'societe',
'client',
'voir') && !$socid) {
350 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
352 $sql .=
" WHERE s.entity IN (".getEntity($staticrecruitmentjobposition->element).
")";
353 if (
isModEnabled(
'societe') && !$user->hasRight(
'societe',
'client',
'voir') && !$socid) {
354 $sql .=
" AND s.fk_soc = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
357 $sql .=
" AND s.fk_soc = $socid";
359 $sql .=
" GROUP BY s.rowid, s.ref, s.label, s.date_creation, s.tms, s.status";
360 $sql .=
$db->order(
's.tms',
'DESC');
361 $sql .=
$db->plimit($max, 0);
363 $resql =
$db->query($sql);
365 $num =
$db->num_rows($resql);
368 print
'<div class="div-table-responsive-no-min">';
369 print
'<table class="noborder centpercent">';
370 print
'<tr class="liste_titre">';
371 print
'<th colspan="2">';
372 print $langs->trans(
"BoxTitleLatestModifiedJobPositions", $max);
374 print
'<th class="right">';
375 print $langs->trans(
"Applications");
377 print
'<th class="right" colspan="2"><a href="'.DOL_URL_ROOT.
'/recruitment/recruitmentjobposition_list.php?sortfield=t.tms&sortorder=DESC">'.$langs->trans(
"FullList").
'</th>';
381 $objp =
$db->fetch_object($resql);
382 $staticrecruitmentjobposition->id = $objp->rowid;
383 $staticrecruitmentjobposition->ref = $objp->ref;
384 $staticrecruitmentjobposition->label = $objp->label;
385 $staticrecruitmentjobposition->status = $objp->status;
386 $staticrecruitmentjobposition->date_creation = $objp->date_creation;
388 print
'<tr class="oddeven">';
389 print
'<td class="nowrap">'.$staticrecruitmentjobposition->getNomUrl(1,
'').
'</td>';
390 print
'<td class="right nowrap">';
392 print
'<td class="right">';
393 print $objp->nbapplications;
395 print
'<td class="right nowrap">'.dol_print_date(
$db->jdate($objp->tms),
'day').
"</td>";
396 print
'<td class="right nowrap" width="16">';
397 print $staticrecruitmentjobposition->getLibStatut(3);
405 print
'<tr class="oddeven"><td colspan="4"><span class="opacitymedium">'.$langs->trans(
"None").
'</span></td></tr>';
416if (
isModEnabled(
'recruitment') && $user->hasRight(
'recruitment',
'recruitmentjobposition',
'read')) {
417 $sql =
"SELECT rc.rowid, rc.ref, rc.email, rc.lastname, rc.firstname, rc.date_creation, rc.tms, rc.status";
418 $sql .=
" FROM ".MAIN_DB_PREFIX.
"recruitment_recruitmentcandidature as rc";
419 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"recruitment_recruitmentjobposition as s ON rc.fk_recruitmentjobposition = s.rowid";
420 if (
isModEnabled(
'societe') && !$user->hasRight(
'societe',
'client',
'voir') && !$socid) {
421 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
423 $sql .=
" WHERE rc.entity IN (".getEntity($staticrecruitmentjobposition->element).
")";
424 if (
isModEnabled(
'societe') && !$user->hasRight(
'societe',
'client',
'voir') && !$socid) {
425 $sql .=
" AND s.fk_soc = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
428 $sql .=
" AND s.fk_soc = $socid";
430 $sql .=
$db->order(
'rc.tms',
'DESC');
431 $sql .=
$db->plimit($max, 0);
433 $resql =
$db->query($sql);
435 $num =
$db->num_rows($resql);
438 print
'<div class="div-table-responsive-no-min">';
439 print
'<table class="noborder centpercent">';
440 print
'<tr class="liste_titre">';
441 print
'<th colspan="2">';
442 print $langs->trans(
"BoxTitleLatestModifiedCandidatures", $max);
444 print
'<th class="right" colspan="2"><a href="'.DOL_URL_ROOT.
'/recruitment/recruitmentcandidature_list.php?sortfield=t.tms&sortorder=DESC">'.$langs->trans(
"FullList").
'</th>';
448 $objp =
$db->fetch_object($resql);
449 $staticrecruitmentcandidature->id = $objp->rowid;
450 $staticrecruitmentcandidature->ref = $objp->ref;
451 $staticrecruitmentcandidature->email = $objp->email;
452 $staticrecruitmentcandidature->status = $objp->status;
453 $staticrecruitmentcandidature->date_creation = $objp->date_creation;
454 $staticrecruitmentcandidature->firstname = $objp->firstname;
455 $staticrecruitmentcandidature->lastname = $objp->lastname;
457 print
'<tr class="oddeven">';
458 print
'<td class="nowrap">'.$staticrecruitmentcandidature->getNomUrl(1,
'').
'</td>';
459 print
'<td class="right nowrap">';
461 print
'<td class="right nowrap">'.dol_print_date(
$db->jdate($objp->tms),
'day').
"</td>";
462 print
'<td class="right nowrap" width="16">';
463 print $staticrecruitmentcandidature->getLibStatut(3);
471 print
'<tr class="oddeven"><td colspan="4"><span class="opacitymedium">'.$langs->trans(
"None").
'</span></td></tr>';
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.
Class for RecruitmentCandidature.
Class for RecruitmentJobPosition.
const STATUS_VALIDATED
Validated.
const STATUS_RECRUITED
Recruited.
const STATUS_CANCELED
Canceled.
const STATUS_DRAFT
Draft status.
dol_html_entity_decode($a, $b, $c='UTF-8', $keepsomeentities=0)
Replace html_entity_decode functions to manage errors.
dol_now($mode='gmt')
Return date for now.
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.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
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.
isModEnabled($module)
Is Dolibarr module enabled.
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.