. */ include_once __DIR__.'/../../core.php'; // Verifico se è già stata eseguita l'apertura bilancio $bilancio_gia_aperto = $dbo->fetchNum('SELECT id FROM co_movimenti WHERE is_apertura=1 AND data BETWEEN '.prepare($_SESSION['period_start']).' AND '.prepare($_SESSION['period_end'])); $msg = tr('Sei sicuro di voler aprire il bilancio?'); $btn_class = 'btn-info'; if ($bilancio_gia_aperto) { $msg .= ' '.tr('I movimenti di apertura già esistenti verranno annullati e ricreati').'.'; $btn_class = 'btn-default'; } echo '
'; // Livello 1 $query1 = 'SELECT * FROM `co_pianodeiconti1` ORDER BY id DESC'; $primo_livello = $dbo->fetchArray($query1); foreach ($primo_livello as $conto_primo) { $totale_attivita = []; $totale_passivita = []; $costi = []; $ricavi = []; $titolo = $conto_primo['descrizione'] == 'Economico' ? tr('Conto economico') : tr('Stato patrimoniale'); echo '

'.$titolo.'

'; // Livello 2 $query2 = 'SELECT * FROM `co_pianodeiconti2` WHERE idpianodeiconti1 = '.prepare($conto_primo['id']).' ORDER BY numero ASC'; $secondo_livello = $dbo->fetchArray($query2); foreach ($secondo_livello as $conto_secondo) { // Livello 2 if ($conto_primo['descrizione'] == 'Economico') { $totale_conto2 = $dbo->fetchOne('SELECT SUM(-totale) AS totale FROM `co_movimenti` INNER JOIN co_pianodeiconti3 ON co_movimenti.idconto=co_pianodeiconti3.id WHERE idconto IN(SELECT id FROM co_pianodeiconti3 WHERE idpianodeiconti2='.prepare($conto_secondo['id']).') AND co_movimenti.data>='.prepare($_SESSION['period_start']).' AND co_movimenti.data<='.prepare($_SESSION['period_end']))['totale']; } else { $totale_conto2 = $dbo->fetchOne('SELECT SUM(totale) AS totale FROM `co_movimenti` INNER JOIN co_pianodeiconti3 ON co_movimenti.idconto=co_pianodeiconti3.id WHERE idconto IN(SELECT id FROM co_pianodeiconti3 WHERE idpianodeiconti2='.prepare($conto_secondo['id']).') AND co_movimenti.data>='.prepare($_SESSION['period_start']).' AND co_movimenti.data<='.prepare($_SESSION['period_end']))['totale']; } echo '
'.moneyFormat($totale_conto2, 2).'   '.Prints::getLink('Mastrino', $conto_secondo['id'], 'btn-info btn-xs', '', null, 'lev=2').'
'.$conto_secondo['numero'].' '.$conto_secondo['descrizione'].'
'; // Somma dei totali if ($conto_primo['descrizione'] == 'Patrimoniale') { if ($totale_conto2 > 0) { $totale_attivita[] = abs($totale_conto2); } else { $totale_passivita[] = abs($totale_conto2); } } else { if ($totale_conto2 > 0) { $totale_ricavi[] = abs($totale_conto2); } else { $totale_costi[] = abs($totale_conto2); } } $totale_conto2 = 0; $totale_reddito2 = 0; } echo '
'; // Riepiloghi if ($conto_primo['descrizione'] == 'Patrimoniale') { $attivita = abs(sum($totale_attivita)); $passivita = abs(sum($totale_passivita)); $utile_perdita = abs(sum($totale_ricavi)) - abs(sum($totale_costi)); if ($utile_perdita < 0) { $pareggio1 = $attivita + abs($utile_perdita); $pareggio2 = abs($passivita); } else { $pareggio1 = $attivita; $pareggio2 = abs($passivita) + abs($utile_perdita); } // Attività echo ' '; // Passività echo ' '; // Perdita d'esercizio if ($utile_perdita < 0) { echo ' '; } else { echo ' '; } // Totale a pareggio echo ' '; } else { echo ' '; } echo '
'.tr('Totale attività').': '.moneyFormat($attivita, 2).' '.tr('Passività').': '.moneyFormat($passivita, 2).'
'.tr("Perdita d'esercizio").': '.moneyFormat(sum($utile_perdita), 2).'
'.tr('Utile').': '.moneyFormat(sum($utile_perdita), 2).'
'.tr('Totale a pareggio').': '.moneyFormat(sum($pareggio1), 2).' '.tr('Totale a pareggio').': '.moneyFormat(sum($pareggio2), 2).'
'.tr('Ricavi').': '.moneyFormat(sum($totale_ricavi), 2).'
'.tr('Costi').': '.moneyFormat(sum($totale_costi), 2).'
'.tr('Utile/perdita').': '.moneyFormat(sum($totale_ricavi) - abs(sum($totale_costi)), 2).'
'; } // Verifico se è già stata eseguita l'apertura bilancio $bilancio_gia_chiuso = $dbo->fetchNum('SELECT id FROM co_movimenti WHERE is_chiusura=1 AND data BETWEEN '.prepare($_SESSION['period_start']).' AND '.prepare($_SESSION['period_end'])); $msg = tr('Sei sicuro di voler aprire il bilancio?'); $btn_class = 'btn-info'; if ($bilancio_gia_chiuso) { $msg .= ' '.tr('I movimenti di apertura già esistenti verranno annullati e ricreati').'.'; $btn_class = 'btn-default'; } echo '

';