Files correlati : lv0.exe, lvtbcau.msk Ricompilazione Demo : [ ] Commento : Aggiunta la gestione delle causali di magazzino (solo campi di lavanderia) nelle causali di lavanderia git-svn-id: svn://10.65.10.50/trunk@18208 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			155 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
| // gestione tabelle lavanderie
 | |
| 
 | |
| #include <automask.h>
 | |
| #include <modtbapp.h>
 | |
| #include <tabutil.h>
 | |
| 
 | |
| #include "lvtbcau.h"
 | |
| 
 | |
| ///////////////////////////////////////////////////////////
 | |
| // Maschera generica di gestione tabelle lavanderie 
 | |
| ///////////////////////////////////////////////////////////
 | |
| 
 | |
| class TLV_table_mask : public TAutomask
 | |
| {
 | |
| protected:
 | |
| 	virtual bool on_field_event(TOperable_field &o, TField_event e, long jolly);
 | |
| 
 | |
| public:
 | |
| 	TLV_table_mask(const char* name) : TAutomask(name) {}
 | |
| };
 | |
| 
 | |
| bool TLV_table_mask::on_field_event(TOperable_field &o, TField_event e, long jolly)
 | |
| {
 | |
|   return true;
 | |
| }
 | |
| 
 | |
| ///////////////////////////////////////////////////////////
 | |
| // Applicazione generica di gestione tabelle lavanderie 
 | |
| ///////////////////////////////////////////////////////////
 | |
| 
 | |
| // applicazione per la gestione delle tabelle di lavanderia
 | |
| class TLV_table_app : public TTable_module_application
 | |
| {
 | |
| protected:  // TRelation_application 
 | |
|   virtual TMask* user_create_mask();
 | |
|   virtual int write(const TMask& m);
 | |
|   virtual int rewrite(const TMask& m);
 | |
|   virtual bool get_next_key(TToken_string& key);
 | |
| 
 | |
|   void cambia_segni(const TMask& m, const bool ritirato);
 | |
|   
 | |
| public:
 | |
| };
 | |
| 
 | |
| // Ridefinire questo metodo per le eventuali maschere speciali
 | |
| // che abbiano controlli speciali da effettuare nella on_field_evebt
 | |
| TMask* TLV_table_app::user_create_mask()
 | |
| {
 | |
|   const TString4 name = get_relation()->file(0).name();
 | |
|   if (name == "???")
 | |
|     return new TLV_table_mask("???");
 | |
|   // Le maschere normali sono gia' gestite dalla TTable_module_application
 | |
|   return TTable_module_application::user_create_mask();
 | |
| }
 | |
| 
 | |
| void TLV_table_app::cambia_segni(const TMask& m, const bool ritirato)
 | |
| {
 | |
|   //instanzio una TTable sulla ytabella delle causali di magazzino
 | |
|   TTable cau("%CAU");
 | |
|   const TString16 causale = m.get(ritirato ? F_CAUSALE_RITIRO : F_CAUSALE_CONSEGNA);
 | |
|   cau.put("CODTAB", causale);
 | |
|   //se trovo la causale
 | |
|   if (cau.read(_isequal, _lock) == NOERR)
 | |
|   {
 | |
|     TString s2 = cau.get("S2");
 | |
|     TString16 sgn = "";
 | |
|     int min = ritirato ? F_SGNDOTIN_R : F_SGNDOTIN_C;
 | |
|     int max = ritirato ? F_SGNCONMN_R : F_SGNCONMN_C;
 | |
|     //mi costruisco la stringa dei segni delle movimentazioni riportata in maschera
 | |
|     for (short i = min; i <= max; i++)
 | |
|     {
 | |
|       TString4 tmp;
 | |
|       switch (m.get_int(i))
 | |
|       {
 | |
|       case 0: tmp << "0 "; break;
 | |
|       case 1: tmp << "+1"; break;
 | |
|       case -1: tmp << "-1"; break;      
 | |
|       default:  break;
 | |
|       }      
 | |
|       sgn << tmp;
 | |
|     }
 | |
|     
 | |
|     //estraggo la sottostringa che mi interessa dalla tabella delle causali e la porto a lunghezza 10
 | |
|     TString16 str = s2.mid(28,10);
 | |
|     if(str.len() < 10)
 | |
|       str << " ";
 | |
| 
 | |
|     //chiedo se volglio proprio modificare i segni della movimentazione di magazzino
 | |
|     if (str != sgn && yesno_box(TR("Si desidera veramente modificare i segni delle causali?")))
 | |
|     {
 | |
|       s2.overwrite(sgn,28,10);
 | |
|       cau.put("S2", s2);
 | |
|       cau.rewrite();
 | |
|     }
 | |
|   }
 | |
|   else
 | |
|     cau.unlock();
 | |
| }
 | |
| 
 | |
| // Ridefinizione del metodo write
 | |
| int TLV_table_app::write(const TMask& m)
 | |
| {
 | |
|   const TString4 name = get_relation()->file(0).name();
 | |
|   if (name == "CAU")
 | |
|   {
 | |
|     if(m.get_bool(F_RITIRATO))
 | |
|       cambia_segni(m, true);
 | |
|     
 | |
|     if(m.get_bool(F_CONSEGNATO))
 | |
|       cambia_segni(m, false);    
 | |
|   }
 | |
|   return TTable_module_application::write(m);      
 | |
| }
 | |
| 
 | |
| // Ridefinizione del metodo rewrite
 | |
| int TLV_table_app::rewrite(const TMask& m)
 | |
| {
 | |
|   const TString4 name = get_relation()->file(0).name();
 | |
|   if (name == "CAU")
 | |
|   {
 | |
|     if(m.get_bool(F_RITIRATO))
 | |
|       cambia_segni(m, true);
 | |
|     
 | |
|     if(m.get_bool(F_CONSEGNATO))
 | |
|       cambia_segni(m, false);    
 | |
|   }
 | |
|   return TTable_module_application::rewrite(m);      
 | |
| }
 | |
| 
 | |
| 
 | |
| // Cerca di generare automaticamente la prossima chiave numerica di una tabella
 | |
| bool TLV_table_app::get_next_key(TToken_string& key)
 | |
| {
 | |
|   // Controlla se il campo COTDAB e' numerico
 | |
|   TMask& msk = curr_mask();
 | |
|   TMask_field* keyfield = msk.find_by_fieldname("CODTAB");
 | |
|   if (keyfield != NULL && keyfield->is_kind_of(CLASS_REAL_FIELD))
 | |
|   {
 | |
|     long num = 1;
 | |
|     TLocalisamfile& tab = get_relation()->lfile();
 | |
|     if (tab.last() == NOERR) // Cerca l'eventuale ultimo record della tabella
 | |
|       num += tab.get_long("CODTAB");
 | |
|     // Costrusci la chiave formattata alla giusta lunghezza del campo, es: "101|0003"
 | |
|     key.format("%d|%0*ld", keyfield->dlg(), keyfield->size(), num);
 | |
|   }
 | |
|   return key.full(); // Ritorna true se la procedura e' riuscita
 | |
| }
 | |
| 
 | |
| int lv0100(int argc, char* argv[])
 | |
| {
 | |
|   TLV_table_app a;
 | |
|   a.run(argc, argv, TR("Tabella Lavanderie"));
 | |
|   return 0;
 | |
| }
 |