This commit is contained in:
paoloar77
2025-02-20 10:11:42 +01:00
parent 8f661a471c
commit d4d98c9a4e
5 changed files with 50 additions and 32 deletions

View File

@@ -429,27 +429,37 @@ function isArticleInPrevendita($id, $checkqtanegativa)
function loadArticleByIdArticle($id, $checkprevendita = false, $checkqtanegativa = false)
{
{
try {
$articles = Article::join(DB::raw('(SELECT IdArticolo, MAX(DataOra) AS data FROM T_WEB_Articoli GROUP BY IdArticolo) b'), function ($join) {
$join->on('T_WEB_Articoli.IdArticolo', '=', 'b.IdArticolo')
->on('T_WEB_Articoli.DataOra', '=', 'b.data');
})
->leftJoin(DB::raw('(SELECT e.IdStatoProdotto, e.Descrizione as DescrizioneStatoProdotto FROM T_WEB_StatiProdotto e
JOIN (SELECT IdStatoProdotto, MAX(DataOra) as data1
FROM T_WEB_StatiProdotto GROUP BY IdStatoProdotto) c
ON e.IdStatoProdotto = c.IdStatoProdotto AND e.DataOra = c.data1) f'), function ($join) {
$join->on('T_WEB_Articoli.IdStatoProdotto', '=', 'f.IdStatoProdotto');
})
->leftJoin(DB::raw('(SELECT o.Codice, o.QtaDisponibile FROM T_WEB_Disponibile o
JOIN (SELECT Codice, MAX(DataOra) as data1
FROM T_WEB_Disponibile GROUP BY Codice) p
ON o.Codice = p.Codice AND o.DataOra = p.data1) q'), function ($join) {
$join->on('T_WEB_Articoli.IdArticolo', '=', 'q.Codice');
})
->where('T_WEB_Articoli.IdArticolo', $id)
->get();
if ($checkprevendita) {
$articles = Article::join(DB::raw('(SELECT IdArticolo, MAX(DataOra) AS data FROM T_WEB_Articoli GROUP BY IdArticolo) b'), function ($join) {
$join->on('T_WEB_Articoli.IdArticolo', '=', 'b.IdArticolo')
->on('T_WEB_Articoli.DataOra', '=', 'b.data');
})
->leftJoin(DB::raw('(SELECT e.IdStatoProdotto, e.Descrizione as DescrizioneStatoProdotto FROM T_WEB_StatiProdotto e
JOIN (SELECT IdStatoProdotto, MAX(DataOra) as data1
FROM T_WEB_StatiProdotto GROUP BY IdStatoProdotto) c
ON e.IdStatoProdotto = c.IdStatoProdotto AND e.DataOra = c.data1) f'), function ($join) {
$join->on('T_WEB_Articoli.IdStatoProdotto', '=', 'f.IdStatoProdotto');
})
->leftJoin(DB::raw('(SELECT o.Codice, o.QtaDisponibile FROM T_WEB_Disponibile o
JOIN (SELECT Codice, MAX(DataOra) as data1
FROM T_WEB_Disponibile GROUP BY Codice) p
ON o.Codice = p.Codice AND o.DataOra = p.data1) q'), function ($join) {
$join->on('T_WEB_Articoli.IdArticolo', '=', 'q.Codice');
})
->where('T_WEB_Articoli.IdArticolo', $id)
->get();
} else {
$articles = Article::join(DB::raw('(SELECT IdArticolo, MAX(DataOra) AS data FROM T_WEB_Articoli GROUP BY IdArticolo) b'), function ($join) {
$join->on('T_WEB_Articoli.IdArticolo', '=', 'b.IdArticolo')
->on('T_WEB_Articoli.DataOra', '=', 'b.data');
})
->where('T_WEB_Articoli.IdArticolo', $id)
->get();
}
if ($checkprevendita) {
foreach ($articles as $article) {
@@ -2514,20 +2524,24 @@ function getClienti()
function getvalstr($mystr, $value, $separato = false)
{
$my = '';
if ($mystr) {
$my = " " . $mystr . ": " . $value;
} else {
if ($value) {
$my = $value;
if (!$separato) {
$my = " " . $value;
try {
$my = '';
if ($mystr) {
$my = " " . $mystr . ": " . $value;
} else {
if ($value) {
$my = $value;
if (!$separato) {
$my = " " . $value;
}
}
}
}
if ($separato) {
$my = '[' . $my . '] ';
if ($separato) {
$my = '[' . $my . '] ';
}
} catch (Exception $e) {
echo "Errore: " . $e->getMessage();
}
return $my;