1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-01-22 20:09:58 +01:00
openstamanager/modules/primanota/movimenti.php

330 lines
8.8 KiB
PHP
Raw Normal View History

2019-07-31 18:22:35 +02:00
<?php
2020-09-07 15:04:06 +02:00
/*
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
* Copyright (C) DevCode s.n.c.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
2019-07-31 18:22:35 +02:00
include_once __DIR__.'/../../core.php';
use Modules\Fatture\Fattura;
2019-07-31 18:22:35 +02:00
function renderRiga($id, $riga)
{
2019-07-31 18:22:35 +02:00
// Conto
echo '
<tr>
2020-08-10 10:20:22 +02:00
<input type="hidden" name="id_documento['.$id.']" value="'.$riga['iddocumento'].'">
<input type="hidden" name="id_scadenza['.$id.']" value="'.$riga['id_scadenza'].'">
<td>
{[ "type": "select", "name": "idconto['.$id.']", "id": "conto'.$id.'", "value": "'.($riga['id_conto'] ?: '').'", "ajax-source": "conti" ]}
</td>';
2019-07-31 18:22:35 +02:00
// Dare
echo '
<td>
{[ "type": "number", "name": "dare['.$id.']", "id": "dare'.$id.'", "value": "'.($riga['dare'] ?: 0).'" ]}
</td>';
2019-07-31 18:22:35 +02:00
// Avere
echo '
<td>
{[ "type": "number", "name": "avere['.$id.']", "id": "avere'.$id.'", "value": "'.($riga['avere'] ?: 0).'" ]}
</td>
</tr>';
2019-07-31 18:22:35 +02:00
}
2020-08-10 10:20:22 +02:00
function renderTabella($nome, $righe)
{
global $counter;
2020-08-10 10:20:22 +02:00
$prima_riga = $righe->first();
$id_documento = $prima_riga ? $prima_riga['iddocumento'] : null;
$id_scadenza = $prima_riga ? $prima_riga['id_scadenza'] : null;
echo '
2020-08-10 10:20:22 +02:00
<div class="raggruppamento_primanota" data-id_scadenza="'.$id_scadenza.'" data-id_documento="'.$id_documento.'">
<button class="btn btn-info btn-xs pull-right" type="button" onclick="addRiga(this)">
2019-11-25 19:30:50 +01:00
<i class="fa fa-plus"></i> '.tr('Aggiungi riga').'
</button>
<h4>'.$nome.'</h4>
<table class="table table-striped table-condensed table-hover table-bordered scadenze">
<thead>
<tr>
<th>'.tr('Conto').'</th>
<th width="20%">'.tr('Dare').'</th>
<th width="20%">'.tr('Avere').'</th>
</tr>
</thead>
<tbody>';
foreach ($righe as $riga) {
renderRiga($counter++, $riga);
}
// Totale per controllare sbilancio
echo '
</tbody>
<tfoot>
2019-07-31 18:22:35 +02:00
<tr>
<td class="text-right"><b>'.tr('Totale').':</b></td>';
2019-07-31 18:22:35 +02:00
// Totale dare
echo '
<td class="text-right">
<span class="totale_dare"></span> '.currency().'
2019-07-31 18:22:35 +02:00
</td>';
// Totale avere
echo '
<td class="text-right">
<span class="totale_avere"></span> '.currency().'
2019-07-31 18:22:35 +02:00
</td>
</tr>';
echo '
</tfoot>
</table>';
// Verifica dello sbilancio
echo '
<div class="alert alert-warning hide sbilancio">
<i class="fa fa-warning"></i> '.tr('Sbilancio di _MONEY_', [
'_MONEY_' => '<span class="money"></span> '.currency(),
]).'
</div>
</div>';
}
$counter = 0;
$movimenti = collect($movimenti);
// Elenco per documenti
$scadenze = $movimenti
->where('iddocumento', '<>', '')
->groupBy('iddocumento');
foreach ($scadenze as $id_documento => $righe) {
$documento = Fattura::find($id_documento);
$nome = tr('Documento num. _NUM_', [
'_NUM_' => $documento['numero_esterno'] ?: $documento['numero'],
]);
2020-08-10 10:20:22 +02:00
renderTabella($nome, $righe);
}
// Elenco per scadenze
$scadenze = $movimenti
->where('iddocumento', '=', '')
->where('id_scadenza', '<>', '')
->groupBy('id_scadenza');
foreach ($scadenze as $id_scadenza => $righe) {
$nome = tr('Scadenza num. _ID_', [
'_ID_' => $id_scadenza,
]);
2020-08-10 10:20:22 +02:00
renderTabella($nome, $righe);
}
// Elenco generale
$movimenti_generali = $movimenti
->where('iddocumento', '=', '')
->where('id_scadenza', '=', '');
if ($movimenti_generali->isEmpty()) {
$movimenti_generali->push([]);
$movimenti_generali->push([]);
}
$nome = tr('Generale');
renderTabella($nome, $movimenti_generali);
// Nuova riga
2019-07-31 18:22:35 +02:00
echo '
<table class="hide">
<tbody id="template">';
renderRiga('-id-', [
2020-08-10 10:20:22 +02:00
'iddocumento' => '-id_documento-',
'id_scadenza' => '-id_scadenza-',
]);
echo '
</tbody>
</table>';
2019-07-31 18:22:35 +02:00
echo '
<script>
var formatted_zero = "'.Translator::numberToLocale(0).'";
var n = '.$counter.';
2019-07-31 18:22:35 +02:00
function addRiga(btn) {
var raggruppamento = $(btn).parent();
cleanup_inputs();
var tabella = raggruppamento.find("tbody");
var content = $("#template").html();
2020-08-10 10:20:22 +02:00
content = content.replace("-id_scadenza-", raggruppamento.data("id_scadenza"))
.replace("-id_documento-", raggruppamento.data("id_documento"));
var text = replaceAll(content, "-id-", "" + n);
tabella.append(text);
restart_inputs();
n++;
}
/**
* Funzione per controllare lo stato dei conti della prima nota.
*
* @returns {boolean}
*/
function controllaConti() {
var continuare = true;
// Controlli sullo stato dei raggruppamenti
$(".raggruppamento_primanota").each(function() {
var bilancio = calcolaBilancio(this);
continuare &= bilancio == 0;
2019-07-31 18:22:35 +02:00
});
// Blocco degli input con valore non impostato
$("input[id*=dare], input[id*=avere]").each(function() {
var conto_relativo = $(this).parent().parent().find("select").val();
if (!conto_relativo) {
$(this).prop("disabled", true);
}
if ($(this).val().toEnglish()){
continuare &= conto_relativo ? true : false;
}
});
if (continuare) {
$("#add-submit").removeClass("hide");
$("#btn_crea_modello").removeClass("hide");
} else {
$("#add-submit").addClass("hide");
$("#btn_crea_modello").addClass("hide");
}
return continuare;
}
2019-07-31 18:22:35 +02:00
/**
* Ad ogni modifica dell\'importo verifica che siano stati selezionati: il conto, la causale, la data.
* Inoltre aggiorna lo sbilancio.
*
* @param gruppo
* @returns {number}
*/
function calcolaBilancio(gruppo) {
var raggruppamento = $(gruppo);
var totale_dare = 0.00;
var totale_avere = 0.00;
// Calcolo il totale dare
raggruppamento.find("input[id*=dare]").each(function() {
2019-07-31 18:22:35 +02:00
valore = $(this).val() ? $(this).val().toEnglish() : 0;
totale_dare += valore;
2019-07-31 18:22:35 +02:00
});
// Calcolo il totale avere
raggruppamento.find("input[id*=avere]").each(function() {
valore = $(this).val() ? $(this).val().toEnglish() : 0;
2019-07-31 18:22:35 +02:00
totale_avere += valore;
});
2019-07-31 18:22:35 +02:00
// Visualizzazione dei totali
raggruppamento.find(".totale_dare").text(totale_dare.toLocale());
raggruppamento.find(".totale_avere").text(totale_avere.toLocale());
// Calcolo il bilancio
2020-01-02 16:10:33 +01:00
var bilancio = totale_dare.toFixed(2) - totale_avere.toFixed(2);
// Visualizzazione dello sbilancio eventuale
var sbilancio = raggruppamento.find(".sbilancio");
var valore_sbilancio = sbilancio.find(".money");
valore_sbilancio.text(bilancio.toLocale());
2019-07-31 18:22:35 +02:00
if (bilancio == 0) {
sbilancio.addClass("hide");
2019-07-31 18:22:35 +02:00
} else {
sbilancio.removeClass("hide");
2019-07-31 18:22:35 +02:00
}
return bilancio;
2019-07-31 18:22:35 +02:00
}
$(document).ready(function() {
controllaConti();
// Fix per l\'inizializzazione degli input
2019-07-31 18:22:35 +02:00
$("input[id*=dare], input[id*=avere]").each(function() {
if ($(this).val() == formatted_zero) {
$(this).prop("disabled", true);
} else {
$(this).prop("disabled", false);
}
});
// Trigger dell\'evento keyup() per la prima volta, per eseguire i dovuti controlli nel caso siano predisposte delle righe in prima nota
$("input[id*=dare][value!=\'\'], input[id*=avere][value!=\'\']").keyup();
2019-07-31 18:22:35 +02:00
$("select[id*=idconto]").click(function() {
$("input[id*=dare][value!=\'\'], input[id*=avere][value!=\'\']").keyup();
2019-07-31 18:22:35 +02:00
});
});
2019-07-31 18:22:35 +02:00
$(document).on("change", "select", function() {
var row = $(this).parent().parent();
2019-07-31 18:22:35 +02:00
if ($(this).parent().parent().find("input[disabled]").length != 1) {
row.find("input").prop("disabled", $(this).val() ? false : true);
}
controllaConti();
});
2019-07-31 18:22:35 +02:00
$(document).on("keyup change", "input[id*=dare]", function() {
var row = $(this).parent().parent();
2019-07-31 18:22:35 +02:00
if (!$(this).prop("disabled")) {
row.find("input[id*=avere]").prop("disabled", $(this).val() ? true : false);
2019-07-31 18:22:35 +02:00
controllaConti();
}
});
2019-07-31 18:22:35 +02:00
$(document).on("keyup change", "input[id*=avere]", function() {
var row = $(this).parent().parent();
if (!$(this).prop("disabled")) {
row.find("input[id*=dare]").prop("disabled", $(this).val() ? true : false);
controllaConti();
}
2019-07-31 18:22:35 +02:00
});
</script>';