mirror of
https://github.com/devcode-it/openstamanager.git
synced 2024-12-29 01:00:00 +01:00
388 lines
17 KiB
PHP
388 lines
17 KiB
PHP
|
<?php
|
||
|
|
||
|
include_once __DIR__.'/../../core.php';
|
||
|
|
||
|
$rs = $dbo->fetchArray('SELECT co_tipidocumento.descrizione, dir FROM co_tipidocumento INNER JOIN co_documenti ON co_tipidocumento.id=co_documenti.idtipodocumento WHERE co_documenti.id='.prepare($id_record));
|
||
|
$dir = $rs[0]['dir'];
|
||
|
$tipodoc = $rs[0]['descrizione'];
|
||
|
|
||
|
?>
|
||
|
<form action="" class="text-right" method="post" id="form-copy">
|
||
|
<input type="hidden" name="backto" value="record-list">
|
||
|
<input type="hidden" name="op" value="copy">
|
||
|
</form>
|
||
|
|
||
|
<form action="" method="post" role="form">
|
||
|
<input type="hidden" name="backto" value="record-edit">
|
||
|
<input type="hidden" name="op" value="update">
|
||
|
<input type="hidden" name="id_record" value="<?php echo $id_record ?>">
|
||
|
|
||
|
<!-- INTESTAZIONE -->
|
||
|
<div class="panel panel-primary">
|
||
|
<div class="panel-heading">
|
||
|
<h3 class="panel-title"><?php echo _('Intestazione') ?></h3>
|
||
|
</div>
|
||
|
|
||
|
<div class="panel-body">
|
||
|
<div class="pull-right">
|
||
|
<button type="button" class="btn btn-primary" onclick="if( confirm('Duplicare questa fattura?') ){ $('#form-copy').submit(); }"><i class="fa fa-copy"></i> <?php echo _('Duplica fattura'); ?></button>
|
||
|
|
||
|
<button type="submit" class="btn btn-success"><i class="fa fa-check"></i> <?php echo _('Salva modifiche'); ?></button>
|
||
|
</div>
|
||
|
<div class="clearfix"></div>
|
||
|
|
||
|
<div class="row">
|
||
|
<?php
|
||
|
if ($dir == 'uscita') {
|
||
|
echo '
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "span", "label": "'._('Numero fattura').'", "name": "numero","class": "text-center", "value": "$numero$" ]}
|
||
|
</div>';
|
||
|
}
|
||
|
?>
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "text", "label": "<?php echo _('Numero secondario'); ?>", "name": "numero_esterno", "class": "text-center", "value": "$numero_esterno$" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "date", "label": "<?php echo _('Data emissione'); ?>", "maxlength": 10, "name": "data", "required": 1, "value": "$data$" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Stato'); ?>", "name": "idstatodocumento", "required": 1, "values": "query=SELECT * FROM co_statidocumento", "value": "$idstatodocumento$" ]}
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<div class="row">
|
||
|
<div class="col-md-3">
|
||
|
<?php
|
||
|
if ($dir == 'entrata') {
|
||
|
?>
|
||
|
{[ "type": "select", "label": "<?php echo _('Cliente'); ?>", "name": "idanagrafica", "required": 1, "ajax-source": "clienti", "value": "$idanagrafica$" ]}
|
||
|
<?php
|
||
|
|
||
|
} else {
|
||
|
?>
|
||
|
{[ "type": "select", "label": "<?php echo _('Fornitore'); ?>", "name": "idanagrafica", "required": 1, "ajax-source": "fornitori", "value": "$idanagrafica$" ]}
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
?>
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Riferimento sede cliente'); ?>", "name": "idsede", "ajax-source": "sedi", "value": "$idsede$" ]}
|
||
|
</div>
|
||
|
|
||
|
<?php if ($dir == 'entrata') {
|
||
|
?>
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Agente di riferimento'); ?>", "name": "idagente", "values": "query=SELECT an_anagrafiche_agenti.idagente AS id, ragione_sociale AS descrizione FROM an_anagrafiche_agenti INNER JOIN an_anagrafiche ON an_anagrafiche_agenti.idagente=an_anagrafiche.idanagrafica WHERE an_anagrafiche_agenti.idanagrafica='$idanagrafica$' ORDER BY ragione_sociale", "value": "$idagente$" ]}
|
||
|
</div>
|
||
|
<?php
|
||
|
|
||
|
} ?>
|
||
|
|
||
|
<?php
|
||
|
if ($records[0]['stato'] == 'Emessa') {
|
||
|
$scadenze = $dbo->fetchArray('SELECT * FROM co_scadenziario WHERE iddocumento = '.prepare($id_record));
|
||
|
echo '
|
||
|
<div class="col-md-3">
|
||
|
<p><strong>'._('Scadenze').'</strong></p>';
|
||
|
foreach ($scadenze as $scadenza) {
|
||
|
echo '
|
||
|
<p>'.Translator::dateToLocale($scadenza['scadenza']).' - '.Translator::numberToLocale($scadenza['da_pagare']).'€</p>';
|
||
|
}
|
||
|
echo '
|
||
|
</div>';
|
||
|
}
|
||
|
?>
|
||
|
</div>
|
||
|
<hr>
|
||
|
|
||
|
|
||
|
<div class="row">
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Tipo fattura'); ?>", "name": "idtipodocumento", "required": 1, "values": "query=SELECT id, descrizione FROM co_tipidocumento WHERE dir='<?php echo $dir ?>'", "value": "$idtipodocumento$" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
<?php
|
||
|
if ($dir == 'entrata') {
|
||
|
$ajaxsource = 'conti-vendite';
|
||
|
} else {
|
||
|
$ajaxsource = 'conti-acquisti';
|
||
|
}
|
||
|
?>
|
||
|
{[ "type": "select", "label": "<?php echo _('Conto'); ?>", "name": "idconto", "required": 1, "value": "$idconto$", "ajax-source": "<?php echo $ajaxsource ?>" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Pagamento'); ?>", "name": "idpagamento", "required": 1, "values": "query=SELECT id, descrizione FROM co_pagamenti GROUP BY descrizione ORDER BY descrizione ASC", "value": "$idpagamento$" ]}
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
|
||
|
<?php
|
||
|
if ($tipodoc == 'Fattura accompagnatoria di vendita') {
|
||
|
?>
|
||
|
<div class="row">
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Aspetto beni'); ?>", "name": "idaspettobeni", "placeholder": "-", "values": "query=SELECT id, descrizione FROM dt_aspettobeni ORDER BY descrizione ASC", "value": "$idaspettobeni$" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Causale trasporto'); ?>", "name": "idcausalet", "placeholder": "-", "values": "query=SELECT id, descrizione FROM dt_causalet ORDER BY descrizione ASC", "value": "$idcausalet$" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "select", "label": "<?php echo _('Porto'); ?>", "name": "idporto", "placeholder": "-", "values": "query=SELECT id, descrizione FROM dt_porto ORDER BY descrizione ASC", "value": "$idporto$" ]}
|
||
|
</div>
|
||
|
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "text", "label": "<?php echo _('N<sup>o</sup> colli'); ?>", "name": "n_colli", "value": "$n_colli$" ]}
|
||
|
</div>
|
||
|
</div>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
|
||
|
if ($dir == 'uscita') {
|
||
|
?>
|
||
|
<div class="row">
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "number", "label": "<?php echo _('Marca da bollo'); ?>", "name": "bollo", "value": "$bollo$" ]}
|
||
|
</div>
|
||
|
</div>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
?>
|
||
|
|
||
|
|
||
|
<div class="pull-right">
|
||
|
<?php
|
||
|
//Aggiunta prima nota solo se non c'è già, se non si è in bozza o se il pagamento non è completo
|
||
|
$query2 = 'SELECT id FROM co_movimenti WHERE iddocumento='.$id_record.' AND primanota=1';
|
||
|
$n2 = $dbo->fetchNum($query2);
|
||
|
|
||
|
$query3 = 'SELECT SUM(da_pagare-pagato) AS differenza, SUM(da_pagare) FROM co_scadenziario GROUP BY iddocumento HAVING iddocumento='.$id_record.'';
|
||
|
$rs3 = $dbo->fetchArray($query3);
|
||
|
$differenza = $rs3[0]['differenza'];
|
||
|
$da_pagare = $rs3[0]['da_pagare'];
|
||
|
|
||
|
if (($n2 <= 0 && $records[0]['stato'] == 'Emessa') || $differenza != 0) {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary" href="javascript:;" onclick="launch_modal( 'Aggiungi prima nota', '<?php echo $rootdir ?>/add.php?id_module=<?php echo Modules::getModule('Prima nota')['id'] ?>&iddocumento=<?php echo $id_record ?>&dir=<?php echo $dir ?>', 1 );"><i class="fa fa-euro"></i> Aggiungi prima nota...</a><br><br>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
|
||
|
if ($records[0]['stato'] == 'Pagato') {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary" href="javascript:;" onclick="if( confirm('Se riapri questa fattura verrà azzerato lo scadenzario e la prima nota. Continuare?') ){ $.post( '<?php echo $rootdir ?>/editor.php?id_module=<?php echo Modules::getModule($name)['id'] ?>&id_record=<?php echo $id_record ?>', { id_module: '<?php echo Modules::getModule($name)['id'] ?>', id_record: '<?php echo $id_record ?>', op: 'reopen' }, function(){ location.href='<?php echo $rootdir ?>/editor.php?id_module=<?php echo Modules::getModule($name)['id'] ?>&id_record=<?php echo $id_record ?>'; } ); }" title="Aggiungi prima nota"><i class="fa fa-folder-open"></i> Riapri fattura...</a>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
?>
|
||
|
</div>
|
||
|
<div class="clearfix"></div>
|
||
|
|
||
|
<div class="row">
|
||
|
<div class="col-md-3">
|
||
|
{[ "type": "number", "label": "<?php echo _('Sconto totale') ?>", "name": "sconto_generico", "value": "$sconto_globale$", "icon-after": "choice|untprc|$tipo_sconto_globale$" ]}
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<div class="row">
|
||
|
<div class="col-md-12">
|
||
|
{[ "type": "textarea", "label": "<?php echo _('Note'); ?>", "name": "note", "value": "$note$" ]}
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<div class="row">
|
||
|
<div class="col-md-12">
|
||
|
{[ "type": "textarea", "label": "<?php echo _('Note aggiuntive'); ?>", "name": "note_aggiuntive", "value": "$note_aggiuntive$" ]}
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
|
||
|
<div class="pull-right">
|
||
|
<button type="submit" class="btn btn-success"><i class="fa fa-check"></i> <?php echo _('Salva modifiche'); ?></button>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</form>
|
||
|
|
||
|
|
||
|
|
||
|
<!-- RIGHE -->
|
||
|
<div class="panel panel-primary">
|
||
|
<div class="panel-heading">
|
||
|
<h3 class="panel-title">Righe</h3>
|
||
|
</div>
|
||
|
|
||
|
<div class="panel-body">
|
||
|
<div class="row">
|
||
|
<div class="col-md-12">
|
||
|
<div class="pull-left">
|
||
|
<?php
|
||
|
if ($records[0]['stato'] != 'Pagato' && $records[0]['stato'] != 'Emessa') {
|
||
|
if ($dir == 'entrata') {
|
||
|
//Lettura interventi non rifiutati, non fatturati e non collegati a preventivi o contratti
|
||
|
$qi = 'SELECT id FROM in_interventi WHERE idanagrafica='.prepare($records[0]['idanagrafica'])." AND NOT idstatointervento='DENY' AND id NOT IN (SELECT idintervento FROM co_righe_documenti WHERE idintervento IS NOT NULL) AND id NOT IN (SELECT idintervento FROM co_preventivi_interventi WHERE idintervento IS NOT NULL) AND id NOT IN (SELECT idintervento FROM co_righe_contratti WHERE idintervento IS NOT NULL)";
|
||
|
$rsi = $dbo->fetchArray($qi);
|
||
|
$ni = sizeof($rsi);
|
||
|
|
||
|
//Se non trovo niente provo a vedere se ce ne sono per clienti terzi
|
||
|
if ($ni == 0) {
|
||
|
//Lettura interventi non rifiutati, non fatturati e non collegati a preventivi o contratti (clienti terzi)
|
||
|
$qi = 'SELECT id FROM in_interventi WHERE idclientefinale='.prepare($records[0]['idanagrafica'])." AND NOT idstatointervento='DENY' AND id NOT IN (SELECT idintervento FROM co_righe_documenti WHERE idintervento IS NOT NULL) AND id NOT IN (SELECT idintervento FROM co_preventivi_interventi WHERE idintervento IS NOT NULL) AND id NOT IN (SELECT idintervento FROM co_righe_contratti WHERE idintervento IS NOT NULL)";
|
||
|
$rsi = $dbo->fetchArray($qi);
|
||
|
$ni = sizeof($rsi);
|
||
|
}
|
||
|
|
||
|
//Lettura preventivi accettati, in attesa di conferma o in lavorazione
|
||
|
$qp = 'SELECT id FROM co_preventivi WHERE idanagrafica='.prepare($records[0]['idanagrafica'])." AND id NOT IN (SELECT idpreventivo FROM co_righe_documenti WHERE NOT idpreventivo=NULL) AND idstato IN( SELECT id FROM co_statipreventivi WHERE descrizione='Accettato' OR descrizione='In lavorazione' OR descrizione='In attesa di conferma')";
|
||
|
$rsp = $dbo->fetchArray($qp);
|
||
|
$np = sizeof($rsp);
|
||
|
|
||
|
//Lettura contratti accettati, in attesa di conferma o in lavorazione
|
||
|
$qc = 'SELECT id FROM co_contratti WHERE idanagrafica='.prepare($records[0]['idanagrafica']).' AND id NOT IN (SELECT idcontratto FROM co_righe_documenti WHERE NOT idcontratto=NULL) AND idstato IN( SELECT id FROM co_staticontratti WHERE fatturabile = 1) AND NOT EXISTS (SELECT id FROM co_righe_documenti WHERE co_righe_documenti.idcontratto = co_contratti.id)';
|
||
|
$rsc = $dbo->fetchArray($qc);
|
||
|
$nc = sizeof($rsc);
|
||
|
|
||
|
//Lettura ddt
|
||
|
$qd = 'SELECT id FROM dt_ddt WHERE idanagrafica='.prepare($records[0]['idanagrafica']);
|
||
|
$rsd = $dbo->fetchArray($qd);
|
||
|
$nd = sizeof($rsd);
|
||
|
if ($ni > 0) {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary" data-href="<?php echo $rootdir ?>/modules/fatture/add_intervento.php?id_module=<?php echo $id_module ?>&id_record=<?php echo $id_record ?>" data-toggle="modal" data-title="Aggiungi riga" data-target="#bs-popup"><i class="fa fa-plus"></i> Intervento</a>
|
||
|
<?php
|
||
|
|
||
|
} else {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary tip" title="<?php echo _('Nessun Intervento'); ?>" style="opacity:0.5;cursor:default;" ><i class="fa fa-plus"></i> Intervento</a>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
|
||
|
if ($np > 0) {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary" data-href="<?php echo $rootdir ?>/modules/fatture/add_preventivo.php?id_module=<?php echo $id_module ?>&id_record=<?php echo $id_record ?>" data-toggle="modal" data-title="Aggiungi riga" data-target="#bs-popup"><i class="fa fa-plus"></i> Preventivo</a>
|
||
|
<?php
|
||
|
|
||
|
} else {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary tip" title="<?php echo _('Nessun Preventivo'); ?>" style="opacity:0.5;cursor:default;" ><i class="fa fa-plus"></i> Preventivo</a>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
|
||
|
if ($nc > 0) {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary" data-href="<?php echo $rootdir ?>/modules/fatture/add_contratto.php?id_module=<?php echo $id_module ?>&id_record=<?php echo $id_record ?>" data-toggle="modal" data-title="Aggiungi riga" data-target="#bs-popup"><i class="fa fa-plus"></i> Contratto</a>
|
||
|
<?php
|
||
|
|
||
|
} else {
|
||
|
?>
|
||
|
<a class="btn btn-sm btn-primary tip" title="<?php echo _('Nessun Contratto'); ?>" style="opacity:0.5;cursor:default;" ><i class="fa fa-plus"></i> Contratto</a>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
|
||
|
$numero_doc = ($records[0]['numero_esterno'] != '') ? $records[0]['numero_esterno'] : $records[0]['numero'];
|
||
|
|
||
|
if ($nd > 0) {
|
||
|
echo '
|
||
|
<a class="btn btn-sm btn-primary" data-href="'.$rootdir.'/modules/fatture/add_ddt.php?id_module='.$id_module.'&id_record='.$id_record.'" data-toggle="modal" data-title="Aggiungi ddt su fattura nr. '.$numero_doc.'" data-target="#bs-popup"><i class="fa fa-plus"></i> Ddt</a>';
|
||
|
} else {
|
||
|
echo '
|
||
|
<a class="btn btn-sm btn-primary tip" title="Nessun ddt" style="opacity:0.5;cursor:default;"><i class="fa fa-plus"></i> Ddt</a>';
|
||
|
}
|
||
|
} ?>
|
||
|
|
||
|
<a class="btn btn-sm btn-primary" data-href="<?php echo $rootdir ?>/modules/fatture/add_articolo.php?id_module=<?php echo $id_module ?>&id_record=<?php echo $id_record ?>" data-toggle="modal" data-title="Aggiungi articolo" data-target="#bs-popup"><i class="fa fa-plus"></i> Articolo</a>
|
||
|
<a class="btn btn-sm btn-primary" data-href="<?php echo $rootdir ?>/modules/fatture/add_riga.php?id_module=<?php echo $id_module ?>&id_record=<?php echo $id_record ?>" data-toggle="modal" data-title="Aggiungi riga" data-target="#bs-popup"><i class="fa fa-plus"></i> Riga generica</a>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
?>
|
||
|
</div>
|
||
|
|
||
|
<div class="pull-right">
|
||
|
<!-- Stampe -->
|
||
|
<?php
|
||
|
|
||
|
if ($dir == 'entrata') {
|
||
|
$rs2 = $dbo->fetchArray('SELECT piva, codice_fiscale, citta, indirizzo, cap, provincia FROM an_anagrafiche WHERE idanagrafica='.prepare($records[0]['idanagrafica']));
|
||
|
$campi_mancanti = [];
|
||
|
|
||
|
if ($rs2[0]['piva'] == '') {
|
||
|
if ($rs2[0]['codice_fiscale'] == '') {
|
||
|
array_push($campi_mancanti, 'codice fiscale');
|
||
|
}
|
||
|
}
|
||
|
if ($rs2[0]['citta'] == '') {
|
||
|
array_push($campi_mancanti, 'citta');
|
||
|
}
|
||
|
if ($rs2[0]['indirizzo'] == '') {
|
||
|
array_push($campi_mancanti, 'indirizzo');
|
||
|
}
|
||
|
if ($rs2[0]['cap'] == '') {
|
||
|
array_push($campi_mancanti, 'C.A.P.');
|
||
|
}
|
||
|
|
||
|
if ($dir == 'entrata') {
|
||
|
if (sizeof($campi_mancanti) > 0) {
|
||
|
echo "<div class='alert alert-warning'><i class='fa fa-warning'></i> Prima di procedere alla stampa completa i seguenti campi dell'anagrafica:<br/><b>".implode(', ', $campi_mancanti).'</b><br/>
|
||
|
'.Modules::link('Anagrafiche', $records[0]['idanagrafica'], _('Vai alla scheda anagrafica <i class="fa fa-chevron-right"></i>'), null).'</div>';
|
||
|
} else {
|
||
|
if ($records[0]['descrizione_tipodoc'] == 'Fattura accompagnatoria di vendita') {
|
||
|
?>
|
||
|
<a class="btn btn-info btn-sm pull-right" href="<?php echo $rootdir ?>/pdfgen.php?ptype=fatture_accompagnatorie&iddocumento=<?php echo $id_record ?>" target="_blank"><i class="fa fa-print"></i> Stampa fattura</a>
|
||
|
<?php
|
||
|
|
||
|
} else {
|
||
|
?>
|
||
|
<a class="btn btn-info btn-sm pull-right" href="<?php echo $rootdir ?>/pdfgen.php?ptype=fatture&iddocumento=<?php echo $id_record ?>" target="_blank"><i class="fa fa-print"></i> Stampa fattura</a>
|
||
|
<?php
|
||
|
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
?>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="clearfix"></div>
|
||
|
<br>
|
||
|
|
||
|
<div class="row">
|
||
|
<div class="col-md-12">
|
||
|
<?php
|
||
|
include $docroot.'/modules/fatture/row-list.php';
|
||
|
?>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
{( "name": "filelist_and_upload", "id_module": "<?php echo $id_module ?>", "id_record": "<?php echo $id_record ?>" )}
|
||
|
|
||
|
<script type="text/javascript">
|
||
|
$('#idanagrafica').change( function(){
|
||
|
session_set('superselect,idanagrafica', $(this).val(), 0);
|
||
|
|
||
|
$("#idsede").selectReset();
|
||
|
});
|
||
|
</script>
|
||
|
|
||
|
<a class="btn btn-danger ask" data-backto="record-list">
|
||
|
<i class="fa fa-trash"></i> <?php echo _('Elimina'); ?>
|
||
|
</a>
|