Stampa EC

git-svn-id: svn://10.65.10.50/trunk@2234 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
guy 1995-12-04 11:06:42 +00:00
parent e029749e8b
commit f6fefe5ed6
4 changed files with 557 additions and 464 deletions

View File

@ -20,16 +20,13 @@
class TCreatepart_app : public TApplication class TCreatepart_app : public TApplication
{ {
TLocalisamfile* _conti;
TLocalisamfile* _partite;
TLocalisamfile* _scadenze;
TLocalisamfile* _pagsca;
TEsercizi_contabili _esc; TEsercizi_contabili _esc;
bool _num_cli, _num_for; bool _num_cli, _num_for;
TString _desccl, _descfo; TString _desccl, _descfo;
TDate _today; TDate _today;
TLocalisamfile* _conti;
protected: // Applicat protected: // Applicat
virtual void on_firm_change(); virtual void on_firm_change();
virtual void on_config_change(); virtual void on_config_change();
@ -39,7 +36,8 @@ protected: // Applicat
virtual bool menu(MENU_TAG m); virtual bool menu(MENU_TAG m);
protected: protected:
bool zap_partite(); void zap_file(int logicnum) const;
bool zap_partite() const;
int crea_partite(int anno_es, int anno_rif, bool check); int crea_partite(int anno_es, int anno_rif, bool check);
public: public:
@ -54,9 +52,6 @@ bool TCreatepart_app::create()
TApplication::create(); TApplication::create();
_conti = new TLocalisamfile(LF_PCON); _conti = new TLocalisamfile(LF_PCON);
_partite = new TLocalisamfile(LF_PARTITE);
_scadenze = new TLocalisamfile(LF_SCADENZE);
_pagsca = new TLocalisamfile(LF_PAGSCA);
dispatch_e_menu(BAR_ITEM(1)); dispatch_e_menu(BAR_ITEM(1));
return TRUE; return TRUE;
@ -65,9 +60,6 @@ bool TCreatepart_app::create()
bool TCreatepart_app::destroy() bool TCreatepart_app::destroy()
{ {
delete _conti; delete _conti;
delete _partite;
delete _scadenze;
delete _pagsca;
return TApplication::destroy(); return TApplication::destroy();
} }
@ -85,28 +77,45 @@ void TCreatepart_app::on_config_change()
TPartita::carica_allineamento(); TPartita::carica_allineamento();
} }
bool TCreatepart_app::zap_partite() void TCreatepart_app::zap_file(int logicnum) const
{ {
bool first = TRUE; TDir dir;
for (_partite->first(); !_partite->eof(); _partite->next()) dir.get(logicnum, _lock, _nordir, _sysdirop);
dir.eod() = 0;
dir.put(logicnum, _nordir, _sysdirop);
TSystemisamfile f(logicnum);
f.pack();
}
bool TCreatepart_app::zap_partite() const
{ {
if (first) bool ok = TRUE;
TSystemisamfile partite(LF_PARTITE);
partite.open();
bool zap = partite.items() != 0;
partite.close();
if (zap)
{ {
bool ok = yesno_box("Il saldaconto non e' vuoto." zap = yesno_box("Il saldaconto non e' vuoto.\n"
" La procedura lo azzera completamente." "La procedura lo azzera completamente.\n"
"Si desidera proseguire?"); "Si desidera proseguire?");
if (ok) if (zap)
ok = yesno_box("Confermare l'azzeramento del saldaconto esistente"); zap = yesno_box("Confermare l'azzeramento del saldaconto esistente");
if (!ok)
return FALSE; if (zap)
first = FALSE; {
zap_file(LF_PARTITE);
zap_file(LF_SCADENZE);
zap_file(LF_PAGSCA);
}
else
ok = FALSE;
} }
TPartita game(_partite->curr()); return ok;
game.remove();
}
return TRUE;
} }
@ -141,6 +150,11 @@ int TCreatepart_app::crea_partite(int anno_es, int anno_rif, bool check)
begin_wait(); begin_wait();
// Apre i files per usarli con l'oggetto TPartita
TLocalisamfile partite(LF_PARTITE);
TLocalisamfile scadenze(LF_SCADENZE);
TLocalisamfile pagamenti(LF_PAGSCA);
int n_part = 0; int n_part = 0;
TProgind prind(items, "Creazione saldaconto", FALSE, TRUE, 45); TProgind prind(items, "Creazione saldaconto", FALSE, TRUE, 45);
@ -193,9 +207,9 @@ int TCreatepart_app::crea_partite(int anno_es, int anno_rif, bool check)
const int g = riga.get_int(PART_GRUPPOCL); const int g = riga.get_int(PART_GRUPPOCL);
const int c = riga.get_int(PART_CONTOCL); const int c = riga.get_int(PART_CONTOCL);
if (gruppo == g && conto == c) if (gruppo == g && conto == c)
break; break; // Esiste gia' una riga con questo conto
} }
if (p > 0) if (p > 0) // Il cliente esiste gia', per cui ignoro il saldo
continue; continue;
} }
@ -208,17 +222,17 @@ int TCreatepart_app::crea_partite(int anno_es, int anno_rif, bool check)
riga.put(PART_DESCR, cf == 'C' ? _desccl : _descfo); riga.put(PART_DESCR, cf == 'C' ? _desccl : _descfo);
// cazzata dare/avere/fare/baciare/cagare // cazzata dare/avere/fare/baciare/cagare
const int tipo = (cf == 'C' ? (saldo.sezione() == 'D' ? 1 : 2) : const tipo_movimento tipo = (cf == 'C' ? (saldo.sezione() == 'D' ? tm_fattura : tm_nota_credito) :
(saldo.sezione() == 'D' ? 2 : 1)); (saldo.sezione() == 'D' ? tm_nota_credito : tm_fattura));
riga.put(PART_TIPOMOV, tipo); riga.put(PART_TIPOMOV, (int)tipo);
if (tipo == 1) if (tipo == tm_fattura)
{ {
TRiga_scadenze& scad = riga.new_row(); TRiga_scadenze& scad = riga.new_row();
scad.put(SCAD_IMPORTO, saldo.valore()); scad.put(SCAD_IMPORTO, saldo.valore());
scad.put(SCAD_DATASCAD, _today); scad.put(SCAD_DATASCAD, _today);
scad.put(SCAD_TIPOPAG, 1); scad.put(SCAD_TIPOPAG, 1); // rimessa diretta
} }
else else
{ {
@ -281,11 +295,10 @@ bool TCreatepart_app::menu(MENU_TAG)
else else
message_box("Nessun saldo presente per l'esercizio %d", anno_es); message_box("Nessun saldo presente per l'esercizio %d", anno_es);
if (n_part > 0) if (n_part > 0) // May be -1
m.set(F_NUMPART, n_part); m.set(F_NUMPART, n_part);
else else
m.reset(F_NUMPART) ; m.reset(F_NUMPART) ;
} // while run } // while run
return FALSE; return FALSE;

View File

@ -10,9 +10,11 @@
#include "sc2101.h" #include "sc2101.h"
#include "sc2100a.h" #include "sc2100a.h"
#include "sc21pec.h"
#include <clifo.h> #include <clifo.h>
#include <causali.h> #include <causali.h>
#include <pagsca.h>
#include <scadenze.h> #include <scadenze.h>
/////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////
@ -22,13 +24,13 @@
class TTotalizer : public TAssoc_array class TTotalizer : public TAssoc_array
{ {
public: public:
void add(const TImporto& imp, const char* val); void add(const TImporto& imp, const TString& val);
TTotalizer() { } TTotalizer() { }
virtual ~TTotalizer() { } virtual ~TTotalizer() { }
}; };
void TTotalizer::add(const TImporto& imp, const char* val) void TTotalizer::add(const TImporto& imp, const TString& val)
{ {
TString16 codice(val); TString16 codice(val);
if (codice == "LIT") if (codice == "LIT")
@ -58,6 +60,9 @@ class TEC_form : public TForm
TTotalizer _totali; TTotalizer _totali;
TDecoder _causali; TDecoder _causali;
TString _lingua;
TDate _dlo, _dls;
protected: protected:
static void ec_header_handler(TPrinter& p); static void ec_header_handler(TPrinter& p);
static void ec_footer_handler(TPrinter& p); static void ec_footer_handler(TPrinter& p);
@ -66,9 +71,13 @@ public:
TTotalizer& totali() { return _totali; } TTotalizer& totali() { return _totali; }
TDecoder& causali() { return _causali; } TDecoder& causali() { return _causali; }
const TDate& data_limite_operazione() const { return _dlo; }
const TDate& data_limite_scaduto() const { return _dls; }
const TString& lingua() const { return _lingua; }
bool print_game(const TPartita& game); bool print_game(const TPartita& game);
TEC_form(const char* codice, TCursor* cursor); TEC_form(const TEC_mask& m);
virtual ~TEC_form(); virtual ~TEC_form();
}; };
@ -83,6 +92,7 @@ class TEC_row : public TSortable
{ {
TDate _data; TDate _data;
int _riga; int _riga;
int _rata;
TString _causale; TString _causale;
TString _descrizione; TString _descrizione;
@ -91,50 +101,64 @@ class TEC_row : public TSortable
TString _num_doc; TString _num_doc;
long _num_prot; long _num_prot;
TImporto _importo; TImporto _importo;
TImporto _importo_lire;
real _scaduto;
real _totale;
TValuta _valuta; TValuta _valuta;
TImporto _totale_doc;
protected: // TSortable protected: // TSortable
virtual int compare(const TSortable& s) const; virtual int compare(const TSortable& s) const;
public: public:
void descrizione(const char* s) { _descrizione = s; } void descrizione(const char* s) { _descrizione = s; }
void scaduto(const real& s) { _scaduto = s; }
const TValuta& valuta() const { return _valuta; } const TValuta& valuta() const { return _valuta; }
const TImporto& importo() const { return _importo; } const TImporto& importo() const { return _importo; }
const TDate& data() const { return _data; }
void print_on(TPrint_section& body); void print_on(TPrint_section& body);
TEC_row(const TRiga_partite& row, const TDate& data, const TImporto& imp, int riga); TEC_row(const TRiga_partite& row, const TDate& data, const TImporto& imp, int rata);
TEC_row(const char* desc, const TImporto& imp); TEC_row(const char* desc, const TImporto& imp);
virtual ~TEC_row() {} virtual ~TEC_row() {}
}; };
TEC_row::TEC_row(const TRiga_partite& row, const TDate& data, const TImporto& imp, int riga) TEC_row::TEC_row(const TRiga_partite& row, const TDate& data, const TImporto& imp, int rata)
: _riga(riga), _num_prot(0) : _num_prot(0)
{ {
_riga = row.get_int(PART_NRIGA);
_rata = rata;
_data = data; _data = data;
_causale = row.get(PART_CODCAUS); _causale = row.get(PART_CODCAUS);
_data_doc = row.get(PART_DATADOC); _data_doc = row.get(PART_DATADOC);
_num_prot = row.get_long(PART_PROTIVA); _num_prot = row.get_long(PART_PROTIVA);
_importo = imp; _importo.normalize();
_totale = row.get_real(PART_IMPTOTPAG);
_valuta.get(row); _valuta.get(row);
_importo = imp;
// _totale = row.get_long(???);
} }
TEC_row::TEC_row(const char* desc, const TImporto& imp) TEC_row::TEC_row(const char* desc, const TImporto& imp)
: _riga(0), _num_prot(0) : _num_prot(0)
{ {
_descrizione = desc; _descrizione = desc;
_importo = imp; _importo = imp; _importo.normalize();
} }
// Le righe dell'estratto conto sono ordinate per data, riga partita, numero rata,
// posizione iniziale nell'array (in caso di uguaglianza di tutto il resto)
int TEC_row::compare(const TSortable& s) const int TEC_row::compare(const TSortable& s) const
{ {
const TEC_row& r = (const TEC_row&)s; const TEC_row& r = (const TEC_row&)s;
int c = 0; int c = 0;
if (_data == r._data) if (_data == r._data)
{
c = r._riga - _riga; c = r._riga - _riga;
if (c == 0)
c = r._rata - _rata;
}
else else
c = _data < r._data ? +1 : -1; c = _data < r._data ? +1 : -1;
return c; return c;
@ -144,56 +168,33 @@ void TEC_row::print_on(TPrint_section& body)
{ {
TEC_form& form = (TEC_form&)body.form(); TEC_form& form = (TEC_form&)body.form();
body.reset(); TForm_item& causale = body.find_field(PEC_CODCAUS);
if (_causale.not_empty())
{
TForm_item& causale = body.find_field(201);
causale.set(_causale); causale.set(_causale);
if (_causale.not_empty() && _descrizione.empty())
if (_descrizione.empty())
{ {
TDecoder& causali = form.causali(); TDecoder& causali = form.causali();
_descrizione = causali.decode(_causale); _descrizione = causali.decode(_causale);
} }
}
if (_descrizione.not_empty()) TForm_item& descr = body.find_field(PEC_DESCR1);
{
TForm_item& descr = body.find_field(202);
descr.set(_descrizione); descr.set(_descrizione);
}
if (_data_doc.ok()) TForm_item& datadoc = body.find_field(PEC_DATADOC);
{
TForm_item& datadoc = body.find_field(203);
datadoc.set(_data_doc.string()); datadoc.set(_data_doc.string());
}
if (_num_doc.not_empty()) TForm_item& numdoc = body.find_field(PEC_NUMDOC);
{
TForm_item& numdoc = body.find_field(204);
numdoc.set(_num_doc); numdoc.set(_num_doc);
}
if (_num_prot != 0) TForm_item& numprot = body.find_field(PEC_PROTIVA);
{
TForm_item& numprot = body.find_field(205);
TString16 protiva; protiva << _num_prot; TString16 protiva; protiva << _num_prot;
numprot.set(protiva); numprot.set(protiva);
}
if (_data.ok()) TForm_item& datapag = body.find_field(PEC_DATAPAG);
{
TForm_item& datapag = body.find_field(207);
datapag.set(_data.string()); datapag.set(_data.string());
}
const real& imp = _importo.valore(); const real& imp = _importo.valore();
if (!imp.is_zero()) TForm_item& dare = body.find_field(PEC_DARE);
{ TForm_item& avere = body.find_field(PEC_AVERE);
TForm_item& dare = body.find_field(208);
TForm_item& avere = body.find_field(209);
if (_importo.sezione() == 'D') if (_importo.sezione() == 'D')
{ {
@ -205,25 +206,17 @@ void TEC_row::print_on(TPrint_section& body)
avere.set(imp.string()); avere.set(imp.string());
dare.set(""); dare.set("");
} }
}
if (!_valuta.in_lire()) TForm_item& scaduto = body.find_field(PEC_SCADUTO);
{ scaduto.set(_scaduto.string());
TForm_item& cambio = body.find_field(212);
TForm_item& cambio = body.find_field(PEC_CAMBIO);
cambio.set(_valuta.cambio().string()); cambio.set(_valuta.cambio().string());
if (_valuta.data().ok()) TForm_item& datacambio = body.find_field(PEC_DATACAM);
{
TForm_item& datacambio = body.find_field(213);
datacambio.set(_valuta.data().string()); datacambio.set(_valuta.data().string());
}
}
body.update(); body.update();
TPrinter& pr = printer();
for (word j = 0; j < body.height(); j++)
pr.print(body.row(j));
} }
/////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////
@ -235,20 +228,48 @@ class TEC_array : public TArray
const TEC_form* _form; const TEC_form* _form;
protected: protected:
TEC_row& new_row(const TRiga_partite& row, const TDate& data, const TImporto& imp); TEC_row& new_row(const TRiga_partite& row, const TDate& data, const TImporto& imp, int rata = 0);
void add_row(const TRiga_partite& row); void add_row(const TRiga_partite& row);
public:
TEC_row& row(int r) { return (TEC_row&)operator[](r); }
const TEC_form& form() const { return *_form; } const TEC_form& form() const { return *_form; }
void calcola_scaduto(const TRiga_scadenze& rata, real& scaduto) const;
public:
TEC_row& row(int r) const { return (TEC_row&)operator[](r); }
TEC_array(const TPartita& game, const TEC_form* f); TEC_array(const TPartita& game, const TEC_form* f);
virtual ~TEC_array() {} virtual ~TEC_array() {}
}; };
TEC_row& TEC_array::new_row(const TRiga_partite& row, const TDate& data, const TImporto& imp) void TEC_array::calcola_scaduto(const TRiga_scadenze& rata, real& scaduto) const
{ {
const int n = items(); const TPartita& game = rata.partita();
TImporto imp_scaduto = rata.importo(TRUE);
const char* const field = rata.in_valuta() ? PAGSCA_IMPORTOVAL : PAGSCA_IMPORTO;
TImporto imp;
for (int p = rata.last(); p > 0; p = rata.pred(p))
{
const TRectype& pag = rata.row(p);
const TRiga_partite& sum = game.riga(pag.get_int(PAGSCA_NRIGP));
const tipo_movimento tm = sum.tipo();
if (tm != tm_insoluto && tm != tm_pagamento_insoluto)
{
imp.set(sum.sezione(), pag.get_real(field));
imp_scaduto += imp;
}
}
const char sezione = game.conto().tipo() == 'C' ? 'D' : 'A';
imp_scaduto.normalize(sezione);
scaduto = imp_scaduto.valore();
}
TEC_row& TEC_array::new_row(const TRiga_partite& row, const TDate& data,
const TImporto& imp, int n)
{
if (n == 0)
n = items();
TEC_row* riga = new TEC_row(row, data, imp, n); TEC_row* riga = new TEC_row(row, data, imp, n);
add(riga, n); add(riga, n);
return *riga; return *riga;
@ -261,18 +282,28 @@ void TEC_array::add_row(const TRiga_partite& row)
for (int r = 1; r <= row.rate(); r++) for (int r = 1; r <= row.rate(); r++)
{ {
const TRiga_scadenze& rata = row.rata(r); const TRiga_scadenze& rata = row.rata(r);
const TImporto imp(row.sezione(), rata.get_real(PART_IMPORTO));
const TDate data(rata.get(SCAD_DATASCAD)); const TDate data(rata.get(SCAD_DATASCAD));
new_row(row, data, imp); if (data <= form().data_limite_operazione())
{
TEC_row& rec = new_row(row, data, rata.importo(TRUE), r);
if (data <= form().data_limite_scaduto())
{
real s;
calcola_scaduto(rata, s);
rec.scaduto(s);
}
}
} }
} }
else else
{ {
const TImporto imp(row.sezione(), row.get_real(PART_IMPORTO));
const TDate data(row.get(PART_DATAPAG)); const TDate data(row.get(PART_DATAPAG));
if (data <= form().data_limite_operazione())
{
const TImporto imp(row.importo(FALSE, 0x1));
new_row(row, data, imp); new_row(row, data, imp);
const TImporto abbuoni(row.get_char(PART_SEZABB), row.get_real(PART_ABBUONI)); const TImporto abbuoni(row.importo(FALSE, 0x2));
if (!abbuoni.is_zero()) if (!abbuoni.is_zero())
{ {
TEC_row& r = new_row(row, data, abbuoni); TEC_row& r = new_row(row, data, abbuoni);
@ -280,7 +311,7 @@ void TEC_array::add_row(const TRiga_partite& row)
r.descrizione(desc_abb.prompt()); r.descrizione(desc_abb.prompt());
} }
const TImporto diffcam(row.get_char(PART_SEZDIFCAM), row.get_real(PART_DIFFCAM)); const TImporto diffcam(row.importo(FALSE, 0x4));
if (!diffcam.is_zero()) if (!diffcam.is_zero())
{ {
TEC_row& r = new_row(row, data, diffcam); TEC_row& r = new_row(row, data, diffcam);
@ -289,6 +320,7 @@ void TEC_array::add_row(const TRiga_partite& row)
} }
} }
} }
}
TEC_array::TEC_array(const TPartita& game, const TEC_form* f) TEC_array::TEC_array(const TPartita& game, const TEC_form* f)
: _form(f) : _form(f)
@ -306,7 +338,6 @@ TEC_array::TEC_array(const TPartita& game, const TEC_form* f)
void TEC_form::ec_header_handler(TPrinter& pr) void TEC_form::ec_header_handler(TPrinter& pr)
{ {
TPrint_section& head = _form->section('H'); TPrint_section& head = _form->section('H');
head.reset(); head.reset();
pr.resetheader(); pr.resetheader();
@ -315,12 +346,51 @@ void TEC_form::ec_header_handler(TPrinter& pr)
pr.setheaderline(j, head.row(j)); pr.setheaderline(j, head.row(j));
} }
static int val_compare(const void* o1, const void* o2)
void TEC_form::ec_footer_handler(TPrinter& p)
{ {
TRACE("Stamperei un footer"); const THash_object* h1 = (const THash_object*)o1;
const THash_object* h2 = (const THash_object*)o2;
const TString& s1 = (const TString&)h1->obj();
const TString& s2 = (const TString&)h2->obj();
return s2.compare(s1, -1, TRUE); // same as stricmp(s1, s2) in reverse order
} }
void TEC_form::ec_footer_handler(TPrinter& pr)
{
TPrint_section& foot = _form->section('F');
pr.resetfooter();
const word MAXTOT = 32;
THash_object* tot[MAXTOT];
// I totali sono in un assoc array disordinato per cui li copio in un array e li ordino
// alfabeticamente in base al loro codice valuta
TTotalizer& totali = _form->totali();
totali.restart();
word numtot = 0;
for (THash_object* obj = totali.get_hashobj();
numtot < MAXTOT && obj != NULL;
obj = totali.get_hashobj())
tot[numtot++] = obj;
qsort(tot, numtot, sizeof(THash_object*), val_compare);
if (numtot > foot.height())
numtot = foot.height();
TPrint_section& body = _form->section('B');
for (word j = 0; j < numtot; j++)
{
const TString& key = tot[j]->key();
TImporto& imp = (TImporto&)tot[j]->obj();
TEC_row r(key, imp.normalize());
r.print_on(body);
const TPrintrow& ri = body.row(0);
pr.setfooterline(j, ri);
}
}
bool TEC_form::print_game(const TPartita& game) bool TEC_form::print_game(const TPartita& game)
{ {
bool ok = FALSE; bool ok = FALSE;
@ -337,11 +407,13 @@ bool TEC_form::print_game(const TPartita& game)
// Stampa le righe di partita // Stampa le righe di partita
for (int r = 0; r < righe.items(); r++) for (int r = 0; r < righe.items(); r++)
{ {
TEC_row& riga = righe.row(r);
if (pr.rows_left() < body.height()) if (pr.rows_left() < body.height())
pr.formfeed(); pr.formfeed();
TEC_row& riga = righe.row(r);
riga.print_on(body); riga.print_on(body);
pr.print(body.row(0));
totali().add(riga.importo(), riga.valuta().codice()); totali().add(riga.importo(), riga.valuta().codice());
@ -364,12 +436,19 @@ bool TEC_form::print_game(const TPartita& game)
return ok; return ok;
} }
TEC_form::TEC_form(const char* codice, TCursor* cur) TEC_form::TEC_form(const TEC_mask& m)
: TForm(BASE_EC_PROFILE, codice), : TForm(BASE_EC_PROFILE, m.get_prof_code()),
_causali(LF_CAUSALI, CAU_CODCAUS, CAU_DESCR) _causali(LF_CAUSALI, CAU_CODCAUS, CAU_DESCR)
{ {
_form = this; _form = this;
_cursore = cur;
_lingua = m.get_prof_lang();
TCursor_sheet& cs = m.cur_sheet();
_cursore = cs.cursor();
_dlo = m.get(F_DATALIMOP);
_dls = m.get(F_DATALIMSC);
TPrinter& pr = printer(); TPrinter& pr = printer();
@ -430,8 +509,7 @@ class TStampaEC_application : public TApplication
TFile_array _file; TFile_array _file;
TString _lingua; TString _lingua_ditta;
TString _linprof;
bool _gesval; bool _gesval;
protected: // TApplication protected: // TApplication
@ -461,8 +539,7 @@ bool TStampaEC_application::select_ec()
TEC_mask& m = mask(); TEC_mask& m = mask();
while (m.run() != K_ESC) while (m.run() != K_ESC)
{ {
_linprof = m.get_prof_lang(); _form = new TEC_form(m);
_form = new TEC_form(m.get_prof_code(), sheet().cursor());
print_selected(); print_selected();
@ -500,7 +577,7 @@ bool TStampaEC_application::print_selected()
const bool ok = print_ec(); const bool ok = print_ec();
if (!ok) analfabeti++; if (!ok) analfabeti++;
} }
printer().formfeed();
printer().close(); printer().close();
if (analfabeti > 0) if (analfabeti > 0)
@ -520,8 +597,8 @@ bool TStampaEC_application::print_ec()
bool ok = TRUE; bool ok = TRUE;
// make controllations per lingua profilo/CF // make controllations per lingua profilo/CF
if ((_linprof == _lingua && !lincf.empty()) || _linprof != _lingua) if ((f.lingua() == _lingua_ditta && !lincf.empty()) || f.lingua() != _lingua_ditta)
ok = lincf == _linprof; ok = lincf == f.lingua();
if (!ok) // Cliente analfabeta if (!ok) // Cliente analfabeta
return FALSE; return FALSE;
@ -611,7 +688,7 @@ void TStampaEC_application::on_firm_change()
{ {
TApplication::on_firm_change(); TApplication::on_firm_change();
TConfig c(CONFIG_DITTA, "cg"); TConfig c(CONFIG_DITTA, "cg");
_lingua = c.get("CodLin"); _lingua_ditta = c.get("CodLin");
_gesval = c.get_bool("GesVal"); _gesval = c.get_bool("GesVal");
} }
@ -622,7 +699,7 @@ bool TStampaEC_application::menu(MENU_TAG m)
} }
TStampaEC_application::TStampaEC_application() TStampaEC_application::TStampaEC_application()
: _lingua(1), _linprof(1), _msk(NULL), _form(NULL) : _lingua_ditta(1), _msk(NULL), _form(NULL)
{} {}
int sc2100(int argc, char** argv) int sc2100(int argc, char** argv)

View File

@ -1,8 +1,5 @@
#include "scselect.h"
/////////////////////////////////////////////////////////////////////////////// #include "scselect.h"
// TSelection_mask //
///////////////////////////////////////////////////////////////////////////////
TSelection_mask::TSelection_mask(const char* name) TSelection_mask::TSelection_mask(const char* name)
: TMask(name), _who('C'), _key(1), _clifo_rel(NULL), : TMask(name), _who('C'), _key(1), _clifo_rel(NULL),
@ -11,9 +8,10 @@ TSelection_mask::TSelection_mask(const char* name)
// crea relazioni, cursori e cursor_sheets // crea relazioni, cursori e cursor_sheets
_clifo_rel = new TRelation(LF_CLIFO); _clifo_rel = new TRelation(LF_CLIFO);
_cli_cur_k1 = new TCursor(_clifo_rel, "TIPOCF=\"C\"", 1); TRectype filter(LF_CLIFO);
_cli_cur_k2 = new TCursor(_clifo_rel, "TIPOCF=\"C\"", 2); filter.put("TIPOCF", "C");
_cli_cur_k1 = new TCursor(_clifo_rel, "", 1, &filter, &filter);
_cli_cur_k2 = new TCursor(_clifo_rel, "", 2, &filter, &filter);
_cli_sh_k1 = new TCursor_sheet(_cli_cur_k1, " |CODCF|RAGSOC", "Selezione clienti per codice", _cli_sh_k1 = new TCursor_sheet(_cli_cur_k1, " |CODCF|RAGSOC", "Selezione clienti per codice",
"@1|Codice|Ragione Sociale@50"); "@1|Codice|Ragione Sociale@50");
@ -22,8 +20,9 @@ TSelection_mask::TSelection_mask(const char* name)
if (id2pos(SC_CLIFO) >= 0) if (id2pos(SC_CLIFO) >= 0)
{ {
_for_cur_k1 = new TCursor(_clifo_rel, "TIPOCF=\"F\"", 1); filter.put("TIPOCF", "F");
_for_cur_k2 = new TCursor(_clifo_rel, "TIPOCF=\"F\"", 2); _for_cur_k1 = new TCursor(_clifo_rel, "", 1, &filter, &filter);
_for_cur_k2 = new TCursor(_clifo_rel, "", 2, &filter, &filter);
_for_sh_k1 = new TCursor_sheet(_for_cur_k1, " |CODCF|RAGSOC", "Selezione fornitori per codice", _for_sh_k1 = new TCursor_sheet(_for_cur_k1, " |CODCF|RAGSOC", "Selezione fornitori per codice",
"@1|Codice|Ragione Sociale@50"); "@1|Codice|Ragione Sociale@50");
_for_sh_k2 = new TCursor_sheet(_for_cur_k2, " |RAGSOC|CODCF", "Selezione fornitori per ragione sociale", _for_sh_k2 = new TCursor_sheet(_for_cur_k2, " |RAGSOC|CODCF", "Selezione fornitori per ragione sociale",
@ -62,7 +61,7 @@ void TSelection_mask::set_handler(short fld_id, CONTROL_HANDLER handler)
fld(pos).set_handler(handler); fld(pos).set_handler(handler);
} }
TCursor_sheet& TSelection_mask::cur_sheet() TCursor_sheet& TSelection_mask::cur_sheet() const
{ {
TCursor_sheet* cs; TCursor_sheet* cs;
if (get_key() == 1) cs = get_who() == 'C' ? _cli_sh_k1 : _for_sh_k1; if (get_key() == 1) cs = get_who() == 'C' ? _cli_sh_k1 : _for_sh_k1;
@ -93,41 +92,45 @@ void TSelection_mask::select_clifo_range(long from, long to)
TCursor_sheet& c = cur_sheet(); TCursor_sheet& c = cur_sheet();
const long items = c.items(); const long items = c.items();
const int key = get_key(); const int key = get_key();
TString s_from(50), s_to(50);
long nsel = 0; if (from > to) // Controlla limiti
if (to == 0l)
to = c.row(items-1).get_long(key);
if (from == 0l)
from = c.row(0).get_long(key);
if (from > to)
{ {
long tmp = to; long tmp = to;
to = from; to = from;
from = tmp; from = tmp;
} }
bool go = FALSE; s_from = c.row(from).get(3-key); // Legge ragione sociale iniziale
s_to = c.row(to).get(3-key); // ... e finale
bool cod1ok = FALSE, cod2ok = FALSE; bool cod1ok = FALSE, cod2ok = FALSE;
long last = 0l; long last = 0;
long firs = 0l; long firs = 0;
for (long i = 0; i < items; i++) for (long i = 0; i < items; i++)
{ {
TToken_string& tt = c.row(i); TToken_string& tt = c.row(i);
long cod = tt.get_long(key); const long cod = tt.get_long(key);
if (cod >= from && cod <= to) bool add;
if (key == 2)
{
const char* s = tt.get(1);
add = s_from <= s && s_to >= s;
}
else
add = cod >= from && cod <= to;
if (add)
{ {
c.check(i); c.check(i);
nsel ++; if (firs == 0)
if (firs == 0l) firs = cod; firs = cod;
last = cod; last = cod;
} }
else else
{
c.uncheck(i); c.uncheck(i);
}
if (cod == from) cod1ok = TRUE; if (cod == from) cod1ok = TRUE;
if (cod == to) cod2ok = TRUE; if (cod == to) cod2ok = TRUE;
} }
@ -137,7 +140,7 @@ void TSelection_mask::select_clifo_range(long from, long to)
set(SC_CFCODFR, from); set(SC_CFCODFR, from);
set(SC_CFCODTO, to); set(SC_CFCODTO, to);
set(SC_NSEL, nsel); set(SC_NSEL, c.checked());
} }
// Cerca il primo e l'ultimo cliente selezionati // Cerca il primo e l'ultimo cliente selezionati

View File

@ -43,7 +43,7 @@ protected:
void set_who(char w) { _who = w; } void set_who(char w) { _who = w; }
void set_key (int k) { _key = k; } void set_key (int k) { _key = k; }
virtual void reset_sheets(); void reset_sheets();
// handlers // handlers
static bool bfrom_handler(TMask_field& f, KEY k); static bool bfrom_handler(TMask_field& f, KEY k);
@ -56,7 +56,7 @@ protected:
static bool rsortcf_handler(TMask_field& f, KEY k); static bool rsortcf_handler(TMask_field& f, KEY k);
public: public:
virtual TCursor_sheet& cur_sheet(); TCursor_sheet& cur_sheet() const;
char get_who() const { return _who; } char get_who() const { return _who; }
int get_key() const { return _key; } int get_key() const { return _key; }