Stock Addresses on Stock report

This commit is contained in:
2025-11-30 16:08:08 +00:00
parent 2424bb76a3
commit 292748248b
2 changed files with 356 additions and 308 deletions

View File

@@ -1,6 +1,6 @@
<?php <?php
if (! defined ( 'sugarEntry' ) || ! sugarEntry) if (! defined('sugarEntry') || ! sugarEntry)
die ( 'Not A Valid Entry Point' ); die('Not A Valid Entry Point');
/** /**
* ************************************************** * **************************************************
@@ -11,64 +11,64 @@ if (! defined ( 'sugarEntry' ) || ! sugarEntry)
/** /**
* ************************************************** * **************************************************
*/ */
$db = $GLOBALS ['db']; $db = $GLOBALS['db'];
$data = array (); $data = array();
$categoryArray = array (); $categoryArray = array();
$sum = array (); $sum = array();
$sumSub = array (); $sumSub = array();
$sumSub2 = array (); $sumSub2 = array();
$KSGROUPS=array(); $KSGROUPS = array();
$group['id']='1'; $group['id'] = '1';
$group['name']='Towar handlowy'; $group['name'] = 'Towar handlowy';
$KSGROUPS[]=$group; $KSGROUPS[] = $group;
$group['id']='2'; $group['id'] = '2';
$group['name']='Wyrób gotowy'; $group['name'] = 'Wyrób gotowy';
$KSGROUPS[]=$group; $KSGROUPS[] = $group;
$group['id']='3'; $group['id'] = '3';
$group['name']='Surowiec'; $group['name'] = 'Surowiec';
$KSGROUPS[]=$group; $KSGROUPS[] = $group;
$group['id']='4'; $group['id'] = '4';
$group['name']='Transport'; $group['name'] = 'Transport';
$KSGROUPS[]=$group; $KSGROUPS[] = $group;
if ($_GET ['selectProductActive'] != "") { if ($_GET['selectProductActive'] != "") {
$selectProductActive = $_GET ['selectProductActive']; $selectProductActive = $_GET['selectProductActive'];
} else { } else {
$selectProductActive = ""; $selectProductActive = "";
} }
if ($_GET ['selectProductEol'] != "") { if ($_GET['selectProductEol'] != "") {
$selectProductEol = $_GET ['selectProductEol']; $selectProductEol = $_GET['selectProductEol'];
} else { } else {
$selectProductEol = ""; $selectProductEol = "";
} }
if ($_GET ['selectStock'] != "") { if ($_GET['selectStock'] != "") {
$selectStock = $_GET ['selectStock']; $selectStock = $_GET['selectStock'];
} else { } else {
$selectStock = ""; $selectStock = "";
} }
$datastocks = array (); $datastocks = array();
$users = array (); $users = array();
$queryStocks = "SELECT $queryStocks = "SELECT
name, name,
id id
FROM ecmstocks FROM ecmstocks
where deleted= 0"; where deleted= 0";
$rowsStocks = $db->query ( $queryStocks ); $rowsStocks = $db->query($queryStocks);
while ( $rowStocks = $db->fetchByAssoc ( $rowsStocks ) ) { while ($rowStocks = $db->fetchByAssoc($rowsStocks)) {
$stocks ["name"] = $rowStocks ["name"]; $stocks["name"] = $rowStocks["name"];
$stocks ["id"] = $rowStocks ["id"]; $stocks["id"] = $rowStocks["id"];
$datastocks [] = $stocks; $datastocks[] = $stocks;
} }
$query = "SELECT $query = "SELECT
@@ -80,20 +80,20 @@ ON ss.product_id = p.id
WHERE WHERE
p.deleted = '0' AND ss.quantity IS NOT NULL"; p.deleted = '0' AND ss.quantity IS NOT NULL";
if ($_GET ['selectStock'] != "") if ($_GET['selectStock'] != "")
$query .= " AND ss.stock_id = '" . $_GET ["selectStock"] . "' "; $query .= " AND ss.stock_id = '" . $_GET["selectStock"] . "' ";
if ($_GET ['selectProductActive'] != "") if ($_GET['selectProductActive'] != "")
$query .= " AND p.product_active = '" . $_GET ["selectProductActive"] . "' "; $query .= " AND p.product_active = '" . $_GET["selectProductActive"] . "' ";
if ($_GET ['selectProductEol'] != "") { if ($_GET['selectProductEol'] != "") {
if ($_GET ['selectProductEol'] == "1") if ($_GET['selectProductEol'] == "1")
$query .= " AND p.status='end_of_line' "; $query .= " AND p.status='end_of_line' ";
if ($_GET ['selectProductEol'] == "0") if ($_GET['selectProductEol'] == "0")
$query .= " AND p.status!='end_of_line' "; $query .= " AND p.status!='end_of_line' ";
} }
if($_GET['productKS']!=''){ if ($_GET['productKS'] != '') {
$query .= " AND p.group_ks = '" . $_GET ["productKS"] . "' "; $query .= " AND p.group_ks = '" . $_GET["productKS"] . "' ";
} }
$query .= " GROUP BY p.id"; $query .= " GROUP BY p.id";
@@ -106,30 +106,38 @@ $query .= " GROUP BY p.id";
/** /**
* ************************************************** * **************************************************
*/ */
$rows = $db->query ( $query ); $rows = $db->query($query);
// prepare data for Smarty // prepare data for Smarty
while ( $r = $db->fetchByAssoc ( $rows ) ) { while ($r = $db->fetchByAssoc($rows)) {
$row = array (); $row = array();
$row ["id"] = $r ["id"]; $row["id"] = $r["id"];
$row ["name"] = $r ["name"]; $row["name"] = $r["name"];
$row ["code"] = $r ["code"]; $row["code"] = $r["code"];
$row ["quantity"] = $r ["quantity"]; $row["quantity"] = $r["quantity"];
$row ["price"] = $r ["price"] ; $row["price"] = $r["price"];
// stock addresses
$a = $db->query("SELECT stock_address FROM ecmproducts_stock_addresses WHERE ecmproduct_id='" . $r['id'] . "' ORDER BY stock_address");
$addresses = array();
while ($addr = $db->fetchByAssoc($a)) {
$addresses[] = $addr['stock_address'];
}
$row['stock_address'] = implode(", ", $addresses);
$querySubCategory = "SELECT category.name as 'podkategoria' $querySubCategory = "SELECT category.name as 'podkategoria'
FROM FROM
ecmproductcategories_bean bean ecmproductcategories_bean bean
JOIN JOIN
ecmproductcategories category ON bean.ecmproductcategory_id = category.id ecmproductcategories category ON bean.ecmproductcategory_id = category.id
WHERE bean.bean_id='" . $row ["id"] . "' WHERE bean.bean_id='" . $row["id"] . "'
and bean.position = '1' and bean.position = '1'
and bean.deleted = '0' and bean.deleted = '0'
and category.deleted = '0';"; and category.deleted = '0';";
$rowsSubCategory = $db->query ( $querySubCategory ); $rowsSubCategory = $db->query($querySubCategory);
$row["podkategoria"] =""; $row["podkategoria"] = "";
while ( $rowSubCategory = $db->fetchByAssoc ( $rowsSubCategory ) ) { while ($rowSubCategory = $db->fetchByAssoc($rowsSubCategory)) {
$row ["podkategoria"] = $rowSubCategory ["podkategoria"]; $row["podkategoria"] = $rowSubCategory["podkategoria"];
} }
$queryCategory = "SELECT category.name as 'kategoria' $queryCategory = "SELECT category.name as 'kategoria'
@@ -137,51 +145,53 @@ while ( $r = $db->fetchByAssoc ( $rows ) ) {
ecmproductcategories_bean bean ecmproductcategories_bean bean
JOIN JOIN
ecmproductcategories category ON bean.ecmproductcategory_id = category.id ecmproductcategories category ON bean.ecmproductcategory_id = category.id
WHERE bean.bean_id='" . $row ["id"] . "' WHERE bean.bean_id='" . $row["id"] . "'
and bean.position = '0' and bean.position = '0'
and bean.deleted = '0' and bean.deleted = '0'
and category.deleted = '0';"; and category.deleted = '0';";
$rowscategory = $db->query ( $queryCategory ); $rowscategory = $db->query($queryCategory);
$row["kategoria"] = ""; $row["kategoria"] = "";
while ( $rowcategory = $db->fetchByAssoc ( $rowscategory ) ) { while ($rowcategory = $db->fetchByAssoc($rowscategory)) {
$row ["kategoria"] = $rowcategory ["kategoria"]; $row["kategoria"] = $rowcategory["kategoria"];
} }
$data [] = $row; $data[] = $row;
} }
// //////////////// SUM ///////////////////////////////// // //////////////// SUM /////////////////////////////////
foreach ( $data as $key => &$element ) { foreach ($data as $key => &$element) {
$categoryArray1 [$element ["kategoria"] == "" ? "Inne" : $element ["kategoria"]] [$element ["podkategoria"] == "" ? "Reszta" : $element ["podkategoria"]] [$key] = $element; $categoryArray1[$element["kategoria"] == "" ? "Inne" : $element["kategoria"]][$element["podkategoria"] == "" ? "Reszta" : $element["podkategoria"]][$key] = $element;
} }
function cmp($a, $b) { function cmp($a, $b)
if ($a ["name"] == $b ["name"]) { {
if ($a["name"] == $b["name"]) {
return 0; return 0;
} }
return ($a ["name"] < $b ["name"]) ? - 1 : 1; return ($a["name"] < $b["name"]) ? -1 : 1;
} }
// grupowanie po kategoriach // grupowanie po kategoriach
foreach ( $categoryArray1 as $key1 => &$element1 ) { foreach ($categoryArray1 as $key1 => &$element1) {
foreach ( $element1 as $key2 => &$element2 ) { foreach ($element1 as $key2 => &$element2) {
usort ( $element2, "cmp" ); usort($element2, "cmp");
$i = 0; $i = 0;
$tmp2 [$key1] [$key2] [0] = array ( $tmp2[$key1][$key2][0] = array(
'name' => null 'name' => null
); );
$counter = 0; $counter = 0;
foreach ( $element2 as $count => &$element3 ) { foreach ($element2 as $count => &$element3) {
if ($element3 ["id"] != $tmp2 [$key1] [$key2] [$i] ["id"]) { if ($element3["id"] != $tmp2[$key1][$key2][$i]["id"]) {
if ($tmp2 [$key1] [$key2] [$i] ["id"] != null) { if ($tmp2[$key1][$key2][$i]["id"] != null) {
$i ++; $i++;
} }
$tmp2 [$key1] [$key2] [$i] ["id"] = $element3 ["id"]; $tmp2[$key1][$key2][$i]["id"] = $element3["id"];
$tmp2 [$key1] [$key2] [$i] ["name"] = $element3 ["name"]; $tmp2[$key1][$key2][$i]["name"] = $element3["name"];
$tmp2 [$key1] [$key2] [$i] ["code"] = $element3 ["code"]; $tmp2[$key1][$key2][$i]["code"] = $element3["code"];
$tmp2 [$key1] [$key2] [$i] ["quantity"] = $element3 ["quantity"]; $tmp2[$key1][$key2][$i]["stock_address"] = $element3["stock_address"];
$tmp2 [$key1] [$key2] [$i] ["price"] = $element3 ["price"]; $tmp2[$key1][$key2][$i]["quantity"] = $element3["quantity"];
$tmp2[$key1][$key2][$i]["price"] = $element3["price"];
} }
$counter += 1; $counter += 1;
@@ -197,67 +207,67 @@ foreach ( $categoryArray1 as $key1 => &$element1 ) {
$categoryArray = $tmp2; $categoryArray = $tmp2;
} }
} }
foreach ( $categoryArray as $key => &$element ) { foreach ($categoryArray as $key => &$element) {
$count = 0; $count = 0;
foreach ( $element as $keyy => &$elementt ) { foreach ($element as $keyy => &$elementt) {
foreach ( $elementt as $keyyy => &$elementtt ) { foreach ($elementt as $keyyy => &$elementtt) {
$sumSub ["QuantitySum"] [$key] += $elementtt ["quantity"]; $sumSub["QuantitySum"][$key] += $elementtt["quantity"];
$sumSub ["PriceSum"] [$key] += $elementtt ["price"]; $sumSub["PriceSum"][$key] += $elementtt["price"];
$sumSub2 ["QuantitySum"] [$key] [$keyy] += $elementtt ["quantity"]; $sumSub2["QuantitySum"][$key][$keyy] += $elementtt["quantity"];
$sumSub2 ["PriceSum"] [$key] [$keyy] += $elementtt ["price"]; $sumSub2["PriceSum"][$key][$keyy] += $elementtt["price"];
} }
$count += sizeof ( $elementt ); $count += sizeof($elementt);
$categoryArray [$key] [$keyy] ["QuantitySum2"] = $sumSub2 ["QuantitySum"] [$key] [$keyy]; $categoryArray[$key][$keyy]["QuantitySum2"] = $sumSub2["QuantitySum"][$key][$keyy];
$categoryArray [$key] [$keyy] ["PriceSum2"] = $sumSub2 ["PriceSum"] [$key] [$keyy]; $categoryArray[$key][$keyy]["PriceSum2"] = $sumSub2["PriceSum"][$key][$keyy];
} }
$categoryArray [$key] ["QuantitySum"] = $sumSub ["QuantitySum"] [$key]; $categoryArray[$key]["QuantitySum"] = $sumSub["QuantitySum"][$key];
$categoryArray [$key] ["PriceSum"] = $sumSub ["PriceSum"] [$key]; $categoryArray[$key]["PriceSum"] = $sumSub["PriceSum"][$key];
} }
foreach ( $categoryArray as $key => &$element ) { foreach ($categoryArray as $key => &$element) {
$sum ["QuantitySumSum"] += $sumSub ["QuantitySum"] [$key]; $sum["QuantitySumSum"] += $sumSub["QuantitySum"][$key];
$sum ["PriceSumSum"] += $sumSub ["PriceSum"] [$key]; $sum["PriceSumSum"] += $sumSub["PriceSum"][$key];
} }
foreach ( $categoryArray as $key1 => &$element ) { foreach ($categoryArray as $key1 => &$element) {
foreach ( $element as $key2 => &$elements ) { foreach ($element as $key2 => &$elements) {
foreach ( $element as $key3 => &$element2 ) { foreach ($element as $key3 => &$element2) {
if ($sumSub2 ["PriceSum"] [$key1] [$key2] > $sumSub2 ["PriceSum"] [$key1] [$key3]) { if ($sumSub2["PriceSum"][$key1][$key2] > $sumSub2["PriceSum"][$key1][$key3]) {
$tmp = $sumSub2 ["PriceSum"] [$key1] [$key2]; $tmp = $sumSub2["PriceSum"][$key1][$key2];
$sumSub2 ["PriceSum"] [$key1] [$key2] = $sumSub2 ["PriceSum"] [$key1] [$key3]; $sumSub2["PriceSum"][$key1][$key2] = $sumSub2["PriceSum"][$key1][$key3];
$sumSub2 ["PriceSum"] [$key1] [$key3] = $tmp; $sumSub2["PriceSum"][$key1][$key3] = $tmp;
} }
} }
} }
} }
foreach ( $sumSub ["PriceSum"] as $key1 => &$element ) { foreach ($sumSub["PriceSum"] as $key1 => &$element) {
foreach ( $sumSub ["PriceSum"] as $key2 => &$element2 ) { foreach ($sumSub["PriceSum"] as $key2 => &$element2) {
if ($sumSub ["PriceSum"] [$key1] > $sumSub ["PriceSum"] [$key2]) { if ($sumSub["PriceSum"][$key1] > $sumSub["PriceSum"][$key2]) {
$tmp = $sumSub ["PriceSum"] [$key1]; $tmp = $sumSub["PriceSum"][$key1];
$sumSub ["PriceSum"] [$key1] = $sumSub ["PriceSum"] [$key2]; $sumSub["PriceSum"][$key1] = $sumSub["PriceSum"][$key2];
$sumSub ["PriceSum"] [$key2] = $tmp; $sumSub["PriceSum"][$key2] = $tmp;
} }
} }
} }
// //////////////// SORT array ///////////////////////////////// // //////////////// SORT array /////////////////////////////////
$newArray2; $newArray2;
foreach ( $sumSub ["PriceSum"] as $key1 => &$element1 ) { foreach ($sumSub["PriceSum"] as $key1 => &$element1) {
foreach ( $categoryArray as $key2 => &$element2 ) { foreach ($categoryArray as $key2 => &$element2) {
if ($sumSub ["PriceSum"] [$key1] == $categoryArray [$key2] ["PriceSum"]) { if ($sumSub["PriceSum"][$key1] == $categoryArray[$key2]["PriceSum"]) {
$newArray2 [$key2] = $categoryArray [$key2]; $newArray2[$key2] = $categoryArray[$key2];
} }
} }
} }
$newArray1; $newArray1;
foreach ( $newArray2 as $key1 => &$element1 ) { foreach ($newArray2 as $key1 => &$element1) {
foreach ( $element1 as $key2 => &$element2 ) { foreach ($element1 as $key2 => &$element2) {
foreach ( $element1 as $key3 => &$element3 ) { foreach ($element1 as $key3 => &$element3) {
if ($sumSub2 ["PriceSum"] [$key1] [$key2] == $newArray2 [$key1] [$key3] ["PriceSum2"]) { if ($sumSub2["PriceSum"][$key1][$key2] == $newArray2[$key1][$key3]["PriceSum2"]) {
$newArray1 [$key1] [$key3] = $newArray2 [$key1] [$key3]; $newArray1[$key1][$key3] = $newArray2[$key1][$key3];
} }
} }
} }
@@ -274,17 +284,15 @@ foreach ( $newArray2 as $key1 => &$element1 ) {
* ************************************************** * **************************************************
*/ */
// create & execute smarty // create & execute smarty
$smarty = new Sugar_Smarty (); $smarty = new Sugar_Smarty();
global $mod_strings; global $mod_strings;
$smarty->assign ( "MOD", $mod_strings ); $smarty->assign("MOD", $mod_strings);
$smarty->assign ( "DATA", $newArray1 ); $smarty->assign("DATA", $newArray1);
$smarty->assign ( "SUM", $sum ); $smarty->assign("SUM", $sum);
$smarty->assign ('KSGROUPS',$KSGROUPS); $smarty->assign('KSGROUPS', $KSGROUPS);
$smarty->assign ( "STOCKS", $datastocks ); $smarty->assign("STOCKS", $datastocks);
$smarty->assign ( "selectStock", $selectStock ); $smarty->assign("selectStock", $selectStock);
$smarty->assign ('selectKS',$_GET['productKS']); $smarty->assign('selectKS', $_GET['productKS']);
$smarty->assign ( "selectProductActive", $selectProductActive ); $smarty->assign("selectProductActive", $selectProductActive);
$smarty->assign ( "selectProductEol", $selectProductEol ); $smarty->assign("selectProductEol", $selectProductEol);
echo $smarty->display ( 'modules/EcmReports/tpls/ReportStocks.tpl' ); echo $smarty->display('modules/EcmReports/tpls/ReportStocks.tpl');
?>

View File

@@ -1,7 +1,7 @@
<link rel="stylesheet" type="text/css" href="include/jQuery/jquery-table/jquery.appendGrid-1.3.1.css"/> <link rel="stylesheet" type="text/css" href="include/jQuery/jquery-table/jquery.appendGrid-1.3.1.css" />
<link rel="stylesheet" type="text/css" href="include/jQuery/jquery-ui/themes/base/jquery-ui.css"/> <link rel="stylesheet" type="text/css" href="include/jQuery/jquery-ui/themes/base/jquery-ui.css" />
<link rel="stylesheet" type="text/css" href="modules/EcmReports/TableSorter/css/theme.blue.css"/> <link rel="stylesheet" type="text/css" href="modules/EcmReports/TableSorter/css/theme.blue.css" />
<link rel="stylesheet" type="text/css" href="modules/EcmReports/TableSorter/css/theme.blue2.css"/> <link rel="stylesheet" type="text/css" href="modules/EcmReports/TableSorter/css/theme.blue2.css" />
<!-- Tablesorter --> <!-- Tablesorter -->
<script type="text/javascript" src="modules/EcmReports/TableSorter/js/jquery.min.js"></script> <script type="text/javascript" src="modules/EcmReports/TableSorter/js/jquery.min.js"></script>
<script type="text/javascript" src="modules/EcmReports/TableSorter/js/jquery.tablesorter.min.js"></script> <script type="text/javascript" src="modules/EcmReports/TableSorter/js/jquery.tablesorter.min.js"></script>
@@ -34,7 +34,7 @@
background-color: #BDC7B5; background-color: #BDC7B5;
} }
.sumAll td{ .sumAll td {
background-color: #BDC7B5; background-color: #BDC7B5;
} }
@@ -48,6 +48,7 @@
background: #EFEFF1; background: #EFEFF1;
color: #343432; color: #343432;
} }
table.tablesorter tbody tr.alt-row td { table.tablesorter tbody tr.alt-row td {
background: #FFF; background: #FFF;
color: #343432; color: #343432;
@@ -58,21 +59,25 @@
background: #E8E8E8; background: #E8E8E8;
color: #343432; color: #343432;
} }
table.tablesorter tbody tr.alt-row:hover td { table.tablesorter tbody tr.alt-row:hover td {
background: #E8E8E8; background: #E8E8E8;
color: #343432; color: #343432;
} }
table.tablesorter tbody tr.sumAll td { table.tablesorter tbody tr.sumAll td {
background: #EBEBED; background: #EBEBED;
color: black; color: black;
} }
table.tablesorter tbody tr.sumAll:hover td { table.tablesorter tbody tr.sumAll:hover td {
background: #E0E0E2; background: #E0E0E2;
color: black; color: black;
font-weight: bold; font-weight: bold;
} }
table.tablesorter .sumRow, .oddListRowS1 { table.tablesorter .sumRow,
.oddListRowS1 {
text-align: right; text-align: right;
} }
@@ -99,10 +104,11 @@
<table id="tableMenu" cellspacing="0" cellpadding="0" border="0"> <table id="tableMenu" cellspacing="0" cellpadding="0" border="0">
<tbody> <tbody>
<tr> <tr>
<td> <td>
<img src="themes/Sugar/images/EcmProducts.gif" style="margin-top: 3px; margin-right: 3px;" alt="EcmProducts" width="16" border="0" height="16"> <img src="themes/Sugar/images/EcmProducts.gif" style="margin-top: 3px; margin-right: 3px;"
alt="EcmProducts" width="16" border="0" height="16">
</td> </td>
<td> <td>
<h2>{$MOD.LBL_REPORT_STOCKS} </h2> <h2>{$MOD.LBL_REPORT_STOCKS} </h2>
@@ -120,15 +126,17 @@
<form action="index.php" method="get" name="searchReportStocks"> <form action="index.php" method="get" name="searchReportStocks">
<input type="hidden" name="module" value="EcmReports" /> <input type="hidden" name="module" value="EcmReports" />
<input type="hidden" name="action" value="ReportStocks" /> <input type="hidden" name="action" value="ReportStocks" />
<table style="border-top: 0px none; margin-bottom: 4px;width:100%" class="tabForm" border="0" cellpadding="0" cellspacing="0"> <table style="border-top: 0px none; margin-bottom: 4px;width:100%" class="tabForm" border="0" cellpadding="0"
cellspacing="0">
<tr> <tr>
<td class="dataLabel" width="5%" nowrap="nowrap">{$MOD.LBL_STOCK}</td> <td class="dataLabel" width="5%" nowrap="nowrap">{$MOD.LBL_STOCK}</td>
<td class="dataField" width="10%" nowrap="nowrap"> <td class="dataField" width="10%" nowrap="nowrap">
<select id="stock" name="selectStock"> <select id="stock" name="selectStock">
<option value="" { if $selectStock==""} selected="true" {/if} >{$MOD.LBL_ALL_STOCKS}</option> <option value="" { if $selectStock=="" } selected="true" {/if}>{$MOD.LBL_ALL_STOCKS}</option>
{foreach from=$STOCKS item=STOCK key=count name=loop} {foreach from=$STOCKS item=STOCK key=count name=loop}
<option value="{$STOCK.id}" { if $selectStock==$STOCK.id} selected="true" {/if} >{$STOCK.name}</option> <option value="{$STOCK.id}" { if $selectStock==$STOCK.id} selected="true" {/if}>{$STOCK.name}
</option>
{/foreach} {/foreach}
</select> </select>
</td> </td>
@@ -137,27 +145,29 @@
<td class="dataLabel" width="5%" nowrap="nowrap">{$MOD.LBL_PRODUCT_ACTIVE}</td> <td class="dataLabel" width="5%" nowrap="nowrap">{$MOD.LBL_PRODUCT_ACTIVE}</td>
<td class="dataField" width="10%" nowrap="nowrap"> <td class="dataField" width="10%" nowrap="nowrap">
<select id="productActive" name="selectProductActive"> <select id="productActive" name="selectProductActive">
<option value="" { if $selectProductActive==""} selected="true" {/if} >{$MOD.LBL_YES}/{$MOD.LBL_NO}</option> <option value="" { if $selectProductActive=="" } selected="true" {/if}>{$MOD.LBL_YES}/{$MOD.LBL_NO}
<option value="1" { if $selectProductActive=="1"} selected="true" {/if} >{$MOD.LBL_YES}</option> </option>
<option value="0" { if $selectProductActive=="0"} selected="true" {/if} >{$MOD.LBL_NO}</option> <option value="1" { if $selectProductActive=="1" } selected="true" {/if}>{$MOD.LBL_YES}</option>
<option value="0" { if $selectProductActive=="0" } selected="true" {/if}>{$MOD.LBL_NO}</option>
</select> </select>
</td> </td>
<td class="dataLabel" width="25%" nowrap="nowrap"></td> <td class="dataLabel" width="25%" nowrap="nowrap"></td>
<td class="dataLabel" width="5%" nowrap="nowrap">End of line</td> <td class="dataLabel" width="5%" nowrap="nowrap">End of line</td>
<td class="dataField" width="10%" nowrap="nowrap"> <td class="dataField" width="10%" nowrap="nowrap">
<select id="productEol" name="selectProductEol"> <select id="productEol" name="selectProductEol">
<option value="" { if $selectProductEol==""} selected="true" {/if} >{$MOD.LBL_YES}/{$MOD.LBL_NO}</option> <option value="" { if $selectProductEol=="" } selected="true" {/if}>{$MOD.LBL_YES}/{$MOD.LBL_NO}
<option value="1" { if $selectProductEol=="1"} selected="true" {/if} >{$MOD.LBL_YES}</option> </option>
<option value="0" { if $selectProductEol=="0"} selected="true" {/if} >{$MOD.LBL_NO}</option> <option value="1" { if $selectProductEol=="1" } selected="true" {/if}>{$MOD.LBL_YES}</option>
<option value="0" { if $selectProductEol=="0" } selected="true" {/if}>{$MOD.LBL_NO}</option>
</select> </select>
</td> </td>
<td class="dataLabel" width="25%" nowrap="nowrap"></td> <td class="dataLabel" width="25%" nowrap="nowrap"></td>
<td class="dataLabel" width="5%" nowrap="nowrap">Grupa księgowa</td> <td class="dataLabel" width="5%" nowrap="nowrap">Grupa księgowa</td>
<td class="dataField" width="10%" nowrap="nowrap"> <td class="dataField" width="10%" nowrap="nowrap">
<select id="productKS" name="productKS"> <select id="productKS" name="productKS">
<option value="" { if $selectKS==""} selected="true" {/if} >Wszystkie</option> <option value="" { if $selectKS=="" } selected="true" {/if}>Wszystkie</option>
{foreach from=$KSGROUPS item=GROUP key=count name=loop} {foreach from=$KSGROUPS item=GROUP key=count name=loop}
<option value="{$GROUP.id}" { if $selectKS==$GROUP.id} selected="true" {/if} >{$GROUP.name}</option> <option value="{$GROUP.id}" { if $selectKS==$GROUP.id} selected="true" {/if}>{$GROUP.name}</option>
{/foreach} {/foreach}
</select> </select>
</td> </td>
@@ -175,50 +185,76 @@
<td class="dataLabel" width="25%" nowrap="nowrap"></td> <td class="dataLabel" width="25%" nowrap="nowrap"></td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
<input class="button" name="submit" value="{$MOD.LBL_EXECUTE}" type="submit"> <input class="button" name="submit" value="{$MOD.LBL_EXECUTE}" type="submit">
<input class="button" name="clear" value="{$MOD.LBL_CLEAR}" type="button" onclick="location.href='index.php?module=EcmReports&action=ReportSales';"> <input class="button" name="clear" value="{$MOD.LBL_CLEAR}" type="button"
<input id="excelEksport" class="button" name="importToExcel" value="{$MOD.BTN_EXCEL_EXPORT}" type="button"> onclick="location.href='index.php?module=EcmReports&action=ReportSales';">
<input id="excelEksport" class="button" name="importToExcel" value="{$MOD.BTN_EXCEL_EXPORT}" type="button">
<br> <br>
<br> <br>
<table id="myTable" class="tablesorter tablesorter-blue" role="grid"> <table id="myTable" class="tablesorter tablesorter-blue" role="grid">
<thead> <thead>
<tr class="tablesorter-headerRow" role="row"> <tr class="tablesorter-headerRow" role="row">
<th width="30%" class="sorter-text tablesorter-header tablesorter-headerUnSorted" data-column="0" tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on" style="-moz-user-select: none;" aria-sort="none" aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_PRODUCTS}</th> <th width="30%" class="sorter-text tablesorter-header tablesorter-headerUnSorted" data-column="0"
<th width="10%" class="sorter-text tablesorter-header tablesorter-headerUnSorted" data-column="1" tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on" style="-moz-user-select: none;" aria-sort="none" aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_INDEX}</th> tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on"
<th width="8%" class="sorter-saas tablesorter-header tablesorter-headerUnSorted" data-column="5" tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on" style="-moz-user-select: none;" aria-sort="none" aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_QUANTITY}</th> style="-moz-user-select: none;" aria-sort="none"
<th width="8%" class="sorter-saas tablesorter-header tablesorter-headerUnSorted" data-column="6" tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on" style="-moz-user-select: none;" aria-sort="none" aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_VALUE}</th> aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_PRODUCTS}</th>
<th width="8%" class="sorter-saas tablesorter-header tablesorter-headerUnSorted" data-column="6" tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on" style="-moz-user-select: none;" aria-sort="none" aria-label="Name: No sort applied, activate to apply an ascending sort">Średnia Cena</th> <th width="4%" class="sorter-text tablesorter-header tablesorter-headerUnSorted" data-column="1"
tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on"
style="-moz-user-select: none;" aria-sort="none"
aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_INDEX}</th>
<th width="6%" class="sorter-text tablesorter-header tablesorter-headerUnSorted" data-column="1"
tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on"
style="-moz-user-select: none;" aria-sort="none"
aria-label="Name: No sort applied, activate to apply an ascending sort">Adres magazynowy</th>
<th width="8%" class="sorter-saas tablesorter-header tablesorter-headerUnSorted" data-column="5"
tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on"
style="-moz-user-select: none;" aria-sort="none"
aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_QUANTITY}</th>
<th width="8%" class="sorter-saas tablesorter-header tablesorter-headerUnSorted" data-column="6"
tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on"
style="-moz-user-select: none;" aria-sort="none"
aria-label="Name: No sort applied, activate to apply an ascending sort">{$MOD.LBL_VALUE}</th>
<th width="8%" class="sorter-saas tablesorter-header tablesorter-headerUnSorted" data-column="6"
tabindex="0" scope="col" role="columnheader" aria-disabled="false" unselectable="on"
style="-moz-user-select: none;" aria-sort="none"
aria-label="Name: No sort applied, activate to apply an ascending sort">Średnia Cena</th>
</tr> </tr>
</thead> </thead>
{foreach from=$DATA item=CAT key=CATNAME name=loop} {foreach from=$DATA item=CAT key=CATNAME name=loop}
{* Table headers *} {* Table headers *}
<tbody id="functions-core" class="tablesorter-infoOnly"> <tbody id="functions-core" class="tablesorter-infoOnly">
<tr class="static category"> <tr class="static category">
{if $CATNAME != ""} {if $CATNAME != ""}
<td class="oddListRowS1 alignLeft"><a class="plusStyle showTables">[+]</a><b> {$CATNAME}</b></td> <td class="oddListRowS1 alignLeft"><a class="plusStyle showTables">[+]</a><b> {$CATNAME}</b></td>
{/if} {/if}
<td class="oddListRowS1" ></td> <td class="oddListRowS1"></td>
<td class="oddListRowS1 sumRow" ><b>{$DATA.$CATNAME.QuantitySum|number_format:4:",":"." }</b></td> <td class="oddListRowS1"></td>
<td class="oddListRowS1 sumRow" ><b>{$DATA.$CATNAME.PriceSum|number_format:2:",":"." }</b></td> <td class="oddListRowS1 sumRow"><b>{$DATA.$CATNAME.QuantitySum|number_format:4:",":"." }</b></td>
<td class="oddListRowS1 sumRow" ><b>{$DATA.$CATNAME.PriceSum/$DATA.$CATNAME.QuantitySum|number_format:2:",":"." }</b></td> <td class="oddListRowS1 sumRow"><b>{$DATA.$CATNAME.PriceSum|number_format:2:",":"." }</b></td>
<td class="oddListRowS1 sumRow">
<b>{$DATA.$CATNAME.PriceSum/$DATA.$CATNAME.QuantitySum|number_format:2:",":"." }</b></td>
</tr> </tr>
</tbody> </tbody>
{foreach from=$CAT item=CAT2 key=CAT2NAME name=loop} {foreach from=$CAT item=CAT2 key=CAT2NAME name=loop}
{if $CAT2NAME!="QuantitySum" && $CAT2NAME!="PriceSum"} {if $CAT2NAME!="QuantitySum" && $CAT2NAME!="PriceSum"}
<tbody id="functions-core" class="tablesorter-infoOnly tablesShowHide"> <tbody id="functions-core" class="tablesorter-infoOnly tablesShowHide">
<tr class="subcategory"> <tr class="subcategory">
<td class="oddListRowS1 alignLeft"><a class="showRows" style="color: cadetblue; text-decoration: none; cursor: pointer;">[+]</a><b> {$CAT2NAME}</b></td> <td class="oddListRowS1 alignLeft"><a class="showRows"
<td class="oddListRowS1" ></td> style="color: cadetblue; text-decoration: none; cursor: pointer;">[+]</a><b> {$CAT2NAME}</b>
<td class="oddListRowS1 sumRow" ><b>{$CAT.$CAT2NAME.QuantitySum2|number_format:4:",":"." }</b></td> </td>
<td class="oddListRowS1 sumRow" ><b>{$CAT.$CAT2NAME.PriceSum2|number_format:2:",":"." }</b></td> <td class="oddListRowS1"></td>
<td class="oddListRowS1 sumRow" ><b>{$CAT.$CAT2NAME.PriceSum2/$CAT.$CAT2NAME.QuantitySum2|number_format:2:",":"." }</b></td> <td class="oddListRowS1"></td>
<td class="oddListRowS1 sumRow"><b>{$CAT.$CAT2NAME.QuantitySum2|number_format:4:",":"." }</b></td>
<td class="oddListRowS1 sumRow"><b>{$CAT.$CAT2NAME.PriceSum2|number_format:2:",":"." }</b></td>
<td class="oddListRowS1 sumRow">
<b>{$CAT.$CAT2NAME.PriceSum2/$CAT.$CAT2NAME.QuantitySum2|number_format:2:",":"." }</b></td>
</tr> </tr>
</tbody> </tbody>
@@ -232,14 +268,16 @@
{/if} {/if}
<td class="oddListRowS1 alignLeft" style="text-align:left;"> <td class="oddListRowS1 alignLeft" style="text-align:left;">
<a target="new" href="index.php?module=EcmProducts&action=index&return_module=EcmProducts&action=DetailView&record={$ROW.id}"> <a target="new"
href="index.php?module=EcmProducts&action=index&return_module=EcmProducts&action=DetailView&record={$ROW.id}">
{$ROW.name} {$ROW.name}
</a> </a>
</td> </td>
<td class="oddListRowS1 alignLeft" >{$ROW.code}</td> <td class="oddListRowS1 alignLeft">{$ROW.code}</td>
<td class="oddListRowS1" >{$ROW.quantity|number_format:4:",":"."}</td> <td class="oddListRowS1">{$ROW.stock_address}</td>
<td class="oddListRowS1" >{$ROW.price|number_format:2:",":"."}</td> <td class="oddListRowS1">{$ROW.quantity|number_format:4:",":"."}</td>
<td class="oddListRowS1" >{$ROW.price/$ROW.quantity|number_format:2:",":"."}</td> <td class="oddListRowS1">{$ROW.price|number_format:2:",":"."}</td>
<td class="oddListRowS1">{$ROW.price/$ROW.quantity|number_format:2:",":"."}</td>
</tr> </tr>
{/if} {/if}
{/foreach} {/foreach}
@@ -248,15 +286,17 @@
{/if} {/if}
{/foreach} {/foreach}
<tbody id="stopTables"></tbody> <tbody id="stopTables"></tbody>
{/foreach} {/foreach}
<tbody id="functions-core" class="tablesorter-infoOnly"> <tbody id="functions-core" class="tablesorter-infoOnly">
<tr class="static category sumAll"> <tr class="static category sumAll">
<td class="oddListRowS1 alignLeft"><b>{$MOD.LBL_SUM}:</b></td> <td class="oddListRowS1 alignLeft"><b>{$MOD.LBL_SUM}:</b></td>
<td class="oddListRowS1" ></td> <td class="oddListRowS1"></td>
<td class="oddListRowS1 sumRow" ><b>{$SUM.QuantitySumSum|number_format:4:",":"." }</b></td> <td class="oddListRowS1"></td>
<td class="oddListRowS1 sumRow" ><b>{$SUM.PriceSumSum|number_format:2:",":"." }</b></td> <td class="oddListRowS1 sumRow"><b>{$SUM.QuantitySumSum|number_format:4:",":"." }</b></td>
<td class="oddListRowS1 sumRow" ><b>{$SUM.PriceSumSum/$SUM.QuantitySumSum|number_format:2:",":"." }</b></td> <td class="oddListRowS1 sumRow"><b>{$SUM.PriceSumSum|number_format:2:",":"." }</b></td>
<td class="oddListRowS1 sumRow"><b>{$SUM.PriceSumSum/$SUM.QuantitySumSum|number_format:2:",":"." }</b>
</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
<br/> <br />