. */ include_once __DIR__.'/../../core.php'; use Models\Module; use Models\PrintTemplate; use Modules\Fatture\Tipo; use Modules\Scadenzario\Scadenza; use Plugins\AssicurazioneCrediti\AssicurazioneCrediti; switch (post('op')) { case 'add': $idanagrafica = post('idanagrafica'); $data = post('data'); $tipo = post('tipo'); $da_pagare = post('da_pagare'); $descrizione = post('descrizione'); $iddocumento = post('iddocumento') ?: ''; $data_emissione = post('data_emissione') ?: date('Y-m-d'); $dbo->query('INSERT INTO co_scadenziario(idanagrafica, iddocumento, descrizione, tipo, data_emissione, scadenza, da_pagare, pagato) VALUES('.prepare($idanagrafica).', '.prepare($iddocumento).', '.prepare($descrizione).', '.prepare($tipo).', '.prepare($data_emissione).', '.prepare($data).', '.prepare($da_pagare).", '0')"); $id_record = $dbo->lastInsertedID(); $assicurazione_crediti = AssicurazioneCrediti::where('id_anagrafica', $idanagrafica)->where('data_inizio', '<=', $data)->where('data_fine', '>=', $data)->first(); if (!empty($assicurazione_crediti)) { $assicurazione_crediti->fixTotale(); $assicurazione_crediti->save(); } flash()->info(tr('Scadenza inserita!')); break; case 'update': $idanagrafica = post('idanagrafica'); $tipo = post('tipo'); $descrizione = post('descrizione'); $iddocumento = post('iddocumento') ?: 0; if (!empty($iddocumento)) { $scadenze = database()->table('co_scadenziario')->where('iddocumento', '=', $iddocumento)->orderBy('scadenza')->get(); } $totale_pagato = 0; $id_scadenza_non_completa = null; $da_pagare = 0; foreach ($scadenze as $id => $scadenza) { $pagato = floatval(post('pagato')[$id]); $data_scadenza = post('scadenza')[$id]; $data_concordata = post('data_concordata')[$id]; $da_pagare = post('da_pagare')[$id]; if (!empty($iddocumento)) { $tipo_documento = Tipo::find($documento->idtipodocumento); if ($tipo_documento['dir'] == 'uscita') { if ($pagato > 0) { $pagato = -$pagato; } if ($da_pagare > 0) { $da_pagare = -$da_pagare; } } else { if ($pagato < 0) { $pagato = -$pagato; } if ($da_pagare < 0) { $da_pagare = -$da_pagare; } } if (!empty($tipo_documento['reversed'])) { $pagato = -$pagato; $da_pagare = -$da_pagare; } } $totale_pagato = sum($totale_pagato, $pagato); $id_pagamento = post('id_pagamento')[$id] ?: $documento->idpagamento; $id_banca_azienda = post('id_banca_azienda')[$id] ?: $documento->id_banca_azienda; $id_banca_controparte = post('id_banca_controparte')[$id] ?: $documento->id_banca_controparte; $id_scadenza = $scadenza->id ?? $scadenza['id']; if (!empty($id_scadenza)) { $database->update('co_scadenziario', [ 'idanagrafica' => $idanagrafica, 'descrizione' => $descrizione, 'da_pagare' => $da_pagare, 'pagato' => $pagato, 'scadenza' => $data_scadenza, 'data_concordata' => $data_concordata, 'id_pagamento' => $id_pagamento, 'id_banca_azienda' => $id_banca_azienda, 'id_banca_controparte' => $id_banca_controparte, 'note' => post('note'), 'distinta' => post('distinta') ?: null, ], ['id' => $id_scadenza]); if ($da_pagare == 0) { $database->delete('co_scadenziario', ['id' => $id_scadenza]); } } else { $database->insert('co_scadenziario', [ 'idanagrafica' => $idanagrafica, 'descrizione' => $descrizione, 'tipo' => $tipo, 'iddocumento' => $iddocumento, 'da_pagare' => $da_pagare, 'pagato' => $pagato, 'scadenza' => $data_scadenza, 'data_concordata' => $data_concordata, 'data_emissione' => date('Y-m-d'), 'note' => post('note'), ]); $id_scadenza = $database->lastInsertedID(); } if ($pagato != $da_pagare) { $id_scadenza_non_completa = $id_scadenza; } $assicurazione_crediti = AssicurazioneCrediti::where('id_anagrafica', $idanagrafica)->where('data_inizio', '<=', $scadenza->scadenza)->where('data_fine', '>=', $scadenza->scadenza)->first(); if (!empty($assicurazione_crediti)) { $assicurazione_crediti->fixTotale(); $assicurazione_crediti->save(); } } flash()->info(tr('Scadenze aggiornate!')); break; case 'delete': $scadenza = Scadenza::find($id_record); $assicurazione_crediti = AssicurazioneCrediti::where('id_anagrafica', $scadenza->idanagrafica)->where('data_inizio', '<=', $scadenza->scadenza)->where('data_fine', '>=', $scadenza->scadenza)->first(); $dbo->query("DELETE FROM co_scadenziario WHERE id='".$id_record."'"); if (!empty($assicurazione_crediti)) { $assicurazione_crediti->fixTotale(); $assicurazione_crediti->save(); } flash()->info(tr('Scadenza eliminata!')); break; case 'allega_fattura': $scadenza = Scadenza::find($id_record); $id_documento = post('iddocumento'); $print_predefined = PrintTemplate::where('predefined', 1)->where('id_module', (new Module())->getByField('title', 'Fatture di vendita', Models\Locale::getPredefined()->id))->first(); $print = Prints::render($print_predefined->id, $id_documento, null, true); $upload = Uploads::upload($print['pdf'], [ 'name' => $scadenza->descrizione, 'original_name' => $scadenza->descrizione.'.pdf', 'category' => 'Generale', 'id_module' => $id_module, 'id_record' => $id_record, ]); flash()->info(tr('Stampa allegata correttamente!')); break; }