2017-08-04 16:28:16 +02:00
< ? php
include_once __DIR__ . '/../../core.php' ;
2019-07-25 12:54:28 +02:00
use Modules\Fatture\Fattura ;
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
$module = Modules :: get ( 'Prima nota' );
2019-04-11 16:04:08 +02:00
2019-07-25 12:54:28 +02:00
$variables = Modules :: get ( 'Fatture di vendita' ) -> getPlaceholders ( $id_documento );
$righe = [];
// Registrazione da remoto
$id_records = get ( 'id_records' );
if ( ! empty ( $id_records )) {
$id_records = str_replace ( ';' , ',' , $id_records );
if ( get ( 'origine' ) == 'fatture' ) {
$id_documenti = $id_records ;
} else {
$id_scadenze = $id_records ;
2019-04-11 16:04:08 +02:00
}
2019-07-25 12:54:28 +02:00
}
2019-04-11 16:04:08 +02:00
2019-07-25 15:06:07 +02:00
// ID predefiniti
$dir = get ( 'dir' );
$singola_scadenza = get ( 'single' ) != null ;
2019-07-25 12:54:28 +02:00
$id_documenti = $id_documenti ? : get ( 'id_documenti' );
$id_documenti = $id_documenti ? explode ( ',' , $id_documenti ) : [];
2019-07-25 15:06:07 +02:00
$id_scadenze = $id_scadenze ? : get ( 'id_scadenze' );
$id_scadenze = $id_scadenze ? explode ( ',' , $id_scadenze ) : [];
// Scadenze
foreach ( $id_scadenze as $id_scadenza ) {
$scadenza = $dbo -> fetchOne ( 'SELECT descrizione, scadenza, iddocumento, SUM(da_pagare - pagato) AS rata FROM co_scadenziario WHERE id=' . prepare ( $id_scadenza ));
2019-07-25 15:48:28 +02:00
if ( ! empty ( $scadenza [ 'iddocumento' ])) {
2019-07-25 15:06:07 +02:00
$id_documenti [] = $scadenza [ 'iddocumento' ];
continue ;
}
$descrizione_conto = ( $dir == 'entrata' ) ? 'Riepilogativo clienti' : 'Riepilogativo fornitori' ;
$conto = $dbo -> fetchOne ( 'SELECT id FROM co_pianodeiconti3 WHERE descrizione = ' . prepare ( $descrizione_conto ));
$id_conto_controparte = $conto [ 'id' ];
$righe_documento = [];
$righe_documento [] = [
'id_scadenza' => $scadenza [ 'id' ],
'conto' => null ,
'dare' => ( $dir == 'entrata' ) ? 0 : $scadenza [ 'rata' ],
'avere' => ( $dir == 'entrata' ) ? $scadenza [ 'rata' ] : 0 ,
];
$righe_documento [] = [
'id_scadenza' => $scadenza [ 'id' ],
'conto' => $id_conto_controparte ,
'dare' => ( $dir == 'entrata' ) ? $scadenza [ 'rata' ] : 0 ,
'avere' => ( $dir == 'entrata' ) ? 0 : $scadenza [ 'rata' ],
];
$righe = array_merge ( $righe , $righe_documento );
}
// Fatture
2019-07-25 12:54:28 +02:00
$numeri = [];
2019-07-25 15:06:07 +02:00
$counter = 0 ;
2019-07-25 12:54:28 +02:00
foreach ( $id_documenti as $id_documento ) {
$fattura = Fattura :: find ( $id_documento );
2019-07-25 15:06:07 +02:00
$tipo = $fattura -> stato ;
2019-07-25 12:54:28 +02:00
$dir = $fattura -> direzione ;
2019-02-14 01:40:54 +01:00
2019-07-25 15:06:07 +02:00
// Inclusione delle sole fatture in stato Emessa, Parzialmente pagato o Pagato
if ( ! in_array ( $fattura -> stato -> descrizione , [ 'Emessa' , 'Parzialmente pagato' , 'Pagato' ])) {
++ $counter ;
continue ;
}
2019-07-25 12:54:28 +02:00
$numeri [] = ! empty ( $fattura [ 'numero_esterno' ]) ? $fattura [ 'numero_esterno' ] : $fattura [ 'numero' ];
2019-04-11 16:04:08 +02:00
2019-07-25 12:54:28 +02:00
$nota_credito = $tipo -> descrizione == 'Nota di credito' ;
2019-07-25 15:06:07 +02:00
$is_insoluto = ( ! empty ( $fattura [ 'riba' ]) && $dir == 'entrata' );
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
// Predisposizione prima riga
$conto_field = 'idconto_' . ( $dir == 'entrata' ? 'vendite' : 'acquisti' );
$id_conto_aziendale = $fattura -> pagamento [ $conto_field ] ? : setting ( 'Conto aziendale predefinito' );
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
// Predisposizione conto crediti clienti
$conto_field = 'idconto_' . ( $dir == 'entrata' ? 'cliente' : 'fornitore' );
$id_conto_controparte = $fattura -> anagrafica [ $conto_field ];
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
// Lettura delle scadenza della fattura
$scadenze = $dbo -> fetchArray ( 'SELECT id, ABS(da_pagare - pagato) AS rata FROM co_scadenziario WHERE iddocumento=' . prepare ( $id_documento ) . ' AND ABS(da_pagare) > ABS(pagato) ORDER BY YEAR(scadenza) ASC, MONTH(scadenza) ASC' );
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
// Selezione prima scadenza
if ( $singola_scadenza && ! empty ( $scadenze )) {
$scadenze = [ $scadenze [ 0 ]];
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
$righe_documento = [];
// Riga aziendale
$totale = sum ( array_column ( $scadenze , 'rata' ));
if ( $totale != 0 ) {
$righe_documento [] = [
2019-07-25 15:06:07 +02:00
'id_scadenza' => $scadenze [ 0 ][ 'id' ],
2019-07-25 12:54:28 +02:00
'insoluto' => $is_insoluto ,
'conto' => $id_conto_aziendale ,
'dare' => ( $dir == 'entrata' ) ? 0 : $totale ,
'avere' => ( $dir == 'entrata' ) ? $totale : 0 ,
];
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
// Riga controparte
foreach ( $scadenze as $scadenza ) {
$righe_documento [] = [
'id_scadenza' => $scadenza [ 'id' ],
'insoluto' => $is_insoluto ,
'conto' => $id_conto_controparte ,
'dare' => ( $dir == 'entrata' ) ? $scadenza [ 'rata' ] : 0 ,
'avere' => ( $dir == 'entrata' ) ? 0 : $scadenza [ 'rata' ],
];
}
// Se è una nota di credito, inverto i valori
if ( $nota_credito || $is_insoluto ) {
foreach ( $righe_documento as $key => $value ) {
$tmp = $value [ 'avere' ];
$righe_documento [ $key ][ 'avere' ] = $righe_documento [ $key ][ 'dare' ];
$righe_documento [ $key ][ 'dare' ] = $tmp ;
2017-08-04 16:28:16 +02:00
}
2019-07-25 12:54:28 +02:00
}
$righe = array_merge ( $righe , $righe_documento );
}
// Descrizione
$numero_scadenze = count ( $id_scadenze );
$numero_documenti = count ( $id_documenti );
if ( $numero_documenti + $numero_scadenze > 1 ) {
$descrizione = 'Pag. fatture num. ' . implode ( ', ' , $numeri );
} elseif ( $numero_documenti == 1 ) {
$numero_fattura = ! empty ( $fattura [ 'numero_esterno' ]) ? $fattura [ 'numero_esterno' ] : $fattura [ 'numero' ];
2019-04-19 17:42:16 +02:00
2019-07-25 12:54:28 +02:00
$tipo_fattura = $fattura -> isNota () ? $tipo -> descrizione : tr ( 'Fattura' );
2019-07-04 09:20:02 +02:00
2019-07-25 12:54:28 +02:00
if ( ! empty ( $is_insoluto )) {
$operation = tr ( 'Registrazione insoluto' );
} else {
$operation = tr ( 'Pag.' );
2017-08-04 16:28:16 +02:00
}
2018-05-11 14:48:46 +02:00
2019-07-25 12:54:28 +02:00
$descrizione = tr ( '_OP_ _DOC_ num. _NUM_ del _DATE_ (_NAME_)' , [
'_OP_' => $operation ,
'_DOC_' => strtolower ( $tipo_fattura ),
'_NUM_' => $numero_fattura ,
'_DATE_' => Translator :: dateToLocale ( $fattura [ 'data' ]),
'_NAME_' => $fattura -> anagrafica [ 'ragione_sociale' ],
]);
} elseif ( $numero_scadenze == 1 ) {
$descrizione = tr ( 'Pag. _OP_ del _DATE_' , [
'_OP_' => $scadenza [ 'descrizione' ],
'_DATE_' => Translator :: dateToLocale ( $scadenza [ 'scadenza' ]),
]);
}
2019-07-25 15:06:07 +02:00
if ( ! empty ( $id_records ) && get ( 'origine' ) == 'fatture' && ! empty ( $counter )) {
$descrizione_stati = [];
$stati = $database -> fetchArray ( " SELECT * FROM `co_statidocumento` WHERE descrizione IN ('Emessa', 'Parzialmente pagato', 'Pagato') ORDER BY descrizione " );
foreach ( $stati as $stato ) {
$descrizione_stati [] = '<i class="' . $stato [ 'icona' ] . '"></i> <small>' . $stato [ 'descrizione' ] . '</small>' ;
}
echo '
< div class = " alert alert-info " >
< p > '.tr(' Solo le fatture in stato _STATE_ possono essere registrate contabilmente ignorate ' , [
'_STATE_' => implode ( ', ' , $descrizione_stati ),
]) . ' .</ p >
< p >< b > '.tr(' Sono state ignorate _NUM_ fatture ' , [
'_NUM_' => $counter ,
]) . ' .</ b ></ p >
</ div > ' ;
}
2019-07-25 12:54:28 +02:00
echo '
< form action = " '.ROOTDIR.'/controller.php?id_module='. $module->id .' " method = " post " id = " add-form " >
< input type = " hidden " name = " op " value = " add " >
< input type = " hidden " name = " backto " value = " record-edit " >
< input type = " hidden " name = " crea_modello " id = " crea_modello " value = " 0 " >
< input type = " hidden " name = " idmastrino " id = " idmastrino " value = " 0 " > ' ;
echo '
2018-05-04 17:57:46 +02:00
< div class = " row " >
< div class = " col-md-12 " >
2019-07-25 12:54:28 +02:00
{[ " type " : " select " , " label " : " '.tr('Modello primanota').' " , " id " : " modello_primanota " , " values " : " query=SELECT idmastrino AS id, nome AS descrizione, descrizione as causale FROM co_movimenti_modelli GROUP BY idmastrino " ]}
2018-05-04 17:57:46 +02:00
</ div >
</ div >
2017-08-04 16:28:16 +02:00
< div class = " row " >
< div class = " col-md-4 " >
2019-07-25 12:54:28 +02:00
{[ " type " : " date " , " label " : " '.tr('Data movimento').' " , " name " : " data " , " required " : 1 , " value " : " -now- " ]}
2017-08-04 16:28:16 +02:00
</ div >
< div class = " col-md-8 " >
2019-07-25 12:54:28 +02:00
{[ " type " : " text " , " label " : " '.tr('Causale').' " , " name " : " descrizione " , " id " : " desc " , " required " : 1 , " value " : '.json_encode($descrizione).' ]}
2017-08-04 16:28:16 +02:00
</ div >
2019-07-25 12:54:28 +02:00
</ div > ' ;
2017-08-04 16:28:16 +02:00
echo '
< table class = " table table-striped table-condensed table-hover table-bordered "
< tr >
2017-09-04 12:02:29 +02:00
< th > '.tr(' Conto ').' </ th >
< th width = " 20% " > '.tr(' Dare ').' </ th >
< th width = " 20% " > '.tr(' Avere ').' </ th >
2017-08-04 16:28:16 +02:00
</ tr > ' ;
2019-07-25 12:54:28 +02:00
$max = max ( count ( $righe ), 10 );
for ( $i = 0 ; $i < $max ; ++ $i ) {
$required = ( $i <= 1 );
$riga = $righe [ $i ];
2018-05-11 14:48:46 +02:00
// Conto
2017-08-04 16:28:16 +02:00
echo '
< tr >
2019-07-25 12:54:28 +02:00
< input type = " hidden " name = " id_scadenza[] " value = " '. $riga['id_scadenza'] .' " >
< input type = " hidden " name = " insoluto[] " value = " '. $riga['insoluto'] .' " >
2017-08-04 16:28:16 +02:00
< td >
2019-07-25 12:54:28 +02:00
{[ " type " : " select " , " name " : " idconto[] " , " id " : " conto'. $i .' " , " value " : " '.( $riga['conto'] ?: '').' " , " ajax-source " : " conti " , " required " : " '. $required .' " ]}
2017-08-04 16:28:16 +02:00
</ td > ' ;
// Dare
echo '
< td >
2019-07-25 12:54:28 +02:00
{[ " type " : " number " , " name " : " dare[] " , " id " : " dare'. $i .' " , " value " : " '.( $riga['dare'] ?: 0).' " ]}
2017-08-04 16:28:16 +02:00
</ td > ' ;
// Avere
echo '
< td >
2019-07-25 12:54:28 +02:00
{[ " type " : " number " , " name " : " avere[] " , " id " : " avere'. $i .' " , " value " : " '.( $riga['avere'] ?: 0).' " ]}
2017-08-04 16:28:16 +02:00
</ td >
</ tr > ' ;
}
// Totale per controllare sbilancio
echo '
< tr >
2017-09-04 12:02:29 +02:00
< td align = " right " >< b > '.tr(' Totale ').' :</ b ></ td > ' ;
2017-08-04 16:28:16 +02:00
// Totale dare
echo '
< td align = " right " >
2019-04-12 15:09:48 -07:00
< span >< span id = " totale_dare " ></ span > '.currency().' </ span >
2017-08-04 16:28:16 +02:00
</ td > ' ;
// Totale avere
echo '
< td align = " right " >
2019-04-12 15:09:48 -07:00
< span >< span id = " totale_avere " ></ span > '.currency().' </ span >
2017-08-04 16:28:16 +02:00
</ td >
</ tr > ' ;
// Verifica sbilancio
echo '
< tr >
< td align = " right " ></ td >
< td colspan = " 2 " align = " center " >
< span id = " testo_aggiuntivo " ></ span >
</ td >
</ tr >
</ table > ' ;
2019-07-25 12:54:28 +02:00
echo '
2017-08-04 16:28:16 +02:00
<!-- PULSANTI -->
< div class = " row " >
< div class = " col-md-12 text-right " >
2019-07-25 12:54:28 +02:00
< button type = " button " class = " btn btn-default " id = " btn_crea_modello " >
< i class = " fa fa-plus " ></ i > '.tr(' Aggiungi e crea modello ').'
</ button >
< button type = " submit " class = " btn btn-primary " id = " add-submit " >
< i class = " fa fa-plus " ></ i > '.tr(' Aggiungi ').'
</ button >
2017-08-04 16:28:16 +02:00
</ div >
</ div >
2019-07-25 12:54:28 +02:00
</ form > ' ;
?>
< script type = " text/javascript " >
var variables = < ? php echo json_encode ( $variables ); ?> ;
var formatted_zero = " <?php echo Translator::numberToLocale(0); ?> " ;
var nuovo_modello = " <?php echo tr('Aggiungi e crea modello'); ?> " ;
var modifica_modello = " <?php echo tr('Aggiungi e modifica modello'); ?> " ;
var sbilancio = " <?php echo tr('sbilancio di _NUM_', [
'_NUM_' => '|value| ' . currency (),
]); ?> ";
$ ( " #bs-popup #add-form " ) . submit ( function () {
return calcolaBilancio ();
});
// Ad ogni modifica dell'importo verifica che siano stati selezionati: il conto, la causale, la data. Inoltre aggiorna lo sbilancio
function calcolaBilancio () {
bilancio = 0.00 ;
totale_dare = 0.00 ;
totale_avere = 0.00 ;
// Calcolo il totale dare e totale avere
$ ( '#bs-popup input[id*=dare]' ) . each ( function () {
valore = $ ( this ) . val () ? $ ( this ) . val () . toEnglish () : 0 ;
totale_dare += Math . round ( valore * 100 ) / 100 ;
});
$ ( '#bs-popup input[id*=avere]' ) . each ( function () {
valore = $ ( this ) . val () ? $ ( this ) . val () . toEnglish () : 0 ;
totale_avere += Math . round ( valore * 100 ) / 100 ;
});
$ ( '#bs-popup #totale_dare' ) . text ( totale_dare . toLocale ());
$ ( '#bs-popup #totale_avere' ) . text ( totale_avere . toLocale ());
bilancio = Math . round ( totale_dare * 100 ) / 100 - Math . round ( totale_avere * 100 ) / 100 ;
if ( bilancio == 0 ) {
$ ( '#bs-popup #testo_aggiuntivo' ) . removeClass ( 'text-danger' ) . html ( " " );
$ ( '#bs-popup #add-submit' ) . removeClass ( 'hide' );
$ ( '#bs-popup #btn_crea_modello' ) . removeClass ( 'hide' );
} else {
$ ( '#bs-popup #testo_aggiuntivo' ) . addClass ( 'text-danger' ) . html ( sbilancio . replace ( '|value|' , bilancio . toLocale ()));
$ ( '#bs-popup #add-submit' ) . addClass ( 'hide' );
$ ( '#bs-popup #btn_crea_modello' ) . addClass ( 'hide' );
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
return bilancio == 0 ;
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
function bloccaZeri (){
$ ( '#bs-popup input[id*=dare], #bs-popup input[id*=avere]' ) . each ( function () {
if ( $ ( this ) . val () == formatted_zero ) {
$ ( this ) . prop ( " disabled " , true );
} else {
$ ( this ) . prop ( " disabled " , false );
}
});
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
$ ( document ) . ready ( function () {
calcolaBilancio ();
bloccaZeri ();
$ ( " #bs-popup #add-form " ) . submit ( function () {
var result = calcolaBilancio ();
if ( ! result ) bloccaZeri ();
return result ;
});
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
$ ( 'select' ) . on ( 'change' , function () {
if ( $ ( this ) . parent () . parent () . find ( 'input[disabled]' ) . length != 1 ) {
if ( $ ( this ) . val ()) {
$ ( this ) . parent () . parent () . find ( 'input' ) . prop ( " disabled " , false );
} else {
$ ( this ) . parent () . parent () . find ( 'input' ) . prop ( " disabled " , true );
$ ( this ) . parent () . parent () . find ( 'input' ) . val ( " 0.00 " );
2017-08-04 16:28:16 +02:00
}
2019-07-25 12:54:28 +02:00
}
});
$ ( '#bs-popup input[id*=dare]' ) . on ( 'keyup change' , function () {
if ( ! $ ( this ) . prop ( 'disabled' )) {
if ( $ ( this ) . val ()) {
$ ( this ) . parent () . parent () . find ( 'input[id*=avere]' ) . prop ( " disabled " , true );
} else {
$ ( this ) . parent () . parent () . find ( 'input[id*=avere]' ) . prop ( " disabled " , false );
}
calcolaBilancio ();
}
});
$ ( '#bs-popup input[id*=avere]' ) . on ( 'keyup change' , function () {
if ( ! $ ( this ) . prop ( 'disabled' )) {
if ( $ ( this ) . val ()) {
$ ( this ) . parent () . parent () . find ( 'input[id*=dare]' ) . prop ( " disabled " , true );
} else {
$ ( this ) . parent () . parent () . find ( 'input[id*=dare]' ) . prop ( " disabled " , false );
}
calcolaBilancio ();
}
});
// Trigger dell'evento keyup() per la prima volta, per eseguire i dovuti controlli nel caso siano predisposte delle righe in prima nota
$ ( " #bs-popup input[id*=dare][value!=''], #bs-popup input[id*=avere][value!=''] " ) . keyup ();
$ ( " #bs-popup select[id*=idconto] " ) . click ( function () {
$ ( " #bs-popup input[id*=dare][value!=''], #bs-popup input[id*=avere][value!=''] " ) . keyup ();
});
$ ( '#bs-popup #modello_primanota' ) . change ( function () {
if ( $ ( this ) . val () != '' ) {
$ ( '#btn_crea_modello' ) . html ( '<i class="fa fa-edit"></i> ' + modifica_modello );
$ ( '#bs-popup #idmastrino' ) . val ( $ ( this ) . val ());
} else {
$ ( '#btn_crea_modello' ) . html ( '<i class="fa fa-plus"></i> ' + nuovo_modello );
$ ( '#bs-popup #idmastrino' ) . val ( 0 );
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
var idmastrino = $ ( this ) . val ();
var replaced = 0 ;
if ( idmastrino != '' ) {
var causale = $ ( this ) . find ( 'option:selected' ) . data ( 'causale' );
if ( $ ( '#iddocumento' ) . val () != '' ) {
for ( i in variables ) {
if ( causale . includes ( '{' + i + '}' )) {
replaced ++ ;
causale = causale . replace ( '{' + i + '}' , variables [ i ]);
}
2017-08-04 16:28:16 +02:00
}
2019-07-25 12:54:28 +02:00
} else {
for ( i in variables ) {
causale = causale . replace ( '{' + i + '}' , '_' );
2017-08-04 16:28:16 +02:00
}
2019-07-25 12:54:28 +02:00
}
2017-08-04 16:28:16 +02:00
2019-07-25 12:54:28 +02:00
// aggiornava erroneamente anche la causale ed eventuale numero di fattura e data
if ( replaced > 0 || $ ( '#iddocumento' ) . val () == '' ) {
$ ( '#bs-popup #desc' ) . val ( causale );
2017-08-04 16:28:16 +02:00
}
2019-07-25 12:54:28 +02:00
$ . get ( globals . rootdir + '/ajax_complete.php?op=get_conti&idmastrino=' + idmastrino , function ( data ) {
var conti = data . split ( ',' );
for ( i = 0 ; i < conti . length ; i ++ ) {
var conto = conti [ i ] . split ( ';' );
// Sostituzione conto cliente/fornitore
if ( conto [ 0 ] == - 1 ) {
if ( $ ( '#iddocumento' ) . val () != '' ) {
var option = $ ( " <option selected></option> " ) . val ( variables [ 'conto' ]) . text ( variables [ 'conto_descrizione' ]);
$ ( '#bs-popup #conto' + i ) . selectReset ();
$ ( '#bs-popup #conto' + i ) . append ( option ) . trigger ( 'change' );
2019-04-11 16:04:08 +02:00
}
2019-07-25 12:54:28 +02:00
} else {
var option = $ ( " <option selected></option> " ) . val ( conto [ 0 ]) . text ( conto [ 1 ]);
$ ( '#bs-popup #conto' + i ) . selectReset ();
$ ( '#bs-popup #conto' + i ) . append ( option ) . trigger ( 'change' );
2019-04-11 16:04:08 +02:00
}
}
2019-07-25 12:54:28 +02:00
for ( i = 9 ; i >= conti . length ; i -- ) {
$ ( '#bs-popup #conto' + i ) . selectReset ();
console . log ( '#bs-popup #conto' + i );
2019-04-11 16:04:08 +02:00
}
2019-07-25 12:54:28 +02:00
});
}
});
$ ( '#bs-popup #btn_crea_modello' ) . click ( function () {
$ ( '#bs-popup #crea_modello' ) . val ( " 1 " );
$ ( '#bs-popup #add-form' ) . submit ();
});
});
</ script >