d2816f518e
Files correlati : Quelli delle patch AGA Ricompilazione Demo : [ ] Commento : Riportata la versione AGA 1.7 patch 349. git-svn-id: svn://10.65.10.50/trunk@10557 c028cbd2-c16b-5b4b-a496-9718f37d4682
1251 lines
38 KiB
C++
Executable File
1251 lines
38 KiB
C++
Executable File
#include <applicat.h>
|
||
#include <currency.h>
|
||
#include <filetext.h>
|
||
#include <form.h>
|
||
#include <mask.h>
|
||
#include <os_dep.h>
|
||
#include <relation.h>
|
||
#include <tabutil.h>
|
||
#include <printer.h>
|
||
#include <progind.h>
|
||
#include <utility.h>
|
||
|
||
#include "ef0.h"
|
||
#include "ef0301.h"
|
||
#include "ef0500.h"
|
||
|
||
#include <clifo.h>
|
||
#include <comuni.h>
|
||
#include <cfven.h>
|
||
#include <indsp.h>
|
||
|
||
class TRiba_form;
|
||
class TDistinta_form;
|
||
class TRiba_file;
|
||
enum fo { kb360 = 1, kb720 = 2, kb1200 = 3, kb1440 = 4 };
|
||
|
||
#define RIBAFILENAME "ribael.dat"
|
||
|
||
///////////////////////////////////////////////////////////////////////
|
||
// Classe per l'emissione di effetti e distinte su carta o su floppy //
|
||
///////////////////////////////////////////////////////////////////////
|
||
|
||
class TEmissione: public TSkeleton_application
|
||
{
|
||
fo _foutput;
|
||
TMask* _msk;
|
||
TRelation* _firmrel;
|
||
TRelation* _rel;
|
||
TCursor* _cur;
|
||
TRiba_form* _formrb;
|
||
TDistinta_form* _formdse;
|
||
TRiba_file* _trasfile;
|
||
int _base_page_no;
|
||
|
||
protected:
|
||
virtual bool create(void);
|
||
virtual void main_loop();
|
||
virtual bool destroy(void) ;
|
||
virtual void on_firm_change(void);
|
||
void conferma(void);
|
||
void enable_dettaglio(TForm& form) const;
|
||
virtual void print_rb(char tipost, int ndist, char tipodist, int ncopie, const bool is_vis);
|
||
virtual void print_dse(char tipost, int ndist, char tipodist, int ncopie, const bool is_vis);
|
||
virtual void print(void);
|
||
void floppy(void);
|
||
void save_data_emis(void);
|
||
void header_rb(void);
|
||
void footer_ef(void);
|
||
void inizializza_cur(void);
|
||
void inizializza_file(void);
|
||
void record(THash_object& lavoro);
|
||
bool ok_write(void);
|
||
void aggiorna_rb(TCursor*);
|
||
void aggiorna_dist(TCursor*);
|
||
static bool annulla_handler(TMask_field& f, KEY k);
|
||
public:
|
||
|
||
int base_no() const { return _base_page_no; }
|
||
const TMask& msk() const { return *_msk; }
|
||
const TRelation& firm_rel() const { return *_firmrel; }
|
||
|
||
TEmissione() {}
|
||
virtual ~TEmissione() {}
|
||
};
|
||
|
||
// restituisce un riferimento all' applicazione
|
||
inline TEmissione& app() { return (TEmissione&) main_app();}
|
||
|
||
/////////////////////////////////////////////////////////////
|
||
// Classe TRiba_form customizzata dalla Form per le Ri.Ba. //
|
||
/////////////////////////////////////////////////////////////
|
||
class TRiba_form: public TForm
|
||
{
|
||
protected:
|
||
virtual bool validate(TForm_item &, TToken_string &);
|
||
|
||
public:
|
||
TRiba_form(const char *);
|
||
virtual ~TRiba_form() { }
|
||
};
|
||
|
||
///////////////////////////////////////////////////////////////////
|
||
// Classe TDistinta_form customizzata dalla Form per le Distinte //
|
||
///////////////////////////////////////////////////////////////////
|
||
|
||
class TDistinta_form: public TForm
|
||
{
|
||
TRelation *_firmrel;
|
||
TSorted_cursor *_cursor;// cursore che permette l'ordinamento degli effetti
|
||
|
||
protected: // nella distinta per data scadenza o per dati fattura
|
||
virtual bool validate(TForm_item &, TToken_string &);
|
||
|
||
public:
|
||
void set_order(const char tipo);
|
||
virtual TCursor* cursor() const { return (TCursor*)_cursor;}
|
||
TDistinta_form(const char*, TRelation *);
|
||
virtual ~TDistinta_form();
|
||
};
|
||
|
||
/////////////////////////////////////////////////////
|
||
// Classe TRiba_file customizzata dalla TFile_text //
|
||
/////////////////////////////////////////////////////
|
||
class TRiba_file: public TFile_text
|
||
{
|
||
real _tot_importi;
|
||
char _codice_moneta;
|
||
bool _tracciato_setif;
|
||
|
||
protected:
|
||
virtual void validate(TCursor& cur,TRecord_text &rec, TToken_string &val, TString& str);
|
||
|
||
public:
|
||
void set_tot_importi(const real& importo) { _tot_importi = importo; }
|
||
void add_tot_importi(const real& importo) { _tot_importi += importo; }
|
||
const real tot_importi() const { return _tot_importi; }
|
||
bool tracciato_setif() {return _tracciato_setif;}
|
||
void set_tracciato_setif(const bool tracciato_setif=TRUE) {_tracciato_setif = tracciato_setif;}
|
||
|
||
TRiba_file(const TString& file_name, const TString& config_name);
|
||
virtual ~TRiba_file() { }
|
||
};
|
||
|
||
TRiba_file::TRiba_file(const TString& file_name, const TString& config_name)
|
||
: TFile_text(file_name, config_name)
|
||
{
|
||
_codice_moneta = TCurrency::get_firm_dec() == 0 ? ' ' : 'E';
|
||
}
|
||
|
||
// creazione dell'applicazione
|
||
bool TEmissione::create()
|
||
{
|
||
_formrb = NULL;
|
||
_formdse = NULL;
|
||
_msk = new TMask("ef0500a");
|
||
_firmrel= new TRelation(LF_NDITTE);
|
||
_firmrel->add(LF_ANAG, "TIPOA=TIPOA|CODANAGR=CODANAGR");
|
||
_firmrel->add(LF_UNLOC,"CODDITTA=CODDITTA");
|
||
_rel = new TRelation(LF_EFFETTI);
|
||
_rel->add(LF_REFFETTI, "NPROGTR=NPROGTR");
|
||
_rel->add(LF_CESS, "NPROGTR=NPROGTR");
|
||
_rel->add(LF_CLIFO, "TIPOCF=TIPOCF|CODCF=CODCF");
|
||
_rel->add(LF_CFVEN, "TIPOCF==TIPOCF|CODCF==CODCF", 1, LF_CLIFO);
|
||
_rel->add(LF_INDSP, "TIPOCF==TIPOCF|CODCF==CODCF|CODIND==CODINDEFF", 1, LF_CFVEN);
|
||
_rel->add("%BAN", "CODTAB[1,5]=CODABI", 1, 0, 401);
|
||
_rel->add("%BAN", "CODTAB=CODABI+CODCAB", 1, 0, 402);
|
||
_rel->add(LF_COMUNI, "STATO=STATOCF|COM=COMCF",1,LF_CLIFO);
|
||
_rel->add(LF_COMUNI, "STATO=STATO|COM=COM", 1, LF_INDSP, 213);
|
||
_rel->add("BNP", "CODTAB=CODABIP+CODCABP", 1, 0, 403);
|
||
_cur = NULL;
|
||
_msk->set(F_NOMEFILE,RIBAFILENAME);
|
||
// _trasfile = new TRiba_file(RIBAFILENAME, "riba.ini");
|
||
// _trasfile->set_ditta(get_firm());
|
||
_msk->set_handler(DLG_CANCEL, annulla_handler);
|
||
_trasfile = NULL;
|
||
return TSkeleton_application::create();
|
||
}
|
||
|
||
// distruzione dell'applicazione
|
||
bool TEmissione::destroy()
|
||
{
|
||
if (_formrb) delete _formrb;
|
||
if (_formdse) delete _formdse;
|
||
delete _msk;
|
||
delete _firmrel;
|
||
delete _rel;
|
||
delete _cur;
|
||
if (_trasfile)
|
||
delete _trasfile;
|
||
return TSkeleton_application::destroy();
|
||
}
|
||
|
||
// carica la ditta corrente
|
||
void TEmissione::on_firm_change()
|
||
{
|
||
TRectype& firm = _firmrel->curr();
|
||
firm.put("CODDITTA", get_firm());
|
||
_firmrel->read();
|
||
}
|
||
|
||
// carica la maschera per emissione effetti e distinte
|
||
void TEmissione::main_loop()
|
||
{
|
||
// Preimposta gli eventuali valori specificati sulla riga di comando
|
||
if (argc() >= 4)
|
||
{
|
||
TLocalisamfile eff(LF_EFFETTI);
|
||
eff.setkey(4);
|
||
eff.put(EFF_TIPODIST, argv(2));
|
||
eff.put(EFF_NDIST, argv(3));
|
||
eff.put(EFF_NRIGADIST, 1);
|
||
if (eff.read() == NOERR)
|
||
{
|
||
_msk->set(F_TIPODIST, eff.get(EFF_TIPODIST));
|
||
_msk->set(F_TIPOCF, eff.get(EFF_TIPOCF));
|
||
_msk->set(F_NUMBER, eff.get(EFF_NDIST));
|
||
}
|
||
}
|
||
|
||
KEY key = K_ENTER;
|
||
while (key != K_QUIT)
|
||
{
|
||
key = _msk->run();
|
||
if (key == K_ENTER)
|
||
conferma();
|
||
}
|
||
}
|
||
|
||
// gestisce la scelta fra le due possibili emissioni
|
||
void TEmissione::conferma()
|
||
{
|
||
const int tipoemis = _msk->get_int(F_TIPOEMIS);
|
||
if (tipoemis == 1)
|
||
floppy();
|
||
else
|
||
print();
|
||
}
|
||
|
||
// gestione emissione su floppy
|
||
void TEmissione::floppy()
|
||
{
|
||
inizializza_cur();
|
||
|
||
*_cur = 0L; // Posizionati all'inizio
|
||
const TRectype& eff = _cur->curr();
|
||
const long codabi = eff.get_long(EFF_CODABIP);
|
||
const char tipocf = eff.get_char(EFF_TIPOCF);
|
||
const char tipopag = eff.get_char(EFF_TIPOPAG);
|
||
|
||
TFilename ribaini;
|
||
ribaini.format("r%c%c%05ld.ini", tipocf, tipopag, codabi); // compongo il nome del tracciato
|
||
if (!ribaini.exist()) // se non esiste
|
||
ribaini.overwrite("00000", 3); // Elimino codice banca
|
||
if (!ribaini.exist()) // se non esiste
|
||
ribaini.overwrite("0", 2); // Elimino tipo pagamaneto
|
||
if (!ribaini.exist()) // se non esiste
|
||
ribaini = "riba.ini"; // utilizzo quello generico
|
||
if (!ribaini.exist()) // se non esiste ancora!
|
||
{
|
||
error_box("Impossibile leggere il file %s", (const char*)ribaini);
|
||
return;
|
||
}
|
||
|
||
_trasfile = new TRiba_file(RIBAFILENAME, ribaini);
|
||
TTracciato_record * rb = _trasfile->t_rec("RB");
|
||
if (rb != NULL)
|
||
{
|
||
TTracciato_record * ib = new TTracciato_record(*rb);
|
||
ib->set_type("IB");
|
||
_trasfile->tracciati().add("IB", ib);
|
||
}
|
||
inizializza_file();
|
||
|
||
long n_eff = _cur->items();
|
||
bool condition = ok_write();
|
||
|
||
if (!condition)
|
||
error_box("Impossibile continuare dischetto pieno");
|
||
else
|
||
{
|
||
TProgind pi(n_eff,"Emissione Ri.Ba. su floppy...",FALSE,TRUE);
|
||
|
||
TAssoc_array& tracciati = _trasfile->tracciati();
|
||
header_rb();//intestazione flusso effetti
|
||
//scandisco tutti gli effetti della distinta selezionata
|
||
for (*_cur = 0; _cur->pos() < n_eff; ++(*_cur))
|
||
{
|
||
pi.addstatus(1L);
|
||
save_data_emis();
|
||
THash_object* lavoro = tracciati.get_hashobj();
|
||
//scandisco tutti i record di un effetto
|
||
for (int i = 0; lavoro != NULL; i++)
|
||
{
|
||
record(*lavoro);//emetto il record
|
||
lavoro = tracciati.get_hashobj();
|
||
}
|
||
}
|
||
footer_ef(); //chiusura flusso effetti
|
||
}
|
||
_trasfile->close();
|
||
delete _trasfile;
|
||
_trasfile = NULL;
|
||
|
||
delete _cur;
|
||
_cur = NULL;
|
||
}
|
||
|
||
// registro la data ed il numero di emissione dell'effetto corrente
|
||
void TEmissione::save_data_emis()
|
||
{
|
||
const TDate data_emis = _msk->get_date(F_DATAEMIS);
|
||
TLocalisamfile& effetti = _rel->lfile();
|
||
TEffetto effetto = effetti.curr();
|
||
long numero = effetto.numero();
|
||
effetto.put(EFF_NUMEMISS, numero);
|
||
effetto.put(EFF_DATAEMISS, data_emis);
|
||
effetto.put(EFF_DATARIBA, data_emis);
|
||
bool cond = TRUE;
|
||
effetto.put(EFF_DISRIBAEST, cond);
|
||
effetto.rewrite(effetti);
|
||
}
|
||
|
||
//emetto il record d'intestazione del flusso di effetti
|
||
void TEmissione::header_rb()
|
||
{
|
||
TRecord_text rec;
|
||
*_cur = 0;
|
||
TTable bnp("BNP");
|
||
TString16 codtab(_rel->lfile().get(EFF_CODABIP));
|
||
codtab << _rel->lfile().get(EFF_CODCABP);
|
||
bnp.put("CODTAB", codtab);
|
||
if (bnp.read() == NOERR && bnp.get_bool("B0"))
|
||
{
|
||
rec.set_type("RB");
|
||
_trasfile->set_tracciato_setif(TRUE);
|
||
}
|
||
else
|
||
{
|
||
rec.set_type("IB");
|
||
_trasfile->set_tracciato_setif(FALSE);
|
||
}
|
||
_trasfile->autoload(rec, *_cur);
|
||
_trasfile->write(rec);
|
||
}
|
||
|
||
//emetto il record di chiusura del flusso di effetti
|
||
void TEmissione::footer_ef()
|
||
{
|
||
TRecord_text rec;
|
||
*_cur = 0;
|
||
rec.set_type("EF");
|
||
|
||
if (!_trasfile->tracciato_setif())
|
||
{
|
||
TTracciato_record * trec = _trasfile->t_rec("EF");
|
||
const int p1 = trec->get(7).position();
|
||
const int p2 = trec->get(8).position();
|
||
|
||
trec->get(7).set_position(p2);
|
||
trec->get(8).set_position(p1);
|
||
}
|
||
_trasfile->autoload(rec, *_cur);
|
||
_trasfile->write(rec);
|
||
_trasfile->write_file()->seekp(0, ios::end);
|
||
}
|
||
|
||
//inizializza il cursore per la gestione dei dati da caricare negli effetti
|
||
void TEmissione::inizializza_cur()
|
||
{
|
||
const int ndist = _msk->get_int(F_NUMBER);
|
||
const char tipodist = _msk->get(F_TIPODIST)[0];
|
||
TRectype from(_rel->curr());
|
||
from.zero();
|
||
from.put(EFF_TIPODIST, tipodist);
|
||
from.put(EFF_NDIST, ndist);
|
||
if (_cur != NULL)
|
||
delete _cur;
|
||
_cur = new TCursor(_rel,"",4,&from,&from);
|
||
_cur->freeze();
|
||
}
|
||
|
||
//inizializza il file di testo su cui emettere gli effetti
|
||
void TEmissione::inizializza_file()
|
||
{
|
||
TFilename fileriba = _msk->get(F_UNITA);
|
||
fileriba << ":\\" << _msk->get(F_NOMEFILE);
|
||
_trasfile->open(fileriba,'w');
|
||
_trasfile->set_tot_importi(ZERO);
|
||
_trasfile->force_record_separator(_msk->get_bool(F_FORCESEP));
|
||
_foutput = (fo)_msk->get_int(F_FOR_OUT);
|
||
}
|
||
|
||
//emetto un record del flusso di effetti
|
||
void TEmissione::record(THash_object& lavoro)
|
||
{
|
||
const TString& chiave = lavoro.key();
|
||
if (chiave !="EF" && chiave !="RB" && chiave != "IB")
|
||
{
|
||
TTracciato_record& oggetto = (TTracciato_record&)lavoro.obj();
|
||
const TString& tipo = oggetto.type();
|
||
TRecord_text rec(tipo);
|
||
//carico il record da emettere
|
||
_trasfile->autoload(rec, *_cur, &tipo);
|
||
_trasfile->write(rec);//emetto i dati su file
|
||
}
|
||
}
|
||
|
||
//controllo che ci sia spazio a sufficenza per emettere il flusso
|
||
//sull'unit<69> scelta dall'utente,ritorna TRUE se <20> possibile farlo
|
||
bool TEmissione::ok_write()
|
||
{
|
||
long elem = _cur->items();
|
||
int dim = _trasfile->recordsize();
|
||
unsigned long nbyte = (elem*7+2)*dim;
|
||
|
||
TString16 unita; unita << _msk->get(F_UNITA)[0] << ":/";
|
||
return os_test_disk_free_space(unita, nbyte);
|
||
}
|
||
|
||
// aggiorna numero e data di emissione ed il flag di stampa
|
||
// su tutti gli effetti nel cursore
|
||
void TEmissione::aggiorna_rb(TCursor* cur)
|
||
{
|
||
TLocalisamfile &eff = cur->file(LF_EFFETTI);
|
||
for (*cur = 0; cur->pos() < cur->items(); ++(*cur))
|
||
{
|
||
TEffetto effetto = eff.curr();
|
||
long numero = effetto.numero();
|
||
effetto.put(EFF_NUMEMISS, numero);
|
||
TDate data = _msk->get_date(F_DATAEMIS);
|
||
effetto.put(EFF_DATAEMISS, data);
|
||
bool cond = TRUE;
|
||
effetto.put(EFF_EFFSTAMP, cond);
|
||
effetto.rewrite(eff);
|
||
}
|
||
}
|
||
|
||
// aggiorna il flag di stampa della distinta
|
||
// su tutti gli effetti nel cursore
|
||
void TEmissione::aggiorna_dist(TCursor* cur)
|
||
{
|
||
TLocalisamfile &eff = cur->file(LF_EFFETTI);
|
||
for (*cur = 0; cur->pos() < cur->items(); ++(*cur))
|
||
{
|
||
TEffetto effetto = eff.curr();
|
||
bool cond = TRUE;
|
||
effetto.put(EFF_DISTSTAM, cond);
|
||
effetto.rewrite(eff);
|
||
}
|
||
}
|
||
|
||
// gestione emissione su moduli cartacei delle riba
|
||
void TEmissione::print_rb(char tipost, int ndist, char tipodist, int ncopie, const bool is_vis)
|
||
{
|
||
TCursor* fcur = _formrb->cursor();
|
||
TLocalisamfile &eff = fcur->file(LF_EFFETTI);
|
||
|
||
TString filter;
|
||
if (tipost == 'D' && !_msk->get_bool(F_RIST)) // se stampa definitiva effetti e se non deve ristampare le riba
|
||
filter = "EFFSTAMP=\" \"";// setta il filtro del cursore per stampare solo gli effetti non ancora stampati
|
||
|
||
// setta la chiave 4 per il cursore per poter leggere tutti gli effetti della distinta
|
||
fcur->setkey(4);
|
||
if (ndist > 0)
|
||
{
|
||
TRectype darec(eff.curr());// fissa i dati per la scelta degli ...
|
||
darec.zero();// ... effetti nel primo e nell'ultimo record del cursore
|
||
darec.put(EFF_TIPODIST, tipodist);
|
||
darec.put(EFF_NDIST, ndist);
|
||
fcur->setregion(darec, darec);
|
||
}
|
||
else
|
||
{
|
||
if (filter.not_empty()) filter << "&&";
|
||
filter << "(TIPODIST==\"\")&&(NDIST==\"\")";
|
||
}
|
||
fcur->setfilter(filter,TRUE);
|
||
|
||
long n = fcur->items();
|
||
fcur->freeze();
|
||
// se la stampa non si fa a video istanzia puntatore per la gestione
|
||
// della barra di attesa
|
||
TProgind* pi = is_vis ? NULL : new TProgind(ncopie,"Stampa Effetti...",FALSE,TRUE);
|
||
for (int j=0; j < ncopie; j++)
|
||
{
|
||
if (pi) pi->addstatus(1L); // aggiorna la barra d'attesa
|
||
// ciclo sugli elementi del cursore di stampa
|
||
//for (*fcur = 0; fcur->pos() < n; ++(*fcur))
|
||
{
|
||
_formrb->print(); // stampa il form
|
||
}
|
||
}
|
||
if (tipost == 'D') // se emetto riba in definitiva devo aggiornare
|
||
aggiorna_rb(fcur);// data, numero emissione e flag di stampa effetto
|
||
if (pi) delete pi;
|
||
}
|
||
|
||
// gestione emissione su moduli cartacei delle distinte
|
||
void TEmissione::print_dse(char tipost, int ndist, char tipodist, int ncopie, const bool is_vis)
|
||
{
|
||
TCursor* fcur = _formdse->cursor();
|
||
TLocalisamfile &eff = fcur->file(LF_EFFETTI);
|
||
// setta la chiave 4 per il cursore per poter leggere tutti gli effetti
|
||
// della distinta
|
||
TString16 filter;
|
||
if (tipost == 'D' && !_msk->get_bool(F_RIST)) // se stampa definitiva effetti e se non deve ristampare le riba
|
||
filter = "DISTSTAM=\" \"";// setta il filtro del cursore per ...
|
||
fcur->setfilter(filter,TRUE);
|
||
fcur->setkey(4);
|
||
TRectype darec(eff.curr()); // fissa i dati per la scelta degli ...
|
||
darec.zero(); // ... effetti nel primo e nell'ultimo record del cursore
|
||
if (ndist > 0)
|
||
{
|
||
darec.put(EFF_NDIST, ndist);
|
||
darec.put(EFF_TIPODIST, tipodist);
|
||
TRectype arec(darec);
|
||
fcur->setregion(darec, arec);
|
||
fcur->setfilter("");
|
||
}
|
||
else
|
||
fcur->setfilter("(TIPODIST==\"\")&&(NDIST==\"\")");
|
||
long n = fcur->items();
|
||
fcur->freeze();
|
||
// se la stampa non si fa a video istanzia puntatore per la gestione
|
||
// della barra di attesa
|
||
TProgind* pi = is_vis ? NULL : new TProgind(ncopie,"Stampa Distinta...",FALSE,TRUE);
|
||
for (int j=0; j < ncopie; j++)
|
||
{
|
||
_base_page_no = 0;
|
||
if (pi) pi->addstatus(1L); // aggiorna la barra d'attesa
|
||
_formdse->find_field('F',last_page,2).set(""); // Azzera nr documenti
|
||
_formdse->find_field('F',last_page,3).set(""); // Azzera tot documenti
|
||
_formdse->print(); // stampa il form
|
||
// stampa numero di pagina (solo nella distinta)
|
||
_base_page_no = printer().getcurrentpage() -1;
|
||
}
|
||
if (tipost == 'D') // se emetto distinta in definitiva ...
|
||
aggiorna_dist(fcur);// ... devo aggiornare flag di stampa distinta
|
||
if (pi) delete pi;
|
||
}
|
||
|
||
void TEmissione::enable_dettaglio(TForm& form) const
|
||
{
|
||
TForm_subsection* fss = form.exist_field('B', odd_page, "RIGHE_EFFETTO");
|
||
const bool dett = _msk->get_bool(F_DETTAGLIO);
|
||
if (fss)
|
||
fss->show(dett);
|
||
else
|
||
{
|
||
if (dett)
|
||
{
|
||
warning_box("Il modulo %s non prevede la stampa dei dettagli:\n"
|
||
"E' necessario aggiungere la sezione RIGHE_EFFETTO",
|
||
(const char*)form.name());
|
||
}
|
||
}
|
||
}
|
||
|
||
// gestione emissione effetti/distinte su moduli cartacei
|
||
void TEmissione::print()
|
||
{
|
||
int ncopie = _msk->get_int(F_NCOPIE);
|
||
if (ncopie == 0) ncopie = 1;
|
||
printer().open();
|
||
// TRUE se si stampa a video
|
||
const bool is_vis = printer().printtype() == screenvis;
|
||
int emis = _msk->get_int(F_EMIS);
|
||
int ndist = _msk->get_int(F_NUMBER);
|
||
char tipodist = _msk->get(F_TIPODIST)[0];
|
||
_rel->curr().put(EFF_TIPODIST,tipodist);
|
||
_rel->curr().put(EFF_NDIST,ndist);
|
||
_rel->curr().put(EFF_NRIGADIST,1);
|
||
_rel->lfile().setkey(4);
|
||
_rel->read();
|
||
long codabi = _rel->curr().get_long(EFF_CODABIP);
|
||
const char tipocf = _rel->curr().get_char(EFF_TIPOCF);
|
||
const char tipopag = _rel->curr().get_char(EFF_TIPOPAG);
|
||
|
||
char tipost = _msk->get(F_TIPOST)[0];
|
||
char tipord = _msk->get(F_TIPORD)[0];
|
||
// se emetto riba istanzio il form per le riba
|
||
// se emetto distinta istanzio il form per le distinte
|
||
TFilename nomeform; // compongo il nome del form
|
||
if (emis == 1)
|
||
{
|
||
nomeform.format("r%c%c%05ld.frm",tipocf, tipopag, codabi);
|
||
if (!nomeform.exist()) // se non esiste
|
||
nomeform.overwrite("00000", 3); // elimino codice banca
|
||
if (!nomeform.exist()) // se non esiste
|
||
nomeform.overwrite("0", 2); // elimino tipo pagamento
|
||
if (!nomeform.exist()) // se non esiste
|
||
nomeform = "rb.frm"; // utilizzo quello generico
|
||
_formrb = new TRiba_form(nomeform);
|
||
enable_dettaglio(*_formrb);
|
||
print_rb(tipost,ndist,tipodist,ncopie,is_vis);
|
||
}
|
||
else
|
||
{
|
||
nomeform.format("d%c%c%05ld.frm",tipocf, tipopag, codabi);// compongo il nome del form
|
||
if (!nomeform.exist()) // se non esiste
|
||
nomeform.overwrite("00000", 3); // elimino codice banca
|
||
if (!nomeform.exist()) // se non esiste
|
||
nomeform.overwrite("0", 2); // elimino tipo pagamento
|
||
if (!nomeform.exist()) // se non esiste
|
||
nomeform = "dse.frm"; // utilizzo quello generico
|
||
_formdse = new TDistinta_form(nomeform, _firmrel);
|
||
enable_dettaglio(*_formdse);
|
||
_formdse->set_order(tipord);
|
||
print_dse(tipost,ndist,tipodist,ncopie,is_vis);
|
||
}
|
||
printer().close();
|
||
}
|
||
|
||
// handler per gestire la conferma dell'annullamento dei dati inseriti
|
||
// nella maschera
|
||
bool TEmissione::annulla_handler(TMask_field& f, KEY k)
|
||
{
|
||
TMask &m = f.mask();
|
||
if (k == K_SPACE)
|
||
{
|
||
if (yesno_box("Vuoi veramente annullare i dati inseriti"))
|
||
m.reset();
|
||
}
|
||
return TRUE;
|
||
}
|
||
|
||
// costruttore classe TRiba_form
|
||
TRiba_form::TRiba_form(const char* name): TForm()
|
||
{
|
||
read(name);
|
||
}
|
||
|
||
// gestione dei messaggi estesi nei campi
|
||
bool TRiba_form::validate(TForm_item &cf, TToken_string &s)
|
||
{
|
||
const TString16 code(s.get(0));
|
||
TString valore; // Attenzione pu<70> essere molto lunga (descrizione di 5 righe)
|
||
|
||
if (code == "_IMPORTO")
|
||
{
|
||
// gestione dei campi relativi all'importo dell'effetto. Setta il valore da
|
||
// solo se e' in valuta (cambia anche la picture)
|
||
// sintassi: _IMPORTO
|
||
TEffetto effetto(cursor()->file().curr());
|
||
const bool in_valuta = effetto.in_valuta();
|
||
real importo = effetto.importo(in_valuta);
|
||
cf.set(importo.string());
|
||
}
|
||
else if (code == "_BANCAP")
|
||
{
|
||
// gestione dei campi relativi alla banca di presentazione dell'effetto
|
||
// sintassi: _BANCAP
|
||
TCursor* cur = cursor();
|
||
if (cur->curr().get_int(EFF_NDIST) > 0)
|
||
{
|
||
TRectype & ban = cur->curr(-204);
|
||
valore.cut(0);
|
||
valore << ban.get("S0");
|
||
valore.trim();
|
||
ban = cur->curr(-202);
|
||
valore << " " << ban.get("S0");
|
||
valore.trim();
|
||
cf.set(valore);
|
||
cf.put_paragraph(valore);
|
||
}
|
||
}
|
||
else if (code == "_FATT")
|
||
{
|
||
// gestione dei campi relativi alle/a fatture/a a cui si riferisce un effetto
|
||
// sintassi: _FATT,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!A" fattura o fatture
|
||
// "!DATI" numero e data fattura
|
||
// "!IMPFATT" importo fattura
|
||
//TCursor* fcur = cursor();
|
||
//TLocalisamfile &eff = fcur->file(LF_EFFETTI);
|
||
TEffetto effetto(cursor()->file().curr());// = eff.curr();
|
||
long num = effetto.numero();
|
||
const bool in_valuta = effetto.in_valuta();
|
||
bool condition = (effetto.fatt(num));//TRUE se effetto non raggruppato
|
||
TToken_string dati; effetto.dati_fatt(num, in_valuta, dati);
|
||
TString in(s.get());
|
||
if (in[0]=='!')
|
||
{
|
||
in.ltrim(1);
|
||
// "!A" se 1 sola fattura stampa 'a' altrimenti stampa 'e'
|
||
if (in == "A")
|
||
{
|
||
if (condition)
|
||
cf.set("a");
|
||
else
|
||
cf.set("e");
|
||
}
|
||
// "!DATIFATT" stampa numero e data fattura delle fatture a cui si riferisce l'effetto
|
||
if (in == "DATIFATT")
|
||
{
|
||
int elem = dati.items();
|
||
TString descfatt;
|
||
for (int i = 0; i < elem; i+=3)
|
||
{
|
||
descfatt << dati.get(i);
|
||
descfatt << ' ';
|
||
descfatt << dati.get(i+1);
|
||
descfatt << '\n';
|
||
}
|
||
cf.set(descfatt);
|
||
}
|
||
// "!IMPFATT" se 1 sola fattura ne stampa l' importo
|
||
if (in == "IMPFATT")
|
||
{
|
||
if (condition)
|
||
{
|
||
real importo(dati.get(2));
|
||
cf.set(importo.string());
|
||
}
|
||
}
|
||
}
|
||
valore = cf.get();
|
||
cf.put_paragraph(valore);
|
||
return (TRUE);
|
||
}
|
||
else
|
||
if (code == "_CLI")
|
||
{
|
||
// gestione dei campi relativi al cliente a cui si riferisce un effetto
|
||
// sintassi: _CLI,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!IND" INDIRIZZO + NR. CIVICO
|
||
// "!LOCALITA" LOCALITA
|
||
// "!PIAZZA" COMUNE + PROVINCIA
|
||
// "!CAP" CAP
|
||
// "!RAGSOC" Ragione sociale
|
||
// Queste macro sono state implementate per permettere di utilizzare
|
||
// L'indirizzo di spedizione effetti memorizzato in LF_CFVEN->CODINDEFF
|
||
TString in(s.get());
|
||
if (in[0]=='!')
|
||
{
|
||
in.ltrim(1);
|
||
TRelation* rel = relation();
|
||
|
||
const bool pick_normal = rel->curr(LF_CFVEN).get_int(CFV_CODINDEFF) == 0;
|
||
|
||
if (in=="IND")
|
||
{
|
||
const TRectype& cli = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP);
|
||
valore = cli.get(pick_normal ? CLI_INDCF : IND_INDIR);
|
||
const TString& civ = cli.get(pick_normal ? CLI_CIVCF : IND_CIV);
|
||
if (civ.not_empty())
|
||
valore << ", " << civ;
|
||
}
|
||
else
|
||
if (in=="PIAZZA" || in=="COMUNE")
|
||
{
|
||
const TRectype& com = rel->curr(pick_normal ? LF_COMUNI : -213);
|
||
valore = com.get(COM_DENCOM);
|
||
const TString& prov = com.get(COM_PROVCOM);
|
||
if (prov.not_empty())
|
||
valore << " (" << prov << ")";
|
||
}
|
||
else
|
||
if (in=="LOCALITA")
|
||
{
|
||
const TRectype& cli = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP);
|
||
valore = cli.get(pick_normal ? CLI_LOCCF : IND_LOCALITA);
|
||
}
|
||
else
|
||
if (in=="RAGSOC")
|
||
valore = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP).get(pick_normal ? CLI_RAGSOC : IND_RAGSOC);
|
||
else
|
||
if (in=="CAPCF")
|
||
valore = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP).get(pick_normal ? CLI_CAPCF : IND_CAP);
|
||
}
|
||
cf.put_paragraph(valore);
|
||
return (TRUE);
|
||
}
|
||
return TForm::validate(cf, s);
|
||
}
|
||
|
||
// costruttore classe TDistinta_form
|
||
TDistinta_form::TDistinta_form(const char* name, TRelation *rel): TForm(), _firmrel(rel)
|
||
{
|
||
read(name);
|
||
_cursor = NULL;
|
||
}
|
||
|
||
// setta l'ordinamento del TSordet_cursor del form
|
||
void TDistinta_form::set_order(const char tipo)
|
||
{
|
||
TString ordine;
|
||
// ordinamento secondo la data di scadenza dell'effetto
|
||
if (tipo == 'S')
|
||
ordine = "DATASCAD|TIPODIST|NDIST|NRIGADIST";
|
||
// ordinamento seconda il numero e la data della fattura
|
||
if (tipo == 'F')
|
||
ordine = "14->NFATT|TIPODIST|NDIST|NRIGADIST";
|
||
_cursor = new TSorted_cursor(relation(),ordine);
|
||
}
|
||
|
||
// distruttore classe TDistinta_form
|
||
TDistinta_form::~TDistinta_form()
|
||
{
|
||
if (_cursor) delete _cursor;
|
||
}
|
||
|
||
// gestione dei messaggi estesi nei campi
|
||
bool TDistinta_form::validate(TForm_item &cf, TToken_string &s)
|
||
{
|
||
const TString code(s.get(0));
|
||
TString valore;
|
||
if (code == "_IMPORTO")
|
||
{
|
||
// gestione dei campi relativi all'importo dell'effetto. Setta il valore da
|
||
// solo se e' in valuta (cambia anche la picture)
|
||
// sintassi: _IMPORTO
|
||
TEffetto effetto(cursor()->file().curr());
|
||
const bool in_valuta = effetto.in_valuta();
|
||
real importo = effetto.importo(in_valuta);
|
||
cf.set(importo.string());
|
||
return (TRUE);
|
||
}
|
||
if (code == "_BANCAP")
|
||
{
|
||
// gestione dei campi relativi alla banca di presentazione della distinta
|
||
// sintassi: _BANCAP
|
||
TCursor* cur = cursor();
|
||
TRectype & ban = cur->curr(-204);
|
||
valore.cut(0);
|
||
valore << ban.get("S0");
|
||
valore.trim();
|
||
ban = cur->curr(-202);
|
||
valore << " " << ban.get("S0");
|
||
valore.trim();
|
||
cf.set(valore);
|
||
cf.put_paragraph(valore);
|
||
return (TRUE);
|
||
}
|
||
if (code == "_DITTA")
|
||
{
|
||
// gestione di campi della ditta corrente
|
||
// sintassi: _DITTA,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!RAGSOC" ragione sociale
|
||
TString in(s.get());
|
||
if (in[0]=='!')
|
||
{
|
||
in.ltrim(1);
|
||
// "!RAGSOC" prende la ragione sociale della ditta corrente
|
||
if (in=="RAGSOC")
|
||
{
|
||
valore = _firmrel->curr().get("RAGSOC");
|
||
valore.strip_d_spaces();
|
||
cf.set(valore);
|
||
}
|
||
}
|
||
valore = cf.get();
|
||
cf.put_paragraph(valore);
|
||
cf.set("");
|
||
return (TRUE);
|
||
}
|
||
if (code == "_CLI")
|
||
{
|
||
// gestione dei campi relativi al cliente a cui si riferisce un effetto
|
||
// sintassi: _CLI,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!IND" INDIRIZZO + NR. CIVICO
|
||
// "!PIAZZA" COMUNE + PROVINCIA
|
||
// "!CAP" CAP
|
||
// "!RAGSOC" Ragione sociale
|
||
// Queste macro sono state implementate per permettere di utilizzare
|
||
// L'indirizzo di spedizione effetti memorizzato in LF_CFVEN->CODINDEFF
|
||
TString in(s.get());
|
||
if (in[0]=='!')
|
||
{
|
||
in.ltrim(1);
|
||
TRelation* rel = relation();
|
||
|
||
const bool pick_normal = rel->lfile(LF_CFVEN).get_int(CFV_CODINDEFF) == 0;
|
||
|
||
if (in=="IND")
|
||
{
|
||
valore = rel->lfile(pick_normal ? LF_CLIFO : LF_INDSP).get(pick_normal ? CLI_INDCF : IND_INDIR);
|
||
in = rel->lfile(pick_normal ? LF_CLIFO : LF_INDSP).get(pick_normal ? CLI_CIVCF : IND_CIV);
|
||
if (in.not_empty())
|
||
valore << ", " << in;
|
||
}
|
||
else
|
||
if (in=="PIAZZA" || in=="COMUNE")
|
||
{
|
||
valore = rel->curr(pick_normal ? LF_COMUNI : -213).get(COM_DENCOM);
|
||
in = rel->curr(pick_normal ? LF_COMUNI : -213).get(COM_PROVCOM);
|
||
if (in.not_empty())
|
||
valore << " (" << in << ")";
|
||
} else
|
||
if (in=="LOCALITA")
|
||
{
|
||
const TRectype& cli = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP);
|
||
valore = cli.get(pick_normal ? CLI_LOCCF : IND_LOCALITA);
|
||
} else
|
||
if (in=="RAGSOC")
|
||
valore = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP).get(pick_normal ? CLI_RAGSOC : IND_RAGSOC);
|
||
else
|
||
if (in=="CAPCF")
|
||
valore = rel->curr(pick_normal ? LF_CLIFO : LF_INDSP).get(pick_normal ? CLI_CAPCF : IND_CAP);
|
||
}
|
||
cf.set(valore);
|
||
cf.put_paragraph(valore);
|
||
return (TRUE);
|
||
}
|
||
if (code == "_FATT")
|
||
{
|
||
// gestione dei campi relativi alle fatture a cui si riferisce un effetto
|
||
// sintassi: _FATT,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!DATI" numero e data fattura
|
||
TEffetto effetto(cursor()->file().curr()); //= eff.curr();
|
||
long num = effetto.numero();
|
||
TToken_string dati; effetto.dati_fatt(num, FALSE, dati);
|
||
const int elem = dati.items();
|
||
TString80 in(s.get()); // prende il primo parametro, il codice del messaggio
|
||
if (in[0]=='!')
|
||
{
|
||
in.ltrim(1);
|
||
// "!DATIFATT" stampa numero e data fattura delle fatture a cui si riferisce l'effetto
|
||
if (in == "DATIFATT")
|
||
{
|
||
TString descfatt;
|
||
for (int i = 0; i < elem; i+=3)
|
||
{
|
||
descfatt << dati.get(i);
|
||
descfatt << ' ';
|
||
descfatt << dati.get(i+1);
|
||
descfatt << '\n';
|
||
}
|
||
cf.set(descfatt);
|
||
}
|
||
}
|
||
valore = cf.get();
|
||
cf.put_paragraph(valore);
|
||
return (TRUE);
|
||
}
|
||
if (code == "_DATA")
|
||
{
|
||
// gestione della data di emissione delle riba
|
||
// sintassi: _DATA
|
||
const TDate data_emis = app().msk().get_date(F_DATAEMIS);
|
||
valore = data_emis.string();
|
||
cf.set(valore);
|
||
cf.put_paragraph(valore);
|
||
cf.set("");
|
||
return TRUE;
|
||
}
|
||
return TForm::validate(cf, s);
|
||
}
|
||
|
||
// gestione dei messaggi estesi nei campi
|
||
void TRiba_file::validate(TCursor& cur,TRecord_text &rec, TToken_string &s, TString& str)
|
||
{
|
||
const TString code(s.get(0));
|
||
TString valore;
|
||
if (code == "_FISSO")
|
||
{
|
||
// gestione dei campi fissi per i record delle riba
|
||
// sintassi: _FISSO,!<valore>
|
||
// dove: <valore> <20> la stringa fissa da emettere
|
||
TString in(s.get());
|
||
CHECK(in[0]=='!',"Macro _FISSO senza carattere '!'");
|
||
in.ltrim(1);
|
||
in.trim();
|
||
valore = in;
|
||
}
|
||
else if (code == "_DATA")
|
||
{
|
||
// gestione della data di emissione delle riba
|
||
// sintassi: _DATA
|
||
const TDate data_emis = app().msk().get_date(F_DATAEMIS);
|
||
valore = data_emis.string();
|
||
}
|
||
else if (code == "_NRIBA")
|
||
{
|
||
// gestione dei campi relativi al flusso di effetti (riba)
|
||
// sintassi: _NRIBA,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!NUM" numero progressivo riba all'interno del flusso
|
||
// "!TOT" numero di effetti nel flusso
|
||
// "!NREC" numero di records nel flusso
|
||
int items = (int)cur.items();
|
||
TString in(s.get());
|
||
CHECK(in[0]=='!',"Macro _NRIBA senza carattere '!'");
|
||
in.ltrim(1);
|
||
if (in=="NUM")
|
||
{
|
||
valore.cut(0);
|
||
valore << cur.pos() + 1;
|
||
}
|
||
else if (in=="TOT")
|
||
{
|
||
valore.cut(0);
|
||
valore << items;
|
||
}
|
||
else if (in=="NREC")
|
||
{
|
||
valore.cut(0);
|
||
int rec = items * 7 + 2;
|
||
valore << rec;
|
||
}
|
||
else
|
||
CHECKS (TRUE,"Sotto-Macro _NRIBA non definita",(const char *)in);
|
||
}
|
||
else if (code == "_DITTA")
|
||
{
|
||
// gestione di campi della ditta corrente
|
||
// sintassi: _DITTA,<macro>,<opzione>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!RAGSOC" ragione sociale
|
||
// dove: <opzione> <20> uno delle opzioni seguenti:
|
||
// "0" la ragione sociale andr<64> ad occupare un unico campo
|
||
// "1" la ragione sociale andr<64> ad occupare pi<70> campi, primo segmento
|
||
// "2" la ragione sociale andr<64> ad occupare pi<70> campi, secondo segmento
|
||
// "3" la ragione sociale andr<64> ad occupare pi<70> campi, terzo segmento
|
||
// "4" la ragione sociale andr<64> ad occupare pi<70> campi, quarto segmento
|
||
|
||
TString in(s.get());
|
||
CHECK(in[0]=='!',"Macro _DITTA senza carattere '!'");
|
||
in.ltrim(1);
|
||
if (in=="RAGSOC")
|
||
{
|
||
const TRectype& ditte = app().firm_rel().curr();
|
||
const TString ragsoc = ditte.get("RAGSOC");
|
||
in = s.get();
|
||
if (in == "0")
|
||
{
|
||
valore.cut(0);
|
||
valore = ragsoc.left(30);
|
||
valore.trim();
|
||
TString str = ragsoc.right(20);
|
||
str.trim();
|
||
valore << " " << str;
|
||
}
|
||
else
|
||
{
|
||
TParagraph_string string(ragsoc,24);
|
||
const int indice = atoi(in);
|
||
valore = string.get(indice-1);
|
||
}
|
||
}
|
||
else
|
||
CHECKS (TRUE,"Sotto-Macro _DITTA non definita",(const char *)in);
|
||
}
|
||
else if (code == "_DEBITORE")
|
||
{
|
||
// gestione di campi della ditta corrente
|
||
// sintassi: _DEBITORE,<macro>,<opzione>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!RAGSOC" ragione sociale
|
||
// "!CFPI" Partita IVA o Codice fiscale
|
||
// "!INDIRIZZO" indirizzo
|
||
// "!PIAZZA" comune + sigla provincia
|
||
// dove: <opzione> <20> uno delle opzioni seguenti:
|
||
// "1" la ragione sociale andr<64> ad occupare pi<70> campi, primo segmento
|
||
// "2" la ragione sociale andr<64> ad occupare pi<70> campi, secondo segmento
|
||
const bool pick_normal = cur.relation()->lfile(LF_CFVEN).get_int(CFV_CODINDEFF) == 0;
|
||
|
||
TRectype& clifo_1 = cur.curr(LF_CLIFO);
|
||
TRectype& clifo_2 = cur.curr(pick_normal ? LF_CLIFO : LF_INDSP);
|
||
TRectype& comuni = cur.curr(pick_normal ? LF_COMUNI: -213);
|
||
|
||
TString in(s.get());
|
||
CHECK(in[0]=='!',"Macro _DEBITORE senza carattere '!'");
|
||
in.ltrim(1);
|
||
if (in=="RAGSOC")
|
||
{
|
||
TString ragsoc = clifo_2.get(pick_normal ? CLI_RAGSOC : IND_RAGSOC);
|
||
in = s.get();
|
||
TParagraph_string string(ragsoc,30);
|
||
string.restart();
|
||
int indice = atoi(in);
|
||
if (in == "1") valore = string.get(indice-1);
|
||
if (in == "2") valore = string.get(indice-1);
|
||
}
|
||
else if (in=="INDIRIZZO")
|
||
{
|
||
valore = clifo_2.get(pick_normal ? CLI_INDCF : IND_INDIR);
|
||
valore.trim();
|
||
valore << " " << clifo_2.get_int(pick_normal ? CLI_CIVCF : IND_CIV);
|
||
valore.trim();
|
||
valore << " " << clifo_2.get(pick_normal ? CLI_LOCCF : IND_LOCALITA);
|
||
valore.trim();
|
||
}
|
||
else if (in=="COMUNE")
|
||
{
|
||
valore = comuni.get("DENCOM");
|
||
valore.trim();
|
||
}
|
||
else if (in=="PROV")
|
||
{
|
||
valore = comuni.get("PROVCOM");
|
||
valore.trim();
|
||
}
|
||
else if (in=="LOCALITA")
|
||
{
|
||
valore = clifo_2.get(pick_normal ? CLI_LOCCF : IND_LOCALITA);
|
||
valore.trim();
|
||
}
|
||
else if (in=="LOCALITA+COMUNE")
|
||
{
|
||
valore = clifo_2.get(pick_normal ? CLI_LOCCF : IND_LOCALITA);
|
||
valore.trim();
|
||
if (valore.not_empty())
|
||
valore << " (" << comuni.get("DENCOM") << ')';
|
||
else
|
||
valore = comuni.get("DENCOM");
|
||
valore.trim();
|
||
}
|
||
else if (in=="CFPI")
|
||
{
|
||
valore = clifo_1.get("PAIV");
|
||
valore.trim();
|
||
if (valore.empty())
|
||
valore = clifo_1.get("COFI");
|
||
valore.trim();
|
||
}
|
||
else
|
||
CHECKS (TRUE,"Sotto-Macro _DEBITORE non definita",(const char *)in);
|
||
}
|
||
else if (code == "_BANCA")
|
||
{
|
||
// gestione dei campi relativi alla banca d'appoggio dell'effetto
|
||
// sintassi: _BANCA
|
||
TRectype & ban = cur.curr(-401);
|
||
valore.cut(0);
|
||
valore << ban.get("S0");
|
||
valore.trim();
|
||
ban = cur.curr(-402);
|
||
valore << " " << ban.get("S0");
|
||
valore.trim();
|
||
}
|
||
else if (code == "_FATT")
|
||
{
|
||
// gestione dei campi relativi alle/a fatture/a a cui si riferisce un effetto
|
||
// sintassi: _FATT,<opzione>
|
||
// dove: <opzione> <20> uno delle opzioni seguenti:
|
||
// "1" i dati della fattura andranno ad occupare pi<70> campi, primo segmento
|
||
// "2" i dati della fattura andranno ad occupare pi<70> campi, secondo segmento
|
||
TLocalisamfile &eff = cur.file();
|
||
TEffetto effetto = eff.curr();
|
||
long num = effetto.numero();
|
||
TString descfatt;
|
||
if (tracciato_setif())
|
||
{
|
||
TToken_string dati; effetto.dati_fatt(num, FALSE, dati);
|
||
int elem = dati.items();
|
||
for (int i = 0; i < elem; i+=3)
|
||
{
|
||
descfatt << dati.get(i);
|
||
descfatt << " ";
|
||
descfatt << dati.get(i+1);
|
||
descfatt << " ";
|
||
}
|
||
}
|
||
else
|
||
{
|
||
TToken_string dati; effetto.altridati_fatt(num, dati);
|
||
int elem = dati.items();
|
||
TString16 str;
|
||
for (int i = 0; i < elem; i+=3)
|
||
{
|
||
if (i!=0)
|
||
descfatt << "/";
|
||
str = dati.get(i); str.trim(); // codnum
|
||
if (str.not_empty()) descfatt << str << ' ';
|
||
|
||
str = dati.get(); str.trim(); // numdoc
|
||
if (str.not_empty()) descfatt << str;
|
||
|
||
str = dati.get(i); // anno (2 cifre)
|
||
str.trim();
|
||
if (str.len() >= 2)
|
||
descfatt << ' ' << str.right(2);
|
||
}
|
||
}
|
||
const int l = descfatt.len();
|
||
TString in(s.get());
|
||
if (in[0]=='!')
|
||
{
|
||
in.ltrim(1);
|
||
if (in == "1")
|
||
{
|
||
valore = descfatt.left(40);
|
||
valore.trim();
|
||
}
|
||
if (in == "2")
|
||
{
|
||
valore = descfatt.mid(40, l);
|
||
valore.trim();
|
||
}
|
||
}
|
||
}
|
||
else if (code == "_IMPORTO")
|
||
{
|
||
// gestione di campi degli importi degli effetti nel flusso
|
||
// sintassi: _IMPORTO,<macro>
|
||
// dove: <macro> <20> uno delle macro seguenti:
|
||
// "!ADD" aggiunge l'importo dell'effetto corrente al totale
|
||
// "!TOT" emette il totale
|
||
const TString in(s.get());
|
||
CHECK(in[0]=='!',"Macro _IMPORTO senza carattere '!'");
|
||
if (in=="!ADD")
|
||
{
|
||
|
||
real importo = cur.curr(LF_EFFETTI).get(EFF_IMPORTO);
|
||
if (_codice_moneta == 'E')
|
||
importo *= 100.0;
|
||
/* GF only
|
||
real importo = cur.curr(LF_EFFETTI).get(EFF_IMPORTOVAL);
|
||
if (importo.is_zero())
|
||
{
|
||
importo = cur.curr(LF_EFFETTI).get_real(EFF_IMPORTO);
|
||
importo /= 1936.27;
|
||
}
|
||
importo *= 100.0;
|
||
*/
|
||
/* Allore only
|
||
real importo = cur.curr(LF_EFFETTI).get(EFF_IMPORTOVAL);
|
||
if (importo.is_zero())
|
||
importo = cur.curr(LF_EFFETTI).get_real(EFF_IMPORTO);
|
||
else
|
||
importo *= 100.0;
|
||
*/
|
||
importo.round(0);
|
||
add_tot_importi(importo);
|
||
valore = importo.string(13,0);
|
||
}
|
||
else if (in=="!TOT")
|
||
{
|
||
const real& importo = tot_importi();
|
||
valore = importo.string("##############@");
|
||
set_tot_importi(ZERO);
|
||
}
|
||
else
|
||
CHECKS (TRUE,"Sotto-Macro _IMPORTO non definita",(const char *)in);
|
||
}
|
||
else if (code == "_CODSIA")
|
||
{
|
||
TConfig cnf(CONFIG_DITTA, "ef");
|
||
valore = cnf.get("CODSIA");
|
||
}
|
||
else if (code == "_CODMON")
|
||
{
|
||
valore.format("%c", _codice_moneta);
|
||
}
|
||
else NFCHECK("Macro non definita: %s", (const char *)code);
|
||
|
||
str = valore;
|
||
}
|
||
|
||
int ef0500(int argc, char* argv[])
|
||
{
|
||
TEmissione a ;
|
||
a.run(argc, argv, "Emissione Effetti e Distinte");
|
||
return 0;
|
||
} |