2017-08-04 16:28:16 +02:00
< ? php
include_once __DIR__ . '/../../core.php' ;
/**
* Elenco conti .
*/
$query1 = 'SELECT * FROM `co_pianodeiconti1` ORDER BY id DESC' ;
$rs1 = $dbo -> fetchArray ( $query1 );
$n1 = sizeof ( $rs1 );
2017-09-14 18:48:45 +02:00
// Livello 1
2017-08-04 16:28:16 +02:00
for ( $x = 0 ; $x < $n1 ; ++ $x ) {
2018-02-10 19:42:52 +01:00
$totale_attivita = [];
$totale_passivita = [];
2017-08-04 16:28:16 +02:00
2018-02-10 19:42:52 +01:00
$costi = [];
$ricavi = [];
2017-08-04 16:28:16 +02:00
if ( $rs1 [ $x ][ 'descrizione' ] == 'Economico' ) {
echo " <hr><h2 class= \" pull-left \" >Conto economico</h2> \n " ;
} else {
echo " <hr><h2 class= \" pull-left \" >Stato patrimoniale</h2> \n " ;
}
2017-09-21 17:48:41 +02:00
echo " <div class= \" pull-right \" ><br> \n " ;
echo Prints :: getLink ( 'Mastrino' , $rs1 [ $x ][ 'id' ], null , tr ( 'Stampa' ), null , 'lev=1' );
2017-08-04 16:28:16 +02:00
echo " </div> \n " ;
echo " <div class= \" clearfix \" ></div> \n " ;
2017-09-14 18:48:45 +02:00
// Livello 2
2017-08-04 16:28:16 +02:00
$query2 = " SELECT * FROM `co_pianodeiconti2` WHERE idpianodeiconti1=' " . $rs1 [ $x ][ 'id' ] . " ' ORDER BY numero ASC " ;
$rs2 = $dbo -> fetchArray ( $query2 );
$n2 = sizeof ( $rs2 );
echo " <div style='padding-left:10px;'> \n " ;
for ( $y = 0 ; $y < $n2 ; ++ $y ) {
2017-09-14 18:48:45 +02:00
// Livello 2
2017-08-04 16:28:16 +02:00
echo " <div> \n " ;
2017-09-14 18:48:45 +02:00
// Stampa mastrino
2017-09-21 17:48:41 +02:00
echo Prints :: getLink ( 'Mastrino' , $rs2 [ $y ][ 'id' ], 'btn-info btn-xs' , '' , null , 'lev=2' );
2017-08-04 16:28:16 +02:00
echo ' <b>' . $rs2 [ $y ][ 'numero' ] . ' ' . htmlentities ( $rs2 [ $y ][ 'descrizione' ], ENT_QUOTES , 'ISO-8859-1' ) . " </b><br> \n " ;
echo " </div> \n " ;
2017-09-14 18:48:45 +02:00
// Livello 3
2018-10-18 17:55:59 +02:00
$query3 = " SELECT `co_pianodeiconti3`.*, `clienti`.`idanagrafica` AS id_cliente, `fornitori`.`idanagrafica` AS id_fornitore FROM `co_pianodeiconti3` LEFT OUTER JOIN `an_anagrafiche` `clienti` ON `clienti`.`idconto_cliente` = `co_pianodeiconti3`.`id` LEFT OUTER JOIN `an_anagrafiche` `fornitori` ON `fornitori`.`idconto_fornitore` = `co_pianodeiconti3`.`id` WHERE `idpianodeiconti2` = " . prepare ( $rs2 [ $y ][ 'id' ]) . " ORDER BY numero ASC " ;
2017-08-04 16:28:16 +02:00
$rs3 = $dbo -> fetchArray ( $query3 );
$n3 = sizeof ( $rs3 );
echo " <div style='padding-left:10px;'> \n " ;
echo " <table class='table table-striped table-hover table-condensed' style='margin-bottom:0;'> \n " ;
for ( $z = 0 ; $z < $n3 ; ++ $z ) {
2018-02-10 19:42:52 +01:00
$totale_conto_liv3 = [];
2017-08-04 16:28:16 +02:00
echo " <tr><td> \n " ;
2017-09-14 18:48:45 +02:00
// Se il conto non ha documenti collegati posso eliminarlo
2017-08-04 16:28:16 +02:00
$query = " SELECT id FROM co_movimenti WHERE idconto=' " . $rs3 [ $z ][ 'id' ] . " ' " ;
$nr = $dbo -> fetchNum ( $query );
2017-09-14 18:48:45 +02:00
// Calcolo totale conto da elenco movimenti di questo conto
$query = " SELECT co_movimenti.*, dir FROM (co_movimenti LEFT OUTER JOIN co_documenti ON co_movimenti.iddocumento=co_documenti.id) LEFT OUTER JOIN co_tipidocumento ON co_documenti.idtipodocumento=co_tipidocumento.id WHERE co_movimenti.idconto=' " . $rs3 [ $z ][ 'id' ] . " ' AND co_movimenti.data >= ' " . $_SESSION [ 'period_start' ] . " ' AND co_movimenti.data <= ' " . $_SESSION [ 'period_end' ] . " ' ORDER BY co_movimenti.data ASC " ;
$rs = $dbo -> fetchArray ( $query );
2017-08-04 16:28:16 +02:00
2017-09-14 18:48:45 +02:00
$tools = " <span class='hide tools'> \n " ;
// Stampa mastrino
if ( ! empty ( $rs )) {
2017-09-21 17:48:41 +02:00
$tools .= Prints :: getLink ( 'Mastrino' , $rs3 [ $z ][ 'id' ], 'btn-info btn-xs' , '' , null , 'lev=3' );
2017-09-14 18:48:45 +02:00
}
2017-08-04 16:28:16 +02:00
if ( $nr <= 0 && $rs3 [ $z ][ 'can_delete' ] == '1' ) {
$tools .= '
2017-09-04 12:02:29 +02:00
< a class = " btn btn-danger btn-xs ask " data - toggle = " tooltip " title = " '.tr('Elimina').' " data - backto = " record-list " data - op = " del " data - idconto = " '. $rs3[$z] ['id'].' " >
2017-08-04 16:28:16 +02:00
< i class = " fa fa-trash " ></ i >
</ a > ' ;
}
2017-09-14 18:48:45 +02:00
// Possibilità di modificare il nome del conto livello3
2017-08-04 16:28:16 +02:00
if ( $rs3 [ $z ][ 'can_edit' ] == '1' ) {
$tools .= " <button type='button' class='btn btn-warning btn-xs' data-toggle='tooltip' title='Modifica questo conto...' onclick= \" launch_modal( 'Modifica conto', ' " . $rootdir . '/modules/partitario/edit_conto.php?id=' . $rs3 [ $z ][ 'id' ] . " ', 1 ); \" ><i class='fa fa-edit'></i></button> \n " ;
}
2017-09-14 18:48:45 +02:00
$tools .= " </span> \n " ;
2017-08-04 16:28:16 +02:00
2017-09-14 18:48:45 +02:00
echo "
< span class = 'clickable' onmouseover = \ " $ (this).find('.tools').removeClass('hide'); \" onmouseleave= \" $ (this).find('.tools').addClass('hide'); \" onclick= \" $ ('#conto_ " . $rs3 [ $z ][ 'id' ] . " ').slideToggle(); $ (this).find('.plus-btn i').toggleClass('fa-plus').toggleClass('fa-minus'); \" > " ;
2017-08-04 16:28:16 +02:00
2017-09-14 18:48:45 +02:00
if ( ! empty ( $rs )) {
echo '
< a href = " javascript:; " class = " btn btn-primary btn-xs plus-btn " >< i class = " fa fa-plus " ></ i ></ a > ' ;
}
2017-08-04 16:28:16 +02:00
2018-10-18 17:55:59 +02:00
$id_anagrafica = $rs3 [ $z ][ 'id_cliente' ] ? : $rs3 [ $z ][ 'id_fornitore' ];
2017-09-14 18:48:45 +02:00
echo '
2018-10-18 17:55:59 +02:00
'.$tools.' & nbsp ; '.$rs2[$y][' numero '].' . '.$rs3[$z][' numero '].' '.$rs3[$z][' descrizione '].' '.(isset($id_anagrafica) ? Modules::link(' Anagrafiche ', $id_anagrafica, ' Anagrafica ', null) : ' ').'
2017-09-14 18:48:45 +02:00
</ span > ' ;
2018-10-18 17:55:59 +02:00
2017-09-14 18:48:45 +02:00
echo ' <div id="conto_' . $rs3 [ $z ][ 'id' ] . " \" style= \" display:none; \" > \n " ;
2017-08-04 16:28:16 +02:00
if ( sizeof ( $rs ) > 0 ) {
2018-02-10 19:42:52 +01:00
$totale_conto_liv3 = [];
2017-08-04 16:28:16 +02:00
echo " <table class='table table-bordered table-hover table-condensed table-striped'> \n " ;
echo " <tr><th>Causale</th> \n " ;
echo " <th width='100'>Data</th> \n " ;
echo " <th width='100'>Dare</th> \n " ;
echo " <th width='100'>Avere</th></tr> \n " ;
2017-09-14 18:48:45 +02:00
// Elenco righe del partitario
2017-08-04 16:28:16 +02:00
for ( $i = 0 ; $i < sizeof ( $rs ); ++ $i ) {
echo " <tr><td> \n " ;
2018-09-03 18:57:22 +02:00
if ( ! empty ( $rs [ $i ][ 'iddocumento' ])) {
2017-09-22 15:19:59 +02:00
$module = ( $rs [ $i ][ 'dir' ] == 'entrata' ) ? Modules :: get ( 'Fatture di vendita' )[ 'id' ] : Modules :: get ( 'Fatture di acquisto' )[ 'id' ];
2017-09-18 17:24:25 +02:00
echo " <a data-toggle='modal' data-title='Dettagli movimento...' data-target='#bs-popup' class='clickable' data-href=' " . $rootdir . '/modules/partitario/dettagli_movimento.php?id_movimento=' . $rs [ $i ][ 'id' ] . '&id_conto=' . $rs [ $i ][ 'idconto' ] . '&id_module=' . $module . " ' > " . $rs [ $i ][ 'descrizione' ] . " </a> \n " ;
2018-02-10 19:42:52 +01:00
// echo " <a href='".$rootdir.'/editor.php?id_module='.$module.'&id_record='.$rs[$i]['iddocumento']."'>".$rs[$i]['descrizione']."</a>\n";
2017-08-04 16:28:16 +02:00
} else {
echo ' <span>' . $rs [ $i ][ 'descrizione' ] . " </span> \n " ;
}
echo " </td> \n " ;
2017-09-14 18:48:45 +02:00
// Data
2017-08-04 16:28:16 +02:00
echo " <td> \n " ;
echo date ( 'd/m/Y' , strtotime ( $rs [ $i ][ 'data' ]));
echo " </td> \n " ;
2017-09-14 18:48:45 +02:00
// Dare
2017-08-04 16:28:16 +02:00
if ( $rs [ $i ][ 'totale' ] > 0 ) {
echo " <td align='right'> \n " ;
echo Translator :: numberToLocale ( abs ( $rs [ $i ][ 'totale' ])) . " € \n " ;
echo " </td> \n " ;
echo " <td></td></tr> \n " ;
if ( $rs1 [ $x ][ 'descrizione' ] == 'Patrimoniale' ) {
2018-02-10 19:42:52 +01:00
$totale_conto_liv3 [] = $rs [ $i ][ 'totale' ];
2017-08-04 16:28:16 +02:00
} else {
2018-02-10 19:42:52 +01:00
$totale_conto_liv3 [] = - $rs [ $i ][ 'totale' ];
2017-08-04 16:28:16 +02:00
}
}
2017-09-14 18:48:45 +02:00
// Avere
2017-08-04 16:28:16 +02:00
else {
echo " <td></td><td align='right'> \n " ;
echo Translator :: numberToLocale ( abs ( $rs [ $i ][ 'totale' ])) . " € \n " ;
echo " </td> \n " ;
if ( $rs1 [ $x ][ 'descrizione' ] == 'Patrimoniale' ) {
2018-02-10 19:42:52 +01:00
$totale_conto_liv3 [] = $rs [ $i ][ 'totale' ];
2017-08-04 16:28:16 +02:00
} else {
2018-02-10 19:42:52 +01:00
$totale_conto_liv3 [] = - $rs [ $i ][ 'totale' ];
2017-08-04 16:28:16 +02:00
}
}
echo " </td></tr> \n " ;
}
2017-09-14 18:48:45 +02:00
// Somma dei totali
2017-08-04 16:28:16 +02:00
if ( $rs1 [ $x ][ 'descrizione' ] == 'Patrimoniale' ) {
2018-02-10 19:42:52 +01:00
if ( sum ( $totale_conto_liv3 ) > 0 ) {
$totale_attivita [] = abs ( sum ( $totale_conto_liv3 ));
2017-08-04 16:28:16 +02:00
} else {
2018-02-10 19:42:52 +01:00
$totale_passivita [] = abs ( sum ( $totale_conto_liv3 ));
2017-08-04 16:28:16 +02:00
}
} else {
2018-02-10 19:42:52 +01:00
if ( sum ( $totale_conto_liv3 ) > 0 ) {
$totale_ricavi [] = abs ( sum ( $totale_conto_liv3 ));
2017-08-04 16:28:16 +02:00
} else {
2018-02-10 19:42:52 +01:00
$totale_costi [] = abs ( sum ( $totale_conto_liv3 ));
2017-08-04 16:28:16 +02:00
}
}
echo " </table> \n " ;
}
echo " </div> \n " ;
echo " </td> \n " ;
echo " <td width='100' align='right' valign='top'> \n " ;
2018-02-10 19:42:52 +01:00
echo Translator :: numberToLocale ( sum ( $totale_conto_liv3 )) . " € \n " ;
2017-08-04 16:28:16 +02:00
echo " </td></tr> \n " ;
2017-09-14 18:48:45 +02:00
} // Fine livello3
2017-08-04 16:28:16 +02:00
echo " </table> \n " ;
2017-09-14 18:48:45 +02:00
// Possibilità di inserire un nuovo conto
2018-06-15 15:57:32 +02:00
echo " <button type='button' class='btn btn-xs btn-primary' data-toggle='tooltip' title=' " . tr ( 'Aggiungi un nuovo conto...' ) . " ' onclick= \" launch_modal( ' " . tr ( 'Nuovo conto' ) . " ', ' " . $rootdir . '/modules/partitario/add_conto.php?id=' . $rs2 [ $y ][ 'id' ] . " ', 1 ); \" ><i class='fa fa-plus-circle'></i></button><br><br> \n " ;
2017-08-04 16:28:16 +02:00
echo " </div> \n " ;
2017-09-14 18:48:45 +02:00
} // Fine livello 2
2017-08-04 16:28:16 +02:00
echo " </div> \n " ;
if ( $rs1 [ $x ][ 'descrizione' ] == 'Patrimoniale' ) {
2017-09-14 18:48:45 +02:00
// Riepilogo
2018-02-10 19:42:52 +01:00
$attivita = abs ( sum ( $totale_attivita ));
$passivita = abs ( sum ( $totale_passivita ));
$utile_perdita = abs ( sum ( $totale_ricavi )) - abs ( sum ( $totale_costi ));
2017-08-04 16:28:16 +02:00
if ( $utile_perdita < 0 ) {
$pareggio1 = $attivita + abs ( $utile_perdita );
$pareggio2 = abs ( $passivita );
} else {
$pareggio1 = $attivita ;
$pareggio2 = abs ( $passivita ) + abs ( $utile_perdita );
}
echo " <table class='table table-condensed table-hover'> \n " ;
2017-09-14 18:48:45 +02:00
// Attività
2017-08-04 16:28:16 +02:00
echo " <tr><th> \n " ;
echo " <p align='right'><big>Totale attività:</big></p> \n " ;
echo " </th> \n " ;
echo " <td width='150' align='right'> \n " ;
echo " <p align='right'><big> " . Translator :: numberToLocale ( $attivita ) . " €</big></p> \n " ;
echo " </td> \n " ;
echo " <td width='50'></td> \n " ;
2017-09-14 18:48:45 +02:00
// Passività
2017-08-04 16:28:16 +02:00
echo " <th align='right'> \n " ;
echo " <p align='right'><big>Passività:</big></p> \n " ;
echo " </th> \n " ;
echo " <td width='150' align='right'> \n " ;
echo " <p align='right'><big> " . Translator :: numberToLocale ( $passivita ) . " €</big></p> \n " ;
echo " </td></tr> \n " ;
2017-09-14 18:48:45 +02:00
// Perdita d'esercizio
2017-08-04 16:28:16 +02:00
if ( $utile_perdita < 0 ) {
echo " <tr><th align='right'> \n " ;
echo " <p align='right'><big>Perdita d'esercizio:</big></p> \n " ;
echo " </th> \n " ;
echo " <td align='right'> \n " ;
2018-02-10 19:42:52 +01:00
echo " <p align='right'><big> " . Translator :: numberToLocale ( sum ( $utile_perdita )) . " €</big></p> \n " ;
2017-08-04 16:28:16 +02:00
echo " </td> \n " ;
echo " <td></td> \n " ;
echo " <td></td><td></td></tr> \n " ;
} else {
echo " <tr><td></td><td></td><td></td><th align='right'> \n " ;
echo " <p align='right'><big>Utile:</big></p> \n " ;
echo " </th> \n " ;
echo " <td align='right'> \n " ;
2018-02-10 19:42:52 +01:00
echo " <p align='right'><big> " . Translator :: numberToLocale ( sum ( $utile_perdita )) . " €</big></p> \n " ;
2017-08-04 16:28:16 +02:00
echo " </td></tr> \n " ;
}
2017-09-14 18:48:45 +02:00
// Totale a pareggio
2017-08-04 16:28:16 +02:00
echo " <tr><th align='right'> \n " ;
echo " <p align='right'><big>Totale a pareggio:</big></p> \n " ;
echo " </th> \n " ;
echo " <td align='right'> \n " ;
2018-02-10 19:42:52 +01:00
echo " <p align='right'><big> " . Translator :: numberToLocale ( sum ( $pareggio1 )) . " €</big></p> \n " ;
2017-08-04 16:28:16 +02:00
echo " </td> \n " ;
echo " <td></td> \n " ;
2017-09-14 18:48:45 +02:00
// Totale a pareggio
2017-08-04 16:28:16 +02:00
echo " <th align='right'> \n " ;
echo " <p align='right'><big>Totale a pareggio:</big></p> \n " ;
echo " </th> \n " ;
echo " <td align='right'> \n " ;
2018-02-10 19:42:52 +01:00
echo " <p align='right'><big> " . Translator :: numberToLocale ( sum ( $pareggio2 )) . " €</big></p> \n " ;
2017-08-04 16:28:16 +02:00
echo " </td></tr> \n " ;
echo '</table>' ;
} else {
2018-02-10 19:42:52 +01:00
echo " <p align='right'><big><b>RICAVI:</b> " . Translator :: numberToLocale ( sum ( $totale_ricavi )) . " €</big></p> \n " ;
2018-04-17 18:05:22 +02:00
echo " <p align='right'><big><b>COSTI:</b> " . Translator :: numberToLocale ( abs ( sum ( $totale_costi ))) . " €</big></p> \n " ;
2018-09-07 17:22:12 +02:00
echo " <p align='right'><big><b>UTILE/PERDITA:</b> " . Translator :: numberToLocale ( sum ( $totale_ricavi ) - abs ( sum ( $totale_costi ))) . " €</big></p> \n " ;
2017-08-04 16:28:16 +02:00
}
}