#include #include #include "cg0.h" #include "cg0100.h" #define ATTIVITA 1 #define PASSIVITA 2 #define COSTI 3 #define RICAVI 4 #define ORDINE 5 class CG0100_application : public TRelation_application { TMask* _msk; TRelation *_rel; TLocalisamfile* _saldi; TLocalisamfile* _tabcom; bool user_create(); bool user_destroy(); virtual TMask* get_mask(int mode) {return _msk;} virtual bool changing_mask(int mode) {return FALSE;} virtual bool protected_record(TRectype &rec); virtual void init_query_mode(TMask& m); virtual void init_insert_mode(TMask& m); virtual void init_modify_mode(TMask& m) {init_insert_mode(m);} virtual int write(const TMask& m); virtual int rewrite(const TMask & m); virtual int read(TMask& m); public: virtual TRelation* get_relation() const {return _rel;} CG0100_application() {} }; HIDDEN inline CG0100_application & app() { return (CG0100_application &) main_app();} int CG0100_application::read(TMask& m) { const TRelation *r = get_relation(); m.autoload(r); if (m.get(FLD_CM1_LETTIVD).empty()) { int sezivd = m.get_int(FLD_CM1_SEZIVD); if (sezivd == 1 || sezivd == 2) m.set(FLD_CM1_SEZIVD, sezivd + 5); } if (m.get(FLD_CM1_LETTIVDOPP).empty()) { int sezivd = m.get_int(FLD_CM1_SEZIVDOPP); if (sezivd == 1 || sezivd == 2) m.set(FLD_CM1_SEZIVDOPP, sezivd + 5); } return NOERR; } int CG0100_application::rewrite(const TMask& m) { TRelation *r = get_relation(); m.autosave(r); int sezivd = m.get_int(FLD_CM1_SEZIVD); TString16 sez; if (sezivd == 6 || sezivd == 7) { sez.format("%d", sezivd - 5); r->lfile().put(PCN_SEZIVD, sez); } sezivd = m.get_int(FLD_CM1_SEZIVDOPP); if (sezivd == 6 || sezivd == 7) { sez.format("%d", sezivd - 5); r->lfile().put(PCN_SEZIVDOPP, sez); } return r->rewrite(); } int CG0100_application::write(const TMask& m) { TRelation *r = get_relation(); TString16 sez; m.autosave(r); int sezivd = m.get_int(FLD_CM1_SEZIVD); if (sezivd == 6 || sezivd == 7) { sez.format("%d", sezivd - 5); r->lfile().put(PCN_SEZIVD, sez); } sezivd = m.get_int(FLD_CM1_SEZIVDOPP); if (sezivd == 6 || sezivd == 7) { sez.format("%d", sezivd - 5); r->lfile().put(PCN_SEZIVDOPP, sez); } return r->write(); } // Controlla se puo' essere effettuata la cancellazione di un conto bool CG0100_application::protected_record(TRectype &rec) { TMask* m = get_mask(MODE_MOD); TLocalisamfile& pconti = _rel->lfile(); const int gruppo = atoi(m->get(FLD_CM1_GRUPPO)); const int conto = atoi(m->get(FLD_CM1_CONTO)); const long sottoc = atol(m->get(FLD_CM1_SOTTOCONTO)); // Se e' un sottoconto posso cancellarlo se non esistono saldi if ((gruppo != 0) && (conto != 0) && (sottoc != 0)) { _saldi->zero(); _saldi->put(PCN_GRUPPO, gruppo); _saldi->put(PCN_CONTO, conto); _saldi->put(PCN_SOTTOCONTO, sottoc); _saldi->read(_isgteq); return _saldi->good() && gruppo ==_saldi->get_int(PCN_GRUPPO) && conto ==_saldi->get_int(PCN_CONTO) && sottoc ==_saldi->get_long(PCN_SOTTOCONTO); } get_relation()->save_status(); pconti.zero() ; pconti.put(PCN_GRUPPO, gruppo); // Se e' un conto controllo se ha dei sottoconti if (conto != 0) pconti.put(PCN_CONTO, conto); TRectype rec1(pconti.curr()); pconti.setkey(1) ; pconti.read(); pconti.next(); const bool prot = (pconti.good() && (pconti.curr() == rec1)); get_relation()->restore_status(); return prot; } void CG0100_application::init_query_mode(TMask& m) { m.show(-1); m.show(-2); m.show(-3); } HIDDEN bool tmcf_handler(TMask_field& f, KEY key) { if (f.active() && key == K_SPACE) { TMask& m = f.mask(); const int conto = atoi(m.get(FLD_CM1_CONTO)); const long sottoc = atol(m.get(FLD_CM1_SOTTOCONTO)); const bool enable_sezsaldi = (sottoc != 0) || (sottoc == 0 && conto != 0 && m.get(FLD_CM1_TMCF).not_empty()); m.show(FLD_CM2_SEZSALDI, enable_sezsaldi); } return TRUE; } void CG0100_application::init_insert_mode(TMask& m) { const int gruppo = atoi(m.get(FLD_CM1_GRUPPO)); const int conto = atoi(m.get(FLD_CM1_CONTO)); const long sottoc = atol(m.get(FLD_CM1_SOTTOCONTO)); bool ivd_enable = TRUE; if (conto == 0 && sottoc == 0) m.show(-1, FALSE); else if (sottoc == 0) m.show(-2, FALSE); else m.show(-3, FALSE); TLocalisamfile& pconti = _rel->lfile(); TString s(15), s2(1), s3(8), s4(2); int s1 = 0; pconti.setkey(1) ; int indbil = 0; if (sottoc != 0) { pconti.zero(); pconti.put(PCN_GRUPPO, gruppo); pconti.put(PCN_CONTO, conto); pconti.read(); if (pconti.good()) { s = pconti.get(PCN_CODCBL); s1 = atoi(pconti.get(PCN_SEZIVD)); s2 = pconti.get(PCN_LETTIVD); s3 = pconti.get(PCN_NUMRIVD); s4 = pconti.get(PCN_NUMIVD); indbil = pconti.get_int(PCN_INDBIL); } ivd_enable = (s1 == 0) && s2.empty() && s3.empty() && s4.empty(); } m.show(FLD_CM1_RICSER, indbil == PASSIVITA || indbil == RICAVI); if (conto != 0) { m.enable(FLD_CM1_SEZIVD, ivd_enable); m.show(FLD_CM1_LETTIVD, ivd_enable); m.show(FLD_CM1_NUMRIVD, ivd_enable); m.show(FLD_CM1_NUMIVD, ivd_enable); m.show(FLD_CM1_LETTIVDH, !ivd_enable); m.show(FLD_CM1_NUMRIVDH, !ivd_enable); m.show(FLD_CM1_NUMIVDH, !ivd_enable); if (!ivd_enable) { m.set(FLD_CM1_SEZIVD, s1); m.set(FLD_CM1_LETTIVDH, s2); m.set(FLD_CM1_NUMRIVDH, s3); m.set(FLD_CM1_NUMIVDH, s4); m.enable(FLD_CM1_SEZIVDOPP); } pconti.zero(); pconti.put(PCN_GRUPPO, gruppo); pconti.read(); if (pconti.good()) if (s.empty()) s = pconti.get(PCN_CODCBL); } if (s.not_empty()) { m.set(FLD_CM1_CODANALISIH, s); m.show(FLD_CM1_CODANALISIH); m.hide(FLD_CM1_CODTABANALISI); } else { m.show(FLD_CM1_CODTABANALISI); m.hide(FLD_CM1_CODANALISIH); } const bool enable_sezsaldi = (sottoc != 0) || (sottoc == 0 && conto != 0 && m.get(FLD_CM1_TMCF).not_empty()); m.show(FLD_CM2_SEZSALDI, enable_sezsaldi); } HIDDEN bool gruppo_handler(TMask_field& f, KEY key) { if (key == K_ENTER) { const TMask& m = f.mask(); const int gruppo = atoi(m.get(FLD_CM1_GRUPPO)); const int conto = atoi(m.get(FLD_CM1_CONTO)); TLocalisamfile& pconti = app().get_relation()->lfile(); if (gruppo != 0 && conto != 0) { pconti.zero() ; pconti.put(PCN_GRUPPO, gruppo) ; pconti.setkey(1) ; pconti.read(); if (pconti.bad()) return f.warning_box ("Il gruppo non esiste"); } } return TRUE; } HIDDEN bool conto_handler(TMask_field& f, KEY key) { if (key == K_ENTER) { const TMask& m = f.mask(); const int gruppo = m.get_int(FLD_CM1_GRUPPO); const int conto = m.get_int(FLD_CM1_CONTO); const long sottoc = m.get_int(FLD_CM1_SOTTOCONTO); TLocalisamfile& pconti = app().get_relation()->lfile(); if (gruppo != 0 && conto != 0 && sottoc != 0) { pconti.zero() ; pconti.put(PCN_GRUPPO, gruppo) ; pconti.put(PCN_CONTO, conto) ; pconti.setkey(1) ; pconti.read(); if (pconti.bad()) return m.field(FLD_CM1_CONTO).warning_box ("Il conto non esiste"); else { if (pconti.get(PCN_TMCF).not_empty()) return m.field(FLD_CM1_SOTTOCONTO).warning_box ("Non e' possibile inserire un sottoconto di un conto relativo ad un cliente/fornitore"); } } } return TRUE; } HIDDEN bool sottoc_handler(TMask_field& f, KEY key) { if (key == K_TAB) { TMask& m = f.mask(); const int gruppo = m.get_int(FLD_CM1_GRUPPO); if (gruppo == 0) return TRUE; const int conto = m.get_int(FLD_CM1_CONTO); const long sottoconto = m.get_long(FLD_CM1_SOTTOCONTO); if (sottoconto != 0 && conto == 0) return m.field(FLD_CM1_CONTO).error_box("Manca il conto"); return m.stop_run(K_AUTO_ENTER); } return TRUE; } bool CG0100_application::user_create() { _msk = new TMask("cg0100a") ; _msk->set_handler(FLD_CM1_GRUPPO, gruppo_handler); _msk->set_handler(FLD_CM1_CONTO, conto_handler); _msk->set_handler(FLD_CM1_SOTTOCONTO, sottoc_handler); _msk->set_handler(FLD_CM1_TMCF, tmcf_handler); _rel = new TRelation(LF_PCON); _saldi = new TLocalisamfile(LF_SALDI); _saldi->setkey(2); set_search_field(FLD_CM1_GRUPPO); return TRUE; } bool CG0100_application::user_destroy() { delete _msk; delete _rel; delete _saldi; return TRUE; } int cg0100(int argc, char* argv[]) { CG0100_application a ; a.run(argc, argv, "Piano dei conti"); return 0; }