#include #include "..\ve\veconf.h" #include "mglib.h" #include "mg3100.h" #include "mg3frm.h" class TForm_giacprezzi : public TForm_stampemg { TConfig *conf_ditta; TCondizione_vendita * listino; public: void set_codlistino(const char * codcm,const char * cod); bool validate(TForm_item &cf, TToken_string &s); TForm_giacprezzi(const char *name,const char *code) ; ~TForm_giacprezzi(); }; bool TForm_giacprezzi::validate(TForm_item &cf, TToken_string &s) { const TString code(s.get(0)); // prende il primo parametro, il codice del messaggio TString subcode; if (code=="_USER") { subcode=s.get(); if (subcode=="PREZZO") { TString codart(relation()->lfile(LF_ANAMAG).get("CODART")); if (listino->ricerca(codart,0.0)) cf.set(listino->get_prezzo().string()); return TRUE; } } return TForm_stampemg::validate(cf, s); } void TForm_giacprezzi::set_codlistino(const char * codcatv,const char * codlist) { listino->put_listino(codlist,codcatv); } TForm_giacprezzi::TForm_giacprezzi(const char *name,const char *code) : TForm_stampemg(name,code) { listino=new TCondizione_vendita(new TConfig(CONFIG_DITTA,"")); listino->set_anamag(relation()->lfile(LF_ANAMAG)); listino->set_umart(relation()->lfile(LF_UMART)); } TForm_giacprezzi::~TForm_giacprezzi() { delete &(listino->config_ditta()); delete listino; } class TStampadatist_mask: public TStampemg_mask { static bool handle_ragg(TMask_field &fld, KEY k); // handler static bool handle_liv(TMask_field &fld, KEY k); // handler static bool handle_subord(TMask_field &fld, KEY k); // handler public: TStampadatist_mask(); virtual ~TStampadatist_mask(){}; }; TStampadatist_mask::TStampadatist_mask(): TStampemg_mask("mg3100") { TConfig prassid(CONFIG_DITTA, "ve"); // apre il file di configurazione della ditta corrente if (prassid.get_bool("GES", NULL, A_LISTINI)) field(F_CATVENLISTINO).enable(prassid.get_bool("GESLISCV")); else { field(F_CATVENLISTINO).disable(); field(F_CODLISTINO).disable(); } set_handler(F_TOLIVELLOART, handle_liv); set_handler(F_TOLIVELLOGIAC, handle_liv); set_handler(F_ORDINE, handle_ragg); set_handler(F_DETTAGLIODEP, handle_ragg); set_handler(F_DETTAGLIOMAG, handle_ragg); set_handler(F_ORDINEART,handle_subord); if (!artlev().enabled()) { TMask_field &f1=field(F_RAGGCODICE); f1.reset(); f1.check();f1.hide(); field(F_FROMLIVELLOART).hide(); field(F_TOLIVELLOART).hide(); } if (!giaclev().enabled()) { TMask_field &f2=field(F_RAGGLIVGIAC); f2.reset(); f2.check();f2.hide(); field(F_FROMLIVELLOGIAC).hide(); field(F_TOLIVELLOGIAC).hide(); } } bool TStampadatist_mask::handle_subord(TMask_field &fld, KEY k) { if (k == K_SPACE) { TStampadatist_mask &m=(TStampadatist_mask &)fld.mask(); TOperable_field &fraggcod=(TOperable_field &)m.field(F_RAGGCODICE); TOperable_field &fragggiac=(TOperable_field &)m.field(F_RAGGLIVGIAC); switch (fld.get()[0]) { case 'C': if (m.get(F_ORDINE)=="A") { fraggcod.enable();m.send_key(K_SPACE,F_RAGGCODICE); } else { if (!m.get_bool(F_TOTALIDEPOSITI) || !m.get_bool(F_DETTAGLIODEP)) { fraggcod.reset(); fraggcod.disable(); fragggiac.reset(); fragggiac.disable(); fraggcod.do_message(0);fragggiac.do_message(0); } } break; case 'M': case 'D': fraggcod.set("X"); fraggcod.disable(); m.field(F_FROMLIVELLOART).set(m.artlev().last_level()); m.disable(F_FROMLIVELLOART); m.field(F_TOLIVELLOART).set("0"); m.disable(F_TOLIVELLOART); m.field(F_FROMLIVELLOGIAC).set("0"); m.disable(F_FROMLIVELLOGIAC); m.field(F_TOLIVELLOGIAC).set("0"); m.disable(F_TOLIVELLOGIAC); break; } } return TRUE; } bool TStampadatist_mask::handle_liv(TMask_field &fld, KEY k) { if (k == K_TAB) { TOperable_field &ftotmag=(TOperable_field &)fld.mask().field(F_TOTALIMAGAZZINI); TOperable_field &fdettmag=(TOperable_field &)fld.mask().field(F_DETTAGLIOMAG); if (fld.mask().get(F_ORDINE)=="A") { if (fld.mask().get_int(F_TOLIVELLOART) || fld.mask().get_int(F_TOLIVELLOGIAC)) { // raggruppamenti prima del dettaglio magazzini ftotmag.reset(); ftotmag.disable();ftotmag.do_message(0); } else { ftotmag.enable(); } } } return TRUE; } bool TStampadatist_mask::handle_ragg(TMask_field &fld, KEY k) { if (k == K_SPACE) { TStampadatist_mask &m=(TStampadatist_mask &)fld.mask(); TOperable_field &ftotmag=(TOperable_field &)fld.mask().field(F_TOTALIMAGAZZINI); TOperable_field &fraggcod=(TOperable_field &)fld.mask().field(F_RAGGCODICE); TOperable_field &fragggiac=(TOperable_field &)fld.mask().field(F_RAGGLIVGIAC); fraggcod.enable(); fragggiac.enable(); if (fld.mask().get(F_ORDINE)=="M") { ftotmag.enable(); if (!fld.mask().get_bool(F_TOTALIDEPOSITI) || !fld.mask().get_bool(F_DETTAGLIODEP)) { fraggcod.reset(); fraggcod.disable(); fragggiac.reset(); fragggiac.disable(); fraggcod.do_message(0);fragggiac.do_message(0); return TRUE; } } else { bool enabmag=m.magazz_ini().gestmultimag() || m.magazz_ini().gestdep(); m.enable(F_TOTALIMAGAZZINI,enabmag && m.field(F_TOTALIMAGAZZINI).enabled()); m.enable(F_DETTAGLIOMAG,enabmag && m.field(F_DETTAGLIOMAG).enabled()); } } return TRUE; } // STAMPA anagrafiche class TStampa_datistorici : public TSkeleton_application { TArray _file; TStampadatist_mask * _mask; TCursor * _cur; TForm_giacprezzi * _form; // to be moved into TPrint_application protected: protected: void open_files(int logicnum, ...); virtual bool create(); virtual bool destroy(); virtual void main_loop(); void setprint_permagazzini(); void setprint_perarticoli(); public: TStampa_datistorici() {} }; bool TStampa_datistorici::create() { _mask = new TStampadatist_mask(); open_files(LF_ANAMAG,LF_MAG,LF_TAB,LF_TABCOM,0); return TSkeleton_application::create(); } bool TStampa_datistorici::destroy() { delete _mask; return TSkeleton_application::destroy(); } void TStampa_datistorici::setprint_permagazzini() { char subordine=*_mask->get(F_ORDINEART); TRectype darec(LF_MAG),arec(LF_MAG); TString cfilter,sortexp,joinexp; _form = new TForm_giacprezzi("mg3100b", ""); _cur = _form->cursor(); // setta il filtro sul cursore if (*_mask->get(F_DAART)) cfilter << "(CODART[1," << _mask->get(F_DAART).len() << "]>=" <<'"' << _mask->get(F_DAART)<< "\")&&" ; if (*_mask->get(F_AART)) cfilter << "(CODART[1," << _mask->get(F_AART).len() << "]<=" <<'"' << _mask->get(F_AART)<< "\")&&" ; switch (*_mask->get(F_FILTRO)) { case '0': // non nulli cfilter << "(STR(" << LF_MAG << "->GIAC!=\"0\"))&&"; break; case 'P': // positivi cfilter << "(STR(" << LF_MAG << "->GIAC>\"0\"))&&"; break; case 'N': // negativi cfilter << "(STR(" << LF_MAG << "->GIAC<\"0\"))&&"; break; case 'S': // sottoscorta cfilter << "(STR(GIACsetdett_permag(_mask->get_int(F_FROMLIVELLOART), _mask->get_int(F_TOLIVELLOART), _mask->get_int(F_FROMLIVELLOGIAC), _mask->get_int(F_TOLIVELLOGIAC), TRUE, _mask->get_bool(F_TOTALIDEPOSITI), _mask->get_bool(F_DETTAGLIODEP)); TString16 ena=((_mask->get_bool(F_STAMPAGIAC) && *_mask->get(F_FILTRO)!='S')? "1": "0"); _form->find_field('H',odd_page,FF_FLAGGIAC).set(ena ); _form->find_field('B',odd_page,FF_FLAGGIAC).set(ena); ena=((_mask->get_bool(F_STAMPAGIAC) && *_mask->get(F_FILTRO)=='S')? "1": "0") ; _form->find_field('H',odd_page,FF_FLAGSOTTOS).set(ena); _form->find_field('B',odd_page,FF_FLAGSOTTOS).set(ena); ena=_mask->get(F_PREZZIVALORI); _form->find_field('H',odd_page,FF_PREZZIVALORI).set(ena); _form->find_field('B',odd_page,FF_PREZZIVALORI).set(ena); ena=_mask->get_bool(F_VALMEDI) ? "1": "0"; _form->find_field('H',odd_page,FF_FLAGVALMEDI).set(ena); _form->find_field('B',odd_page,FF_FLAGVALMEDI).set(ena); _form->set_codlistino(_mask->get(F_CATVENLISTINO),_mask->get(F_CODLISTINO)); darec.put("ANNOES",_mask->get(F_ANNOES)); darec.put("CODMAG",_mask->get(F_DAMAG)); arec.put("ANNOES",_mask->get(F_ANNOES)); arec.put("CODMAG",_mask->get(F_AMAG)); _cur->setfilter(cfilter); _cur->setregion(darec,arec); } // ORDINAMENTO void TStampa_datistorici::setprint_perarticoli() { TRectype darec(LF_ANAMAG),arec(LF_ANAMAG); TString cfilter,filter,joinexp; TString sortexp("ANNOES|CODART|LIVELLO|CODMAG"); char subordine=*_mask->get(F_ORDINEART); _form = new TForm_giacprezzi("mg3100a", ""); _cur = _form->cursor(); if (*_mask->get(F_DAMAG)) filter << "(CODMAG[1,3]>=" <<'"' << _mask->get(F_DAMAG)<< "\")&&" ; if (*_mask->get(F_AMAG)) filter << "(CODMAG[1,3]<=" <<'"' << _mask->get(F_AMAG)<< "\")&&" ; switch (*_mask->get(F_FILTRO)) { case '0': // non nulli filter << "(STR(" << LF_MAG << "->GIAC!=\"0\"))&&"; break; case 'P': // positivi filter << "(STR(" << LF_MAG << "->GIAC>\"0\"))&&"; break; case 'N': // negativi filter << "(STR(" << LF_MAG << "->GIAC<\"0\"))&&"; break; case 'S': // sottoscorta filter << "(STR(GIACsetkey(1); darec.put("CODART",_mask->get(F_DAART)); arec.put("CODART",_mask->get(F_AART)); _form->find_field('B',odd_page,"H_CATMER").hide(); _form->find_field('B',odd_page,"TOT_CATMER").hide(); _form->setcatmer(FALSE); break; case 'D': _cur->setkey(2); darec.put("DESCR",_mask->get(F_DADES)); arec.put("DESCR",_mask->get(F_ADES)); _form->find_field('B',odd_page,"H_CATMER").disable(); _form->find_field('B',odd_page,"TOT_CATMER").hide(); _form->setcatmer(FALSE); break; case 'M': _cur->setkey(3); darec.put("GRMERC",_mask->get(F_DACATMER)); darec.put("CODART",_mask->get(F_DAART)); arec.put("GRMERC",_mask->get(F_ACATMER)); arec.put("CODART",_mask->get(F_AART)); _form->find_field('B',odd_page,"H_CATMER").show(); _form->find_field('B',odd_page,"TOT_CATMER").show(); _form->setcatmer(TRUE); break; } _form->setdett_perart( _mask->get_int(F_FROMLIVELLOART), _mask->get_int(F_TOLIVELLOART), _mask->get_int(F_FROMLIVELLOGIAC), _mask->get_int(F_TOLIVELLOGIAC), _mask->get_bool(F_TOTALIMAGAZZINI), _mask->get_bool(F_TOTALIDEPOSITI)); _form->find_field('H',odd_page,FF_FLAGGIAC).set((_mask->get_bool(F_STAMPAGIAC) && *_mask->get(F_FILTRO)!='S') ? "1": "0"); _form->find_field('H',odd_page,FF_FLAGSOTTOS).set((_mask->get_bool(F_STAMPAGIAC) && *_mask->get(F_FILTRO)=='S') ? "1": "0"); _form->find_field('B',odd_page,FF_FLAGVALMEDI).set(_mask->get_bool(F_VALMEDI) ? "1": "0"); TString16 ena=((_mask->get_bool(F_STAMPAGIAC) && *_mask->get(F_FILTRO)!='S')? "1": "0"); _form->find_field('H',odd_page,FF_FLAGGIAC).set(ena ); _form->find_field('B',odd_page,FF_FLAGGIAC).set(ena); ena=((_mask->get_bool(F_STAMPAGIAC) && *_mask->get(F_FILTRO)=='S')? "1": "0") ; _form->find_field('H',odd_page,FF_FLAGSOTTOS).set(ena); _form->find_field('B',odd_page,FF_FLAGSOTTOS).set(ena); _form->find_field('H',odd_page,FF_PREZZIVALORI).set(_mask->get(F_PREZZIVALORI)); _form->find_field('B',odd_page,FF_PREZZIVALORI).set(_mask->get(F_PREZZIVALORI)); ena=_mask->get_bool(F_VALMEDI) ? "1": "0"; _form->find_field('H',odd_page,FF_FLAGVALMEDI).set(ena); _form->find_field('B',odd_page,FF_FLAGVALMEDI).set(ena); _form->find_field('B',odd_page,FF_FLAGTOTQTA).set("1"); _form->set_codlistino(_mask->get(F_CATVENLISTINO),_mask->get(F_CODLISTINO)); joinexp << "ANNOES==" << _mask->get(F_ANNOES) << "|CODART==CODART"; TSortedfile *mag; mag= new TSortedfile(LF_MAG,NULL,sortexp,filter,1); _cur->relation()->replace(mag,1,joinexp); _cur->setfilter(cfilter); _cur->setregion(darec,arec); } void TStampa_datistorici::main_loop() { while (_mask->run() == K_ENTER) { if (_mask->magazz_ini().gestmag(TRUE)) { if (*_mask->get(F_ORDINE)=='A') { setprint_perarticoli(); } else { setprint_permagazzini(); } _form->print(); delete _form; } } // while true return ; } int mg3100(int argc, char* argv[]) { TStampa_datistorici a;// derivata da Application e con uso di form a.run(argc,argv,"Stampa dati storici di giacenza"); return 0; }