mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-01-04 03:50:15 +01:00
444 lines
17 KiB
PHP
444 lines
17 KiB
PHP
<?php
|
|
|
|
include_once __DIR__.'/../../core.php';
|
|
|
|
?><form action="<?php echo ROOTDIR; ?>/controller.php?id_module=<?php echo Modules::get('Prima nota')['id']; ?>" method="post" id="add-form">
|
|
<input type="hidden" name="op" value="add">
|
|
<input type="hidden" name="backto" value="record-edit">
|
|
<input type="hidden" name="iddocumento" id="iddocumento" value="<?php echo get('iddocumento'); ?>">
|
|
<input type="hidden" name="idscadenza" id="idscadenza" value="<?php echo get('idscadenza'); ?>">
|
|
<input type="hidden" name="crea_modello" id="crea_modello" value="0">
|
|
<input type="hidden" name="idmastrino" id="idmastrino" value="0">
|
|
|
|
<?php
|
|
$idscadenza = get('idscadenza');
|
|
$idconto = get('idconto');
|
|
$iddocumento = get('iddocumento');
|
|
$dir = get('dir');
|
|
$insoluto = get('insoluto');
|
|
|
|
if (!empty($insoluto)) {
|
|
echo '<input type="hidden" name="insoluto" value="1">';
|
|
}
|
|
|
|
// Lettura delle variabili nei singoli moduli
|
|
$id_record = $iddocumento;
|
|
$variables = include Modules::filepath(Modules::get('Fatture di vendita')['id'], 'variables.php');
|
|
|
|
if (!empty($iddocumento)) {
|
|
// Lettura numero e tipo di documento
|
|
$query = 'SELECT dir, numero, numero_esterno, data, co_tipidocumento.descrizione AS tdescrizione, idanagrafica AS parent_idanagrafica, (SELECT ragione_sociale FROM an_anagrafiche WHERE idanagrafica=parent_idanagrafica AND deleted_at IS NULL) AS ragione_sociale FROM co_documenti LEFT OUTER JOIN co_tipidocumento ON co_documenti.idtipodocumento=co_tipidocumento.id WHERE co_documenti.id='.prepare($iddocumento);
|
|
$rs = $dbo->fetchArray($query);
|
|
$dir = $rs[0]['dir'];
|
|
$numero_doc = !empty($rs[0]['numero_esterno']) ? $rs[0]['numero_esterno'] : $rs[0]['numero'];
|
|
$tipo_doc = $rs[0]['tdescrizione'];
|
|
|
|
$nota_credito = false;
|
|
|
|
if ($tipo_doc == 'Nota di credito') {
|
|
$nota_credito = true;
|
|
$tipo_doc = 'nota di credito';
|
|
} elseif ($tipo_doc == 'Nota di debito') {
|
|
$tipo_doc = 'nota di debito';
|
|
} else {
|
|
$tipo_doc = 'fattura';
|
|
}
|
|
|
|
if (!empty($insoluto)) {
|
|
$operation = 'Registrazione insoluto';
|
|
} else {
|
|
$operation = 'Pag.';
|
|
}
|
|
|
|
$descrizione = tr('_OP_ _DOC_ num. _NUM_ del _DATE_ (_NAME_)', [
|
|
'_OP_' => $operation,
|
|
'_DOC_' => $tipo_doc,
|
|
'_NUM_' => $numero_doc,
|
|
'_DATE_' => Translator::dateToLocale($rs[0]['data']),
|
|
'_NAME_' => $rs[0]['ragione_sociale'],
|
|
]);
|
|
|
|
/*
|
|
Predisposizione prima riga
|
|
*/
|
|
$field = 'idconto_'.($dir == 'entrata' ? 'vendite' : 'acquisti');
|
|
$idconto_aziendale = $dbo->fetchArray('SELECT '.$field.' FROM co_pagamenti WHERE id = (SELECT idpagamento FROM co_documenti WHERE id='.prepare($iddocumento).') GROUP BY descrizione')[0][$field];
|
|
|
|
// Lettura conto di default
|
|
$idconto_aziendale = !empty($idconto_aziendale) ? $idconto_aziendale : setting('Conto aziendale predefinito');
|
|
|
|
// Generazione causale (incasso fattura)
|
|
$descrizione_conto_aziendale = $descrizione;
|
|
|
|
/*
|
|
Calcolo totale per chiudere la fattura
|
|
*/
|
|
// Lettura importo da scadenzario (seleziono l'importo di questo mese)
|
|
$query = 'SELECT *, scadenza, ABS(da_pagare-pagato) AS rata FROM co_scadenziario WHERE iddocumento='.prepare($iddocumento).' AND ABS(da_pagare) > ABS(pagato) ORDER BY YEAR(scadenza) ASC, MONTH(scadenza) ASC';
|
|
$rs = $dbo->fetchArray($query);
|
|
$importo_conto_aziendale = $rs[0]['rata'];
|
|
|
|
if ($dir == 'entrata') {
|
|
$totale_dare = abs($importo_conto_aziendale);
|
|
} else {
|
|
$totale_dare = abs($importo_conto_aziendale);
|
|
}
|
|
|
|
// Può essere che voglia inserire un movimento in un mese diverso da quello previsto per l'incasso, perciò devo
|
|
// leggere solo il totale rimanente della fattura rispetto a quello pagato invece di leggere quello da pagare
|
|
// per il mese corrente (viene calcolato sopra)
|
|
if ($totale_dare == 0) {
|
|
// Lettura totale finora pagato
|
|
$query = 'SELECT SUM(pagato) AS tot_pagato, SUM(da_pagare) AS tot_da_pagare FROM co_scadenziario GROUP BY iddocumento HAVING iddocumento='.prepare($iddocumento);
|
|
$rs = $dbo->fetchArray($query);
|
|
|
|
if (!empty($insoluto)) {
|
|
$importo_conto_aziendale = abs($rs[0]['tot_da_pagare']);
|
|
} else {
|
|
$importo_conto_aziendale = abs($rs[0]['tot_da_pagare']) - abs($rs[0]['tot_pagato']);
|
|
}
|
|
$totale_dare = $importo_conto_aziendale;
|
|
}
|
|
|
|
/*
|
|
Predisposizione seconda riga
|
|
*/
|
|
// conto crediti clienti
|
|
if ($dir == 'entrata') {
|
|
// Se è la prima nota di una fattura leggo il conto del cliente
|
|
if ($iddocumento != '') {
|
|
$query = 'SELECT idconto_cliente FROM an_anagrafiche INNER JOIN co_documenti ON an_anagrafiche.idanagrafica=co_documenti.idanagrafica WHERE co_documenti.id='.prepare($iddocumento);
|
|
$rs = $dbo->fetchArray($query);
|
|
$idconto_controparte = $rs[0]['idconto_cliente'];
|
|
} else {
|
|
$query = "SELECT id FROM co_pianodeiconti3 WHERE descrizione='Riepilogativo clienti'";
|
|
$rs = $dbo->fetchArray($query);
|
|
$idconto_controparte = $rs[0]['id'];
|
|
}
|
|
}
|
|
|
|
// conto debiti fornitori
|
|
else {
|
|
// Se è la prima nota di una fattura leggo il conto del fornitore
|
|
if ($iddocumento != '') {
|
|
$query = 'SELECT idconto_fornitore FROM an_anagrafiche INNER JOIN co_documenti ON an_anagrafiche.idanagrafica=co_documenti.idanagrafica WHERE co_documenti.id='.prepare($iddocumento);
|
|
$rs = $dbo->fetchArray($query);
|
|
$idconto_controparte = $rs[0]['idconto_fornitore'];
|
|
} else {
|
|
$query = "SELECT id FROM co_pianodeiconti3 WHERE descrizione='Riepilogativo fornitori'";
|
|
$rs = $dbo->fetchArray($query);
|
|
$idconto_controparte = $rs[0]['id'];
|
|
}
|
|
}
|
|
$_SESSION['superselect']['idconto_controparte'] = $idconto_controparte;
|
|
|
|
// Lettura causale movimento (documento e ragione sociale)
|
|
$descrizione_conto_controparte = $descrizione;
|
|
$importo_conto_controparte = $importo_conto_aziendale;
|
|
|
|
if ($dir == 'entrata') {
|
|
$totale_avere = $importo_conto_controparte;
|
|
} else {
|
|
$totale_avere = $importo_conto_controparte;
|
|
}
|
|
} else {
|
|
$scadenza = $dbo->fetchOne('SELECT descrizione, scadenza, SUM(da_pagare-pagato) AS pagare FROM co_scadenziario WHERE id='.prepare($idscadenza));
|
|
|
|
$descrizione = tr('Pag. _OP_ del _DATE_', [
|
|
'_OP_' => $scadenza['descrizione'],
|
|
'_DATE_' => Translator::dateToLocale($scadenza['scadenza']),
|
|
]);
|
|
|
|
$importo_conto_aziendale = $scadenza['pagare'];
|
|
$importo_conto_controparte = $scadenza['pagare'];
|
|
}
|
|
?>
|
|
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
{[ "type": "select", "label": "<?php echo tr('Modello primanota'); ?>", "id": "modello_primanota", "values": "query=SELECT idmastrino AS id, nome AS descrizione, descrizione as causale FROM co_movimenti_modelli GROUP BY idmastrino" ]}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<div class="col-md-4">
|
|
{[ "type": "date", "label": "<?php echo tr('Data movimento'); ?>", "name": "data", "required": 1, "value": "-now-" ]}
|
|
</div>
|
|
|
|
<div class="col-md-8">
|
|
{[ "type": "text", "label": "<?php echo tr('Causale'); ?>", "name": "descrizione", "id": "desc", "required": 1, "value": <?php echo json_encode($descrizione); ?> ]}
|
|
</div>
|
|
</div>
|
|
|
|
|
|
<?php
|
|
$totale_dare = 0.00;
|
|
$totale_avere = 0.00;
|
|
$idmastrino = $record['idmastrino'];
|
|
|
|
// Salvo l'elenco conti in un array (per non fare il ciclo ad ogni riga)
|
|
|
|
/*
|
|
Form di aggiunta riga movimento
|
|
*/
|
|
echo '
|
|
<table class="table table-striped table-condensed table-hover table-bordered"
|
|
<tr>
|
|
<th>'.tr('Conto').'</th>
|
|
<th width="20%">'.tr('Dare').'</th>
|
|
<th width="20%">'.tr('Avere').'</th>
|
|
</tr>';
|
|
|
|
for ($i = 0; $i < 10; ++$i) {
|
|
($i <= 1) ? $required = 1 : $required = 0;
|
|
// Conto
|
|
echo '
|
|
<tr>
|
|
<td>
|
|
{[ "type": "select", "name": "idconto['.$i.']", "id": "conto'.$i.'", "value": "';
|
|
if ($i == 0) {
|
|
echo $idconto_controparte;
|
|
} elseif ($i == 1) {
|
|
echo $idconto_aziendale;
|
|
}
|
|
echo '", "ajax-source": "conti", "required": "'.$required.'" ]}
|
|
</td>';
|
|
|
|
// Importo dare e avere
|
|
if ($i == 0) {
|
|
if ($dir == 'entrata') {
|
|
$value_dare = '';
|
|
$value_avere = $importo_conto_aziendale;
|
|
} else {
|
|
$value_dare = $importo_conto_aziendale;
|
|
$value_avere = '';
|
|
}
|
|
} elseif ($i == 1) {
|
|
if ($dir == 'entrata') {
|
|
$value_dare = $importo_conto_controparte;
|
|
$value_avere = '';
|
|
} else {
|
|
$value_dare = '';
|
|
$value_avere = $importo_conto_controparte;
|
|
}
|
|
} else {
|
|
$value_dare = '';
|
|
$value_avere = '';
|
|
}
|
|
|
|
// Se è una nota di credito, inverto i valori
|
|
if ($nota_credito || $insoluto) {
|
|
$tmp = $value_dare;
|
|
$value_dare = $value_avere;
|
|
$value_avere = $tmp;
|
|
}
|
|
|
|
// Dare
|
|
echo '
|
|
<td>
|
|
{[ "type": "number", "name": "dare['.$i.']", "value": "'.$value_dare.'", "disabled": 1 ]}
|
|
</td>';
|
|
|
|
// Avere
|
|
echo '
|
|
<td>
|
|
{[ "type": "number", "name": "avere['.$i.']", "value": "'.$value_avere.'", "disabled": 1 ]}
|
|
</td>
|
|
</tr>';
|
|
}
|
|
|
|
// Totale per controllare sbilancio
|
|
echo '
|
|
<tr>
|
|
<td align="right"><b>'.tr('Totale').':</b></td>';
|
|
|
|
// Totale dare
|
|
echo '
|
|
<td align="right">
|
|
<span><span id="totale_dare"></span> '.currency().'</span>
|
|
</td>';
|
|
|
|
// Totale avere
|
|
echo '
|
|
<td align="right">
|
|
<span><span id="totale_avere"></span> '.currency().'</span>
|
|
</td>
|
|
</tr>';
|
|
|
|
// Verifica sbilancio
|
|
echo '
|
|
<tr>
|
|
<td align="right"></td>
|
|
<td colspan="2" align="center">
|
|
<span id="testo_aggiuntivo"></span>
|
|
</td>
|
|
</tr>
|
|
</table>';
|
|
?>
|
|
|
|
<!-- PULSANTI -->
|
|
<div class="row">
|
|
<div class="col-md-12 text-right">
|
|
<button type='button' class="btn btn-default" id='btn_crea_modello'><i class="fa fa-plus"></i> <?php echo tr('Aggiungi e crea modello'); ?></button>
|
|
<button type="submit" class="btn btn-primary" id='btn_submit'><i class="fa fa-plus"></i> <?php echo tr('Aggiungi'); ?></button>
|
|
</div>
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
|
$(document).ready( function(){
|
|
$('#bs-popup input[id*=dare], #bs-popup input[id*=avere]').each(function(){
|
|
if($(this).val() != "<?php echo Translator::numberToLocale(0); ?>") $(this).prop("disabled", false);
|
|
});
|
|
|
|
$('select').on('change', function(){
|
|
if($(this).parent().parent().find('input[disabled]').length != 1){
|
|
if($(this).val()) {
|
|
$(this).parent().parent().find('input').prop("disabled", false);
|
|
}
|
|
else{
|
|
$(this).parent().parent().find('input').prop("disabled", true);
|
|
$(this).parent().parent().find('input').val("0.00");
|
|
}
|
|
}
|
|
});
|
|
|
|
$('#bs-popup input[id*=dare]').on('keyup change', function(){
|
|
if(!$(this).prop('disabled')){
|
|
if($(this).val()) {
|
|
$(this).parent().parent().find('#bs-popup input[id*=avere]').prop("disabled", true);
|
|
}
|
|
else {
|
|
$(this).parent().parent().find('#bs-popup input[id*=avere]').prop("disabled", false);
|
|
}
|
|
|
|
calcolaBilancio();
|
|
}
|
|
});
|
|
|
|
$('#bs-popup input[id*=avere]').on('keyup change', function(){
|
|
if(!$(this).prop('disabled')){
|
|
if($(this).val()) {
|
|
$(this).parent().parent().find('#bs-popup input[id*=dare]').prop("disabled", true);
|
|
}
|
|
else {
|
|
$(this).parent().parent().find('#bs-popup input[id*=dare]').prop("disabled", false);
|
|
}
|
|
|
|
calcolaBilancio();
|
|
}
|
|
});
|
|
|
|
// Ad ogni modifica dell'importo verifica che siano stati selezionati: il conto, la causale, la data. Inoltre aggiorna lo sbilancio
|
|
function calcolaBilancio(){
|
|
bilancio = 0.00;
|
|
totale_dare = 0.00;
|
|
totale_avere = 0.00;
|
|
|
|
// Calcolo il totale dare e totale avere
|
|
$('#bs-popup input[id*=dare]').each( function(){
|
|
if( $(this).val() == '' ) valore = 0;
|
|
else valore = $(this).val().toEnglish();
|
|
totale_dare += Math.round(valore*100)/100;
|
|
});
|
|
|
|
$('#bs-popup input[id*=avere]').each( function(){
|
|
if( $(this).val() == '' ) valore = 0;
|
|
else valore = $(this).val().toEnglish();
|
|
totale_avere += Math.round(valore*100)/100;
|
|
});
|
|
|
|
$('#bs-popup #totale_dare').text(totale_dare.toLocale());
|
|
$('#bs-popup #totale_avere').text(totale_avere.toLocale());
|
|
|
|
bilancio = Math.round(totale_dare*100)/100 - Math.round(totale_avere*100)/100;
|
|
|
|
if(bilancio == 0){
|
|
$('#bs-popup #testo_aggiuntivo').removeClass('text-danger').html("");
|
|
$('#bs-popup #btn_submit').removeClass('hide');
|
|
$('#bs-popup #btn_crea_modello').removeClass('hide');
|
|
}
|
|
else{
|
|
$('#bs-popup #testo_aggiuntivo').addClass('text-danger').html("sbilancio di " + bilancio.toLocale() + " " + globals.currency );
|
|
$('#bs-popup #btn_submit').addClass('hide');
|
|
$('#bs-popup #btn_crea_modello').addClass('hide');
|
|
}
|
|
}
|
|
|
|
// Trigger dell'evento keyup() per la prima volta, per eseguire i dovuti controlli nel caso siano predisposte delle righe in prima nota
|
|
$("#bs-popup input[id*=dare][value!=''], #bs-popup input[id*=avere][value!='']").keyup();
|
|
|
|
$("#bs-popup select[id*=idconto]").click( function(){
|
|
$("#bs-popup input[id*=dare][value!=''], #bs-popup input[id*=avere][value!='']").keyup();
|
|
});
|
|
|
|
|
|
$('#bs-popup #modello_primanota').change(function(){
|
|
|
|
if ($(this).val()!=''){
|
|
$('#btn_crea_modello').html('<i class="fa fa-edit"></i> '+'<?php echo tr('Aggiungi e modifica modello'); ?>');
|
|
$('#bs-popup #idmastrino').val($(this).val());
|
|
}else{
|
|
$('#btn_crea_modello').html('<i class="fa fa-plus"></i> '+'<?php echo tr('Aggiungi e crea modello'); ?>');
|
|
$('#bs-popup #idmastrino').val(0);
|
|
}
|
|
|
|
var idmastrino = $(this).val();
|
|
var variables = <?php echo json_encode($variables); ?>;
|
|
|
|
var replaced = 0;
|
|
|
|
if(idmastrino!=''){
|
|
var causale = $(this).find('option:selected').data('causale');
|
|
|
|
if($('#iddocumento').val()!=''){
|
|
for (i in variables){
|
|
if(causale.includes('{'+i+'}')){
|
|
replaced++;
|
|
causale = causale.replace('{'+i+'}', variables[i]);
|
|
}
|
|
}
|
|
}else{
|
|
for (i in variables){
|
|
causale = causale.replace('{'+i+'}', '_');
|
|
}
|
|
}
|
|
|
|
//aggiornava erroneamente anche la causale ed eventuale numero di fattura e data
|
|
if(replaced>0 || $('#iddocumento').val()==''){
|
|
$('#bs-popup #desc').val(causale);
|
|
}
|
|
|
|
$.get('<?php echo $rootdir; ?>/ajax_complete.php?op=get_conti&idmastrino='+idmastrino, function(data){
|
|
var conti = data.split(',');
|
|
for(i=0;i<conti.length;i++){
|
|
var conto = conti[i].split(';');
|
|
//Sostituzione conto cliente/fornitore
|
|
if(conto[0]==-1){
|
|
if($('#iddocumento').val()!=''){
|
|
var option = $("<option selected></option>").val(variables['conto']).text(variables['conto_descrizione']);
|
|
$('#bs-popup #conto'+i).selectReset();
|
|
$('#bs-popup #conto'+i).append(option).trigger('change');
|
|
}
|
|
}else{
|
|
var option = $("<option selected></option>").val(conto[0]).text(conto[1]);
|
|
$('#bs-popup #conto'+i).selectReset();
|
|
$('#bs-popup #conto'+i).append(option).trigger('change');
|
|
}
|
|
}
|
|
for(i=9;i>=conti.length;i--){
|
|
$('#bs-popup #conto'+i).selectReset();
|
|
console.log('#bs-popup #conto'+i);
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
$('#bs-popup #btn_crea_modello').click(function(){
|
|
$('#bs-popup #crea_modello').val("1");
|
|
$('#bs-popup #add-form').submit();
|
|
});
|
|
|
|
});
|
|
</script>
|
|
</form>
|