1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-01-22 03:55:36 +01:00
openstamanager/modules/primanota/add.php

440 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="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 FROM co_scadenziario WHERE id='.prepare($idscadenza));
$descrizione = tr('Pag. _OP_ del _DATE_', [
'_OP_' => $scadenza['descrizione'],
'_DATE_' => Translator::dateToLocale($scadenza['scadenza']),
]);
}
?>
<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>