. */ use Plugins\PianificazioneFatturazione\Pianificazione; include_once __DIR__.'/../../../core.php'; $pianificazioni = Pianificazione::doesntHave('fattura') ->leftjoin('co_contratti', 'co_contratti.id', '=', 'co_fatturazione_contratti.idcontratto') ->leftjoin('an_anagrafiche', 'an_anagrafiche.idanagrafica', '=', 'co_contratti.idanagrafica') ->orderBy('data_scadenza', 'asc') ->orderBy('ragione_sociale', 'asc') ->whereHas('contratto', function($q){ $q->whereHas('stato', function($q){ $q->where('is_fatturabile', 1); }); }) ->get(); if ($pianificazioni->isEmpty()) { echo '
'.tr('Non ci sono fatture da emettere').'.
'; return; } $raggruppamenti = $pianificazioni->groupBy(function ($item) { return ucfirst($item->data_scadenza->formatLocalized('%B %Y')); }); $counter = 0; foreach ($raggruppamenti as $mese => $raggruppamento) { ++$counter; // Se cambia il mese ricreo l'intestazione della tabella if ($counter == 1) { $attr = ''; $class = 'fa-minus-circle'; } else { $attr = 'style="display:none;"'; $class = 'fa-plus-circle'; } echo "'.tr('Entro il').' | '.tr('Ragione sociale').' | '.tr('Importo').' | |
---|---|---|---|
'.dateFormat($pianificazione->data_scadenza).'
'.reference($contratto).' |
'.Modules::link('Anagrafiche', $anagrafica->id, nl2br($anagrafica->ragione_sociale)).' |
'.moneyFormat($pianificazione->totale).' '.tr('Rata _IND_/_NUM_ (totale: _TOT_)', [ '_IND_' => numberFormat($pianificazione->getNumeroPianificazione(), 0), '_NUM_' => numberFormat($numero_pianificazioni, 0), '_TOT_' => moneyFormat($contratto->totale), ]).' | ';
// Pulsanti
echo '