Skudlerings

Ricomincia a dare risultati sensati (finalmente)


git-svn-id: svn://10.65.10.50/trunk@897 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
villa 1995-01-23 11:52:11 +00:00
parent 24cc12f6dd
commit 0c61ac5a86
3 changed files with 223 additions and 193 deletions

View File

@ -880,16 +880,22 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
// Calcolo liq. mensili e liq. annuali // Calcolo liq. mensili e liq. annuali
{ {
TToken_string atts(codatts); TToken_string atts(codatts);
TToken_string tt(60);
const char* tmpatt; const char* tmpatt;
real risultato = 0.0; real risultato = 0.0;
real vol_aff = 0.0;
real debito_prec = 0.0;
real detrazioni = 0.0; real detrazioni = 0.0;
real versamenti = 0.0; real versamenti = 0.0;
real vers_int = 0.0; real vers_int = 0.0;
real rimborsi = 0.0; real rimborsi = 0.0;
real rettifiche = 0.0; real rettifiche = 0.0;
real res_debt = 0.0;
real res_cred = 0.0;
real cred_prec = 0.0;
real debt_precd = 0.0;
real acc_dec = 0.0;
real iva_vend = 0.0;
real iva_acq = 0.0;
// totali per agenzie viaggio // totali per agenzie viaggio
real c_iCEE = 0.0; real c_iCEE = 0.0;
@ -910,7 +916,7 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
{ {
TString att(tmpatt); TString att(tmpatt);
if (_isdifferita && is_first_month(month) && attc == 0) if (_isdifferita && is_first_month(month))
{ {
// usa i totali del mese di dicembre dell'anno // usa i totali del mese di dicembre dell'anno
// precedente // precedente
@ -924,22 +930,33 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
} }
} }
if (differita) if (differita)
{ {
risultato = result_liq(12); if (attc == 0)
deb_mens = _lim->get_real("R3"); {
detrazioni= _lim->get_real("R6"); risultato = result_liq(12);
perc_r = _lim->get_real("R4"); deb_mens = _lim->get_real("R3");
cred_cost = _lim->get_real("R2"); detrazioni= _lim->get_real("R6");
rettifiche= _lim->get_real("R5"); perc_r = _lim->get_real("R4");
rimborsi = _lim->get_real("R1"); cred_cost = _lim->get_real("R2");
_year = format("%d", atoi(_year)+1); rettifiche= _lim->get_real("R5");
rimborsi = _lim->get_real("R1");
// leggi anche tutti gli altri totali
tt = _lim->get("S0");
iva_vend = tt.get(); iva_acq = tt.get();
tt = _lim->get("S1");
res_debt = tt.get(); res_cred = tt.get();
tt = _lim->get("S2");
cred_prec = tt.get(); debt_precd = tt.get();
acc_dec = (const char*)_lim->get("S3");
_year = format("%d", atoi(_year)+1);
}
} }
else else
{ {
for (int m = 1; m <= month; m++) for (int m = 1; m <= 12; m++)
{ {
// ciclo su tutti i mesi del caso (1 o 3; // ciclo su tutti i mesi del caso (1 o 3;
// tutti se annuale, compreso 13 // tutti se annuale)
if (!is_month_ok(m, month)) if (!is_month_ok(m, month))
continue; continue;
@ -949,37 +966,48 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
// gia' conteggiato: prorata // gia' conteggiato: prorata
// da conteggiare: IVA vendite ag. viaggio // da conteggiare: IVA vendite ag. viaggio
// a debito: IVA vendite, debito precedente // a debito: IVA vendite, debito precedente
// a credito: IVA acquisti, ulteriori detrazioni 1 e 2 // a credito: IVA acquisti, ulteriori detrazioni 1 e 2
iva_vend += _plm->get_real("R0");
iva_acq += _plm->get_real("R1");
risultato += (_plm->get_real("R0") - _plm->get_real("R1")); risultato += (_plm->get_real("R0") - _plm->get_real("R1"));
detrazioni+= (_plm->get_real("R3") + _plm->get_real("R4")); detrazioni+= (_plm->get_real("R3") + _plm->get_real("R4"));
res_debt += _plm->get_real("R0");
res_cred += _plm->get_real("R1");
// detrazioni solo non in regime agricolo // detrazioni solo non in regime agricolo
if (!_isagricolo) if (!_isagricolo)
{
risultato -= (_plm->get_real("R3") + _plm->get_real("R4")); risultato -= (_plm->get_real("R3") + _plm->get_real("R4"));
res_cred += (_plm->get_real("R3") + _plm->get_real("R4"));
}
/* se annuale, somma versamenti mesi 1-12 /* se annuale, somma versamenti mesi 1-12
* solo una volta (non per tutte le attivita') * solo una volta (non per tutte le attivita')
*/ */
if (attc == 0 && month == 13 && m < 13) if (attc == 0 && month == 13)
{ {
// l'acconto a dicembre si conteggia a parte solo // l'acconto a dicembre si conteggia a parte solo
// nei casi previsti e non in annuale (vedi sotto) // nei casi previsti e non in annuale (vedi sotto)
versamenti += versamenti_IVA(m , m == 12 ? "1" : "1|7"); real vs(versamenti_IVA(m , m == 12 ? "1" : "1|7"));
vers_int += versamenti_IVA(m,"5"); real vi(versamenti_IVA(m,"5"));
versamenti += vs;
vers_int += vi;
res_cred += vs + vi;
} }
/* /*
* rimborso se chiesto e previsto * rimborso se chiesto e previsto
*/ */
if (attc == 0 && is_lim && m < 13) if (attc == 0 && is_lim)
{ {
risultato -= _lim->get_real("R1"); risultato -= _lim->get_real("R1");
rimborsi += _lim->get_real("R1"); rimborsi += _lim->get_real("R1");
res_debt += _lim->get_real("R1");
} }
/* /*
* rettifiche gia' col loro bravo segno * rettifiche gia' col loro bravo segno
*/ */
if (attc == 0 && is_lim && m < 13) if (attc == 0 && is_lim)
{ {
// benzinaro le conta solo in annuale, // benzinaro le conta solo in annuale,
// non benzinaro solo in periodica // non benzinaro solo in periodica
@ -989,6 +1017,10 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
{ {
risultato += _lim->get_real("R5"); risultato += _lim->get_real("R5");
rettifiche += _lim->get_real("R5"); rettifiche += _lim->get_real("R5");
if (_lim->get_real("R5").sign() < 0)
res_cred += abs(_lim->get_real("R5"));
else
res_debt += abs(_lim->get_real("R5"));
} }
} }
@ -1011,12 +1043,6 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
if (!(_isdifferita && is_first_month(month))) if (!(_isdifferita && is_first_month(month)))
{ {
// toglie credito precedente considerando rimborsi
// e acconto versato e rettifiche, come da manuale
risultato -= credito_prec(month);
// vedi se c'era un debito precedente per debiti < 50.000
risultato += debt_prec(month);
if (_isviaggio) if (_isviaggio)
{ {
// calcolo credito costo, debito mensile, perc. ripart. // calcolo credito costo, debito mensile, perc. ripart.
@ -1037,16 +1063,44 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
deb_mens = (bi /((CENTO + aliquota_agvia())/CENTO)) * deb_mens = (bi /((CENTO + aliquota_agvia())/CENTO)) *
(aliquota_agvia()/CENTO); (aliquota_agvia()/CENTO);
deb_mens.round(ROUND_LIRA); deb_mens.round(ROUND_LIRA);
risultato += deb_mens; risultato += deb_mens;
res_debt += deb_mens;
} }
} }
} }
} }
if (!(_isdifferita && is_first_month(month)))
{
if (month < 13)
{
// toglie credito precedente
cred_prec = credito_prec(month);
risultato -= cred_prec;
res_cred += cred_prec;
// vedi se c'era un debito precedente per debiti < 50.000
debt_precd = debt_prec(month);
risultato += debt_precd;
res_debt += debt_precd;
}
else
{
// per l'annuale considera solo il credito a inizio anno
cred_prec = credito_prec(1);
risultato -= cred_prec;
res_cred += cred_prec;
}
}
look_lim(month,TRUE);
// azzeriamo tutto
TString codtab = _lim->get("CODTAB");
_lim->zero();
_lim->put("CODTAB", codtab);
look_lim(month,TRUE);
/* /*
* versamenti effettuati: si conteggiano in R0, * versamenti effettuati: si conteggiano in R0,
* sono >0 solo se andavano calcolati (vedi sopra) * sono > 0 solo se andavano calcolati (vedi sopra)
*/ */
risultato -= (versamenti + vers_int); risultato -= (versamenti + vers_int);
/* /*
@ -1054,15 +1108,20 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
*/ */
if ((month == 12 && _isbenzinaro) || if ((month == 12 && _isbenzinaro) ||
(month >= 12 && _freqviva == "M")) (month >= 12 && _freqviva == "M"))
{
risultato -= versamenti_IVA(12,"7"); risultato -= versamenti_IVA(12,"7");
acc_dec = versamenti_IVA(12,"7");
}
risultato.round(month == 13 ? ROUND_MILLELIRE : ROUND_LIRA);
_lim->put("R0",risultato); _lim->put("R0",risultato);
_lim->put("R2",cred_cost); _lim->put("R2",cred_cost);
_lim->put("R3",deb_mens); _lim->put("R3",deb_mens);
_lim->put("R4",perc_r); _lim->put("R4",perc_r);
_lim->put("R6",detrazioni); _lim->put("R6",detrazioni);
if (month == 13 && differita) if (month == 13 || differita)
{ {
// scrivi totali rettifiche e rimborsi // scrivi totali rettifiche e rimborsi
// nella finale oppure se copiati da // nella finale oppure se copiati da
@ -1074,17 +1133,32 @@ void TLiquidazione_app::write_liq(int month, const char* codatts)
/* /*
* Interessi dovuti solo da trimestrali in periodica, * Interessi dovuti solo da trimestrali in periodica,
* non benzinari * non benzinari
*/ */
if (_freqviva == "T" && risultato.sign() > 0 && if (_freqviva == "T" && risultato.sign() > 0 &&
month < 12 && !_isbenzinaro) month < 12 && !_isbenzinaro)
{ {
real interesse = interesse_trimestrale(_month); real interesse = interesse_trimestrale(_month);
real ivi = risultato * interesse / CENTO; ivi.ceil(ROUND_LIRA); real ivi = risultato * (interesse / CENTO);
_lim->put("R7",ivi); ivi.ceil(ROUND_LIRA);
_lim->put("R7", ivi);
_lim->put("R10",interesse_trimestrale(_month));
} }
_lim->put("R8", versamenti); _lim->put("R8", versamenti);
_lim->put("R9", vers_int); _lim->put("R9", vers_int);
// scrivi: totali IVA vendite e acquisti, credito prec,
// debito prec, acconto
// cosi' si fa una volta sola in stampa
tt = iva_vend.string(); tt.add(iva_acq.string());
_lim->put("S0", tt);
tt = res_debt.string(); tt.add(res_cred.string());
_lim->put("S1", tt);
tt = cred_prec.string(); tt.add(debt_precd.string());
_lim->put("S2", tt);
tt = acc_dec.string();
_lim->put("S3", tt);
_lim->put("B0","X"); _lim->put("B0","X");
if (_isfinal) if (_isfinal)

View File

@ -33,6 +33,11 @@ bool TLiquidazione_app::is_month_ok(int x, int mtocalc)
// aggiusta al trimestre il mese da calcolare // aggiusta al trimestre il mese da calcolare
mtocalc += 2 - ((mtocalc-1) % 3); mtocalc += 2 - ((mtocalc-1) % 3);
ret = x >= (mtocalc - 3) && x <= mtocalc; ret = x >= (mtocalc - 3) && x <= mtocalc;
}
else if (!ret && mtocalc == 13)
{
// per l'annuale ritorna TRUE per tutti i mesi da liquidare
ret = x <= 13;
} }
return ret; return ret;
} }
@ -361,7 +366,7 @@ bool TLiquidazione_app::look_lia(bool create, int year)
real TLiquidazione_app::result_liq(int month) real TLiquidazione_app::result_liq(int month)
// risultato esatto della liquidazione del mese month, <0 a credito // risultato esatto della liquidazione del mese month, <0 a credito
// >0 a debito; non comprende il conguaglio prorata (annuale) // > 0 a debito; non comprende il conguaglio prorata (annuale)
{ {
real r(0.0); real r(0.0);
// ulteriori detrazioni, acconti, versamenti, // ulteriori detrazioni, acconti, versamenti,
@ -371,6 +376,7 @@ real TLiquidazione_app::result_liq(int month)
return r; return r;
} }
real TLiquidazione_app::debt_prec(int month) real TLiquidazione_app::debt_prec(int month)
{ {
real r(0.0); real r(0.0);

View File

@ -574,85 +574,38 @@ void TLiquidazione_app::describe_liq(int month, const char* codatts,
_DescrItem* di) _DescrItem* di)
{ {
if (!_isprint || !_canprint) return; if (!_isprint || !_canprint) return;
if (_isannual || _isriepilogo) month = 12; if (!look_lim(month)) return;
_DescrItem* d = new _DescrItem(THE_END); _DescrItem* d = new _DescrItem(THE_END);
TToken_string atts(codatts);
const char* tmpatt; // gli diamo la stessa struttura di LIM
real conguaglio; d->_r0 = _lim->get_real("R0");
d->_r1 = _lim->get_real("R1");
d->_r2 = _lim->get_real("R2");
d->_r3 = _lim->get_real("R3");
d->_r4 = _lim->get_real("R4");
d->_r5 = _lim->get_real("R5");
d->_r6 = _lim->get_real("R6");
d->_r7 = _lim->get_real("R7");
d->_r8 = _lim->get_real("R8");
d->_r9 = _lim->get_real("R9");
d->_s0 = _lim->get("S0");
d->_s1 = _lim->get("S1");
d->_s2 = _lim->get("S2");
d->_s3 = _lim->get("S3");
d->_r11 = (const char*)_lim->get("R10"); // tasso di interesse
// serve per pagare anche meno di 50000 a dicembre if (month == 13)
d->_f1 = month == 12; {
d->_f2 = month; TToken_string a(codatts);
for (int i = 0; i < a.items(); i++)
while ((tmpatt = atts.get()) != NULL) {
{ TString att = a.get();
TString att(tmpatt);
for (int mm = 1; mm <= 12; mm++)
{
if (!is_month_ok(mm, month)) continue;
look_plm(mm, att);
d->_r0 += _plm->get_real("R0"); // IVA vendite
d->_r1 += _plm->get_real("R1"); // IVA acquisti
d->_r2 += _plm->get_real("R3"); // Detrazioni 1
d->_r2 += _plm->get_real("R4"); // Detrazioni 2
d->_r1 -= _plm->get_real("R2"); // pro-rata
}
// ev. conguaglio prorata
if (_isannual || _isriepilogo)
{
look_pla(att); look_pla(att);
conguaglio += _pla->get_real("R10"); // r10 = conguaglio prorata
} d->_r10 += _pla->get_real("R10");
}
} }
look_lim(month);
d->_r3 += _lim->get_real("R0"); // risultato
d->_r4 += _lim->get_real("R1"); // rimborso
if (_lim->get("S7") == "D")
d->_r5 += abs(_lim->get_real("R5")); // rettifiche a debito
else
d->_r6 += abs(_lim->get_real("R5")); // rettifiche a credito
d->_f0 = _freqviva == "T";
// r7 = credito precedente
d->_r7 = credito_prec(month);
// r11 = ulteriori detrazioni
d->_r11 = _lim->get_real("R6");
// se ci sono stati versamenti IVA li riporta in _s2
// e _s3 (integrativi): sono != 0 solo in annuale
d->_s2 = versamenti_IVA(month,"1").string();
d->_s3 = versamenti_IVA(month,"5").string();
// vedi se c'era un debito precedente e schiaffa in r10
if (!is_first_month(month))
{
if (look_lim(previous_month(month)))
{
real r = _lim->get_real("R0");
if (_lim->get_real("R5").sign() > 0)
r += _plm->get_real("R5");
// non considera il rimborso in quanto se e' a debito
// non c'e' rimborso, e se e' rettificato pure
if (r.sign() > 0 && r < IVA_DA_RIPORTARE)
d->_r10 += r;
}
}
if (_isannual || _isriepilogo)
{
look_lia();
// r8 = acconto dicembre
d->_r8 = _lia->get_real("R4");
// r9 = conguaglio prorata
d->_r9 = conguaglio;
}
// aggiunge eventuale satellite per rimborso infraannuale // aggiunge eventuale satellite per rimborso infraannuale
if (di != NULL) d->_arr.add(di); if (di != NULL) d->_arr.add(di);
@ -1012,131 +965,128 @@ void TLiquidazione_app::set_ptm(_DescrItem& d)
void TLiquidazione_app::set_grand(_DescrItem& d) void TLiquidazione_app::set_grand(_DescrItem& d)
{ {
real& risultato = d._r0;
real& rimborso = d._r1;
real& cred_cost = d._r2;
real& deb_mens = d._r3;
real& rettifiche = d._r5;
real& detrazioni = d._r6;
real& interessi = d._r7;
real& versamenti = d._r8;
real& vers_int = d._r9;
TToken_string tt(d._s0);
real iva_vend(tt.get(0));
real iva_acq(tt.get(1));
tt = d._s1;
real res_debt(tt.get(0));
real res_cred(tt.get(1));
tt = d._s2;
real cred_prec(tt.get(0));
real debt_prec(tt.get(1));
real acc_dec(d._s3);
real rett_debt(0.0);
real rett_cred(0.0);
real& interesse = d._r11;
if (rettifiche.sign() > 0) rett_debt = rettifiche;
if (rettifiche.sign() < 0) rett_cred = rettifiche;
set_row(1,""); set_row(2,""); set_row(3,""); set_row(4,""); set_row(1,""); set_row(2,""); set_row(3,""); set_row(4,"");
set_row(5,"@11g@bCALCOLO LIQUIDAZIONE D'IMPOSTA@r"); set_row(5,"@11g@bCALCOLO LIQUIDAZIONE D'IMPOSTA@r");
set_row(6,""); int rw = 7; set_row(6,""); int rw = 7;
set_row(rw++," @66gCredito@84gDebito"); set_row(rw++,""); set_row(rw++," @66gCredito@84gDebito"); set_row(rw++,"");
set_row(rw++,"@11gIva sulle operazioni di vendita@75g%r", &(d._r0)); set_row(rw++,"@11gIva sulle operazioni di vendita@75g%r", &iva_vend);
set_row(rw++,"%s@11gRettifiche IVA a debito@75g%r", set_row(rw++,"%s@11gRettifiche IVA a debito@75g%r",
_is_visliq ? "$[r]" : "", &(d._r5)); _is_visliq ? "$[r]" : "", &rett_debt);
set_row(rw++,"%s@11gIva chiesta a rimborso@75g%r", set_row(rw++,"%s@11gIva chiesta a rimborso@75g%r",
_is_visliq ? "$[r]" : "", &(d._r4)); _is_visliq ? "$[r]" : "", &rimborso);
real rd = d._r0 + d._r5 + d._r4;
real vers;
// conguaglio prorata // conguaglio prorata
if (d._r9.sign() < 0) if (d._r10.sign() > 0)
{ {
real r = abs(d._r9); real r = abs(d._r10);
set_row(rw++,"@11gConguaglio pro-rata@58g%r", &r); set_row(rw++,"@11gConguaglio pro-rata@75g%r", &r);
res_debt += d._r10;
risultato += d._r10;
} }
// debito liq. precedente < 50000 // debito liq. precedente < 50000
if (d._r10 > ZERO) if (debt_prec > ZERO)
{ set_row(rw++,"@11gDebito da liquidazione precedente@75g%r", &debt_prec);
rd += d._r10;
set_row(rw++,"@11gDebito da liquidazione precedente@75g%r", &(d._r10));
}
set_row(rw++,"@11gRISULTATO@75g%r", &rd); set_row(rw++,"@11gRISULTATO@75g%r", &res_debt);
set_row(rw++,"@11gIva sulle operazioni di acquisto@58g%r", &(d._r1)); set_row(rw++,"@11gIva sulle operazioni di acquisto@58g%r", &iva_acq);
if (_isannual)
set_row(rw++,"@11gCredito inizio anno@58g%r", &cred_prec);
else
set_row(rw++,"@11gCredito precedente@58g%r", &cred_prec);
// credito precedente scorporato dell'acconto if (!acc_dec.is_zero())
d._r7 -= d._r8;
set_row(rw++,"@11gCredito precedente@58g%r", &(d._r7));
if ((_is_visliq && _month == 12) || !(d._r8.is_zero()))
set_row(rw++,"%s@11gVersamento acconto dicembre@58g%r", set_row(rw++,"%s@11gVersamento acconto dicembre@58g%r",
_is_visliq ? "$[r]" : "", &(d._r8)); _is_visliq ? "$[r]" : "", &acc_dec);
if (!(d._r11.is_zero())) if (!detrazioni.is_zero())
set_row(rw++,"@11gUlteriori detrazioni@58g%r", &(d._r11)); set_row(rw++,"@11gUlteriori detrazioni@58g%r", &detrazioni);
set_row(rw++,"%s@11gRettifiche IVA a credito@58g%r", set_row(rw++,"%s@11gRettifiche IVA a credito@58g%r",
_is_visliq ? "$[r]" : "", &(d._r6)); _is_visliq ? "$[r]" : "", &rett_cred);
real rc = d._r1 + d._r7 + d._r8 + d._r6 -d._r11;
// conguaglio prorata
if (d._r9.sign() < 0) rc -= d._r9;
// versamenti effettuati // versamenti effettuati
if (!d._s2.empty()) if (!versamenti.is_zero())
{ {
real unixtihavoluto(d._s2); set_row(rw++,"@11gVersamenti effettuati@58g%r", &versamenti);
vers = unixtihavoluto;
rc += vers;
set_row(rw++,"@11gVersamenti effettuati@58g%r", &vers);
} }
// versamenti integrativi // versamenti integrativi
if (!d._s3.empty()) if (!vers_int.is_zero())
{ {
real unixtihavoluto(d._s3); set_row(rw++,"@11gVersamenti integrativi@58g%r", &vers_int);
vers = unixtihavoluto;
rc += vers;
set_row(rw++,"@11gVersamenti integrativi@58g%r", &vers);
} }
set_row(rw++,"@11gRISULTATO@58g%r", &rc); if (d._r10.sign() < 0)
{
real r = abs(d._r10);
set_row(rw++,"@11gConguaglio pro-rata@58g%r", &r);
res_cred += d._r10;
risultato -= d._r10;
}
set_row(rw++,"@11gRISULTATO@58g%r", &res_cred);
real iva = rd - rc;
char how = iva.sign() < 0 ? 'c' : 'd';
iva = abs(iva);
iva.ceil(_isannual ? ROUND_MILLELIRE : ROUND_LIRA);
// se non c'e' nulla da versare stampa solo una riga vuota // se non c'e' nulla da versare stampa solo una riga vuota
// Serve, non toglierla, stronzo. // Serve, non toglierla, stronzo.
if (iva.is_zero()) if (risultato.is_zero())
set_row(rw++,""); set_row(rw++,"");
else else
{ {
if (how == 'c') if (risultato.sign() < 0)
{ {
real iva = abs(risultato);
set_row(rw++,"@23gCREDITO ATTUALE@58g%r",&iva); set_row(rw++,"@23gCREDITO ATTUALE@58g%r",&iva);
} }
else else
{ {
if (d._f0) real iva = risultato + interessi;
if (!iva.is_zero())
{ {
// trimestrale: interesse if (!interessi.is_zero())
real interesse = interesse_trimestrale(d._f2);
real ivi = iva * interesse / CENTO; ivi.ceil(ROUND_LIRA);
real ivt = iva + ivi;
ivt.ceil(_isannual ? ROUND_MILLELIRE : ROUND_LIRA);
if (!iva.is_zero())
{ {
set_row(rw++,"@23gIVA DOVUTA@75g%r",&iva); set_row(rw++,"@23gIVA DOVUTA@75g%r",&risultato);
set_row(rw++,"@23gInteresse %6.2r %%@75g%r",&interesse, &ivi); set_row(rw++,"@23gInteresse %6.2r %%@75g%r",&interesse, &interessi);
if (ivt.is_zero() || ivt >= IVA_DA_RIPORTARE || d._f1)
set_row(rw++,"@23gIVA DA VERSARE@75g%r",&ivt);
else
set_row(rw++,"@23gIVA DA VERSARE@85g0 (%s < 50.000)",
(const char*)ivt.string("."));
}
else set_row(rw++,"");
}
else
{
if (!iva.is_zero())
{
if (iva >= IVA_DA_RIPORTARE || d._f1)
set_row(rw++,"@23gIVA DA VERSARE@75g%r",&iva);
else
set_row(rw++,"@23gIVA DA VERSARE@85g0 (%s < 50.000)",
(const char*)iva.string("."));
} }
else set_row(rw++,""); if (iva >= IVA_DA_RIPORTARE || _isannual)
} set_row(rw++,"@23gIVA DA VERSARE@75g%r",&iva);
else
set_row(rw++,"@23gIVA DA VERSARE@85g0 (%s < 50.000)",
(const char*)iva.string("."));
}
} }
} }
// rapportini per rimborso infraannuale // rapportini per rimborso infraannuale
if (d._arr.items() > 0) if (d._arr.items() > 0)
{ {
_DescrItem& di = (_DescrItem&)d._arr[0]; _DescrItem& di = (_DescrItem&)d._arr[0];
set_print_zero(TRUE); set_print_zero(TRUE);
set_row(rw++,""); set_row(rw++,"");
set_row(rw++,""); set_row(rw++,"");
set_row(rw++, " PROSPETTO DI RIMBORSO"); set_row(rw++, " PROSPETTO DI RIMBORSO");