Compare commits

..

2 Commits

Author SHA1 Message Date
OpenXE
05714cfd21 Bugfix Shop LagerSync 2023-02-16 10:56:00 +01:00
OpenXE
4be2d5af23 Lager Lagerbestandsberechnung removed group by lager, bugfixes regarding calculations 2023-02-15 16:38:48 +01:00
3 changed files with 133 additions and 345 deletions

View File

@ -22853,7 +22853,7 @@ function ChargenMHDAuslagern($artikel, $menge, $lagerplatztyp, $lpid,$typ,$wert,
} }
$isArticleCacheDifferent = $lagerartikel[$ij]['cache_lagerplatzinhaltmenge'] $isArticleCacheDifferent = $lagerartikel[$ij]['cache_lagerplatzinhaltmenge']
!= ($verkaufbare_menge_korrektur + $pseudolager); != ((int) $verkaufbare_menge_korrektur + (int) $pseudolager);
$storageCache = $isArticleCacheDifferent $storageCache = $isArticleCacheDifferent
? null : $this->getStorageCacheInfosByShopId((int)$shop, (int)$lagerartikel[$ij]['id']); ? null : $this->getStorageCacheInfosByShopId((int)$shop, (int)$lagerartikel[$ij]['id']);
@ -22896,9 +22896,9 @@ function ChargenMHDAuslagern($artikel, $menge, $lagerplatztyp, $lpid,$typ,$wert,
} }
} }
$this->LogFile('*** UPDATE '.$lagerartikel[$ij]['nummer'].' '.$lagerartikel[$ij]['name_de'].' Shop: '.$shop.' Lagernd: '.$verkaufbare_menge.' Korrektur: '.round($verkaufbare_menge_korrektur - $verkaufbare_menge,7).' Pseudolager: '.round($pseudolager,8)); $this->LogFile('*** UPDATE '.$lagerartikel[$ij]['nummer'].' '.$lagerartikel[$ij]['name_de'].' Shop: '.$shop.' Lagernd: '.$verkaufbare_menge.' Korrektur: '.round((float) ($verkaufbare_menge_korrektur - $verkaufbare_menge),7).' Pseudolager: '.round((float) $pseudolager,8));
$cacheQuantity = $verkaufbare_menge_korrektur + $pseudolager; $cacheQuantity = (int) $verkaufbare_menge_korrektur + (int) $pseudolager;
$this->app->DB->Update( $this->app->DB->Update(
"UPDATE `artikel` SET `cache_lagerplatzinhaltmenge` = '{$cacheQuantity}' "UPDATE `artikel` SET `cache_lagerplatzinhaltmenge` = '{$cacheQuantity}'
WHERE `id`= '{$lagerartikel[$ij]['id']}' LIMIT 1" WHERE `id`= '{$lagerartikel[$ij]['id']}' LIMIT 1"

View File

@ -40,10 +40,6 @@
<option value="inventurwert" [INVENTURWERT]>{|Inventurwert (wenn vorhanden)|}</option> <option value="inventurwert" [INVENTURWERT]>{|Inventurwert (wenn vorhanden)|}</option>
</select> </select>
</td> </td>
<td>
<input type="checkbox" value="1" id="gruppierenlager" name="gruppierenlager" [GRUPPIERENLAGER]/>
<label for="gruppierenlager">{|Gruppieren Lager|}</label>
</td>
<td> <td>
<input type="checkbox" value="1" id="preiseineuro" name="preiseineuro" [PREISEINEURO]/> <input type="checkbox" value="1" id="preiseineuro" name="preiseineuro" [PREISEINEURO]/>
<label for="preiseineuro">{|alle Preise in EUR anzeigen|}</label> <label for="preiseineuro">{|alle Preise in EUR anzeigen|}</label>

View File

@ -18,93 +18,13 @@ class Lager extends GenLager {
/** @var Application $app */ /** @var Application $app */
var $app; var $app;
/**
* @param string $arttab
* @param string $tab1
* @param string $tab2
*
* @return string
*/
static function LetzterEK($arttab = 'art', $tab1 = 'e1', $tab2 = 'e')
{
return "
(
SELECT $tab2.artikel, $tab2.waehrung, $tab2.preis FROM
(SELECT max( $tab2.id ) AS id, artikel
FROM einkaufspreise $tab2
WHERE $tab2.geloescht !=1
AND (
ifnull($tab2.gueltig_bis,'0000-00-00') = '0000-00-00'
OR $tab2.gueltig_bis >= CURDATE( )
)
GROUP BY artikel) ".$tab1."
INNER JOIN einkaufspreise ".$tab2." ON $tab1.id = $tab2.id
)
";
}
/** /**
* @param string $typ * @param string $typ
* @param bool $live
* *
* @return string * @return string
*/ */
static function Waehrung($typ = 'letzterek', $live = true) static function Waehrung($typ = 'letzterek')
{ {
if(!$live)
{
switch($typ)
{
case 'letzterek':
return "if(ifnull(lw.preis_letzterek,0) <> 0,if(lw.waehrungletzt<>'',lw.waehrungletzt,'EUR'),if(ifnull(ek.waehrung,'')<>'',ek.waehrung,'EUR'))";
break;
case 'letzerekarchiv':
return "if(ifnull(lw.preis_letzterek,0) <> 0,if(lw.waehrungletzt<>'',lw.waehrungletzt,'EUR'),'EUR')";
break;
case 'inventurwertarchiv':
return "if(ifnull(lw.inventurwert,0) <> 0,'EUR',
if(ifnull(lw.preis_letzterek,0) <> 0,
if(lw.waehrungletzt <> '',lw.waehrungletzt,'EUR'),
'EUR'
)
)";
break;
case 'inventurwert':
return "if(ifnull(lw.inventurwert,0) <> 0,'EUR',
if(ifnull(art.inventurekaktiv,0) <> 0
, 'EUR',
if(ifnull(lw.preis_letzterek,0) <> 0,
if(lw.waehrungletzt <> '',lw.waehrungletzt,'EUR'),
if(ifnull(ek.waehrung,'')<>'',ek.waehrung,'EUR')
)
)
)";
break;
case 'kalkulierterekarchiv':
return "
if(
ifnull(lw.preis_kalkulierterek,0) <> 0
,
if(lw.waehrungkalk<>'',lw.waehrungkalk,'EUR')
,
if(ifnull(lw.preis_letzterek,0) <> 0,
if(lw.waehrungletzt<>'',lw.waehrungletzt,'EUR')
,'EUR'
)
)";
break;
default:
return "
if(ifnull(lw.preis_kalkulierterek,0) <> 0,if(lw.waehrungkalk<>'',lw.waehrungkalk,'EUR'),
if(ifnull(art.verwendeberechneterek,0) <> 0, if(ifnull(art.berechneterekwaehrung,'')<>'',art.berechneterekwaehrung,'EUR')
,
if(ifnull(lw.preis_letzterek,0) <> 0,if(lw.waehrungletzt<>'',lw.waehrungletzt,'EUR'),if(ifnull(ek.waehrung,'')<>'',ek.waehrung,'EUR'))
)
)";
break;
}
}else{
switch($typ) switch($typ)
{ {
case 'letzterek': case 'letzterek':
@ -125,11 +45,9 @@ class Lager extends GenLager {
break; break;
} }
} }
}
/** /**
* @param string $typ * @param string $typ
* @param bool $live
* *
* @return string * @return string
*/ */
@ -137,77 +55,30 @@ class Lager extends GenLager {
switch($typ) switch($typ)
{ {
case 'kalkulierterek': case 'kalkulierterek':
return("if (art.verwendeberechneterek,'K','EK')"); return("if (art.verwendeberechneterek,'K','E')");
break; break;
case 'inventurwert': case 'inventurwert':
return("if (art.inventurekaktiv,'I','EK')"); return("if (art.inventurekaktiv,'I','E')");
break; break;
default: default:
case 'letzterek': case 'letzterek':
return("'EK'"); return("'E'");
break; break;
} }
} }
/** /**
* @param string $typ * @param string $typ
* @param bool $live
* *
* @return string * @return string
*/ */
public static function EinzelPreis($typ = 'letzterek', $live = true) public static function EinzelPreis($typ = 'letzterek')
{
if(!$live)
{ {
switch($typ) switch($typ)
{ {
case 'letzterekarchiv':
return "if(ifnull(lw.preis_letzterek,0) <> 0,lw.preis_letzterek,0)";
break;
case 'letzterek': case 'letzterek':
return "if(ifnull(lw.preis_letzterek,0) <> 0,lw.preis_letzterek,ifnull(ek.preis,0))";
break;
case 'inventurwertarchiv':
return "if(ifnull(lw.inventurwert,0) <> 0,lw.inventurwert,
ifnull(lw.preis_letzterek,0)
)";
break;
case 'inventurwert':
return "if(ifnull(lw.inventurwert,0) <> 0,lw.inventurwert,
if(ifnull(art.inventurekaktiv,0) <> 0
, art.inventurek,
if(ifnull(lw.preis_letzterek,0) <> 0,lw.preis_letzterek,ifnull(ek.preis,0))
)
)";
break;
case 'kalkulierterekarchiv':
return "
if(
ifnull(lw.preis_kalkulierterek,0) <> 0,
lw.preis_kalkulierterek,
ifnull(lw.preis_letzterek,0)
)";
break;
default:
return "
if(ifnull(lw.preis_kalkulierterek,0) <> 0,lw.preis_kalkulierterek,
if(ifnull(art.verwendeberechneterek,0) <> 0,art.berechneterek
,if(ifnull(lw.preis_letzterek,0) <> 0,
lw.preis_letzterek,
ifnull(ek.preis,0)
)
)
)";
break;
}
}else{
switch($typ)
{
case 'letzterek':
case 'letzterekarchiv':
return "ifnull(ek.preis,0)"; return "ifnull(ek.preis,0)";
break; break;
case 'inventurwertarchiv':
case 'inventurwert': case 'inventurwert':
return "if(ifnull(art.inventurekaktiv,0) <> 0,art.inventurek,ifnull(ek.preis,0))"; return "if(ifnull(art.inventurekaktiv,0) <> 0,art.inventurek,ifnull(ek.preis,0))";
break; break;
@ -221,162 +92,6 @@ class Lager extends GenLager {
break; break;
} }
} }
}
/**
* @param string $typ
* @param bool $live
*
* @return string
*/
/*
Get the correct currency conversion rate to the date
*/
public static function KursJoin(string $datum, string $waehrung_nach = 'EUR')
{
$relevant_dates = "
SELECT
waehrung_von,
waehrung_nach,
MIN(
DATE
(
REPLACE
(
COALESCE(gueltig_bis,'9999-12-31'),
'0000-00-00',
'9999-12-31'
)
)
) AS gueltig_datum
FROM
`waehrung_umrechnung`
WHERE
REPLACE
(
COALESCE(gueltig_bis,'9999-12-31'),
'0000-00-00',
'9999-12-31'
) >= '".$datum."'
GROUP BY
waehrung_von,
waehrung_nach
";
$list_of_rates = "
SELECT
waehrung_von,
waehrung_nach,
DATE
(
REPLACE
(
COALESCE(gueltig_bis,'9999-12-31'),
'0000-00-00',
'9999-12-31'
)
) AS gueltig_datum,
kurs
FROM
waehrung_umrechnung
";
$sql = "
LEFT JOIN
(
SELECT
lor.waehrung_von,
lor.waehrung_nach,
MAX(lor.kurs) AS kurs
FROM
(
$list_of_rates
) lor
INNER JOIN(
$relevant_dates
) rd
ON
lor.gueltig_datum = rd.gueltig_datum
AND
lor.waehrung_von = rd.waehrung_von
AND
lor.waehrung_nach = rd.waehrung_nach
GROUP BY
lor.waehrung_von,
lor.waehrung_nach
) wt
ON
wt.waehrung_von = ek.waehrung AND wt.waehrung_nach = '".$waehrung_nach."'";
return($sql);
}
/**
* @param Application $app
* @param string $typ
* @param null|bool $live
*
* @return string
*/
public static function PreisUmrechnung($app, $typ, $live = null)
{
$kursusd = $app->erp->GetWaehrungUmrechnungskurs('EUR','USD');
$kurschf = $app->erp->GetWaehrungUmrechnungskurs('EUR','CHF');
if(!$live)
{
return '
if(
ifnull(lw.kursletzt,0)<> 0
,
1 / lw.kursletzt
,
if(
ifnull(wt.kurs,0) <> 0
,
if(
wt.waehrung_nach = '.self::Waehrung($typ, $live).',
(1/wt.kurs),
wt.kurs
)
,
if('.self::Waehrung($typ, $live).' = \'USD\',
1.0 / '.$kursusd.',
if('.self::Waehrung($typ, $live).' = \'CHF\',
1.0 / '.$kurschf.',
1)
)
)
)
*
'.self::EinzelPreis($typ, $live);
}
return '
if(
ifnull(wt.kurs,0) <> 0
,
if(
wt.waehrung_nach = '.self::Waehrung($typ, $live).',
(1/wt.kurs),
wt.kurs
)
,
if('.self::Waehrung($typ, $live).' = \'USD\',
1.0 / '.$kursusd.',
if('.self::Waehrung($typ, $live).' = \'CHF\',
1.0 / '.$kurschf.',
1)
)
)
*
'.self::EinzelPreis($typ, $live);
}
/** /**
* @param Application $app * @param Application $app
@ -603,11 +318,13 @@ class Lager extends GenLager {
}else{ }else{
$datum = date('Y-m-d'); $datum = date('Y-m-d');
} }
$colmenge = 'lw.menge';
$colgewicht = "ifnull(art.gewicht,'0') * ifnull(lw.menge,0)";
$colvolumen = "ifnull(art.laenge,'0')*ifnull(art.breite,'0')*ifnull(art.hoehe,'0')* ifnull(lw.menge,0)";
if($datum == date('Y-m-d')) if($datum == date('Y-m-d'))
{ {
$live = true; $live = true;
$colmenge = 'lw.menge';
}else{ }else{
$live = false; $live = false;
$_datum = $app->DB->Select("SELECT max(datum) FROM lagerwert WHERE datum <= '$datum' AND '$datum' < curdate() "); $_datum = $app->DB->Select("SELECT max(datum) FROM lagerwert WHERE datum <= '$datum' AND '$datum' < curdate() ");
@ -617,30 +334,16 @@ class Lager extends GenLager {
} }
} }
$colgewicht ="if(lw.gewicht = 0,ifnull(art.gewicht,'0') ,lw.gewicht) *lw.menge";
$colvolumen = "if(lw.volumen=0,ifnull(art.laenge,'0')*ifnull(art.breite,'0')*ifnull(art.hoehe,'0'),lw.volumen)*lw.menge";
if($live)
{
$colgewicht = "ifnull(art.gewicht,'0') * ifnull(lw.menge,0)";
$colvolumen = "ifnull(art.laenge,'0')*ifnull(art.breite,'0')*ifnull(art.hoehe,'0')* ifnull(lw.menge,0)";
}
$heading = array('Datum','Artikel-Nr.','Artikel','Artikelkategorie','Lager','Lagerplatz','Menge','Gewicht','Volumen','Preistyp','EK-Preis','W&auml;hrung','Kurs','', 'Gesamt',''); $heading = array('Datum','Artikel-Nr.','Artikel','Artikelkategorie','Lager','Lagerplatz','Menge','Gewicht','Volumen','Preistyp','EK-Preis','W&auml;hrung','Kurs','', 'Gesamt','');
$width = array( '5%', '05%', '20%', '10%', '10%', '5%' , '5%', '5%', '5%', '1%', '5%', '1%', '1%', '1%','2%', '1%'); $width = array( '5%', '05%', '20%', '10%', '10%', '5%' , '5%', '5%', '5%', '1%', '5%', '1%', '1%', '1%','2%', '1%');
$findcols = array('lw.datum','art.nummer','art.name_de','(select bezeichnung from artikelkategorien where id=(select SUBSTRING_INDEX(SUBSTRING_INDEX(art.typ, \'kat\', 1), \'_\', 1) as type from artikel where id=art.id))', 'lagername', 'name',$colmenge,$colgewicht,$colvolumen); $findcols = array('lw.datum','art.nummer','art.name_de','(select bezeichnung from artikelkategorien where id=(select SUBSTRING_INDEX(SUBSTRING_INDEX(art.typ, \'kat\', 1), \'_\', 1) as type from artikel where id=art.id))', 'lagername', 'name',$colmenge,$colgewicht,$colvolumen);
$kursjoin = "";
$preis = self::EinzelPreis($preisart,$live);
$preiscol = $app->erp->FormatPreis($preis,2);
$waehrungcol = self::Waehrung($preisart,$live);
if ($preiseineuro) { if ($preiseineuro) {
$kursjoin = self::KursJoin($datum); $preisEUR = "((SELECT preisfinal)*if((SELECT waehrungfinal) = 'EUR' OR (SELECT waehrungfinal) = NULL,1,kurs))";
$preisEUR = self::PreisUmrechnung($app, $preisart, true); $gesamtcol = "(".$preisEUR."* lw.menge)";
$gesamtcol = "(".$preisEUR.'*'.$colmenge.")";
$kurs = $app->erp->FormatPreis('kurs',2); $kurs = $app->erp->FormatPreis('kurs',2);
} else { } else {
$gesamtcol = "(".$preis.'*'.$colmenge.")"; $gesamtcol = "((SELECT preisfinal)*lw.menge)";
$kurs = 1; $kurs = 1;
} }
@ -662,18 +365,17 @@ class Lager extends GenLager {
$numbercols = array(7,8,9,11,13,15); $numbercols = array(7,8,9,11,13,15);
$datecols = array(0); $datecols = array(0);
$onequeryperuser = true; $onequeryperuser = true;
$joinek = ' LEFT JOIN '.self::LetzterEK('art', 'e1','e2').' ek ON art.id = ek.artikel';
if (!$live) if (!$live)
{ {
$lagerwert_sql = "lagerwert"; $lagermengen_sql = "(SELECT datum, artikel, menge, lager_platz FROM lagerwert WHERE datum = '$datum')";
$where = " lw.datum = '$datum' "; $where = "1";
} else { // LIVE } else { // LIVE
$lagerwert_live = " $lagermengen_sql = "(
SELECT SELECT
DATE_FORMAT(NOW(), '%d.%m.%Y') datum, NOW() as datum,
lager_platz_inhalt.artikel, lager_platz_inhalt.artikel,
SUM(lager_platz_inhalt.menge) AS menge, SUM(lager_platz_inhalt.menge) AS menge,
lager_platz_inhalt.lager_platz AS lager_platz lager_platz_inhalt.lager_platz AS lager_platz
@ -683,43 +385,133 @@ class Lager extends GenLager {
DATE_FORMAT(NOW(), '%d.%m.%Y'), DATE_FORMAT(NOW(), '%d.%m.%Y'),
lager_platz_inhalt.artikel, lager_platz_inhalt.artikel,
lager_platz_inhalt.lager_platz lager_platz_inhalt.lager_platz
"; ) ";
$lagerwert_sql = "(".$lagerwert_live.") ";
$where = "1 "; $where = "1 ";
} // LIVE } // LIVE
// Subselect to obtain the relevant (minimum) currency conversion rates for a given date
$currency_sql = "
SELECT
waehrung_umrechnung.waehrung_von,
waehrung_umrechnung.waehrung_nach,
MIN(kurs) kurs
FROM
waehrung_umrechnung
WHERE
DATE(
REPLACE
(
COALESCE(gueltig_bis, '9999-12-31'),
'0000-00-00',
'9999-12-31'
)
) =(
SELECT
MIN(
DATE(
REPLACE
(
COALESCE(wu4min.gueltig_bis, '9999-12-31'),
'0000-00-00',
'9999-12-31'
)
)
)
FROM
waehrung_umrechnung wu4min
WHERE
waehrung_umrechnung.waehrung_von = wu4min.waehrung_von AND waehrung_umrechnung.waehrung_nach = wu4min.waehrung_nach AND DATE(
REPLACE
(
COALESCE(wu4min.gueltig_bis, '9999-12-31'),
'0000-00-00',
'9999-12-31'
)
) >= DATE('".$datum."')
)
GROUP BY
waehrung_umrechnung.waehrung_von,
waehrung_umrechnung.waehrung_nach
";
// Subselect to obtain the relevant (minimum) prices per article
$prices_sql = "
SELECT
artikel,
waehrung,
preis
FROM
einkaufspreise
WHERE
preis =(
SELECT
MIN(preis)
FROM
einkaufspreise minek
WHERE
einkaufspreise.artikel = minek.artikel AND DATE(
REPLACE
(
COALESCE(gueltig_bis, '9999-12-31'),
'0000-00-00',
'9999-12-31'
)
) =(
SELECT
MIN(
DATE(
REPLACE
(
COALESCE(ek4min.gueltig_bis, '9999-12-31'),
'0000-00-00',
'9999-12-31'
)
)
)
FROM
einkaufspreise ek4min
WHERE
minek.artikel = ek4min.artikel AND ek4min.geloescht != 1 AND minek.geloescht != 1 AND DATE(
REPLACE
(
COALESCE(ek4min.gueltig_bis, '9999-12-31'),
'0000-00-00',
'9999-12-31'
)
) >= DATE('".$datum."')
)
)
GROUP BY
artikel,
waehrung
";
$sql = "SELECT DISTINCT SQL_CALC_FOUND_ROWS $sql = "SELECT DISTINCT SQL_CALC_FOUND_ROWS
art.id, art.id,
date_format(lw.datum,'%d.%m.%Y'), ".$app->erp->FormatDate('lw.datum')." as datum,
art.nummer, art.nummer,
art.name_de, art.name_de,
(select bezeichnung from artikelkategorien where id=(select SUBSTRING_INDEX(SUBSTRING_INDEX(art.typ, 'kat', 1), '_', 1) as type from artikel where id=art.id)) as artikelkategorie, (select bezeichnung from artikelkategorien where id=(select SUBSTRING_INDEX(SUBSTRING_INDEX(art.typ, 'kat', 1), '_', 1) as type from artikel where id=art.id)) as artikelkategorie,
lagerplatz.lagername, lagerplatz.lagername,
lagerplatz.name, lagerplatz.name,
".$app->erp->FormatMenge('lw.menge',2).",".$app->erp->FormatPreis($colgewicht,2).",".$app->erp->FormatPreis($colvolumen,2).", ".$app->erp->FormatMenge('lw.menge',2).",".$app->erp->FormatPreis($colgewicht,2).",".$app->erp->FormatPreis($colvolumen,2)." as menge,
".self::PreisTypErgebnis($preisart).", ".self::PreisTypErgebnis($preisart)." as preisart,
$preiscol, ".self::EinzelPreis($preisart)." AS preisfinal,
$waehrungcol, ".self::Waehrung($preisart)." AS waehrungfinal,
".$kurs." as kurs, ".$kurs." AS kurs,
'', '' as hidden,
".$app->erp->FormatPreis($gesamtcol,2).", ".$app->erp->FormatPreis($gesamtcol,2)." as gesamt,
art.id art.id
FROM FROM
artikel art artikel art
INNER JOIN ".$lagerwert_sql." lw ON lw.artikel = art.id AND (isnull(art.geloescht) OR art.geloescht = 0) AND art.lagerartikel = 1 INNER JOIN ".$lagermengen_sql." AS lw ON lw.artikel = art.id AND (isnull(art.geloescht) OR art.geloescht = 0) AND art.lagerartikel = 1
$joinek LEFT JOIN (".$prices_sql.") AS ek ON art.id = ek.artikel AND ".self::Waehrung($preisart)." = ek.waehrung
$kursjoin LEFT JOIN (".$currency_sql.") AS kurs ON kurs.waehrung_von = ".self::Waehrung($preisart)." AND kurs.waehrung_nach = 'EUR'
$joinartikelbaum
"; ";
if ($gruppierenlager) {
$lagerplatz_sql = "(SELECT lager_platz.id, lager.bezeichnung lagername, '' name from lager INNER JOIN lager_platz on lager_platz.lager = lager.id) lagerplatz";
} else {
$lagerplatz_sql = "(SELECT lager_platz.id, lager.bezeichnung lagername, lager_platz.kurzbezeichnung name from lager INNER JOIN lager_platz on lager_platz.lager = lager.id) lagerplatz"; $lagerplatz_sql = "(SELECT lager_platz.id, lager.bezeichnung lagername, lager_platz.kurzbezeichnung name from lager INNER JOIN lager_platz on lager_platz.lager = lager.id) lagerplatz";
}
$sql .= "INNER JOIN ".$lagerplatz_sql." ON lw.lager_platz = lagerplatz.id"; $sql .= "INNER JOIN ".$lagerplatz_sql." ON lw.lager_platz = lagerplatz.id";