2017-08-04 16:28:16 +02:00
< ? php
include_once __DIR__ . '/../../../core.php' ;
// Gestione dei lotti degli articoli
echo '
< div class = " panel panel-primary " >
< div class = " panel-heading " >
2017-09-04 12:02:29 +02:00
< h3 class = " panel-title " > '.tr(' Produzione ').' </ h3 >
2017-08-04 16:28:16 +02:00
</ div >
< div class = " panel-body " > ' ;
2018-06-23 15:41:32 +02:00
$search_lotto = get ( 'search_lotto' );
$search_serial = get ( 'search_serial' );
$search_altro = get ( 'search_altro' );
2017-08-04 16:28:16 +02:00
// Calcolo prossimo lotto e serial number
2018-07-04 15:38:10 +02:00
$rs = $dbo -> fetchArray ( 'SELECT serial FROM mg_prodotti WHERE id_articolo=' . prepare ( $id_record ) . ' ORDER BY id DESC LIMIT 0,1' );
$max_serial = $rs [ 0 ][ 'serial' ];
2017-08-04 16:28:16 +02:00
$next_serial = get_next_code ( $max_serial );
echo '
< form action = " " method = " post " role = " form " >
< input type = " hidden " name = " backto " value = " record-edit " >
2017-09-12 16:17:11 +02:00
< input type = " hidden " name = " op " value = " addprodotto " > ' ;
2017-08-04 16:28:16 +02:00
// Campi di inserimento lotti
echo '
< div class = " row form-group " >
< div class = " col-md-12 " >
2017-09-04 12:02:29 +02:00
< h4 > '.tr(' Inserimento nuovi prodotti ').' </ h4 >
2017-08-04 16:28:16 +02:00
</ div >
</ div > ' ;
// Serial
echo '
< div class = " row form-group " >
2017-09-04 12:02:29 +02:00
< label class = " col-md-2 control-label " for = " serial_start " > '.tr(' Serial number da ').' :</ label >
2018-07-04 15:38:10 +02:00
2017-08-04 16:28:16 +02:00
< div class = " col-md-2 " >
< input type = " text " class = " form-control input-md " name = " serial_start " onkeyup = " $ ( \ 'input[name=serial_end] \ ').val( $ ( \ 'input[name=serial_start] \ ').val() ); $ ( \ '#warn_serial \ ').hide(); ricalcola_totale_prodotti(); " value = " '. $next_serial .' " />
</ div >
2018-07-04 15:38:10 +02:00
< label class = " col-md-1 control-label text-center " for = " serial_end " >
< i class = " fa fa-arrow-circle-right fa-2x " ></ i >
</ label >
2017-08-04 16:28:16 +02:00
< div class = " col-md-2 " >
< input type = " text " class = " form-control input-md " name = " serial_end " onkeyup = " check_progressivo( $ ( \ 'input[name=serial_start] \ '), $ ( \ 'input[name=serial_end] \ '), $ ( \ '#warn_serial \ '), $ ( \ '#inserisci \ ') ); " value = " '. $next_serial .' " />
</ div > ' ;
if ( ! empty ( $max_serial )) {
echo '
2018-07-04 15:38:10 +02:00
< div class = " col-md-5 " >
2017-09-04 12:02:29 +02:00
< p id = " warn_serial " class = " text-danger " >< b > '.tr(' Ultimo serial number inserito ').' : </ b > '.$max_serial.' </ p >
2017-08-04 16:28:16 +02:00
</ div > ' ;
}
echo '
</ div > ' ;
// Totale prodotti da inserire
echo '
< div class = " row " >
< div class = " col-md-12 " >
2018-07-04 15:38:10 +02:00
< p class = " text-danger " > '.tr(' Totale prodotti da inserire ').' : < span id = " totale_prodotti " > 0 </ span ></ p >
< button type = " submit " id = " inserisci " class = " btn btn-success pull-right " onclick = " if( confirm( \ 'Confermi l \\ \ 'inserimento di \ ' + globalsp.n_prodotti + \ ' prodotti? \ ') ) { $ ( \ '#insert_form \ ').submit(); } " >< i class = " fa fa-check " ></ i > '.tr(' Salva modifiche ').' </ button >
< div class = " clearfix " ></ div >
< div class = " alert alert-info " > ' ;
2017-08-04 16:28:16 +02:00
// Visualizzo, in base alle impostazioni scelte, se il magazzino verrà movimentato
2018-07-08 18:11:17 +02:00
if ( setting ( " Movimenta il magazzino durante l'inserimento o eliminazione dei lotti/serial number " )) {
2017-08-04 16:28:16 +02:00
echo '
2019-07-01 16:36:35 +02:00
'.tr("L' inserimento incrementerà la quantità dell ' articolo ! " );
2017-08-04 16:28:16 +02:00
} else {
echo '
2019-07-01 16:36:35 +02:00
'.tr("L' inserimento non movimenterà la quantità dell ' articolo ! " );
2017-08-04 16:28:16 +02:00
}
echo '
2018-07-04 15:38:10 +02:00
</ div >
2017-08-04 16:28:16 +02:00
</ div >
</ div >
</ form >
</ div >
</ div > ' ;
// Ricerca
echo '
< div class = " box " >
< div class = " box-header with-border " >
2017-09-04 12:02:29 +02:00
< h3 class = " box-title " > '.tr(' Ricerca prodotti ').' </ h3 >
2017-08-04 16:28:16 +02:00
</ div >
< div class = " box-body " >
< div class = " text-right " >
< small style = " color:#f00; " > ' ;
2017-09-05 17:31:58 +02:00
2017-08-04 16:28:16 +02:00
// Visualizzo, in base alle impostazioni scelte, se il magazzino verrà movimentato
2018-07-08 18:11:17 +02:00
if ( setting ( " Movimenta il magazzino durante l'inserimento o eliminazione dei lotti/serial number " )) {
2017-09-04 12:02:29 +02:00
echo tr ( " La cancellazione decrementerà la quantità dell'articolo! " );
2017-08-04 16:28:16 +02:00
} else {
2017-09-04 12:02:29 +02:00
echo tr ( " L'inserimento decrementerà la quantità dell'articolo! " );
2017-08-04 16:28:16 +02:00
}
2017-09-05 17:31:58 +02:00
2017-08-04 16:28:16 +02:00
echo '
</ small >
</ div > ' ;
// Conteggio totale prodotti
2017-09-05 17:31:58 +02:00
$rs = $dbo -> fetchArray ( 'SELECT COUNT(id) AS tot FROM mg_prodotti WHERE id_articolo=' . prepare ( $id_record ));
2017-08-04 16:28:16 +02:00
$tot_prodotti = $rs [ 0 ][ 'tot' ];
// Visualizzazione di tutti i prodotti
2017-09-12 12:31:33 +02:00
$query = 'SELECT id, serial, created_at FROM mg_prodotti WHERE serial IS NOT NULL AND id_articolo=' . prepare ( $id_record ) . ( ! empty ( $search_serial ) ? ' AND serial LIKE ' . prepare ( '%' . $search_serial . '%' ) : '' ) . ' GROUP BY serial ORDER BY created_at DESC, serial DESC, lotto DESC, altro DESC' ;
2017-08-04 16:28:16 +02:00
$rs2 = $dbo -> fetchArray ( $query );
2017-09-05 17:31:58 +02:00
echo '
2017-08-04 16:28:16 +02:00
< table class = " table table-striped table-hover table-condensed table-bordered text-center datatables " >
< thead >
< tr >
2017-09-04 12:02:29 +02:00
< th id = " th_Serial " > '.tr(' Serial ').' </ th >
< th id = " th_Data di creazione " > '.tr(' Data di creazione ').' </ th >
< th id = " th_Documento di vendita " > '.tr(' Documento di vendita ').' </ th >
< th id = " th_Totale " > '.tr(' Totale ').' </ th >
2017-09-05 17:31:58 +02:00
< th class = " text-center " > #</th>
2017-08-04 16:28:16 +02:00
</ tr >
</ thead >
< tbody > ' ;
2017-09-05 17:31:58 +02:00
for ( $i = 0 ; $i < count ( $rs2 ); ++ $i ) {
echo '
< tr >
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
< td > '.$rs2[$i][' serial '].' </ td > ' ;
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
echo '
< td > '.Translator::timestampToLocale($rs2[$i][' created_at ']).' </ td > ' ;
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
// Ricerca vendite
$vendite = $dbo -> fetchArray ( 'SELECT * FROM mg_prodotti WHERE dir=\'entrata\' AND id_articolo=' . prepare ( $id_record ) . ' AND serial=' . prepare ( $rs2 [ $i ][ 'serial' ]));
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
if ( ! empty ( $vendite )) {
echo '
< td > ' ;
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
$totali = [];
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
foreach ( $vendite as $vendita ) {
2017-08-04 16:28:16 +02:00
// Venduto su fatture
2017-09-05 17:31:58 +02:00
if ( ! empty ( $vendita [ 'id_riga_documento' ])) {
2017-09-22 15:19:59 +02:00
$module_id = Modules :: get ( 'Fatture di vendita' )[ 'id' ];
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
// Ricerca vendite su fatture
$query = 'SELECT *, ( SELECT descrizione FROM co_tipidocumento WHERE id=(SELECT idtipodocumento FROM co_documenti WHERE id=iddocumento) ) AS tipo_documento, ( SELECT `dir` FROM co_tipidocumento WHERE id=(SELECT idtipodocumento FROM co_documenti WHERE id=iddocumento) ) AS `dir`, ( SELECT numero FROM co_documenti WHERE id=iddocumento ) AS numero, ( SELECT numero_esterno FROM co_documenti WHERE id=iddocumento ) AS numero_esterno, ( SELECT data FROM co_documenti WHERE id=iddocumento ) AS data FROM co_righe_documenti WHERE co_righe_documenti.id=' . prepare ( $vendita [ 'id_riga_documento' ]);
$data = $dbo -> fetchArray ( $query );
$id = $data [ 0 ][ 'iddocumento' ];
2017-08-04 16:28:16 +02:00
}
// Venduto su ddt
2017-09-05 17:31:58 +02:00
elseif ( ! empty ( $vendita [ 'id_riga_ddt' ])) {
2017-08-04 16:28:16 +02:00
$numero = ( $rs3 [ 0 ][ 'numero_esterno' ] != '' ) ? $rs3 [ 0 ][ 'numero_esterno' ] : $rs3 [ 0 ][ 'numero' ];
2017-09-22 15:19:59 +02:00
$module_id = Modules :: get ( 'Ddt di vendita' )[ 'id' ];
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
$query = 'SELECT *, ( SELECT descrizione FROM dt_tipiddt WHERE id=(SELECT idtipoddt FROM dt_ddt WHERE id=idddt) ) AS tipo_documento, ( SELECT `dir` FROM dt_tipiddt WHERE id=(SELECT idtipoddt FROM dt_ddt WHERE id=idddt) ) AS `dir`, ( SELECT numero FROM dt_ddt WHERE id=idddt ) AS numero, ( SELECT numero_esterno FROM dt_ddt WHERE id=idddt ) AS numero_esterno, ( SELECT data FROM dt_ddt WHERE id=idddt ) AS data FROM dt_righe_ddt WHERE dt_righe_ddt.id=' . prepare ( $vendita [ 'id_riga_ddt' ]);
$data = $dbo -> fetchArray ( $query );
$id = $data [ 0 ][ 'idddt' ];
2017-08-04 16:28:16 +02:00
}
// Inserito su ordini
2017-09-05 17:31:58 +02:00
elseif ( ! empty ( $vendita [ 'id_riga_ordine' ])) {
2017-09-22 15:19:59 +02:00
$module_id = Modules :: get ( 'Ordini cliente' )[ 'id' ];
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
// Ricerca inserimenti su ordini
$query = 'SELECT *, ( SELECT descrizione FROM or_tipiordine WHERE id=(SELECT idtipoordine FROM or_ordini WHERE id=idordine) ) AS tipo_documento, ( SELECT `dir` FROM or_tipiordine WHERE id=(SELECT idtipoordine FROM or_ordini WHERE id=idordine) ) AS `dir`, ( SELECT numero FROM or_ordini WHERE id=idordine ) AS numero, ( SELECT numero_esterno FROM or_ordini WHERE id=idordine ) AS numero_esterno, ( SELECT data FROM or_ordini WHERE id=idordine ) AS data FROM or_righe_ordini WHERE or_righe_ordini.id=' . prepare ( $vendita [ 'id_riga_ordine' ]);
$data = $dbo -> fetchArray ( $query );
$id = $data [ 0 ][ 'idordine' ];
2017-08-04 16:28:16 +02:00
}
// Inserito su intervento
2017-09-05 17:31:58 +02:00
elseif ( ! empty ( $vendita [ 'id_riga_intervento' ])) {
2017-09-22 15:19:59 +02:00
$module_id = Modules :: get ( 'Interventi' )[ 'id' ];
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
// Ricerca inserimenti su interventi
$query = 'SELECT mg_articoli_interventi.*, in_interventi.codice, ( SELECT orario_inizio FROM in_interventi_tecnici WHERE idintervento=mg_articoli_interventi.idintervento LIMIT 0,1 ) AS data FROM mg_articoli_interventi JOIN in_interventi ON in_interventi.id = mg_articoli_interventi.idintervento WHERE mg_articoli_interventi.id=' . prepare ( $vendita [ 'id_riga_intervento' ]);
$data = $dbo -> fetchArray ( $query );
$id = $data [ 0 ][ 'idintervento' ];
$data [ 0 ][ 'tipo_documento' ] = tr ( 'Intervento' ) . ' ' . $data [ 0 ][ 'codice' ];
$data [ 0 ][ 'subtotale' ] = $data [ 0 ][ 'prezzo_vendita' ] * $data [ 0 ][ 'qta' ];
$data [ 0 ][ 'iva' ] = 0 ;
2017-08-04 16:28:16 +02:00
2017-09-10 14:35:41 +02:00
$extra = tr ( '(q.tà _QTA_)' , [
'_QTA_' => $data [ 0 ][ 'qta' ],
]);
2017-08-04 16:28:16 +02:00
}
2017-09-05 17:31:58 +02:00
$totali [] = [ $data [ 0 ][ 'subtotale' ], $data [ 0 ][ 'iva' ]];
2017-09-14 10:27:49 +02:00
$numero = ! empty ( $data [ 0 ][ 'numero_esterno' ]) ? $data [ 0 ][ 'numero_esterno' ] : $data [ 0 ][ 'numero' ];
2017-09-05 17:31:58 +02:00
2017-09-14 10:27:49 +02:00
$text = tr ( '_DOC_ num. _NUM_ del _DATE_' , [
2017-09-10 14:35:41 +02:00
'_DOC_' => $data [ 0 ][ 'tipo_documento' ],
'_NUM_' => $numero ,
'_DATE_' => Translator :: dateToLocale ( $data [ 0 ][ 'data' ]),
2017-09-14 10:27:49 +02:00
]) . ( ! empty ( $extra ) ? ' ' . $extra : '' );
2017-08-04 16:28:16 +02:00
echo '
2017-09-05 17:31:58 +02:00
'.Modules::link($module_id, $id, $text).' < br > ' ;
}
echo '
</ td >
< td class = " text-center " > ' ;
foreach ( $totali as $value ) {
$subtotale = $value [ 0 ];
$iva = $value [ 1 ];
2017-08-04 16:28:16 +02:00
2017-09-05 17:31:58 +02:00
echo '
2019-04-12 17:56:39 -07:00
< span > '.moneyFormat($subtotale + $iva).' </ span > ' ;
2017-08-04 16:28:16 +02:00
if ( ! empty ( $subtotale ) && ! empty ( $iva )) {
echo '
2017-09-05 17:31:58 +02:00
< small style = " color:#555; " > ( '.Translator::numberToLocale($subtotale).' + '.Translator::numberToLocale($iva).' ) </ small > ' ;
2017-08-04 16:28:16 +02:00
}
echo '
2017-09-05 17:31:58 +02:00
< br > ' ;
2017-08-04 16:28:16 +02:00
}
2017-09-05 17:31:58 +02:00
echo '
</ td >
< td ></ td > ' ;
}
// Non venduto
else {
// Documento di vendita
echo '
< td ></ td > ' ;
// Totale
echo '
< td ></ td > ' ;
2017-08-04 16:28:16 +02:00
echo '
2017-09-05 17:31:58 +02:00
< td class = " text-center " >
< a class = " btn btn-danger btn-sm ask " data - backto = " record-edit " data - op = " delprodotto " data - idprodotto = " '. $rs2[$i] ['id'].' " >
< i class = " fa fa-trash " ></ i >
</ a >
</ td > ' ;
2017-08-04 16:28:16 +02:00
}
echo '
2017-09-05 17:31:58 +02:00
</ tr > ' ;
}
echo '
2017-08-04 16:28:16 +02:00
</ tbody >
</ table >
</ div >
</ div > ' ;
?>
< script type = " text/javascript " >
globalsp = { n_prodotti : 0 };
$ ( document ) . ready ( function (){
setInterval ( " ricalcola_totale_prodotti() " , 1000 );
});
/*
Queste funzioni servono a verificare se i codici di lotti , serial number e " altro " sono progressivi
*/
function check_progressivo ( start , end , warn , submit_btn ){
digits_start = get_last_numeric_part ( start . val () . toString () );
digits_end = get_last_numeric_part ( end . val () . toString () );
// Nessun codice numerico trovato
if ( digits_start == " " || digits_end == " " ){
warn . show ();
submit_btn . hide ();
}
else {
warn . hide ();
submit_btn . show ();
}
ricalcola_totale_prodotti ();
}
function ricalcola_totale_prodotti (){
if ( $ ( " input[name=serial_start] " ) . val () != undefined ){
var lotti , altro , serial ;
/*
lotto_start = get_last_numeric_part ( $ ( " input[name=lotto_start] " ) . val () . toString () );
lotto_end = get_last_numeric_part ( $ ( " input[name=lotto_end] " ) . val () . toString () );
lotti = Math . abs ( parseInt ( lotto_end , 10 ) - parseInt ( lotto_start , 10 ) ) + 1 ;
altro_start = get_last_numeric_part ( $ ( " input[name=altro_start] " ) . val () . toString () );
altro_end = get_last_numeric_part ( $ ( " input[name=altro_end] " ) . val () . toString () );
altro = Math . abs ( parseInt ( altro_end , 10 ) - parseInt ( altro_start , 10 ) ) + 1 ;
*/
serial_start = get_last_numeric_part ( $ ( " input[name=serial_start] " ) . val () . toString () );
serial_end = get_last_numeric_part ( $ ( " input[name=serial_end] " ) . val () . toString () );
serial = Math . abs ( parseInt ( serial_end , 10 ) - parseInt ( serial_start , 10 ) ) + 1 ;
// Se tutti i campi sono vuoti, il numero di prodotti è zero!
if ( isNaN ( serial ) /*&& isNaN(lotti) && isNaN(altro)*/ ){
globalsp . n_prodotti = 0 ;
}
else {
if ( isNaN ( lotti ) )
lotti = 1 ;
if ( isNaN ( serial ) )
serial = 1 ;
if ( isNaN ( altro ) )
altro = 1 ;
globalsp . n_prodotti = serial /* * lotti * altro */ ;
}
$ ( " #totale_prodotti " ) . text ( globalsp . n_prodotti );
if ( globalsp . n_prodotti == 0 )
$ ( " #inserisci " ) . hide ();
else
$ ( " #inserisci " ) . show ();
}
}
/*
Questa funzione restituisce la parte numerica di una stringa
*/
function get_last_numeric_part ( str ){
var matches = str . match ( / ( .* ? )([ \d ] * $ ) / );
return matches [ 2 ];
}
</ script >