2021-07-16 14:44:43 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
use Models\Module;
|
|
|
|
use Modules\Anagrafiche\Anagrafica;
|
|
|
|
use Modules\Contratti\Contratto;
|
|
|
|
use Modules\Fatture\Fattura;
|
2024-03-01 11:32:13 +01:00
|
|
|
use Modules\Fatture\Stato;
|
2024-03-22 15:52:24 +01:00
|
|
|
use Modules\Preventivi\Preventivo;
|
2021-07-16 14:44:43 +02:00
|
|
|
|
|
|
|
include_once __DIR__.'/../../core.php';
|
|
|
|
|
|
|
|
$id_anagrafica = get('id_anagrafica');
|
|
|
|
$op = get('op');
|
|
|
|
$numero_documenti = 5;
|
|
|
|
|
|
|
|
switch ($op) {
|
|
|
|
case 'dettagli':
|
|
|
|
// Informazioni sui contratti
|
2024-03-20 11:13:28 +01:00
|
|
|
$modulo_contratti = Module::find((new Module())->getByField('name', 'Contratti'));
|
2021-07-16 14:44:43 +02:00
|
|
|
if ($modulo_contratti->permission != '-') {
|
|
|
|
// Contratti attivi per l'anagrafica
|
|
|
|
$contratti = Contratto::where('idanagrafica', '=', $id_anagrafica)
|
|
|
|
->whereHas('stato', function ($query) {
|
|
|
|
$query->where('is_pianificabile', '=', 1);
|
|
|
|
})
|
|
|
|
->latest()->take($numero_documenti)->get();
|
|
|
|
|
|
|
|
echo '
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-4">
|
|
|
|
<b>'.tr('Contratti').':</b><ul>';
|
|
|
|
if (!$contratti->isEmpty()) {
|
|
|
|
foreach ($contratti as $contratto) {
|
|
|
|
echo '
|
2024-03-20 11:13:28 +01:00
|
|
|
<li>'.$contratto->getReference().' ['.$contratto->stato->getTranslation('name').']: '.dateFormat($contratto->data_accettazione).' - '.dateFormat($contratto->data_conclusione).'</li>';
|
2021-07-16 14:44:43 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
echo '
|
|
|
|
<li>'.tr('Nessun contratto attivo per questo cliente').'</li>';
|
|
|
|
}
|
|
|
|
echo '
|
|
|
|
</ul>
|
|
|
|
</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Informazioni sui preventivi
|
2024-03-20 11:13:28 +01:00
|
|
|
$modulo_preventivi = Module::find((new Module())->getByField('name', 'Preventivi'));
|
2021-07-16 14:44:43 +02:00
|
|
|
if ($modulo_preventivi->permission != '-') {
|
|
|
|
// Preventivi attivi
|
|
|
|
$preventivi = Preventivo::where('idanagrafica', '=', $id_anagrafica)
|
|
|
|
->whereHas('stato', function ($query) {
|
|
|
|
$query->where('is_pianificabile', '=', 1);
|
|
|
|
})
|
|
|
|
->latest()->take($numero_documenti)->get();
|
|
|
|
echo '
|
|
|
|
<div class="col-md-4">
|
|
|
|
<b>'.tr('Preventivi').':</b><ul>';
|
|
|
|
if (!$preventivi->isEmpty()) {
|
|
|
|
foreach ($preventivi as $preventivo) {
|
|
|
|
echo '
|
2024-03-20 11:13:28 +01:00
|
|
|
<li>'.$preventivo->getReference().' ['.$preventivo->stato->getTranslation('name').']</li>';
|
2021-07-16 14:44:43 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
echo '
|
|
|
|
<li>'.tr('Nessun preventivo attivo per questo cliente').'</li>';
|
|
|
|
}
|
|
|
|
echo '
|
|
|
|
</ul>
|
|
|
|
</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Informazioni sui preventivi
|
2024-03-22 15:52:24 +01:00
|
|
|
$modulo_fatture_vendita = Module::find((new Module())->getByField('name', 'Fatture di vendita'));
|
2021-07-16 14:44:43 +02:00
|
|
|
if ($modulo_fatture_vendita->permission != '-') {
|
|
|
|
// Fatture attive
|
|
|
|
$fatture = Fattura::where('idanagrafica', '=', $id_anagrafica)
|
|
|
|
->whereHas('stato', function ($query) {
|
2024-03-20 11:13:28 +01:00
|
|
|
$id_bozza = (new Stato())->getByField('name', 'Bozza');
|
|
|
|
$id_parz_pagato = (new Stato())->getByField('name', 'Parziale pagato');
|
2024-03-01 11:32:13 +01:00
|
|
|
$query->whereIn('id', [$id_bozza, $id_parz_pagato]);
|
2021-07-16 14:44:43 +02:00
|
|
|
})
|
|
|
|
->latest()->take($numero_documenti)->get();
|
|
|
|
echo '
|
|
|
|
<div class="col-md-4">
|
|
|
|
<b>'.tr('Fatture').':</b><ul>';
|
|
|
|
if (!$fatture->isEmpty()) {
|
|
|
|
foreach ($fatture as $fattura) {
|
|
|
|
$scadenze = $fattura->scadenze;
|
|
|
|
$da_pagare = $scadenze->sum('da_pagare') - $scadenze->sum('pagato');
|
|
|
|
echo '
|
|
|
|
<li>'.$fattura->getReference().': '.moneyFormat($da_pagare).'</li>';
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
echo '
|
|
|
|
<li>'.tr('Nessuna fattura attiva per questo cliente').'</li>';
|
|
|
|
}
|
|
|
|
echo '
|
|
|
|
</ul>
|
|
|
|
</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Note dell'anagrafica
|
|
|
|
$anagrafica = Anagrafica::find($id_anagrafica);
|
|
|
|
$note_anagrafica = $anagrafica->note;
|
|
|
|
echo '
|
|
|
|
<div class="col-md-12">
|
|
|
|
<p><b>'.tr('Note interne sul cliente').':</b></p>
|
|
|
|
'.(!empty($note_anagrafica) ? $note_anagrafica : tr('Nessuna nota interna per questo cliente')).'
|
|
|
|
</div>';
|
|
|
|
|
|
|
|
echo '
|
|
|
|
</div>';
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|