Parametri liquidazione e ditte: aggiunto/corretto controllo registri

Liquidazione: corretto controllo esistenza archivi


git-svn-id: svn://10.65.10.50/trunk@660 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
villa 1994-11-18 11:40:45 +00:00
parent 02d74562fc
commit 428d4216bd
5 changed files with 308 additions and 54 deletions

View File

@ -186,11 +186,102 @@ void TPrimanota_application::aggiorna_scadenzario(const TMask& m)
pag.set_total(imponibile, imposta, spese); pag.set_total(imponibile, imposta, spese);
// TBI TBI TBI TBI TBI TBI TBI TBI TBI // se c'e' una rateazione gia' registrata
// controllare se c'e' una rateazione non standard gia' registrata // zappettare e settare le rate a mano
// in tal caso occorre zappare e settare le rate a mano
pag.set_rate_auto();
bool new_part = FALSE;
// should never happen but it doesn't hurt
if (_rel->cg(0).empty()) return;
TLocalisamfile partita (LF_PARTITE);
TLocalisamfile scadenza(LF_SCADENZE);
TString nreg(_rel->lfile().get("NUMREG"));
TString ndoc(_rel->lfile().get("NUMDOC"));
TString tmov(_rel->lfile().get("TIPOMOV"));
TDate ddoc(_rel->lfile().get_date("DATADOC"));
TDate dreg(_rel->lfile().get_date("DATAREG"));
TString reg (_rel->lfile().get("REG"));
TString protiva(_rel->lfile().get("PROTIVA"));
TString codcaus(_rel->lfile().get("CODCAUS"));
TString codval (_rel->lfile().get("CODVAL"));
TString cambio (_rel->lfile().get("CAMBIO"));
TString numpart = m.get(F_NUMRIF);
TString anno = m.get(F_ANNORIF);
char sezione = _rel->cg(0).get_char("SEZIONE"); // Dare/Avere
char tipocf = _rel->cg(0).get_char("TIPOC"); // Cliente || Fornitore || Uncazzo
int gruppo = (tipocf == 'C' || tipocf == 'F') ? 0 :
_rel->cg(0).get_char("GRUPPO");
int conto = (tipocf == 'C' || tipocf == 'F') ? 0 :
_rel->cg(0).get_char("fCONTO");
int sottoconto = _rel->cg(0).get_char("SOTTOCONTO");
int nriga = 1;
int numrig = 1;
partita.put("TIPOCF", tipocf);
partita.put("GRUPPO", gruppo);
partita.put("CONTO", conto);
partita.put("SOTTOCONTO", sottoconto);
partita.put("ANNO", anno);
partita.put("NUMPART", numpart);
partita.put("NRIGA", nriga);
if (partita.read() == NOERR)
{
// se la maschera contiene importi diversi da quelli
// registrati, o se il codice pagamento e' diverso,
// si riparte da zero usando la modalita' indicata
if (imponibile != partita.get_real("IMPORTO") ||
imposta != partita.get_real("IMPOSTA") ||
spese != partita.get_real("SPESE") ||
pag.code() != partita.get("CODPAG"))
pag.set_rate_auto();
else
{
pag.zap_rate();
for (int rata = 1; ; i++)
{
// cerca rata
scadenza.zero();
scadenza.put("TIPOCF", tipocf);
scadenza.put("GRUPPO", gruppo);
scadenza.put("CONTO", conto);
scadenza.put("SOTTOCONTO", sottoconto);
scadenza.put("ANNO", anno);
scadenza.put("NUMPART", numpart);
scadenza.put("NRIGA", nriga);
scadenza.put("NRATA", i+1);
if (scadenza.read() == NOERR)
{
// TBI setta rate
real importo = scadenza.get("IMPORTOVAL");
TDate scad = scadenza.get("DATASCAD");
int tipop = scadenza.get_int("TIPOPAG");
bool paid = scadenza.get_bool("PAGATA");
TString ucl(scadenza.get("ULTCLASS"));
// disable rows if paid
// pag.set_rata(i, importo, scad, tipop, ucl, paid);
}
else break;
}
}
}
else
{
pag.set_rate_auto();
new_part = TRUE;
}
// prepara lo sheet
pag.set_sheet(ps);
TArray rows(ps.rows_array());
// se la prima rata e' fissa non si tocca // se la prima rata e' fissa non si tocca
if (pag.tipo_prima_rata() > 0) if (pag.tipo_prima_rata() > 0)
{ {
@ -200,9 +291,6 @@ void TPrimanota_application::aggiorna_scadenzario(const TMask& m)
ps.disable_cell(0,3); ps.disable_cell(0,3);
} }
// prepara lo sheet
pag.set_sheet(ps);
TArray rows(ps.rows_array());
shuttle sh; shuttle sh;
@ -215,6 +303,77 @@ void TPrimanota_application::aggiorna_scadenzario(const TMask& m)
ms.run(); ms.run();
// TBI se modificato riaggiustare i files // TBI se modificato riaggiustare i files
// chiamando la write del caso // partite e scadenze
// ------------------------------------------------- // ----------------------------------------
if (pag.dirty() || new_part)
{
if (new_part)
{
partita.zero();
partita.put("TIPOCF", tipocf);
partita.put("GRUPPO", gruppo);
partita.put("CONTO", conto);
partita.put("SOTTOCONTO", sottoconto);
partita.put("ANNO", anno);
partita.put("NUMPART", numpart);
partita.put("NRIGA", nriga);
}
// TBI put data on partita
if (new_part) partita.write();
else partita.rewrite();
bool new_scad = FALSE;
for (int i = 0; i < pag.n_rate(); i++)
{
new_scad = FALSE;
scadenza.zero();
scadenza.put("TIPOCF", tipocf);
scadenza.put("GRUPPO", gruppo);
scadenza.put("CONTO", conto);
scadenza.put("SOTTOCONTO", sottoconto);
scadenza.put("ANNO", anno);
scadenza.put("NUMPART", numpart);
scadenza.put("NRIGA", nriga);
scadenza.put("NRATA", i+1);
if (scadenza.read() != NOERR)
{
new_scad = TRUE;
scadenza.zero();
scadenza.put("TIPOCF", tipocf);
scadenza.put("GRUPPO", gruppo);
scadenza.put("CONTO", conto);
scadenza.put("SOTTOCONTO", sottoconto);
scadenza.put("ANNO", anno);
scadenza.put("NUMPART", numpart);
scadenza.put("NRIGA", nriga);
scadenza.put("NRATA", i+1);
}
// TBI set everything
if (new_scad) scadenza.write();
else scadenza.rewrite();
}
// elimina eventuali altre scadenze
// oltre l'ultima registrata
for (; !new_scad ; i++)
{
scadenza.zero();
scadenza.put("TIPOCF", tipocf);
scadenza.put("GRUPPO", gruppo);
scadenza.put("CONTO", conto);
scadenza.put("SOTTOCONTO", sottoconto);
scadenza.put("ANNO", anno);
scadenza.put("NUMPART", numpart);
scadenza.put("NRIGA", nriga);
scadenza.put("NRATA", i+1);
if (scadenza.read() == NOERR)
scadenza.remove();
else new_scad = TRUE;
}
}
} }

View File

@ -7,6 +7,7 @@
#include <defmask.h> #include <defmask.h>
#include <progind.h> #include <progind.h>
#include <sheet.h> #include <sheet.h>
#include <prefix.h>
#include "cg4300.h" #include "cg4300.h"
#include "cg4300a.h" #include "cg4300a.h"
@ -149,9 +150,11 @@ bool TLiquidazione_app::user_create()
if (is_interactive) if (is_interactive)
{ {
for (_nditte->first(); !_nditte->eof(); _nditte->next()) for (_nditte->first(); !_nditte->eof(); _nditte->next())
{ {
if (!(TApplication::set_firm(_nditte_r->get_long("CODDITTA")))) if (!prefhndl->exist(_nditte_r->get_long("CODDITTA")))
continue; continue;
TApplication::set_firm(_nditte_r->get_long("CODDITTA"));
_n_ditte++; _n_ditte++;
TToken_string* d = new TToken_string(64); TToken_string* d = new TToken_string(64);

View File

@ -5,7 +5,6 @@
// ------------------------------------------------------------ // ------------------------------------------------------------
#include <progind.h> #include <progind.h>
#include "cg4300.h" #include "cg4300.h"
// -------------------- QUI comincia l'avventura -------------------------- // -------------------- QUI comincia l'avventura --------------------------
@ -152,7 +151,9 @@ bool TLiquidazione_app::update_firm(int month, bool recalc)
_isannual = (_month == 12 && !mens && !_isbenzinaro) || _isannual = (_month == 12 && !mens && !_isbenzinaro) ||
(_month == 13 && (mens || _isbenzinaro)); (_month == 13 && (mens || _isbenzinaro));
_isriepilogo = _month == 13; _isriepilogo = _month == 13;
_isvent = FALSE;
for (_reg->first(); !_isvent && _reg->good(); _reg->next()) for (_reg->first(); !_isvent && _reg->good(); _reg->next())
{ {
if (codatt == _reg->get("S8") && _reg->get_int("I0") == 2) if (codatt == _reg->get("S8") && _reg->get_int("I0") == 2)
@ -163,8 +164,7 @@ bool TLiquidazione_app::update_firm(int month, bool recalc)
if ((month != 13 || _isannual) && (calc || !recalc)) if ((month != 13 || _isannual) && (calc || !recalc))
if (!update_att(month, cattiv)) if (!update_att(month, cattiv))
describe_error("Attivita' non ricalcolate: possibili errori", describe_error("Attivita' non ricalcolate: possibili errori",
codatt); codatt);
// vediamo se c'e' qualcosa da raccontare // vediamo se c'e' qualcosa da raccontare
gheravergot = _isannual || _isriepilogo; gheravergot = _isannual || _isriepilogo;

View File

@ -2,26 +2,107 @@
#include <lffiles.h> #include <lffiles.h>
#include <files.h> #include <files.h>
#include <isam.h> #include <isam.h>
#include <tabutil.h>
#include <attiv.h>
#include "cg5100a.h" #include "cg5100a.h"
class CG51_App : public TConfig_application class CG51_App : public TConfig_application
{ {
bool _change_pcon; bool _change_pcon;
TString16 _val; TString16 _val;
TArray _atts;
void swap_file(int logicnum, bool tocom); void swap_file(int logicnum, bool tocom);
void check_registers(int year);
public: public:
virtual bool preprocess_config (TMask& mask, TConfig& config); virtual bool preprocess_config (TMask& mask, TConfig& config);
virtual bool postprocess_config (TMask& mask, TConfig& config); virtual bool postprocess_config (TMask& mask, TConfig& config);
virtual bool postprocess_config_changed(const char* par, const char* var, virtual bool postprocess_config_changed(const char* par, const char* var,
const char* oldv, const char* newv); const char* oldv, const char* newv);
virtual bool user_create() { _change_pcon = FALSE; return TRUE;} virtual bool user_create();
virtual bool user_destroy(); virtual bool user_destroy();
CG51_App() : TConfig_application(CONFIG_DITTA) {} CG51_App() : TConfig_application(CONFIG_DITTA) {}
virtual ~CG51_App() {} virtual ~CG51_App() {}
}; };
bool CG51_App::user_create()
{
_change_pcon = FALSE;
TLocalisamfile attiv(LF_ATTIV);
attiv.zero();
attiv.put(ATT_CODDITTA, get_firm());
TRectype r(attiv.curr());
for(attiv.read(_isgteq); attiv.status() == NOERR && attiv.curr() == r;
attiv.next())
// istanzia array _atts on le attivita' della ditta corrente
_atts.add(new TString(attiv.get(ATT_CODATT)));
return TRUE;
}
void CG51_App::check_registers(int year)
{
// controlla che per ogni data attivita' esistano almeno un registro
// acquisti, vendite e giornale; warning appropriato in caso negativo
TTable reg("REG");
TRecfield reg_year(reg.curr(), "CODTAB", 0,3);
const byte R_ACQ = 0x01;
const byte R_VEN = 0x02;
const byte R_ALL = R_ACQ | R_VEN;
bool is_giornale = FALSE;
byte flags = 0x00;
for (int i = 0; i < _atts.items(); i++)
{
TString& att = (TString&)_atts[i];
for (reg.first(); !reg.eof(); reg.next())
{
if (atoi(reg_year) == year && reg.get_int("I0") == 5)
{
is_giornale = TRUE;
continue;
}
if (atoi(reg_year) != year || att != reg.get("S8"))
continue;
switch (reg.get_int("I0"))
{
case 1: // vendite
flags |= R_VEN;
break;
case 2: // acquisti
flags |= R_ACQ;
break;
}
if (flags == R_ALL && is_giornale) break;
}
if (flags < R_ALL)
{
TString wrn("I seguenti registri non esistono per l'attivita' ");
wrn << att << "(" << year << "):";
if ((flags & R_VEN) == 0x00) wrn << "\n\tregistro vendite";
if ((flags & R_ACQ) == 0x00) wrn << "\n\tregistro acquisti";
warning_box(wrn);
}
}
// libro giornale non si controlla per attivita'
if(!is_giornale)
warning_box("Non esiste probabilmente nessun "
"libro giornale per l'anno %d", year);
}
void CG51_App::swap_file(int logicnum, bool tocom) void CG51_App::swap_file(int logicnum, bool tocom)
{ {
TDir dir; TDir dir;
@ -99,6 +180,10 @@ bool CG51_App::postprocess_config_changed(const char* par, const char* var,
else else
return FALSE; return FALSE;
} }
else if (v == "AnLiIv")
{
check_registers(atoi(newv));
}
return TRUE; return TRUE;
} }

View File

@ -71,45 +71,50 @@ void CG5300_App::check_registers(int year)
const byte R_ACQ = 0x01; const byte R_ACQ = 0x01;
const byte R_VEN = 0x02; const byte R_VEN = 0x02;
const byte R_GIO = 0x04; const byte R_ALL = R_ACQ | R_VEN;
const byte R_ALL = R_ACQ | R_VEN | R_GIO;
bool is_giornale = FALSE;
byte flags = 0x00;
for (int i = 0; i < _atts.items(); i++) for (int i = 0; i < _atts.items(); i++)
{ {
byte flags = 0x00; TString& att = (TString&)_atts[i];
TString& att = (TString&)_atts[i]; for (reg.first(); !reg.eof(); reg.next())
{
for (reg.first(); !reg.eof(); reg.next()) if (atoi(reg_year) == year && reg.get_int("I0") == 5)
{ {
if (atoi(reg_year) != year || att != reg.get("S8")) is_giornale = TRUE;
continue; continue;
}
if (atoi(reg_year) != year || att != reg.get("S8"))
continue;
switch ((int)reg.get_long("I0")) switch (reg.get_int("I0"))
{ {
case 1: // vendite case 1: // vendite
flags |= R_VEN; flags |= R_VEN;
break; break;
case 2: // acquisti case 2: // acquisti
flags |= R_ACQ; flags |= R_ACQ;
break; break;
case 5: // giornale }
flags |= R_GIO; if (flags == R_ALL && is_giornale) break;
break; }
} if (flags < R_ALL)
if (flags == R_ALL) break; {
} TString wrn("I seguenti registri non esistono per l'attivita' ");
if (flags < R_ALL) wrn << att << "(" << year << "):";
{ if ((flags & R_VEN) == 0x00) wrn << "\n\tregistro vendite";
TString att = (TString&)_atts[i]; if ((flags & R_ACQ) == 0x00) wrn << "\n\tregistro acquisti";
TString wrn("I seguenti registri probabilmente non esistono per l'attivita' "); warning_box(wrn);
wrn << att << ":"; }
if ((flags & R_VEN) == 0x00) wrn << "\n\tregistro vendite"; }
if ((flags & R_ACQ) == 0x00) wrn << "\n\tregistro acquisti";
if ((flags & R_GIO) == 0x00) wrn << "\n\tlibro giornale"; // libro giornale non si controlla per attivita'
warning_box(wrn); if(!is_giornale)
} warning_box("Non esiste probabilmente nessun "
} "libro giornale per l'anno %d", year);
} }
@ -248,7 +253,8 @@ int CG5300_App::rewrite(const TMask& m)
if (prorata != _pla->get_real("R8") || if (prorata != _pla->get_real("R8") ||
es_a8 != _pla->get_real("R5") || es_a8 != _pla->get_real("R5") ||
es_a8b != _pla->get_real("R6") || es_a8b != _pla->get_real("R6") ||
es_a9 != _pla->get_real("R7")) es_a9 != _pla->get_real("R7") ||
m.field(F_CRED_PREC).dirty())
{ {
// invalida la prima liquidazione calcolata se ce n'e' // invalida la prima liquidazione calcolata se ce n'e'
TTable lim("LIM"); TTable lim("LIM");
@ -361,3 +367,4 @@ int cg5300(int argc, char* argv[])