Revert "NEW sorting elements on project overview"
This commit is contained in:
parent
48661ad88e
commit
eeb219cb55
@ -6,7 +6,6 @@
|
||||
* Copyright (C) 2015-2019 Alexandre Spangaro <aspangaro@open-dsi.fr>
|
||||
* Copyright (C) 2015 Marcos García <marcosgdf@gmail.com>
|
||||
* Copyright (C) 2016 Josep Lluís Amador <joseplluis@lliuretic.cat>
|
||||
* Copyright (C) 2020 Tobias Sekan <tobias.sekan@startmail.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
@ -100,7 +99,7 @@ $mine = $_REQUEST['mode'] == 'mine' ? 1 : 0;
|
||||
|
||||
$object = new Project($db);
|
||||
|
||||
include DOL_DOCUMENT_ROOT.'/core/actions_fetchobject.inc.php'; // Must be include, not include_once
|
||||
include DOL_DOCUMENT_ROOT.'/core/actions_fetchobject.inc.php'; // Must be include, not include_once
|
||||
if (!empty($conf->global->PROJECT_ALLOW_COMMENT_ON_PROJECT) && method_exists($object, 'fetchComments') && empty($object->comments)) $object->fetchComments();
|
||||
|
||||
// Security check
|
||||
@ -170,21 +169,21 @@ print '</td>';
|
||||
print '<td>';
|
||||
if (!empty($conf->global->PROJECT_USE_OPPORTUNITIES))
|
||||
{
|
||||
print '<input type="checkbox" disabled name="usage_opportunity"'.(GETPOSTISSET('usage_opportunity') ? (GETPOST('usage_opportunity', 'alpha') != ''?' checked="checked"':'') : ($object->usage_opportunity ? ' checked="checked"' : '')).'"> ';
|
||||
print '<input type="checkbox" disabled name="usage_opportunity"'.(GETPOSTISSET('usage_opportunity') ? (GETPOST('usage_opportunity', 'alpha') != '' ? ' checked="checked"' : '') : ($object->usage_opportunity ? ' checked="checked"' : '')).'"> ';
|
||||
$htmltext = $langs->trans("ProjectFollowOpportunity");
|
||||
print $form->textwithpicto($langs->trans("ProjectFollowOpportunity"), $htmltext);
|
||||
print '<br>';
|
||||
}
|
||||
if (empty($conf->global->PROJECT_HIDE_TASKS))
|
||||
{
|
||||
print '<input type="checkbox" disabled name="usage_task"'.(GETPOSTISSET('usage_task') ? (GETPOST('usage_task', 'alpha') != ''?' checked="checked"':'') : ($object->usage_task ? ' checked="checked"' : '')).'"> ';
|
||||
print '<input type="checkbox" disabled name="usage_task"'.(GETPOSTISSET('usage_task') ? (GETPOST('usage_task', 'alpha') != '' ? ' checked="checked"' : '') : ($object->usage_task ? ' checked="checked"' : '')).'"> ';
|
||||
$htmltext = $langs->trans("ProjectFollowTasks");
|
||||
print $form->textwithpicto($langs->trans("ProjectFollowTasks"), $htmltext);
|
||||
print '<br>';
|
||||
}
|
||||
if (!empty($conf->global->PROJECT_BILL_TIME_SPENT))
|
||||
{
|
||||
print '<input type="checkbox" disabled name="usage_bill_time"'.(GETPOSTISSET('usage_bill_time') ? (GETPOST('usage_bill_time', 'alpha') != ''?' checked="checked"':'') : ($object->usage_bill_time ? ' checked="checked"' : '')).'"> ';
|
||||
print '<input type="checkbox" disabled name="usage_bill_time"'.(GETPOSTISSET('usage_bill_time') ? (GETPOST('usage_bill_time', 'alpha') != '' ? ' checked="checked"' : '') : ($object->usage_bill_time ? ' checked="checked"' : '')).'"> ';
|
||||
$htmltext = $langs->trans("ProjectBillTimeDescription");
|
||||
print $form->textwithpicto($langs->trans("BillTime"), $htmltext);
|
||||
print '<br>';
|
||||
@ -619,7 +618,7 @@ foreach ($listofreferent as $key => $value)
|
||||
{
|
||||
$element = new $classname($db);
|
||||
|
||||
$elementarray = $object->get_element_list($key, $tablename, $datefieldname, $dates, $datee, !empty($project_field)?$project_field:'fk_projet');
|
||||
$elementarray = $object->get_element_list($key, $tablename, $datefieldname, $dates, $datee, !empty($project_field) ? $project_field : 'fk_projet');
|
||||
|
||||
if (is_array($elementarray) && count($elementarray) > 0)
|
||||
{
|
||||
@ -640,12 +639,12 @@ foreach ($listofreferent as $key => $value)
|
||||
$qualifiedfortotal = true;
|
||||
if ($key == 'invoice')
|
||||
{
|
||||
if (!empty($element->close_code) && $element->close_code == 'replaced') $qualifiedfortotal=false; // Replacement invoice, do not include into total
|
||||
if (!empty($conf->global->FACTURE_DEPOSITS_ARE_JUST_PAYMENTS) && $element->type == Facture::TYPE_DEPOSIT) $qualifiedfortotal=false; // If hidden option to use deposits as payment (deprecated, not recommended to use this), deposits are not included
|
||||
if (!empty($element->close_code) && $element->close_code == 'replaced') $qualifiedfortotal = false; // Replacement invoice, do not include into total
|
||||
if (!empty($conf->global->FACTURE_DEPOSITS_ARE_JUST_PAYMENTS) && $element->type == Facture::TYPE_DEPOSIT) $qualifiedfortotal = false; // If hidden option to use deposits as payment (deprecated, not recommended to use this), deposits are not included
|
||||
}
|
||||
if ($key == 'propal')
|
||||
{
|
||||
if ($element->statut == Propal::STATUS_NOTSIGNED) $qualifiedfortotal = false; // Refused proposal must not be included in total
|
||||
if ($element->statut == Propal::STATUS_NOTSIGNED) $qualifiedfortotal = false; // Refused proposal must not be included in total
|
||||
}
|
||||
|
||||
if ($tablename != 'expensereport_det' && method_exists($element, 'fetch_thirdparty')) $element->fetch_thirdparty();
|
||||
@ -653,7 +652,7 @@ foreach ($listofreferent as $key => $value)
|
||||
// Define $total_ht_by_line
|
||||
if ($tablename == 'don' || $tablename == 'chargesociales' || $tablename == 'payment_various' || $tablename == 'payment_salary') $total_ht_by_line = $element->amount;
|
||||
elseif ($tablename == 'fichinter') $total_ht_by_line = $element->getAmount();
|
||||
elseif ($tablename == 'stock_mouvement') $total_ht_by_line = $element->price*abs($element->qty);
|
||||
elseif ($tablename == 'stock_mouvement') $total_ht_by_line = $element->price * abs($element->qty);
|
||||
elseif ($tablename == 'projet_task')
|
||||
{
|
||||
if ($idofelementuser)
|
||||
@ -668,7 +667,7 @@ foreach ($listofreferent as $key => $value)
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan') {
|
||||
if((empty($dates) && empty($datee)) || (intval($dates) <= $element->datestart && intval($datee) >= $element->dateend)){
|
||||
if ((empty($dates) && empty($datee)) || (intval($dates) <= $element->datestart && intval($datee) >= $element->dateend)) {
|
||||
// Get total loan
|
||||
$total_ht_by_line = -$element->capital;
|
||||
}
|
||||
@ -677,8 +676,8 @@ foreach ($listofreferent as $key => $value)
|
||||
$total_ht_by_line = 0;
|
||||
$loanScheduleStatic = new LoanSchedule($element->db);
|
||||
$loanScheduleStatic->fetchAll($element->id);
|
||||
if(!empty($loanScheduleStatic->lines)){
|
||||
foreach($loanScheduleStatic->lines as $loanSchedule){
|
||||
if (!empty($loanScheduleStatic->lines)) {
|
||||
foreach ($loanScheduleStatic->lines as $loanSchedule) {
|
||||
/**
|
||||
* @var $loanSchedule LoanSchedule
|
||||
*/
|
||||
@ -776,11 +775,7 @@ print "</table>";
|
||||
print '<br><br>';
|
||||
print '<br>';
|
||||
|
||||
$param = 'id='.$object->id.'&mainmenu=home';
|
||||
$sortfield = GETPOST("sortfield", "alpha");
|
||||
$sortorder = GETPOST("sortorder", 'alpha');
|
||||
if (!$sortfield) $sortfield = "nature";
|
||||
if (!$sortorder) $sortorder = "asc";
|
||||
|
||||
|
||||
// Detail
|
||||
foreach ($listofreferent as $key => $value)
|
||||
@ -815,12 +810,12 @@ foreach ($listofreferent as $key => $value)
|
||||
if (!in_array($tablename, $array_of_element_linkable_with_different_thirdparty))
|
||||
{
|
||||
$idtofilterthirdparty = $object->thirdparty->id;
|
||||
if (! empty($conf->global->PROJECT_OTHER_THIRDPARTY_ID_TO_ADD_ELEMENTS)) $idtofilterthirdparty .= ','.$conf->global->PROJECT_OTHER_THIRDPARTY_ID_TO_ADD_ELEMENTS;
|
||||
if (!empty($conf->global->PROJECT_OTHER_THIRDPARTY_ID_TO_ADD_ELEMENTS)) $idtofilterthirdparty .= ','.$conf->global->PROJECT_OTHER_THIRDPARTY_ID_TO_ADD_ELEMENTS;
|
||||
}
|
||||
|
||||
if (empty($conf->global->PROJECT_LINK_ON_OVERWIEW_DISABLED) && $idtofilterthirdparty && !in_array($tablename, $exclude_select_element))
|
||||
{
|
||||
$selectList = $formproject->select_element($tablename, $idtofilterthirdparty, 'minwidth300', -2, !empty($project_field)?$project_field:'fk_projet');
|
||||
$selectList = $formproject->select_element($tablename, $idtofilterthirdparty, 'minwidth300', -2, !empty($project_field) ? $project_field : 'fk_projet');
|
||||
if ($selectList < 0)
|
||||
{
|
||||
setEventMessages($formproject->error, $formproject->errors, 'errors');
|
||||
@ -846,64 +841,60 @@ foreach ($listofreferent as $key => $value)
|
||||
if (empty($conf->global->PROJECT_CREATE_ON_OVERVIEW_DISABLED) && $urlnew)
|
||||
{
|
||||
$addform .= '<div class="inline-block valignmiddle">';
|
||||
if ($testnew) $addform .= '<a class="buttonxxx" href="'.$urlnew.'"><span class="valignmiddle text-plus-circle">'.($buttonnew?$langs->trans($buttonnew):$langs->trans("Create")).'</span><span class="fa fa-plus-circle valignmiddle paddingleft"></span></a>';
|
||||
if ($testnew) $addform .= '<a class="buttonxxx" href="'.$urlnew.'"><span class="valignmiddle text-plus-circle">'.($buttonnew ? $langs->trans($buttonnew) : $langs->trans("Create")).'</span><span class="fa fa-plus-circle valignmiddle paddingleft"></span></a>';
|
||||
elseif (empty($conf->global->MAIN_BUTTON_HIDE_UNAUTHORIZED)) {
|
||||
$addform .= '<a class="buttonxxx buttonRefused" disabled="disabled" href="#"><span class="valignmiddle text-plus-circle">'.($buttonnew?$langs->trans($buttonnew):$langs->trans("Create")).'</span><span class="fa fa-plus-circle valignmiddle"></span></a>';
|
||||
$addform .= '<a class="buttonxxx buttonRefused" disabled="disabled" href="#"><span class="valignmiddle text-plus-circle">'.($buttonnew ? $langs->trans($buttonnew) : $langs->trans("Create")).'</span><span class="fa fa-plus-circle valignmiddle paddingleft"></span></a>';
|
||||
}
|
||||
$addform .= '<div>';
|
||||
}
|
||||
|
||||
print load_fiche_titre($langs->trans($title), $addform, '');
|
||||
|
||||
// Text for line : Date
|
||||
if (in_array($tablename, array('projet_task'))) $label_date = $langs->trans("TimeSpent");
|
||||
if (!in_array($tablename, array('projet_task'))) $label_date = $langs->trans("Date");
|
||||
|
||||
// Text for line : Thirdparty or user
|
||||
if (in_array($tablename, array('projet_task')) && $key == 'project_task') $label_user = ''; // if $key == 'project_task', we don't want details per user
|
||||
elseif (in_array($tablename, array('payment_various'))) $label_user = ''; // if $key == 'payment_various', we don't have any thirdparty
|
||||
elseif (in_array($tablename, array('expensereport_det', 'don', 'projet_task', 'stock_mouvement', 'payment_salary'))) $label_user = $langs->trans("User");
|
||||
else $label_user = $langs->trans("ThirdParty");
|
||||
|
||||
// Text for line : Amount HT
|
||||
//if (empty($value['disableamount']) && ! in_array($tablename, array('projet_task'))) print '<td class="right" width="120">'.$langs->trans("AmountHT").'</td>';
|
||||
//elseif (empty($value['disableamount']) && in_array($tablename, array('projet_task'))) print '<td class="right" width="120">'.$langs->trans("Amount").'</td>';
|
||||
if ($key == 'loan') $label_amount_ht = $langs->trans("LoanCapital").'</td>';
|
||||
elseif (empty($value['disableamount'])) $label_amount_ht = $langs->trans("AmountHT");
|
||||
else $label_amount_ht = '';
|
||||
|
||||
// Text for line : Amount TTC
|
||||
//if (empty($value['disableamount']) && ! in_array($tablename, array('projet_task'))) print '<td class="right" width="120">'.$langs->trans("AmountTTC").'</td>';
|
||||
if ($key == 'loan') $label_amount_ttc = $langs->trans("RemainderToPay");
|
||||
elseif (empty($value['disableamount'])) $label_amount_ttc = $langs->trans("AmountTTC");
|
||||
else $label_amount_ttc = '';
|
||||
|
||||
// Text for line : Status
|
||||
if (in_array($tablename, array('projet_task'))) $label_status = $langs->trans("ProgressDeclared");
|
||||
else $label_status = $langs->trans("Status");
|
||||
|
||||
print "\n".'<!-- Table for tablename = '.$tablename.' -->'."\n";
|
||||
print '<table class="noborder centpercent">';
|
||||
|
||||
$moreattrib = ($tablename != 'actioncomm' && $tablename != 'projet_task') ? ' style="width: 200px"' : '';
|
||||
|
||||
print '<tr class="liste_titre">';
|
||||
|
||||
// Remove link column
|
||||
print '<td style="width: 24px"></td>';
|
||||
|
||||
print_liste_field_titre("Ref", $_SERVER["PHP_SELF"], "ref", "", $param, 'style="width: 200px"', $sortfield, $sortorder);
|
||||
print_liste_field_titre($label_date, $_SERVER["PHP_SELF"], "date", "", $param, $moreattrib, $sortfield, $sortorder, "center ");
|
||||
print_liste_field_titre($label_user, $_SERVER["PHP_SELF"], "user", "", $param, "", $sortfield, $sortorder);
|
||||
print_liste_field_titre($label_amount_ht, $_SERVER["PHP_SELF"], "amount_ht", "", $param, 'style="width: 120px"', $sortfield, $sortorder, "right ");
|
||||
print_liste_field_titre($label_amount_ttc, $_SERVER["PHP_SELF"], "amount_ttc", "", $param, 'style="width: 120px"', $sortfield, $sortorder, "right ");
|
||||
print_liste_field_titre($label_status, $_SERVER["PHP_SELF"], "status", "", $param, 'style="width: 200px"', $sortfield, $sortorder, "right ");
|
||||
|
||||
// Ref
|
||||
print '<td'.(($tablename != 'actioncomm' && $tablename != 'projet_task') ? ' style="width: 200px"' : '').'>'.$langs->trans("Ref").'</td>';
|
||||
// Date
|
||||
print '<td'.(($tablename != 'actioncomm' && $tablename != 'projet_task') ? ' style="width: 200px"' : '').' class="center">';
|
||||
if (in_array($tablename, array('projet_task'))) print $langs->trans("TimeSpent");
|
||||
if (!in_array($tablename, array('projet_task'))) print $langs->trans("Date");
|
||||
print '</td>';
|
||||
// Thirdparty or user
|
||||
print '<td>';
|
||||
if (in_array($tablename, array('projet_task')) && $key == 'project_task') print ''; // if $key == 'project_task', we don't want details per user
|
||||
elseif (in_array($tablename, array('payment_various'))) print ''; // if $key == 'payment_various', we don't have any thirdparty
|
||||
elseif (in_array($tablename, array('expensereport_det', 'don', 'projet_task', 'stock_mouvement', 'payment_salary'))) print $langs->trans("User");
|
||||
else print $langs->trans("ThirdParty");
|
||||
print '</td>';
|
||||
// Duration of intervention
|
||||
if ($tablename == 'fichinter')
|
||||
{
|
||||
print '<td>';
|
||||
print $langs->trans("TotalDuration");
|
||||
$total_duration = 0;
|
||||
print '</td>';
|
||||
}
|
||||
// Amount HT
|
||||
//if (empty($value['disableamount']) && ! in_array($tablename, array('projet_task'))) print '<td class="right" width="120">'.$langs->trans("AmountHT").'</td>';
|
||||
//elseif (empty($value['disableamount']) && in_array($tablename, array('projet_task'))) print '<td class="right" width="120">'.$langs->trans("Amount").'</td>';
|
||||
if ($key == 'loan') print '<td class="right" width="120">'.$langs->trans("LoanCapital").'</td>';
|
||||
elseif (empty($value['disableamount'])) print '<td class="right" width="120">'.$langs->trans("AmountHT").'</td>';
|
||||
else print '<td width="120"></td>';
|
||||
// Amount TTC
|
||||
//if (empty($value['disableamount']) && ! in_array($tablename, array('projet_task'))) print '<td class="right" width="120">'.$langs->trans("AmountTTC").'</td>';
|
||||
if ($key == 'loan') print '<td class="right" width="120">'.$langs->trans("RemainderToPay").'</td>';
|
||||
elseif (empty($value['disableamount'])) print '<td class="right" width="120">'.$langs->trans("AmountTTC").'</td>';
|
||||
else print '<td width="120"></td>';
|
||||
// Status
|
||||
if (in_array($tablename, array('projet_task'))) print '<td class="right" width="200">'.$langs->trans("ProgressDeclared").'</td>';
|
||||
else print '<td class="right" width="200">'.$langs->trans("Status").'</td>';
|
||||
print '</tr>';
|
||||
|
||||
$elementarray = $object->get_element_list($key, $tablename, $datefieldname, $dates, $datee, !empty($project_field) ? $project_field : 'fk_projet');
|
||||
$list = array();
|
||||
|
||||
if (is_array($elementarray) && count($elementarray) > 0)
|
||||
{
|
||||
$total_ht = 0;
|
||||
@ -924,8 +915,6 @@ foreach ($listofreferent as $key => $value)
|
||||
$num = count($elementarray);
|
||||
for ($i = 0; $i < $num; $i++)
|
||||
{
|
||||
$tablerow = new TableRow();
|
||||
|
||||
$tmp = explode('_', $elementarray[$i]);
|
||||
$idofelement = $tmp[0];
|
||||
$idofelementuser = $tmp[1];
|
||||
@ -933,7 +922,6 @@ foreach ($listofreferent as $key => $value)
|
||||
$element->fetch($idofelement);
|
||||
if ($idofelementuser) $elementuser->fetch($idofelementuser);
|
||||
|
||||
|
||||
// Special cases
|
||||
if ($tablename != 'expensereport_det')
|
||||
{
|
||||
@ -965,34 +953,40 @@ foreach ($listofreferent as $key => $value)
|
||||
if (!empty($element->close_code) && $element->close_code == 'replaced') $qualifiedfortotal = false; // Replacement invoice, do not include into total
|
||||
}
|
||||
|
||||
// Unlink - save id of the element, need for the "unlink" action
|
||||
$tablerow->id = $element->id;
|
||||
print '<tr class="oddeven">';
|
||||
|
||||
// Remove link
|
||||
print '<td style="width: 24px">';
|
||||
if ($tablename != 'projet_task' && $tablename != 'stock_mouvement')
|
||||
{
|
||||
if (empty($conf->global->PROJECT_DISABLE_UNLINK_FROM_OVERVIEW) || $user->admin) // PROJECT_DISABLE_UNLINK_FROM_OVERVIEW is empty by defaut, so this test true
|
||||
{
|
||||
print '<a href="'.$_SERVER["PHP_SELF"].'?id='.$object->id.'&action=unlink&tablename='.$tablename.'&elementselect='.$element->id.($project_field ? '&projectfield='.$project_field : '').'" class="reposition">';
|
||||
print img_picto($langs->trans('Unlink'), 'unlink');
|
||||
print '</a>';
|
||||
}
|
||||
}
|
||||
print "</td>\n";
|
||||
|
||||
// Ref
|
||||
print '<td class="left nowrap">';
|
||||
if ($tablename == 'expensereport_det')
|
||||
{
|
||||
$tablerow->ref = $expensereport->ref;
|
||||
$tablerow->ref_text = $expensereport->getNomUrl(1);
|
||||
print $expensereport->getNomUrl(1);
|
||||
}
|
||||
else
|
||||
{
|
||||
$tablerow->ref = $element->ref;
|
||||
|
||||
// Show ref with link
|
||||
if ($element instanceof Task)
|
||||
{
|
||||
$tablerow->ref_text = $element->getNomUrl(1, 'withproject', 'time');
|
||||
$tablerow->ref_text .= ' - '.dol_trunc($element->label, 48);
|
||||
}
|
||||
elseif ($key == 'loan')
|
||||
{
|
||||
$tablerow->ref_text = $element->getNomUrl(1);
|
||||
$tablerow->ref_text .= ' - '.dol_trunc($element->label, 48);
|
||||
}
|
||||
else
|
||||
{
|
||||
$tablerow->ref_text = $element->getNomUrl(1);
|
||||
print $element->getNomUrl(1, 'withproject', 'time');
|
||||
print ' - '.dol_trunc($element->label, 48);
|
||||
}
|
||||
elseif ($key == 'loan') {
|
||||
print $element->getNomUrl(1);
|
||||
print ' - '.dol_trunc($element->label, 48);
|
||||
}
|
||||
else print $element->getNomUrl(1);
|
||||
|
||||
$element_doc = $element->element;
|
||||
$filename = dol_sanitizeFileName($element->ref);
|
||||
@ -1008,19 +1002,14 @@ foreach ($listofreferent as $key => $value)
|
||||
$filedir = $conf->fournisseur->facture->multidir_output[$element->entity].'/'.get_exdir($element->id, 2, 0, 0, $element, 'invoice_supplier').dol_sanitizeFileName($element->ref);
|
||||
}
|
||||
|
||||
$tablerow->ref_text .= '<div class="inline-block valignmiddle">'.$formfile->getDocumentsLink($element_doc, $filename, $filedir).'</div>';
|
||||
print '<div class="inline-block valignmiddle">'.$formfile->getDocumentsLink($element_doc, $filename, $filedir).'</div>';
|
||||
|
||||
// Show supplier ref
|
||||
if (!empty($element->ref_supplier))
|
||||
{
|
||||
$tablerow->ref_text .= ' - '.$element->ref_supplier;
|
||||
}
|
||||
if (!empty($element->ref_supplier)) print ' - '.$element->ref_supplier;
|
||||
// Show customer ref
|
||||
if (!empty($element->ref_customer))
|
||||
{
|
||||
$tablerow->ref_text .= ' - '.$element->ref_customer;
|
||||
}
|
||||
if (!empty($element->ref_customer)) print ' - '.$element->ref_customer;
|
||||
}
|
||||
print "</td>\n";
|
||||
|
||||
// Date or TimeSpent
|
||||
$date = ''; $total_time_by_line = null;
|
||||
@ -1031,114 +1020,111 @@ foreach ($listofreferent as $key => $value)
|
||||
elseif ($tablename == 'chargesociales') $date = $element->date_ech;
|
||||
elseif (!empty($element->status) || !empty($element->statut) || !empty($element->fk_status))
|
||||
{
|
||||
if ($tablename == 'don') $date = $element->datedon;
|
||||
if ($tablename == 'commande_fournisseur' || $tablename == 'supplier_order')
|
||||
{
|
||||
$date = ($element->date_commande ? $element->date_commande : $element->date_valid);
|
||||
}
|
||||
elseif ($tablename == 'supplier_proposal') $date = $element->date_validation; // There is no other date for this
|
||||
elseif ($tablename == 'fichinter') $date = $element->datev; // There is no other date for this
|
||||
elseif ($tablename == 'projet_task') $date = ''; // We show no date. Showing date of beginning of task make user think it is date of time consumed
|
||||
if ($tablename == 'don') $date = $element->datedon;
|
||||
if ($tablename == 'commande_fournisseur' || $tablename == 'supplier_order')
|
||||
{
|
||||
$date = ($element->date_commande ? $element->date_commande : $element->date_valid);
|
||||
}
|
||||
elseif ($tablename == 'supplier_proposal') $date = $element->date_validation; // There is no other date for this
|
||||
elseif ($tablename == 'fichinter') $date = $element->datev; // There is no other date for this
|
||||
elseif ($tablename == 'projet_task') $date = ''; // We show no date. Showing date of beginning of task make user think it is date of time consumed
|
||||
else
|
||||
{
|
||||
$date = $element->date; // invoice, ...
|
||||
if (empty($date)) $date = $element->date_contrat;
|
||||
if (empty($date)) $date = $element->datev;
|
||||
if (empty($date) && !empty($datefieldname)) {
|
||||
$date = $element->date; // invoice, ...
|
||||
if (empty($date)) $date = $element->date_contrat;
|
||||
if (empty($date)) $date = $element->datev;
|
||||
if (empty($date) && !empty($datefieldname)) {
|
||||
$date = $element->$datefieldname;
|
||||
}
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan')
|
||||
{
|
||||
$date = $element->datestart;
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan') {
|
||||
$date = $element->datestart;
|
||||
}
|
||||
|
||||
$tablerow->date = $date;
|
||||
|
||||
print '<td class="center">';
|
||||
if ($tablename == 'actioncomm')
|
||||
{
|
||||
$tablerow->date_text = dol_print_date($element->datep, 'dayhour');
|
||||
|
||||
if ($element->datef && $element->datef > $element->datep)
|
||||
{
|
||||
$tablerow->date_text .= " - ".dol_print_date($element->datef, 'dayhour');
|
||||
}
|
||||
print dol_print_date($element->datep, 'dayhour');
|
||||
if ($element->datef && $element->datef > $element->datep) print " - ".dol_print_date($element->datef, 'dayhour');
|
||||
}
|
||||
elseif (in_array($tablename, array('projet_task')))
|
||||
{
|
||||
$tmpprojtime = $element->getSumOfAmount($elementuser, $dates, $datee); // $element is a task. $elementuser may be empty
|
||||
$tablerow->date_text = '<a href="'.DOL_URL_ROOT.'/projet/tasks/time.php?id='.$idofelement.'&withproject=1">';
|
||||
$tablerow->date_text .= convertSecondToTime($tmpprojtime['nbseconds'], 'allhourmin');
|
||||
$tablerow->date_text .= '</a>';
|
||||
$total_time_by_line = $tmpprojtime['nbseconds'];
|
||||
}
|
||||
else
|
||||
{
|
||||
$tablerow->date_text = dol_print_date($date, 'day');
|
||||
$tmpprojtime = $element->getSumOfAmount($elementuser, $dates, $datee); // $element is a task. $elementuser may be empty
|
||||
print '<a href="'.DOL_URL_ROOT.'/projet/tasks/time.php?id='.$idofelement.'&withproject=1">';
|
||||
print convertSecondToTime($tmpprojtime['nbseconds'], 'allhourmin');
|
||||
print '</a>';
|
||||
$total_time_by_line = $tmpprojtime['nbseconds'];
|
||||
}
|
||||
else print dol_print_date($date, 'day');
|
||||
print '</td>';
|
||||
|
||||
// Third party or user
|
||||
if (is_object($element->thirdparty))
|
||||
{
|
||||
$tablerow->user = $element->thirdparty;
|
||||
}
|
||||
elseif ($tablename == 'expensereport_det')
|
||||
{
|
||||
$tmpuser = new User($db);
|
||||
$tmpuser->fetch($expensereport->fk_user_author);
|
||||
$tablerow->user = $tmpuser;
|
||||
}
|
||||
print '<td class="left">';
|
||||
if (is_object($element->thirdparty)) {
|
||||
print $element->thirdparty->getNomUrl(1, '', 48);
|
||||
} elseif ($tablename == 'expensereport_det') {
|
||||
$tmpuser = new User($db);
|
||||
$tmpuser->fetch($expensereport->fk_user_author);
|
||||
print $tmpuser->getNomUrl(1, '', 48);
|
||||
}
|
||||
elseif ($tablename == 'payment_salary')
|
||||
{
|
||||
$tmpuser = new User($db);
|
||||
$tmpuser->fetch($element->fk_user);
|
||||
$tablerow->user = $tmpuser;
|
||||
print $tmpuser->getNomUrl(1, '', 48);
|
||||
}
|
||||
elseif ($tablename == 'don' || $tablename == 'stock_mouvement')
|
||||
{
|
||||
if ($element->fk_user_author > 0)
|
||||
{
|
||||
$tmpuser2 = new User($db);
|
||||
$tmpuser2->fetch($element->fk_user_author);
|
||||
print $tmpuser2->getNomUrl(1, '', 48);
|
||||
}
|
||||
}
|
||||
elseif ($tablename == 'projet_task' && $key == 'project_task_time') // if $key == 'project_task', we don't want details per user
|
||||
{
|
||||
print $elementuser->getNomUrl(1);
|
||||
}
|
||||
print '</td>';
|
||||
|
||||
// Add duration and store it in counter for fichinter
|
||||
if ($tablename == 'fichinter')
|
||||
{
|
||||
if ($element->fk_user_author > 0)
|
||||
{
|
||||
$tmpuser2 = new User($db);
|
||||
$tmpuser2->fetch($element->fk_user_author);
|
||||
$tablerow->user = $tmpuser2;
|
||||
}
|
||||
}
|
||||
elseif ($tablename == 'projet_task' && $key == 'project_task_time') // if $key == 'project_task', we don't want details per user
|
||||
{
|
||||
$tablerow->user = $elementuser;
|
||||
print '<td>';
|
||||
print convertSecondToTime($element->duration, 'all', $conf->global->MAIN_DURATION_OF_WORKDAY);
|
||||
$total_duration += $element->duration;
|
||||
print '</td>';
|
||||
}
|
||||
|
||||
// Amount without tax
|
||||
// Amount without tax
|
||||
$warning = '';
|
||||
if (empty($value['disableamount']))
|
||||
{
|
||||
$total_ht_by_line = null;
|
||||
$othermessage = '';
|
||||
$total_ht_by_line = null;
|
||||
$othermessage = '';
|
||||
if ($tablename == 'don' || $tablename == 'chargesociales' || $tablename == 'payment_various' || $tablename == 'payment_salary') $total_ht_by_line = $element->amount;
|
||||
elseif ($tablename == 'fichinter') $total_ht_by_line = $element->getAmount();
|
||||
elseif ($tablename == 'stock_mouvement') $total_ht_by_line = $element->price * abs($element->qty);
|
||||
elseif (in_array($tablename, array('projet_task')))
|
||||
{
|
||||
if (!empty($conf->salaries->enabled))
|
||||
{
|
||||
// TODO Permission to read daily rate to show value
|
||||
$total_ht_by_line = price2num($tmpprojtime['amount'], 'MT');
|
||||
if ($tmpprojtime['nblinesnull'] > 0)
|
||||
{
|
||||
$langs->load("errors");
|
||||
$warning = $langs->trans("WarningSomeLinesWithNullHourlyRate", $conf->currency);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$othermessage = $form->textwithpicto($langs->trans("NotAvailable"), $langs->trans("ModuleSalaryToDefineHourlyRateMustBeEnabled"));
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan')
|
||||
{
|
||||
$total_ht_by_line = $element->capital;
|
||||
if (!empty($conf->salaries->enabled))
|
||||
{
|
||||
// TODO Permission to read daily rate to show value
|
||||
$total_ht_by_line = price2num($tmpprojtime['amount'], 'MT');
|
||||
if ($tmpprojtime['nblinesnull'] > 0)
|
||||
{
|
||||
$langs->load("errors");
|
||||
$warning = $langs->trans("WarningSomeLinesWithNullHourlyRate", $conf->currency);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$othermessage = $form->textwithpicto($langs->trans("NotAvailable"), $langs->trans("ModuleSalaryToDefineHourlyRateMustBeEnabled"));
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan') $total_ht_by_line = $element->capital;
|
||||
else
|
||||
{
|
||||
$total_ht_by_line = $element->total_ht;
|
||||
@ -1147,64 +1133,46 @@ foreach ($listofreferent as $key => $value)
|
||||
// Change sign of $total_ht_by_line and $total_ttc_by_line for some cases
|
||||
if ($tablename == 'payment_various')
|
||||
{
|
||||
if ($element->sens == 0)
|
||||
{
|
||||
$total_ht_by_line = -$total_ht_by_line;
|
||||
}
|
||||
}
|
||||
|
||||
$tablerow->amount_ht = $total_ht_by_line;
|
||||
|
||||
if ($othermessage)
|
||||
{
|
||||
$tablerow->amount_ht_text .= $othermessage;
|
||||
if ($element->sens == 0)
|
||||
{
|
||||
$total_ht_by_line = -$total_ht_by_line;
|
||||
}
|
||||
}
|
||||
|
||||
print '<td class="right">';
|
||||
if ($othermessage) print $othermessage;
|
||||
if (isset($total_ht_by_line))
|
||||
{
|
||||
if (! $qualifiedfortotal)
|
||||
{
|
||||
$tablerow->amount_ht_text .= '<strike>';
|
||||
}
|
||||
|
||||
$tablerow->amount_ht_text .= price($total_ht_by_line);
|
||||
|
||||
if (! $qualifiedfortotal)
|
||||
{
|
||||
$tablerow->amount_ht_text .= '</strike>';
|
||||
}
|
||||
}
|
||||
|
||||
if ($warning)
|
||||
{
|
||||
$tablerow->amount_ht_text .= ' '.img_warning($warning);
|
||||
if (!$qualifiedfortotal) print '<strike>';
|
||||
print price($total_ht_by_line);
|
||||
if (!$qualifiedfortotal) print '</strike>';
|
||||
}
|
||||
if ($warning) print ' '.img_warning($warning);
|
||||
print '</td>';
|
||||
}
|
||||
else print '<td></td>';
|
||||
|
||||
// Amount inc tax
|
||||
// Amount inc tax
|
||||
if (empty($value['disableamount']))
|
||||
{
|
||||
$total_ttc_by_line = null;
|
||||
$total_ttc_by_line = null;
|
||||
if ($tablename == 'don' || $tablename == 'chargesociales' || $tablename == 'payment_various' || $tablename == 'payment_salary') $total_ttc_by_line = $element->amount;
|
||||
elseif ($tablename == 'fichinter') $total_ttc_by_line = $element->getAmount();
|
||||
elseif ($tablename == 'stock_mouvement') $total_ttc_by_line = $element->price * abs($element->qty);
|
||||
elseif ($tablename == 'projet_task')
|
||||
{
|
||||
if (!empty($conf->salaries->enabled))
|
||||
{
|
||||
// TODO Permission to read daily rate
|
||||
$defaultvat = get_default_tva($mysoc, $mysoc);
|
||||
$total_ttc_by_line = price2num($total_ht_by_line * (1 + ($defaultvat / 100)), 'MT');
|
||||
}
|
||||
else
|
||||
{
|
||||
$othermessage = $form->textwithpicto($langs->trans("NotAvailable"), $langs->trans("ModuleSalaryToDefineHourlyRateMustBeEnabled"));
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan')
|
||||
{
|
||||
$total_ttc_by_line = $element->capital - $element->getSumPayment();
|
||||
if (!empty($conf->salaries->enabled))
|
||||
{
|
||||
// TODO Permission to read daily rate
|
||||
$defaultvat = get_default_tva($mysoc, $mysoc);
|
||||
$total_ttc_by_line = price2num($total_ht_by_line * (1 + ($defaultvat / 100)), 'MT');
|
||||
}
|
||||
else
|
||||
{
|
||||
$othermessage = $form->textwithpicto($langs->trans("NotAvailable"), $langs->trans("ModuleSalaryToDefineHourlyRateMustBeEnabled"));
|
||||
}
|
||||
}
|
||||
elseif ($key == 'loan') $total_ttc_by_line = $element->capital - $element->getSumPayment();
|
||||
else
|
||||
{
|
||||
$total_ttc_by_line = $element->total_ttc;
|
||||
@ -1213,65 +1181,54 @@ foreach ($listofreferent as $key => $value)
|
||||
// Change sign of $total_ht_by_line and $total_ttc_by_line for some cases
|
||||
if ($tablename == 'payment_various')
|
||||
{
|
||||
if ($element->sens == 0)
|
||||
{
|
||||
$total_ttc_by_line = -$total_ttc_by_line;
|
||||
}
|
||||
}
|
||||
|
||||
$tablerow->amount_ttc = $total_ttc_by_line;
|
||||
|
||||
if ($othermessage)
|
||||
{
|
||||
$tablerow->amount_ttc_text .= $othermessage;
|
||||
if ($element->sens == 0)
|
||||
{
|
||||
$total_ttc_by_line = -$total_ttc_by_line;
|
||||
}
|
||||
}
|
||||
|
||||
print '<td class="right">';
|
||||
if ($othermessage) print $othermessage;
|
||||
if (isset($total_ttc_by_line))
|
||||
{
|
||||
if (! $qualifiedfortotal)
|
||||
{
|
||||
$tablerow->amount_ttc_text .= '<strike>';
|
||||
}
|
||||
|
||||
$tablerow->amount_ttc_text .= price($total_ttc_by_line);
|
||||
|
||||
if (! $qualifiedfortotal)
|
||||
{
|
||||
$tablerow->amount_ttc_text .= '</strike>';
|
||||
}
|
||||
}
|
||||
|
||||
if ($warning)
|
||||
{
|
||||
$tablerow->amount_ttc_text .= ' '.img_warning($warning);
|
||||
if (!$qualifiedfortotal) print '<strike>';
|
||||
print price($total_ttc_by_line);
|
||||
if (!$qualifiedfortotal) print '</strike>';
|
||||
}
|
||||
if ($warning) print ' '.img_warning($warning);
|
||||
print '</td>';
|
||||
}
|
||||
else print '<td></td>';
|
||||
|
||||
// Status
|
||||
print '<td class="right">';
|
||||
if ($tablename == 'expensereport_det')
|
||||
{
|
||||
$tablerow->status = $expensereport->getLibStatut(5);
|
||||
print $expensereport->getLibStatut(5);
|
||||
}
|
||||
elseif ($element instanceof CommonInvoice)
|
||||
{
|
||||
//This applies for Facture and FactureFournisseur
|
||||
$tablerow->status = $element->getLibStatut(5, $element->getSommePaiement());
|
||||
print $element->getLibStatut(5, $element->getSommePaiement());
|
||||
}
|
||||
elseif ($element instanceof Task)
|
||||
{
|
||||
if ($element->progress != '')
|
||||
{
|
||||
$tablerow->status = $element->progress.' %';
|
||||
print $element->progress.' %';
|
||||
}
|
||||
}
|
||||
elseif ($tablename == 'stock_mouvement')
|
||||
{
|
||||
$tablerow->status = $element->getLibStatut(3);
|
||||
print $element->getLibStatut(3);
|
||||
}
|
||||
else
|
||||
{
|
||||
$tablerow->status = $element->getLibStatut(5);
|
||||
print $element->getLibStatut(5);
|
||||
}
|
||||
print '</td>';
|
||||
|
||||
print '</tr>';
|
||||
|
||||
if ($qualifiedfortotal)
|
||||
{
|
||||
@ -1284,70 +1241,25 @@ foreach ($listofreferent as $key => $value)
|
||||
$total_time = $total_time + $total_time_by_line;
|
||||
}
|
||||
|
||||
$sortable_table[] = $tablerow;
|
||||
}
|
||||
|
||||
if($sortfield == "user")
|
||||
{
|
||||
if($sortorder == "asc")
|
||||
if (canApplySubtotalOn($tablename))
|
||||
{
|
||||
usort($sortable_table, "sort_by_user_asc");
|
||||
}
|
||||
else
|
||||
{
|
||||
usort($sortable_table, "sort_by_user_desc");
|
||||
$breakline = '<tr class="liste_total liste_sub_total">';
|
||||
$breakline .= '<td colspan="2">';
|
||||
$breakline .= '</td>';
|
||||
$breakline .= '<td>';
|
||||
$breakline .= '</td>';
|
||||
$breakline .= '<td class="right">';
|
||||
$breakline .= $langs->trans('SubTotal').' : ';
|
||||
if (is_object($element->thirdparty)) $breakline .= $element->thirdparty->getNomUrl(0, '', 48);
|
||||
$breakline .= '</td>';
|
||||
$breakline .= '<td class="right">'.price($total_ht_by_third).'</td>';
|
||||
$breakline .= '<td class="right">'.price($total_ttc_by_third).'</td>';
|
||||
$breakline .= '<td></td>';
|
||||
$breakline .= '</tr>';
|
||||
}
|
||||
|
||||
//var_dump($element->thirdparty->name.' - '.$saved_third_id.' - '.$element->thirdparty->id);
|
||||
}
|
||||
else
|
||||
{
|
||||
$sortable_table = dol_sort_array($sortable_table, $sortfield, $sortorder, 1, 0, 1);
|
||||
}
|
||||
|
||||
foreach ($sortable_table as $tablerow)
|
||||
{
|
||||
print '<tr class="oddeven">';
|
||||
|
||||
// Remove link
|
||||
print '<td style="width: 24px">';
|
||||
if ($tablename != 'projet_task' && $tablename != 'stock_mouvement')
|
||||
{
|
||||
if (empty($conf->global->PROJECT_DISABLE_UNLINK_FROM_OVERVIEW) || $user->admin) // PROJECT_DISABLE_UNLINK_FROM_OVERVIEW is empty by defaut, so this test true
|
||||
{
|
||||
print '<a href="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '&action=unlink&tablename=' . $tablename . '&elementselect=' . $tablerow->id . ($project_field ? '&projectfield=' . $project_field : '') . '" class="reposition">';
|
||||
print img_picto($langs->trans('Unlink'), 'unlink');
|
||||
print '</a>';
|
||||
}
|
||||
}
|
||||
print "</td>\n";
|
||||
|
||||
print '<td class="left nowrap" style="width: 200px">'.$tablerow->ref_text."</td>";
|
||||
print '<td class="center">'.$tablerow->date_text."</td>";
|
||||
print '<td class="left">'.$tablerow->user->getNomUrl(1, '', 48)."</td>";
|
||||
print '<td class="right" style="width: 120px">'.$tablerow->amount_ht_text."</td>";
|
||||
print '<td class="right" style="width: 120px">'.$tablerow->amount_ttc_text."</td>";
|
||||
print '<td class="right" style="width: 200px">'.$tablerow->status."</td>";
|
||||
|
||||
print '</tr>';
|
||||
}
|
||||
|
||||
if (canApplySubtotalOn($tablename))
|
||||
{
|
||||
$breakline = '<tr class="liste_total liste_sub_total">';
|
||||
$breakline .= '<td colspan="2">';
|
||||
$breakline .= '</td>';
|
||||
$breakline .= '<td>';
|
||||
$breakline .= '</td>';
|
||||
$breakline .= '<td class="right">';
|
||||
$breakline .= $langs->trans('SubTotal').' : ';
|
||||
if (is_object($element->thirdparty)) $breakline .= $element->thirdparty->getNomUrl(0, '', 48);
|
||||
$breakline .= '</td>';
|
||||
$breakline .= '<td class="right">'.price($total_ht_by_third).'</td>';
|
||||
$breakline .= '<td class="right">'.price($total_ttc_by_third).'</td>';
|
||||
$breakline .= '<td></td>';
|
||||
$breakline .= '</tr>';
|
||||
}
|
||||
|
||||
//var_dump($element->thirdparty->name.' - '.$saved_third_id.' - '.$element->thirdparty->id);
|
||||
|
||||
if ($breakline) print $breakline;
|
||||
|
||||
@ -1357,19 +1269,21 @@ foreach ($listofreferent as $key => $value)
|
||||
print '<tr class="liste_total"><td colspan="'.$colspan.'">'.$langs->trans("Number").': '.$i.'</td>';
|
||||
if (in_array($tablename, array('projet_task')))
|
||||
{
|
||||
print '<td class="center">';
|
||||
print convertSecondToTime($total_time, 'allhourmin');
|
||||
print '</td>';
|
||||
print '<td>';
|
||||
print '</td>';
|
||||
print '<td class="center">';
|
||||
print convertSecondToTime($total_time, 'allhourmin');
|
||||
print '</td>';
|
||||
print '<td>';
|
||||
print '</td>';
|
||||
}
|
||||
//if (empty($value['disableamount']) && ! in_array($tablename, array('projet_task'))) print '<td class="right" width="100">'.$langs->trans("TotalHT").' : '.price($total_ht).'</td>';
|
||||
//elseif (empty($value['disableamount']) && in_array($tablename, array('projet_task'))) print '<td class="right" width="100">'.$langs->trans("Total").' : '.price($total_ht).'</td>';
|
||||
// If fichinter add the total_duration
|
||||
if ($tablename == 'fichinter') print '<td class="left">'.convertSecondToTime($total_duration, 'all', $conf->global->MAIN_DURATION_OF_WORKDAY).'</td>';
|
||||
print '<td class="right">';
|
||||
if (empty($value['disableamount']))
|
||||
{
|
||||
if ($key == 'loan') print $langs->trans("Total").' '.$langs->trans("LoanCapital").' : '.price($total_ttc);
|
||||
elseif ($tablename != 'projet_task' || !empty($conf->salaries->enabled)) print ''.$langs->trans("TotalHT").' : '.price($total_ht);
|
||||
if ($key == 'loan') print $langs->trans("Total").' '.$langs->trans("LoanCapital").' : '.price($total_ttc);
|
||||
elseif ($tablename != 'projet_task' || !empty($conf->salaries->enabled)) print ''.$langs->trans("TotalHT").' : '.price($total_ht);
|
||||
}
|
||||
print '</td>';
|
||||
//if (empty($value['disableamount']) && ! in_array($tablename, array('projet_task'))) print '<td class="right" width="100">'.$langs->trans("TotalTTC").' : '.price($total_ttc).'</td>';
|
||||
@ -1377,8 +1291,8 @@ foreach ($listofreferent as $key => $value)
|
||||
print '<td class="right">';
|
||||
if (empty($value['disableamount']))
|
||||
{
|
||||
if ($key == 'loan') print $langs->trans("Total").' '.$langs->trans("RemainderToPay").' : '.price($total_ttc);
|
||||
elseif ($tablename != 'projet_task' || !empty($conf->salaries->enabled)) print $langs->trans("TotalTTC").' : '.price($total_ttc);
|
||||
if ($key == 'loan') print $langs->trans("Total").' '.$langs->trans("RemainderToPay").' : '.price($total_ttc);
|
||||
elseif ($tablename != 'projet_task' || !empty($conf->salaries->enabled)) print $langs->trans("TotalTTC").' : '.price($total_ttc);
|
||||
}
|
||||
print '</td>';
|
||||
print '<td> </td>';
|
||||
@ -1391,7 +1305,6 @@ foreach ($listofreferent as $key => $value)
|
||||
print $elementarray;
|
||||
}
|
||||
}
|
||||
|
||||
print "</table>";
|
||||
print "<br>\n";
|
||||
}
|
||||
@ -1462,96 +1375,3 @@ function sortElementsByClientName($elementarray)
|
||||
|
||||
return $elementarray;
|
||||
}
|
||||
|
||||
/**
|
||||
* Compare two TableRow objects by the $user variable in asc order
|
||||
*
|
||||
* @param TableRow $left The left object for the compare
|
||||
* @param TableRow $right The right object for the compare
|
||||
* @return int The compare result
|
||||
*/
|
||||
function sort_by_user_asc($left, $right)
|
||||
{
|
||||
if($left->user instanceof User && $right->user instanceof User)
|
||||
{
|
||||
return strtoupper($left->user->getFullName('', 0, -1)) > strtoupper($right->user->getFullName('', 0, -1));
|
||||
}
|
||||
elseif($left->user instanceof Societe && $right->user instanceof Societe)
|
||||
{
|
||||
return strtoupper($left->user->name) > strtoupper($right->user->name);
|
||||
}
|
||||
|
||||
throw new Exception('unknown class type for sorting in function [sort_by_user_asc] in class [\projet\element.php]');
|
||||
}
|
||||
|
||||
/**
|
||||
* Compare two TableRow objects by the $user variable in desc order
|
||||
*
|
||||
* @param TableRow $left The left object for the compare
|
||||
* @param TableRow $right The right object for the compare
|
||||
* @return int The compare result
|
||||
*/
|
||||
function sort_by_user_desc($left, $right)
|
||||
{
|
||||
if($left->user instanceof User && $right->user instanceof User)
|
||||
{
|
||||
return strtoupper($left->user->getFullName('', 0, -1)) < strtoupper($right->user->getFullName('', 0, -1));
|
||||
}
|
||||
elseif($left->user instanceof Societe && $right->user instanceof Societe)
|
||||
{
|
||||
return strtoupper($left->user->name) < strtoupper($right->user->name);
|
||||
}
|
||||
|
||||
throw new Exception('unknown class type for sorting in function [sort_by_user_des] in class [\projet\element.php]');
|
||||
}
|
||||
|
||||
/**
|
||||
* Presentation of a table row
|
||||
*/
|
||||
class TableRow
|
||||
{
|
||||
/**
|
||||
* The id of this project (need for "unlink" action)
|
||||
*/
|
||||
public $id;
|
||||
|
||||
/**
|
||||
* The reference of this object (only for sorting)
|
||||
*/
|
||||
public $ref;
|
||||
|
||||
/**
|
||||
* The visible text for the reference (string or html)
|
||||
*/
|
||||
public $ref_text;
|
||||
|
||||
/**
|
||||
* The related user or societe of the object
|
||||
*/
|
||||
public $user;
|
||||
|
||||
/**
|
||||
* The ht amount of this object (only for sorting)
|
||||
*/
|
||||
public $amount_ht;
|
||||
|
||||
/**
|
||||
* The visible text for the $amount_ht (string or html)
|
||||
*/
|
||||
public $amount_ht_text;
|
||||
|
||||
/**
|
||||
* The ttc amount of this object (only for sorting)
|
||||
*/
|
||||
public $amount_ttc;
|
||||
|
||||
/**
|
||||
* The visible text for the $amount_ttc (string or html)
|
||||
*/
|
||||
public $amount_ttc_text;
|
||||
|
||||
/**
|
||||
* The status of the object (string or html)
|
||||
*/
|
||||
public $status;
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user