2019-05-29 19:17:57 +02:00
< ? php
2020-09-07 15:04:06 +02:00
/*
* OpenSTAManager : il software gestionale open source per l ' assistenza tecnica e la fatturazione
* Copyright ( C ) DevCode s . n . c .
*
* 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
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < https :// www . gnu . org / licenses />.
*/
2019-05-29 19:17:57 +02:00
2019-09-11 16:50:42 +02:00
include_once __DIR__ . '/../../../core.php' ;
$impegnato = 0 ;
$ordinato = 0 ;
2020-09-07 15:04:06 +02:00
$query = ' SELECT
2019-09-11 16:50:42 +02:00
or_ordini . id AS id ,
or_ordini . numero ,
or_ordini . numero_esterno ,
data ,
SUM ( or_righe_ordini . qta ) AS qta_ordinata ,
or_righe_ordini . um
FROM or_ordini
INNER JOIN or_righe_ordini ON or_ordini . id = or_righe_ordini . idordine
WHERE idarticolo = ' . prepare ( $articolo -> id ) . "
2020-02-13 11:35:27 +01:00
AND ( SELECT dir FROM or_tipiordine WHERE or_tipiordine . id = or_ordini . idtipoordine ) = '|dir|'
2019-09-11 16:50:42 +02:00
AND ( or_righe_ordini . qta - or_righe_ordini . qta_evasa ) > 0
2020-10-06 12:25:22 +02:00
AND or_righe_ordini . confermato = 1
2019-09-11 16:50:42 +02:00
GROUP BY or_ordini . id
HAVING qta_ordinata > 0 " ;
/*
** Impegnato
*/
echo '
< div class = " row " >
< div class = " col-md-3 " >
< div class = " panel panel-primary " >
< div class = " panel-heading " >
2019-12-13 10:05:43 +01:00
< h3 class = " panel-title " > '.tr(' Impegnato ').' < span class = " tip pull-right " title = " '.tr('Quantità impegnate in ordini cliente che non siano già completamente evasi.').' " >
2019-11-23 06:48:58 +01:00
< i class = " fa fa-question-circle-o " ></ i ></ span ></ h3 >
2019-09-11 16:50:42 +02:00
</ div >
2019-11-23 06:48:58 +01:00
< div class = " panel-body " style = " min-height:98px; " > ' ;
2019-09-11 16:50:42 +02:00
2019-09-12 09:12:11 +02:00
$ordini = $dbo -> fetchArray ( str_replace ( '|dir|' , 'entrata' , $query ));
$impegnato = sum ( array_column ( $ordini , 'qta_ordinata' ));
if ( ! empty ( $ordini )) {
echo '
2019-09-11 16:50:42 +02:00
< table class = " table table-bordered table-condensed table-striped " >
< thead >
< tr >
2019-09-12 09:12:11 +02:00
< th > '.tr(' Descrizione ').' </ th >
< th > '.tr(' Qta ').' </ th >
2019-09-11 16:50:42 +02:00
</ tr >
</ thead >
2020-09-07 15:04:06 +02:00
2019-09-11 16:50:42 +02:00
< tbody > ' ;
2019-09-12 09:12:11 +02:00
$modulo = Modules :: get ( 'Ordini cliente' );
foreach ( $ordini as $documento ) {
$numero = ! empty ( $documento [ 'numero_esterno' ]) ? $documento [ 'numero_esterno' ] : $documento [ 'numero' ];
$qta = $documento [ 'qta_ordinata' ];
2019-09-11 16:50:42 +02:00
2019-09-12 09:12:11 +02:00
echo '
2019-09-11 16:50:42 +02:00
< tr >
< td >
'.Modules::link($modulo[' id '], $documento[' id '], tr(' Ordine num . _NUM_ del _DATE_ ' , [
2019-09-12 09:12:11 +02:00
'_NUM_' => $numero ,
'_DATE_' => dateFormat ( $documento [ 'data' ]),
])) . '
2019-09-11 16:50:42 +02:00
</ td >
< td class = " text-right " >
'.numberFormat($qta).' '.$documento[' um '].'
</ td >
</ tr > ' ;
2019-09-12 09:12:11 +02:00
}
2019-09-11 16:50:42 +02:00
2019-09-12 09:12:11 +02:00
echo '
2019-09-11 16:50:42 +02:00
< tr >
< td class = " text-right " >
2019-09-12 09:12:11 +02:00
< b > '.tr(' Totale ').' </ b >
2019-09-11 16:50:42 +02:00
</ td >
< td class = " text-right " >
'.numberFormat($impegnato).'
</ td >
</ tr >
2019-09-12 09:12:11 +02:00
</ table > ' ;
} else {
echo '
< p > '.tr(' Nessun ordine cliente con quantità da evadere individuato ').' .</ p > ' ;
}
echo '
2019-09-11 16:50:42 +02:00
</ div >
</ div >
</ div > ' ;
/*
** In ordine
*/
echo '
< div class = " col-md-3 " >
< div class = " panel panel-primary " >
< div class = " panel-heading " >
2019-11-23 08:23:34 +01:00
< h3 class = " panel-title " > '.tr(' In ordine ').' < span class = " tip pull-right " title = " '.tr('Quantità ordinate al fornitore in ordini che non siano già completamente evasi.').' " >
2019-11-23 06:48:58 +01:00
< i class = " fa fa-question-circle-o " ></ i ></ span ></ h3 >
2019-09-11 16:50:42 +02:00
</ div >
2019-11-23 06:48:58 +01:00
< div class = " panel-body " style = " min-height:98px; " > ' ;
2019-09-11 16:50:42 +02:00
2019-09-12 09:12:11 +02:00
$ordini = $dbo -> fetchArray ( str_replace ( '|dir|' , 'uscita' , $query ));
$ordinato = sum ( array_column ( $ordini , 'qta_ordinata' ));
if ( ! empty ( $ordini )) {
echo '
2019-09-11 16:50:42 +02:00
< table class = " table table-bordered table-condensed table-striped " >
< thead >
< tr >
2019-09-12 09:12:11 +02:00
< th > '.tr(' Descrizione ').' </ th >
< th > '.tr(' Qta ').' </ th >
2019-09-11 16:50:42 +02:00
</ tr >
</ thead >
2020-09-07 15:04:06 +02:00
2019-09-11 16:50:42 +02:00
< tbody > ' ;
2019-09-12 09:12:11 +02:00
$modulo = Modules :: get ( 'Ordini fornitore' );
foreach ( $ordini as $documento ) {
$numero = ! empty ( $documento [ 'numero_esterno' ]) ? $documento [ 'numero_esterno' ] : $documento [ 'numero' ];
$qta = $documento [ 'qta_ordinata' ];
2019-09-11 16:50:42 +02:00
2019-09-12 09:12:11 +02:00
echo '
2019-09-11 16:50:42 +02:00
< tr >
< td >
'.Modules::link($modulo[' id '], $documento[' id '], tr(' Ordine num . _NUM_ del _DATE_ ' , [
'_NUM_' => $numero ,
'_DATE_' => dateFormat ( $documento [ 'data' ]),
])) . '
</ td >
< td class = " text-right " >
'.numberFormat($qta).' '.$documento[' um '].'
</ td >
</ tr > ' ;
2019-09-12 09:12:11 +02:00
}
2019-09-11 16:50:42 +02:00
2019-09-12 09:12:11 +02:00
echo '
2019-09-11 16:50:42 +02:00
< tr >
< td class = " text-right " >
2019-09-12 09:12:11 +02:00
< b > '.tr(' Totale ').' </ b >
2019-09-11 16:50:42 +02:00
</ td >
< td class = " text-right " >
'.numberFormat($ordinato).'
</ td >
</ tr >
2019-09-12 09:12:11 +02:00
</ table > ' ;
} else {
echo '
< p > '.tr(' Nessun ordine fornitore con quantità da evadere individuato ').' .</ p > ' ;
}
echo '
2019-09-11 16:50:42 +02:00
</ div >
</ div >
</ div > ' ;
/**
** Da ordinare .
*/
$qta_presente = $articolo -> qta > 0 ? $articolo -> qta : 0 ;
$diff = ( $qta_presente - $impegnato + $ordinato ) * - 1 ;
$da_ordinare = $diff < 0 ? 0 : $diff ;
echo '
< div class = " col-md-3 " >
< div class = " panel panel-primary " >
< div class = " panel-heading " >
2019-11-23 08:23:34 +01:00
< h3 class = " panel-title " > '.tr(' Da ordinare ').' < span class = " tip pull-right " title = " '.tr('Quantità richieste dal cliente meno le quantità già ordinate.').' " >
2019-11-23 06:48:58 +01:00
< i class = " fa fa-question-circle-o " ></ i ></ span ></ h3 >
2019-09-11 16:50:42 +02:00
</ div >
< div class = " panel-body " >
< div class = " row " >
< div class = " col-md-12 text-center " style = " font-size:35pt; " >
2019-12-13 10:05:43 +01:00
'.numberFormat($da_ordinare).' '.$articolo->um.'
2019-09-11 16:50:42 +02:00
</ div >
</ div >
</ div >
</ div >
</ div > ' ;
/**
** Disponibile .
*/
2020-02-13 11:42:29 +01:00
$disponibile = $qta_presente - $impegnato ;
2019-09-11 16:50:42 +02:00
echo '
< div class = " col-md-3 " >
< div class = " panel panel-primary " >
< div class = " panel-heading " >
2019-11-23 08:23:34 +01:00
< h3 class = " panel-title " > '.tr(' Disponibile ').' < span class = " tip pull-right " title = " '.tr('Quantità disponibili nel magazzino.').' " >
2019-11-23 06:48:58 +01:00
< i class = " fa fa-question-circle-o " ></ i ></ span ></ h3 >
2019-09-11 16:50:42 +02:00
</ div >
< div class = " panel-body " >
< div class = " row " >
< div class = " col-md-12 text-center " style = " font-size:35pt; " >
2019-12-13 10:05:43 +01:00
'.numberFormat($disponibile).' '.$articolo->um.'
2019-09-11 16:50:42 +02:00
</ div >
</ div >
</ div >
</ div >
</ div >
</ div > ' ;
2020-02-04 22:49:34 +01:00
$sedi = $dbo -> fetchArray ( '(SELECT "0" AS id, CONCAT_WS (" - ", "Sede legale", citta) AS nomesede FROM an_anagrafiche WHERE idanagrafica = ' . prepare ( setting ( 'Azienda predefinita' )) . ') UNION (SELECT id, CONCAT_WS(" - ", nomesede, citta ) AS nomesede FROM an_sedi WHERE idanagrafica=' . prepare ( setting ( 'Azienda predefinita' )) . ')' );
2019-05-29 19:17:57 +02:00
2019-09-11 16:50:42 +02:00
echo '
2019-05-29 19:17:57 +02:00
< div class = " row " >
2019-09-11 16:50:42 +02:00
< div class = " col-md-12 " >
< div class = " panel panel-primary " >
< div class = " panel-heading " >
< h3 class = " panel-title " > '.tr(' Giacenze ').' </ h3 >
</ div >
< div class = " panel-body " >
< table class = " table table-striped table-condensed table-bordered " >
< thead >
< tr >
< th width = " 400 " > '.tr(' Sede ').' </ th >
< th width = " 200 " > '.tr(' Q . tà ').' </ th >
</ tr >
</ thead >
2020-09-07 15:04:06 +02:00
2019-09-11 16:50:42 +02:00
< tbody > ' ;
foreach ( $sedi as $sede ) {
// Lettura movimenti delle mie sedi
$qta_azienda = $dbo -> fetchOne ( " SELECT SUM(mg_movimenti.qta) AS qta, IF(mg_movimenti.idsede_azienda= 0,'Sede legale',(CONCAT_WS(' - ',an_sedi.nomesede,an_sedi.citta))) as sede FROM mg_movimenti LEFT JOIN an_sedi ON an_sedi.id = mg_movimenti.idsede_azienda WHERE mg_movimenti.idarticolo= " . prepare ( $id_record ) . ' AND idsede_azienda=' . prepare ( $sede [ 'id' ]) . ' GROUP BY idsede_azienda' );
// Lettura eventuali movimenti ad una propria sede (nel caso di movimenti fra sedi della mia azienda)
if ( $sede [ 'id' ] != 0 ) {
$qta_controparte = $dbo -> fetchOne ( " SELECT SUM(mg_movimenti.qta) AS qta, IF(mg_movimenti.idsede_controparte= 0,'Sede legale',(CONCAT_WS(' - ',an_sedi.nomesede,an_sedi.citta))) as sede FROM mg_movimenti LEFT JOIN an_sedi ON an_sedi.id = mg_movimenti.idsede_controparte WHERE mg_movimenti.idarticolo= " . prepare ( $id_record ) . ' AND idsede_controparte=' . prepare ( $sede [ 'id' ]) . ' GROUP BY idsede_controparte' );
} else {
$qta_controparte = $dbo -> fetchOne ( " SELECT SUM(mg_movimenti.qta) AS qta, IF(mg_movimenti.idsede_controparte= 0,'Sede legale',(CONCAT_WS(' - ',an_sedi.nomesede,an_sedi.citta))) as sede FROM ((( mg_movimenti LEFT JOIN an_sedi ON an_sedi.id = mg_movimenti.idsede_controparte ) LEFT JOIN dt_ddt ON mg_movimenti.idddt = dt_ddt.id ) LEFT JOIN co_documenti ON mg_movimenti.iddocumento = co_documenti.id ) WHERE mg_movimenti.idarticolo= " . prepare ( $id_record ) . ' AND idsede_controparte=' . prepare ( $sede [ 'id' ]) . ' AND IFNULL( dt_ddt.idanagrafica, co_documenti.idanagrafica ) = ' . prepare ( setting ( 'Azienda predefinita' )) . ' GROUP BY idsede_controparte' );
}
echo '
2019-05-29 19:17:57 +02:00
< tr >
2019-06-17 11:10:32 +02:00
< td > '.$sede[' nomesede '].' </ td >
2020-02-04 22:49:34 +01:00
< td class = " text-right " > '.Translator::numberToLocale($qta_azienda[' qta '] - $qta_controparte[' qta ']).' '.$articolo->um.' </ td >
2019-05-29 19:17:57 +02:00
</ tr > ' ;
2019-09-11 16:50:42 +02:00
}
echo '
</ tbody >
</ table >
</ div >
</ div >
2019-05-29 19:17:57 +02:00
</ div >
2019-09-11 16:50:42 +02:00
</ div > ' ;