Stampa soggetti non domiciliati nel comune di sezione: possibilita' di

stampare per sezione o per comune
Patch level         :
Files correlati     :
Ricompilazione Demo : [ ]
Commento            :


git-svn-id: svn://10.65.10.50/trunk@6278 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
cris 1998-02-27 07:58:19 +00:00
parent 2f9789350f
commit a7e0440140
3 changed files with 63 additions and 12 deletions

View File

@ -22,7 +22,8 @@ class TStampaNonDom : public TPrintapp
TAssoc_array _catnondon; TAssoc_array _catnondon;
TParagraph_string _cognome_nome, _dencom; TParagraph_string _cognome_nome, _dencom;
TDate _data_stampa; TDate _data_stampa;
TString16 _codsez, _codsot; TString16 _codsez, _codsot, _codcom;
TString16 _tipostampa;
protected: protected:
virtual bool user_create(); virtual bool user_create();
@ -35,6 +36,7 @@ public:
void crea_intestazione(); void crea_intestazione();
void filtra_sezioni(); void filtra_sezioni();
void header_sezione(const TString16 codsez, const TString16 codsot); void header_sezione(const TString16 codsez, const TString16 codsot);
void header_comune(const TString16 codcom);
TMask& app_mask() { return *_msk; } TMask& app_mask() { return *_msk; }
TStampaNonDom() : _data_stampa(TODAY), _cognome_nome("",25), _dencom("",50) {} TStampaNonDom() : _data_stampa(TODAY), _cognome_nome("",25), _dencom("",50) {}
@ -64,6 +66,8 @@ void TStampaNonDom::filtra_sezioni()
void TStampaNonDom::set_page(int file, int cnt) void TStampaNonDom::set_page(int file, int cnt)
{ {
set_row(1,"@0g@pn", FLD(LF_SOGGETTI,SOG_CODICE,"########")); set_row(1,"@0g@pn", FLD(LF_SOGGETTI,SOG_CODICE,"########"));
set_row(2,"@0g@S", FLD(LF_SOGGETTI,SOG_CODSEZ));
set_row(2,"@3g@S", FLD(LF_SOGGETTI,SOG_CODSOT));
set_row(1,"@9g@S", FLD(LF_SOGGETTI,SOG_CATDON)); set_row(1,"@9g@S", FLD(LF_SOGGETTI,SOG_CATDON));
set_row(1,"@12g#a", &_cognome_nome); set_row(1,"@12g#a", &_cognome_nome);
set_row(1,"@38g@ld", FLD(LF_SOGGETTI,SOG_DATANASC)); set_row(1,"@38g@ld", FLD(LF_SOGGETTI,SOG_DATANASC));
@ -130,6 +134,20 @@ void TStampaNonDom::header_sezione(const TString16 codsez, const TString16 codso
return; return;
} }
void TStampaNonDom::header_comune(const TString16 codcom)
{
const TString80 dencom = current_cursor()->curr(LF_COMUNI).get(COM_DENCOM);
TString intestazione(132);
intestazione = "Comune: ";
intestazione << codcom;
intestazione << " ";
intestazione << dencom;
intestazione.center_just();
set_header(1,"@0g%s", (const char*) intestazione);
return;
}
bool TStampaNonDom::preprocess_page(int file, int counter) bool TStampaNonDom::preprocess_page(int file, int counter)
{ {
TRectype& recsog = current_cursor()->curr(); TRectype& recsog = current_cursor()->curr();
@ -153,17 +171,32 @@ bool TStampaNonDom::preprocess_page(int file, int counter)
localita << current_cursor()->curr(LF_COMUNI).get(COM_DENCOM); localita << current_cursor()->curr(LF_COMUNI).get(COM_DENCOM);
localita.trim(); localita.trim();
_dencom = localita; _dencom = localita;
// salto pagina se cambio sezione // salto pagina se cambio sezione o comune
const TString16 codsez = recsog.get(SOG_CODSEZ); if (_tipostampa == "01")
const TString16 codsot = recsog.get(SOG_CODSOT);
if ((_codsez!=codsez)||(_codsot!=codsot))
{ {
if (_codsez != "**") const TString16 codsez = recsog.get(SOG_CODSEZ);
printer().formfeed(); const TString16 codsot = recsog.get(SOG_CODSOT);
_codsez = codsez; if ((_codsez!=codsez)||(_codsot!=codsot))
_codsot = codsot; {
header_sezione(codsez, codsot); if (_codsez != "**")
printer().formfeed();
_codsez = codsez;
_codsot = codsot;
header_sezione(codsez, codsot);
}
} }
else
{
const TString16 codcom = recsog.get(SOG_DOM_CODCOM);
if (_codcom!=codcom)
{
if (_codcom != "**")
printer().formfeed();
_codcom = codcom;
header_comune(codcom);
}
}
if (printer().rows_left()<3) if (printer().rows_left()<3)
printer().formfeed(); printer().formfeed();
return TRUE; return TRUE;
@ -177,6 +210,13 @@ bool TStampaNonDom::set_print(int m)
{ {
_codsez = "**"; _codsez = "**";
_codsot = "**"; _codsot = "**";
_codcom = "****";
_tipostampa = _msk->get(F_TIPOSTAMPA);
TString80 chiave = "";
if (_tipostampa == "01")
chiave = "90->CODSEZ|90->CODSOT|90->COGNOME|90->NOME";
else
chiave = "90->DOM_CODCOM|90->COGNOME|90->NOME";
reset_files(); reset_files();
add_file(LF_SOGGETTI); add_file(LF_SOGGETTI);
filtra_sezioni(); filtra_sezioni();
@ -219,6 +259,7 @@ bool TStampaNonDom::set_print(int m)
if (catnses.not_empty() && catnses.ok()) if (catnses.not_empty() && catnses.ok())
_catnondon.add((const char*) catnses); _catnondon.add((const char*) catnses);
current_cursor()->set_filterfunction (filter_func_nondom,TRUE); current_cursor()->set_filterfunction (filter_func_nondom,TRUE);
((TSorted_cursor*)current_cursor())->change_order(chiave);
reset_print(); reset_print();
crea_intestazione(); crea_intestazione();
return TRUE; return TRUE;
@ -253,7 +294,7 @@ bool TStampaNonDom::user_create()
_rel->add("LCP", "CODTAB==DOM_CODLOC",1,0,ALIAS_LCP); _rel->add("LCP", "CODTAB==DOM_CODLOC",1,0,ALIAS_LCP);
_rel->add(LF_COMUNI, "COM==DOM_CODCOM"); _rel->add(LF_COMUNI, "COM==DOM_CODCOM");
_rel->add(LF_SEZIONI, "CODSEZ==CODSEZ|CODSOT==CODSOT"); _rel->add(LF_SEZIONI, "CODSEZ==CODSEZ|CODSOT==CODSOT");
add_cursor(new TCursor(_rel, "", 3)); add_cursor(new TSorted_cursor(_rel,"","",3));
_msk = new TMask("at6600a"); _msk = new TMask("at6600a");
return TRUE; return TRUE;
} }

View File

@ -35,3 +35,5 @@
#define F_D_CATN5 310 #define F_D_CATN5 310
#define F_CATN6 311 #define F_CATN6 311
#define F_D_CATN6 312 #define F_D_CATN6 312
#define F_TIPOSTAMPA 401

View File

@ -14,7 +14,7 @@ END
END END
PAGE "Soggetti non domiciliati nel comune di sezione" -1 -1 78 20 PAGE "Soggetti non domiciliati nel comune di sez." -1 -1 78 20
GROUPBOX DLG_NULL 77 4 GROUPBOX DLG_NULL 77 4
BEGIN BEGIN
@ -383,5 +383,13 @@ BEGIN
FLAGS "D" FLAGS "D"
END END
RADIOBUTTON F_TIPOSTAMPA 50
BEGIN
PROMPT 2 14 "Stampa suddivisa per "
ITEM "01|Sezione/Sottogruppo"
ITEM "02|Comune di domicilio"
FLAG "Z"
END
ENDPAGE ENDPAGE
ENDMASK ENDMASK