diff --git a/htdocs/margin/agentMargins.php b/htdocs/margin/agentMargins.php
index aae859666e7..97f9b6c59a1 100644
--- a/htdocs/margin/agentMargins.php
+++ b/htdocs/margin/agentMargins.php
@@ -54,10 +54,17 @@ if (! $sortfield)
$startdate=$enddate='';
-if (!empty($_POST['startdatemonth']))
- $startdate = dol_mktime(0, 0, 0, $_POST['startdatemonth'], $_POST['startdateday'], $_POST['startdateyear']);
-if (!empty($_POST['enddatemonth']))
- $enddate = dol_mktime(23, 59, 59, $_POST['enddatemonth'], $_POST['enddateday'], $_POST['enddateyear']);
+$startdateday = GETPOST('startdateday','int');
+$startdatemonth = GETPOST('startdatemonth','int');
+$startdateyear = GETPOST('startdateyear','int');
+$enddateday = GETPOST('enddateday','int');
+$enddatemonth = GETPOST('enddatemonth','int');
+$enddateyear = GETPOST('enddateyear','int');
+
+if (!empty($startdatemonth))
+ $startdate = dol_mktime(0, 0, 0, $startdatemonth, $startdateday, $startdateyear);
+if (!empty($enddatemonth))
+ $enddate = dol_mktime(23, 59, 59, $enddatemonth, $enddateday, $enddateyear);
// Security check
if ($user->rights->margins->read->all) {
@@ -126,8 +133,7 @@ dol_fiche_end();
print '';
$sql = "SELECT";
-$sql.= " s.rowid as socid,";
-if ($agentid > 0) $sql.= " s.nom as name, s.code_client, s.client,";
+$sql.= " s.rowid as socid, s.nom as name, s.code_client, s.client,";
$sql.= " u.rowid as agent, u.login, u.lastname, u.firstname,";
$sql.= " sum(d.total_ht) as selling_price,";
// Note: qty and buy_price_ht is always positive (if not your database may be corrupted, you can update this)
@@ -162,9 +168,10 @@ if (!empty($enddate))
$sql.= " AND f.datef <= '".$db->idate($enddate)."'";
$sql .= " AND d.buy_price_ht IS NOT NULL";
if (isset($conf->global->ForceBuyingPriceIfNull) && $conf->global->ForceBuyingPriceIfNull == 1) $sql .= " AND d.buy_price_ht <> 0";
-if ($agentid > 0) $sql.= " GROUP BY s.rowid, s.nom, s.code_client, s.client, u.rowid, u.login, u.lastname, u.firstname";
-else $sql.= " GROUP BY u.rowid, u.login, u.lastname, u.firstname";
-$sql.=$db->order($sortfield, $sortorder);
+//if ($agentid > 0) $sql.= " GROUP BY s.rowid, s.nom, s.code_client, s.client, u.rowid, u.login, u.lastname, u.firstname";
+//else $sql.= " GROUP BY u.rowid, u.login, u.lastname, u.firstname";
+$sql.= " GROUP BY s.rowid, s.nom, s.code_client, s.client, u.rowid, u.login, u.lastname, u.firstname";
+$sql.=$db->order($sortfield,$sortorder);
// TODO: calculate total to display then restore pagination
//$sql.= $db->plimit($conf->liste_limit +1, $offset);
@@ -172,6 +179,15 @@ $sql.=$db->order($sortfield, $sortorder);
print '
';
print img_info('').' '.$langs->trans("MarginPerSaleRepresentativeWarning").'
';
+$param='';
+if (!empty($agentid)) $param .= "&agentid=".urlencode($agentid);
+if (!empty($startdateday)) $param .= "&startdateday=".urlencode($startdateday);
+if (!empty($startdatemonth)) $param .= "&startdatemonth=".urlencode($startdatemonth);
+if (!empty($startdateyear)) $param .= "&startdateyear=".urlencode($startdateyear);
+if (!empty($enddateday)) $param .= "&enddateday=".urlencode($enddateday);
+if (!empty($enddatemonth)) $param .= "&enddatemonth=".urlencode($enddatemonth);
+if (!empty($enddateyear)) $param .= "&enddateyear=".urlencode($enddateyear);
+
dol_syslog('margin::agentMargins.php', LOG_DEBUG);
$result = $db->query($sql);
@@ -191,80 +207,101 @@ if ($result)
print "
";
print '';
- if ($agentid > 0)
- print_liste_field_titre("Customer", $_SERVER["PHP_SELF"], "s.nom", "", "&agentid=".$agentid, '', $sortfield, $sortorder);
- else
- print_liste_field_titre("SalesRepresentative", $_SERVER["PHP_SELF"], "u.lastname", "", "&agentid=".$agentid, '', $sortfield, $sortorder);
+ if ($agentid > 0)
+ print_liste_field_titre("Customer",$_SERVER["PHP_SELF"],"s.nom","",$param,'',$sortfield,$sortorder);
+ else
+ print_liste_field_titre("SalesRepresentative",$_SERVER["PHP_SELF"],"u.lastname","",$param,'',$sortfield,$sortorder);
- print_liste_field_titre("SellingPrice", $_SERVER["PHP_SELF"], "selling_price", "", "&agentid=".$agentid, 'align="right"', $sortfield, $sortorder);
- print_liste_field_titre($labelcostprice, $_SERVER["PHP_SELF"], "buying_price", "", "&agentid=".$agentid, 'align="right"', $sortfield, $sortorder);
- print_liste_field_titre("Margin", $_SERVER["PHP_SELF"], "marge", "", "&agentid=".$agentid, 'align="right"', $sortfield, $sortorder);
- if (! empty($conf->global->DISPLAY_MARGIN_RATES))
- print_liste_field_titre("MarginRate", $_SERVER["PHP_SELF"], "", "", "&agentid=".$agentid, 'align="right"', $sortfield, $sortorder);
- if (! empty($conf->global->DISPLAY_MARK_RATES))
- print_liste_field_titre("MarkRate", $_SERVER["PHP_SELF"], "", "", "&agentid=".$agentid, 'align="right"', $sortfield, $sortorder);
+ print_liste_field_titre("SellingPrice",$_SERVER["PHP_SELF"],"selling_price","",$param,'align="right"',$sortfield,$sortorder);
+ print_liste_field_titre($labelcostprice,$_SERVER["PHP_SELF"],"buying_price","",$param,'align="right"',$sortfield,$sortorder);
+ print_liste_field_titre("Margin",$_SERVER["PHP_SELF"],"marge","",$param,'align="right"',$sortfield,$sortorder);
+ if (! empty($conf->global->DISPLAY_MARGIN_RATES))
+ print_liste_field_titre("MarginRate",$_SERVER["PHP_SELF"],"","",$param,'align="right"',$sortfield,$sortorder);
+ if (! empty($conf->global->DISPLAY_MARK_RATES))
+ print_liste_field_titre("MarkRate",$_SERVER["PHP_SELF"],"","",$param,'align="right"',$sortfield,$sortorder);
print "
\n";
$rounding = min($conf->global->MAIN_MAX_DECIMALS_UNIT, $conf->global->MAIN_MAX_DECIMALS_TOT);
- if ($num > 0)
- {
+ if ($num > 0)
+ {
+ $var=true;
- while ($i < $num /*&& $i < $conf->liste_limit*/)
- {
- $objp = $db->fetch_object($result);
+ $group_list = array();
+ while ($objp = $db->fetch_object($result)) {
+ if ($agentid > 0) {
+ $group_id = $objp->socid;
+ } else {
+ $group_id = $objp->agent;
+ }
- $seller_nb = 1;
- if ($objp->socid > 0) {
- // sql nb sellers
- $sql_seller = "SELECT COUNT(sc.rowid) as nb";
- $sql_seller .= " FROM " . MAIN_DB_PREFIX . "societe_commerciaux as sc";
- $sql_seller .= " WHERE sc.fk_soc = " . $objp->socid;
+ if (!isset($group_list[$group_id])) {
+ if ($agentid > 0) {
+ $group_name = $objp->name;
+ $companystatic->id = $objp->socid;
+ $companystatic->name = $objp->name;
+ $companystatic->client = $objp->client;
+ $group_htmlname = $companystatic->getNomUrl(1,'customer');
+ } else {
+ $group_name = $objp->lastname;
+ $userstatic->fetch($objp->agent);
+ $group_htmlname = $userstatic->getFullName($langs,0,0,0);
+ }
+ $group_list[$group_id] = array('name' => $group_name, 'htmlname' => $group_htmlname, 'selling_price' => 0, 'buying_price' => 0, 'marge' => 0);
+ }
- $resql_seller = $db->query($sql_seller);
- if (!$resql_seller) {
- dol_print_error($db);
- } else {
- if ($obj_seller = $db->fetch_object($resql_seller)) {
- if ($obj_seller->nb > 0) {
- $seller_nb = $obj_seller->nb;
- }
- }
+ $seller_nb = 1;
+ if ($objp->socid > 0) {
+ // sql nb sellers
+ $sql_seller = "SELECT COUNT(sc.rowid) as nb";
+ $sql_seller .= " FROM " . MAIN_DB_PREFIX . "societe_commerciaux as sc";
+ $sql_seller .= " WHERE sc.fk_soc = " . $objp->socid;
+ $sql_seller .= " LIMIT 1";
+
+ $resql_seller = $db->query($sql_seller);
+ if (!$resql_seller) {
+ dol_print_error($db);
+ } else {
+ if ($obj_seller = $db->fetch_object($resql_seller)) {
+ if ($obj_seller->nb > 0) {
+ $seller_nb = $obj_seller->nb;
}
}
+ }
+ }
- $pa = $objp->buying_price / $seller_nb;
- $pv = $objp->selling_price / $seller_nb;
- $marge = $objp->marge / $seller_nb;
+ $group_list[$group_id]['selling_price'] += $objp->selling_price / $seller_nb;
+ $group_list[$group_id]['buying_price'] += $objp->buying_price / $seller_nb;
+ $group_list[$group_id]['marge'] += $objp->marge / $seller_nb;
+ }
- $marginRate = ($pa != 0)?(100 * $marge / $pa):'' ;
- $markRate = ($pv != 0)?(100 * $marge / $pv):'' ;
+ // sort group array by sortfield
+ if ($sortfield == 'u.lastname' || $sortfield == 's.nom') {
+ $sortfield = 'name';
+ }
+ $group_list = dol_sort_array($group_list, $sortfield, $sortorder);
- print '';
- if ($agentid > 0) {
- $companystatic->id=$objp->socid;
- $companystatic->name=$objp->name;
- $companystatic->client=$objp->client;
- print "| ".$companystatic->getNomUrl(1, 'customer')." | \n";
- }
- else {
- $userstatic->fetch($objp->agent);
- print "".$userstatic->getFullName($langs, 0, 0, 0)." | \n";
- }
+ foreach ($group_list as $group_id => $group_array) {
+ $pa = $group_array['buying_price'];
+ $pv = $group_array['selling_price'];
+ $marge = $group_array['marge'];
- print "".price($pv, null, null, null, null, $rounding)." | \n";
- print "".price($pa, null, null, null, null, $rounding)." | \n";
- print "".price($marge, null, null, null, null, $rounding)." | \n";
- if (! empty($conf->global->DISPLAY_MARGIN_RATES))
- print "".(($marginRate === '')?'n/a':price($marginRate, null, null, null, null, $rounding)."%")." | \n";
- if (! empty($conf->global->DISPLAY_MARK_RATES))
- print "".(($markRate === '')?'n/a':price($markRate, null, null, null, null, $rounding)."%")." | \n";
- print "
\n";
+ $marginRate = ($pa != 0)?(100 * $marge / $pa):'';
+ $markRate = ($pv != 0)?(100 * $marge / $pv):'';
- $i++;
- }
- }
- print "
";
+ print '';
+ print "| ".$group_array['htmlname']." | \n";
+ print "".price($pv, null, null, null, null, $rounding)." | \n";
+ print "".price($pa, null, null, null, null, $rounding)." | \n";
+ print "".price($marge, null, null, null, null, $rounding)." | \n";
+ if (! empty($conf->global->DISPLAY_MARGIN_RATES))
+ print "".(($marginRate === '')?'n/a':price($marginRate, null, null, null, null, $rounding)."%")." | \n";
+ if (! empty($conf->global->DISPLAY_MARK_RATES))
+ print "".(($markRate === '')?'n/a':price($markRate, null, null, null, null, $rounding)."%")." | \n";
+ print "
\n";
+ }
+ }
+ print "";
}
else
{