ba1100.cpp Tolto include windows.h ba2200.cpp Tolto include windows.h git-svn-id: svn://10.65.10.50/trunk@4083 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			1114 lines
		
	
	
		
			27 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			1114 lines
		
	
	
		
			27 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
| #define STRICT
 | |
| #define XVT_INCL_NATIVE
 | |
| 
 | |
| #include <xi.h>
 | |
| 
 | |
| #include <applicat.h>
 | |
| #include <colors.h>  
 | |
| #include <config.h>
 | |
| #include <execp.h>
 | |
| //#include <golem.h> // TDDE
 | |
| #include <mask.h>
 | |
| #include <isam.h>
 | |
| #include <prefix.h>
 | |
| #include <progind.h>
 | |
| #include <tabutil.h>
 | |
| #include <utility.h>
 | |
| #include <urldefid.h>
 | |
| 
 | |
| #include <nditte.h>
 | |
| 
 | |
| #include "ba0.h"
 | |
| #include "ba0100a.h"
 | |
| 
 | |
| 
 | |
| 
 | |
| ///////////////////////////////////////////////////////////
 | |
| // Picture Mask
 | |
| ///////////////////////////////////////////////////////////
 | |
| 
 | |
| class TPicture_mask : public TMask
 | |
| {
 | |
|   TImage& _image;
 | |
| 
 | |
| protected: // TMask
 | |
|   virtual void update();
 | |
| 
 | |
| public:
 | |
|   virtual bool stop_run(KEY key) { return TWindow::stop_run(key); }
 | |
| 
 | |
|   TPicture_mask(const char* name, int dx, int dy, TImage& image);
 | |
|   virtual ~TPicture_mask() {}
 | |
| };
 | |
| 
 | |
| TPicture_mask::TPicture_mask(const char* name, int dx, int dy, TImage& image)
 | |
| : TMask(name, 1, dx, dy), _image(image)
 | |
| {  
 | |
|   if (_image.ok())
 | |
|     _image.set_palette(win());
 | |
| }
 | |
| 
 | |
| void TPicture_mask::update()
 | |
| {
 | |
|   if (_image.ok())
 | |
|   {
 | |
|     RCT cli; field(101).get_rect(cli);
 | |
|     const int topx = cli.left;
 | |
|     
 | |
|     field(DLG_USER).get_rect(cli);
 | |
|     const int topy = cli.top;
 | |
|     
 | |
|     const double ratiox = double(topx) / _image.width();
 | |
|     const double ratioy = double(topy) / _image.height();
 | |
|     const double ratio = min(ratiox, ratioy);
 | |
|     const int maxx = int(ratio * _image.width()); 
 | |
|     const int maxy = int(ratio * _image.height());
 | |
|     
 | |
|     RCT dst; xvt_rect_set(&dst, 1, 1, maxx, maxy);
 | |
|     
 | |
|     if (xvt_dwin_is_update_needed(win(), &dst))
 | |
|       _image.draw(win(), dst);
 | |
|     
 | |
|     xvt_vobj_get_client_rect(win(), &cli);
 | |
|     cli.bottom--;
 | |
|     cli.right--;
 | |
|     xvt_draw_rect(win(), cli, MASK_LIGHT_COLOR, MASK_DARK_COLOR, 1);
 | |
|   }  
 | |
| }
 | |
| 
 | |
| ///////////////////////////////////////////////////////////
 | |
| // Color Mask
 | |
| ///////////////////////////////////////////////////////////
 | |
| 
 | |
| class TColor_mask : public TMask
 | |
| {      
 | |
|   TAssoc_array _color;
 | |
| 
 | |
| protected: // TMask
 | |
|   virtual void update();              
 | |
|   virtual bool stop_run(KEY key) { return TWindow::stop_run(key); }
 | |
| 
 | |
|   // @cmember Converte le coordinate logiche (caratteri) in coordinate fisiche (pixel)
 | |
|   virtual PNT log2dev(long x, long y) const;
 | |
|   
 | |
| protected:  
 | |
|   static bool color_handler(TMask_field& f, KEY k);
 | |
|   static bool azzera_handler(TMask_field& f, KEY k);
 | |
|   
 | |
|   COLOR get_color_entry(const char* c) const;
 | |
|   void set_color_entry(const char* name, COLOR col);
 | |
|   const char* cid2name(short cid) const;
 | |
|   COLOR cid2color(short cid) const;
 | |
| 
 | |
| public:
 | |
|   void save_colors();
 | |
|  
 | |
|   virtual KEY run();
 | |
| 
 | |
|   TColor_mask();
 | |
|   virtual ~TColor_mask() { }
 | |
| };
 | |
| 
 | |
| TColor_mask::TColor_mask() 
 | |
|            : TMask("ba0200a") 
 | |
| {               
 | |
|   TConfig color(CONFIG_USER, "Colors");
 | |
|   _color = color.list_variables();
 | |
|   
 | |
|   for (int f = fields()-1; f >= 0; f--)
 | |
|   {
 | |
|     TMask_field& mf = fld(f);  
 | |
|     if (mf.is_kind_of(CLASS_BUTTON_FIELD))
 | |
|     {
 | |
|       if (mf.dlg() > DLG_USER)
 | |
|         mf.set_handler(color_handler);
 | |
|       else                    
 | |
|         if (mf.dlg() == DLG_USER)
 | |
|           mf.set_handler(azzera_handler);
 | |
|     }                            
 | |
|   }  
 | |
| }
 | |
| 
 | |
| PNT TColor_mask::log2dev(long x, long y) const
 | |
| {
 | |
|   PNT p = { int(y * XI_FU_MULTIPLE), int(x * XI_FU_MULTIPLE) };
 | |
|   
 | |
|   XI_OBJ* itf = xi_get_itf(win());
 | |
|   xi_fu_to_pu(itf, &p, 1);   
 | |
|   
 | |
|   p.v = int(y * ROWY);
 | |
|   p.h += XI_FU_MULTIPLE / 2;
 | |
|   return p;
 | |
| }
 | |
| 
 | |
| KEY TColor_mask::run()
 | |
| {
 | |
|   KEY k = K_CTRL + 'R';
 | |
|   while (k == K_CTRL + 'R') 
 | |
|     k = TMask::run();             
 | |
|   return k;
 | |
| }
 | |
| 
 | |
| 
 | |
| void TColor_mask::update()
 | |
| { 
 | |
|   COLOR p, b;               
 | |
|   
 | |
|   const int x = 1;
 | |
|   const int y = 7;
 | |
|   const int w = 32;  
 | |
|   const int h = 9;
 | |
|   
 | |
|   set_pen(COLOR_BLACK);
 | |
|   set_brush(b = get_color_entry("MaskBack"));
 | |
|   frame(x+0, y+0, x+w, y+h, 0);
 | |
|   
 | |
|   set_pen(p = get_color_entry("MaskLight"));
 | |
|   line(x+1, y, x+w-2, y); 
 | |
|   line(x+1, y, x+1, y+h-1);
 | |
|   
 | |
|   set_pen(p = get_color_entry("MaskDark"));
 | |
|   line(x+1, y+h-1, x+w-2, y+h-1); 
 | |
|   line(x+w-2, y+h-1, x+w-2, y);
 | |
| 
 | |
|   set_opaque_text(FALSE);
 | |
|   set_pen(p = get_color_entry("Normal"));
 | |
|   set_brush(b = get_color_entry("NormalBack"));
 | |
|   frame(x+3, y+1, x+w-3, y+2, 0);       
 | |
|   set_color(p, b);
 | |
|   stringat(x+4, y+1, "Campo normale");
 | |
| 
 | |
|   set_pen(p = get_color_entry("Focus"));
 | |
|   set_brush(b = get_color_entry("FocusBack"));
 | |
|   frame(x+3, y+3, x+w-3, y+4, 0);
 | |
|   set_color(p, b);
 | |
|   stringat(x+4, y+3, "Campo attivo");
 | |
|   
 | |
|   set_pen(p = get_color_entry("Disabled"));
 | |
|   set_brush(b = get_color_entry("DisabledBack"));
 | |
|   frame(x+3, y+5, x+w-3, y+6, 0);
 | |
|   set_color(p, b);
 | |
|   stringat(x+4, y+5, "Campo disabilitato");
 | |
|   
 | |
|   set_pen(p = get_color_entry("ButtonLight"));
 | |
|   set_brush(b = get_color_entry("ButtonBack"));
 | |
|   frame(x+3, y+7, x+w-3, y+8, 0);
 | |
|   set_color(get_color_entry("Normal"), b);
 | |
|   stringat(x+4, y+7, "Bottone normale");
 | |
| }
 | |
| 
 | |
| void TColor_mask::save_colors()
 | |
| {
 | |
|   TConfig colors(CONFIG_USER, "Colors");
 | |
|   _color.restart();  
 | |
|   for (THash_object* h = _color.get_hashobj(); h; h = _color.get_hashobj())
 | |
|   {
 | |
|     const TString& k = h->key();
 | |
|     const TString& s = (const TString&)h->obj();
 | |
|     colors.set(k, s);
 | |
|   }
 | |
| }
 | |
| 
 | |
| COLOR TColor_mask::get_color_entry(const char* name) const
 | |
| {                               
 | |
|   COLOR c = COLOR_INVALID;
 | |
|   const TObject* s = ((TColor_mask*)this)->_color.objptr(name);
 | |
|   if (s)
 | |
|   {
 | |
|     TToken_string colore(*(TString*)s, ',');
 | |
|     const byte r = (byte)colore.get_int(); 
 | |
|     const byte g = (byte)colore.get_int();
 | |
|     const byte b = (byte)colore.get_int();
 | |
|     c = RGB2COLOR(r, g, b);
 | |
|   }  
 | |
|   return c;
 | |
| }
 | |
| 
 | |
| void TColor_mask::set_color_entry(const char* name, COLOR col)
 | |
| {                               
 | |
|   TString* s = (TString*)_color.objptr(name);
 | |
|   if (s == NULL)
 | |
|   {
 | |
|     s = new TString(16);
 | |
|     _color.add(name, s);
 | |
|   }  
 | |
|   s->format("%d,%d,%d", XVT_COLOR_GET_RED(col), XVT_COLOR_GET_GREEN(col), XVT_COLOR_GET_BLUE(col));
 | |
| }
 | |
| 
 | |
| const char* TColor_mask::cid2name(short cid) const
 | |
| {
 | |
|   const char* name[] = { "MaskBack", "MaskLight", "MaskDark",
 | |
|                          "Normal", "NormalBack",
 | |
|                          "Focus", "FocusBack",
 | |
|                          "Disabled", "DisabledBack",         
 | |
|                          "ButtonBack", "ButtonLight", "ButtonDark"
 | |
|                           };
 | |
|   const int i = cid - 101;                       
 | |
|   CHECK(i >= 0 && i < 12, "Invalid color id");
 | |
|   return name[i];
 | |
| }
 | |
| 
 | |
| COLOR TColor_mask::cid2color(short cid) const
 | |
| {    
 | |
|   COLOR color[] = { COLOR_DKCYAN, COLOR_CYAN, COLOR_GRAY,
 | |
|                     COLOR_BLACK, COLOR_WHITE,
 | |
|                     COLOR_BLACK, COLOR_CYAN,
 | |
|                     COLOR_GRAY, COLOR_DKCYAN, 
 | |
|                     COLOR_LTGRAY, COLOR_WHITE, COLOR_GRAY};
 | |
| 
 | |
|   const int i = cid - 101;                       
 | |
|   CHECK(i >= 0 && i < 12, "Invalid color id");
 | |
|   return color[i];
 | |
| }
 | |
| 
 | |
| bool TColor_mask::color_handler(TMask_field& f, KEY k)
 | |
| {   
 | |
|   bool ok = TRUE;
 | |
| 
 | |
|   if (k == K_SPACE)
 | |
|   {              
 | |
|     TColor_mask& m = (TColor_mask&)f.mask();
 | |
|     const char* name = m.cid2name(f.dlg());
 | |
|     COLOR col = m.get_color_entry(name);
 | |
|     col = choose_color(col, m.win());
 | |
|     ok = col != COLOR_INVALID;
 | |
|     if (ok)
 | |
|     {
 | |
|       m.set_color_entry(name, col);
 | |
|       XVT_PALETTE wp = xvt_vobj_get_palet(m.win());
 | |
|       if (wp != NULL)
 | |
|       {
 | |
|         XVT_PALETTE up = xvt_palet_create(XVT_PALETTE_USER, 0);
 | |
|         if (up != NULL)
 | |
|         {                  
 | |
|           const int MAXPAL = 256;
 | |
|           COLOR color[MAXPAL];
 | |
|           const int n = xvt_palet_get_colors(wp, color, MAXPAL);
 | |
|           if (n < MAXPAL) color[n] = col;
 | |
|           xvt_palet_set_tolerance(up, xvt_palet_get_tolerance(wp));
 | |
|           xvt_palet_add_colors(up, color, n+1);
 | |
|           xvt_vobj_set_palet(m.win(), up);
 | |
|           xvt_palet_destroy(wp);
 | |
|         }  
 | |
|       }  
 | |
|       m.stop_run(K_CTRL + 'R');
 | |
|     }
 | |
|   }              
 | |
|   
 | |
|   return ok;
 | |
| }
 | |
| 
 | |
| bool TColor_mask::azzera_handler(TMask_field& f, KEY k)
 | |
| {
 | |
|   if (k == K_SPACE)
 | |
|   {                                   
 | |
|     TColor_mask& cm = (TColor_mask&)f.mask();
 | |
|     for (int i = cm.fields()-1; i >= 0; i--)
 | |
|     {
 | |
|       TMask_field& mf = cm.fld(i);
 | |
|       if (mf.dlg() > DLG_USER && mf.is_kind_of(CLASS_BUTTON_FIELD))
 | |
|       {
 | |
|         const char* name = cm.cid2name(mf.dlg()); 
 | |
|         const COLOR color = cm.cid2color(mf.dlg());
 | |
|         cm.set_color_entry(name, color);
 | |
|       }
 | |
|     }
 | |
|     cm.update();
 | |
|   }
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| ///////////////////////////////////////////////////////////
 | |
| // Menu application
 | |
| ///////////////////////////////////////////////////////////
 | |
| 
 | |
| class TMenu_application : public TApplication
 | |
| {
 | |
|   const char* _name;
 | |
| 
 | |
|   enum { MAXLEVEL = 512 }; // Non cambiare !! pena di morte . Deve essere < 730
 | |
|   int _first[MAXLEVEL];
 | |
|   TArray _menu;         // TAG|DESCRIPTION|ACTION
 | |
|   TBit_array _enabled;
 | |
|   TArray _modules, _images;
 | |
| 
 | |
|   int _level, _max;
 | |
|   TPicture_mask* _mask;
 | |
|   
 | |
|   static int _last_button;
 | |
|   static bool _find_button;
 | |
| 
 | |
| protected:  // TApplication
 | |
|   virtual bool create();
 | |
|   virtual bool destroy();
 | |
|   virtual bool menu(MENU_TAG m);
 | |
|   virtual bool build_firm_data(long cod, bool flagcom = FALSE);
 | |
|   virtual long handler(WINDOW win, EVENT* ep);
 | |
| 
 | |
| protected:
 | |
|   bool main_loop();
 | |
|   void test_temp();
 | |
|   void load_menu();
 | |
|   int do_level();
 | |
|   int find_menu(const char* s) const;
 | |
|   bool check_user();
 | |
|   static bool menu_item_handler(TMask_field&f, KEY k);
 | |
|   static bool menu_find_handler(TMask_field&f, KEY k);
 | |
|   bool module_enabled(const char * program) const;
 | |
|   bool module_enabled(int module) const { return has_module(module);}
 | |
| 
 | |
|   bool choose_colors();
 | |
|   bool choose_editors();
 | |
|   
 | |
| public:    
 | |
|   void reload_images();
 | |
| 
 | |
|   TMenu_application(const char* name) : _name(name), _mask(NULL) { }
 | |
|   virtual ~TMenu_application() { }
 | |
| };
 | |
| 
 | |
| int TMenu_application::_last_button = 0;
 | |
| bool TMenu_application::_find_button = FALSE;
 | |
| 
 | |
| inline TMenu_application& app() 
 | |
| { return (TMenu_application&)main_app(); }
 | |
| 
 | |
| 
 | |
| bool TMenu_application::build_firm_data(long codditta, bool flagcom)
 | |
| {
 | |
|   const char * const ndir = "/dir.gen";
 | |
|   const char * const ntrc = "/trc.gen";
 | |
|   TFilename  s(firm2dir(codditta)); s << ndir;
 | |
|   bool exist = fexist(s);
 | |
|   
 | |
|   if (!exist)
 | |
|   {
 | |
|     s = s.path(); s.rtrim(1); s << ntrc;
 | |
|     exist = fexist(s);
 | |
|   }
 | |
|   if (exist)
 | |
|     return message_box("Direttorio dati danneggiato, impossibile attivare la ditta %ld", codditta);
 | |
|   if (!yesno_box("Gli archivi della ditta %ld non esistono: si desidera generarli?", codditta))
 | |
|     return FALSE;         
 | |
|   
 | |
|   TLocalisamfile ditte(LF_NDITTE);
 | |
|   ditte.zero();
 | |
|   ditte.put(NDT_CODDITTA,codditta);   
 | |
|   if (ditte.read(_isequal,_testandlock) == _islocked)
 | |
|   {
 | |
|     message_box("Archivi della ditta %ld in fase di creazione da parte di un altro utente.",codditta);
 | |
|     return FALSE;
 | |
|   }
 | |
|   
 | |
|   set_autoload_new_files(yesno_box("Si desidera precaricare gli archivi standard"));
 | |
|   s = s.path();   s.rtrim(1);
 | |
|   
 | |
|   if (!fexist(s) && !make_dir(s))
 | |
|     return error_box("Impossibile creare il direttorio della ditta %ld (%s)",
 | |
|                      codditta, (const char*)s);
 | |
|   
 | |
|   s << ndir;
 | |
|   if (!fcopy(&ndir[1], s))
 | |
|     return error_box("Impossibile copiare il file %s della ditta %ld",
 | |
|                      &ndir[1], codditta);
 | |
|   s = s.path(); s << ntrc;
 | |
|   if (!fcopy(&ntrc[1], s))
 | |
|     return error_box("Impossibile copiare il file %s della ditta %ld",
 | |
|                      ntrc, codditta);
 | |
| 
 | |
|   TDir dir, dir1;
 | |
|   TTrec rec;
 | |
| 
 | |
|   prefix().set("");
 | |
|   dir1.get(LF_DIR, _nolock, _nordir, _sysdirop);
 | |
|   const long maxeod0 = dir1.eod();
 | |
| 
 | |
|   prefix().set_codditta(codditta);
 | |
|   dir.get(LF_DIR, _nolock, _nordir, _sysdirop);
 | |
|   if (dir.eod() == 0)
 | |
|   {
 | |
|     dir1.eod() = 1L;
 | |
|     dir1.put(LF_DIR, _nordir, _sysdirop);
 | |
|     dir.get(LF_DIR, _nolock, _nordir, _sysdirop);
 | |
|   }
 | |
|   const long    maxeod1 = dir.eod();
 | |
| 
 | |
|   if (maxeod0 > maxeod1)
 | |
|   {
 | |
|     dir.get(LF_DIR, _nolock, _nordir, _sysdirop);
 | |
|     dir.eod() = maxeod0;
 | |
|     dir.put(LF_DIR, _nordir, _sysdirop);
 | |
|     rec.zero();
 | |
|   }
 | |
|   TString mess("Generazione archivi della ditta "); mess << codditta;
 | |
|   TProgind p(maxeod0 ? maxeod0 : 1, mess, FALSE, TRUE, 70);
 | |
| 
 | |
|   for (int i = LF_DIR + 1; i <= maxeod0; i++)
 | |
|   {
 | |
|     p.addstatus(1);
 | |
|     prefix().set("");
 | |
|     dir.get(i, _nolock, _nordir, _sysdirop);
 | |
|     rec.get(i);
 | |
|     bool create_now = dir.is_active();
 | |
|     
 | |
|     prefix().set_codditta(codditta);
 | |
|     dir.put(i, _nordir, _sysdirop);
 | |
|     rec.put(i);
 | |
|     const char* name = dir.name();
 | |
|     dir.flags() = 0L;
 | |
|     create_now = create_now && (flagcom ? dir.is_com() : dir.is_firm());
 | |
|     
 | |
|     if (dir.is_valid() && create_now)
 | |
|     {
 | |
|       TSystemisamfile f(i);
 | |
|       f.build(30);
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|       dir.put(i, _nordir, _sysdirop);
 | |
|       rec.put(i);
 | |
|     }
 | |
|   }
 | |
|   
 | |
|   TConfig c(CONFIG_STUDIO, "cg");
 | |
|   
 | |
|   if (c.get_bool("StiReg"))
 | |
|   {
 | |
|     TTable reg("REG");
 | |
|     for (reg.first(_lock); reg.good(); reg.next(_lock))
 | |
|     {
 | |
|       reg.put("B9", "X");
 | |
|       reg.rewrite();
 | |
|     }
 | |
|   } 
 | |
|   ditte.reread(_unlock);
 | |
|   
 | |
|   set_firm(codditta);
 | |
|   set_autoload_new_files(TRUE);
 | |
|   
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| 
 | |
| bool TMenu_application::module_enabled(const char * program) const
 | |
| {
 | |
|   bool found = FALSE;
 | |
|   const int nmod = _modules.items();
 | |
|   
 | |
|   for (int aut = 0; aut < nmod; aut++)
 | |
|   {
 | |
|     const TString& s = (const TString&) _modules[aut];
 | |
|     if (isdigit(program[2]) && s.compare(program, 2) == 0) { found = TRUE; break; }
 | |
|   }     
 | |
|   return (!found) || has_module(aut);
 | |
| }
 | |
| 
 | |
| void TMenu_application::load_menu()
 | |
| {
 | |
|   TScanner s(_name);
 | |
| 
 | |
|   _max = -1;
 | |
| 
 | |
|   while (s.line().not_empty())
 | |
|   {
 | |
|     TToken_string* ts = new TToken_string(s.token());
 | |
|     int l = ts->get_int();
 | |
| 
 | |
|     if (l < _max)
 | |
|     {
 | |
|       error_box("Item of level %d while %d was expected)", l, _max);
 | |
|       l = _max;
 | |
|     }
 | |
|     if (l > _max)
 | |
|     {
 | |
|       if (l >= MAXLEVEL)
 | |
|       {
 | |
|         error_box("Too many menu levels: %d", l);
 | |
|         l = _max;
 | |
|       } 
 | |
|       _first[++_max] = _menu.items();
 | |
|       _first[_max = l] = _menu.items();
 | |
|     }
 | |
| 
 | |
|     _menu.add(ts);
 | |
|     TString80 action(ts->get(2));
 | |
|     const int last = _menu.items() - 1;
 | |
|     TToken_string list(ts->get(), ',');
 | |
| 
 | |
|     if (atoi(action) > 0 || list.items() > 0)
 | |
|     {
 | |
|       const TString16 mod = list.get(0);
 | |
|       int module = atoi(mod); 
 | |
| 
 | |
|       if (module == 0) 
 | |
|       {
 | |
|         bool on = TRUE;
 | |
| //        if (mod[0] == 'P') on = user() == "PRASSI"; // Errore MI1639
 | |
|         _enabled.set(last, on);
 | |
|       }  
 | |
|       while(!_enabled[last] && module > 0)
 | |
|       {
 | |
|         if (has_module(module))
 | |
|           _enabled.set(last);
 | |
|         module = list.get_int(); 
 | |
|       }
 | |
|     }
 | |
|     else
 | |
|     {            
 | |
|       action.trim(); action.upper();
 | |
|       const bool on = action != "DISABLED";
 | |
|       _enabled.set(last, on);
 | |
|     }  
 | |
|     //      _enabled.set(last, module_enabled(action));
 | |
|   }
 | |
|   _first[++_max] = _menu.items();
 | |
| }
 | |
| 
 | |
| int TMenu_application::find_menu(const char* s) const
 | |
| {                             
 | |
|   TString str(s); str.upper();
 | |
|   int found = -1;
 | |
|   TString v(80);
 | |
|   for (int i = 0; i < _menu.items(); i++)
 | |
|   {
 | |
|     if (_enabled[i])
 | |
|     {
 | |
|       TToken_string& l = (TToken_string&)_menu[i];
 | |
|       const int m = l.get_int(0);
 | |
|       if (m != _level)
 | |
|       {
 | |
|         v = l.get(); v.upper();
 | |
|         if (v.find(str) >= 0)
 | |
|         {
 | |
|           found = i;
 | |
|           if (isalpha(l.get_char())) break;
 | |
|         }  
 | |
|       }
 | |
|     }  
 | |
|   }
 | |
|   return found;
 | |
| }
 | |
| 
 | |
| bool TMenu_application::menu_item_handler(TMask_field&f, KEY k)
 | |
| {
 | |
|   if (k == K_SPACE)
 | |
|   {
 | |
|     _last_button = f.dlg();
 | |
|     _find_button = FALSE;
 | |
|     f.set_focusdirty(FALSE);
 | |
|     return f.mask().stop_run(K_AUTO_ENTER);
 | |
|   }     
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| 
 | |
| bool TMenu_application::menu_find_handler(TMask_field&f, KEY k)
 | |
| {
 | |
|   if (k == K_TAB && f.focusdirty())
 | |
|   {
 | |
|     const TString& v = f.get();
 | |
|     if (v.not_empty())
 | |
|     {
 | |
|       _last_button = app().find_menu(v);
 | |
|       if (_last_button >= 0)
 | |
|       {
 | |
|         _find_button = TRUE;
 | |
|         f.set_focusdirty(FALSE);
 | |
|         return f.mask().stop_run(K_AUTO_ENTER);
 | |
|       }  
 | |
|       else
 | |
|       {
 | |
|         beep();
 | |
|         return FALSE;
 | |
|       }  
 | |
|     }    
 | |
|   }     
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| 
 | |
| void TMenu_application::reload_images()
 | |
| {
 | |
|   for (int id = _images.last(); id >= 0; id--)
 | |
|   {
 | |
|     TImage* i = (TImage*)_images.objptr(id);
 | |
|     if (i)
 | |
|     {
 | |
|       TString16 n; n.format("ba%02d.bmp", id);
 | |
|       i->load(n);
 | |
|       i->convert_transparent_color(MASK_BACK_COLOR);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| int TMenu_application::do_level()
 | |
| {                      
 | |
|   const int first = _first[_level];
 | |
|   const int last = _first[_level+1];
 | |
|   TToken_string& row = (TToken_string&)_menu[first];
 | |
|   const TString80 head(row.get(1));
 | |
| 
 | |
|   const int width = 78;
 | |
|   const int height = 18;
 | |
|   const int bwidth = 20;
 | |
|   short id = (short)row.get_int();
 | |
|   
 | |
|   if (_images.objptr(id) == NULL)
 | |
|   { 
 | |
|     char* n = format("ba%02d.bmp", id);
 | |
|     if (id > 0 && !fexist(n))
 | |
|       n = format("ba%02d.bmp", id = 0);
 | |
|     
 | |
|     TImage* image = new TImage(n);  
 | |
|     image->convert_transparent_color(MASK_BACK_COLOR);
 | |
|     _images.add(image, id);
 | |
|   }
 | |
|   
 | |
|   TPicture_mask menu(head, width, height, (TImage&)_images[id]);
 | |
|   _mask = &menu;
 | |
| 
 | |
|   const int x = width / 2;
 | |
|   int y = 1;
 | |
| 
 | |
|   for (int i = first+1; i < last; i++, y++)
 | |
|   {
 | |
|     TToken_string& row = (TToken_string&)_menu[i];
 | |
|     TString80 item(row.get(1));
 | |
|     if (isdigit(*row.get())) item << "...";
 | |
|     menu.add_static(-1, 0, item, x+4, y);
 | |
|     const short id = 100+y;
 | |
|     menu.add_button(id, 0, "", x, y, 1, 1, "", BMP_STOPREC);
 | |
|     menu.set_handler(id, menu_item_handler);
 | |
|     if (!_enabled[i]) menu.disable(id);
 | |
|   }
 | |
|   
 | |
|   menu.add_static(DLG_NULL, 0, "Cerca", 1,-3); 
 | |
|   TEdit_field& ef = menu.add_string(DLG_USER, 0, "", -12, -3, 50, "", bwidth+1);
 | |
|   ef.set_handler(menu_find_handler);
 | |
|   
 | |
|   TButton_field& bf = menu.add_button(DLG_QUIT, 0, "Fine", first ? -12 : -22, -1, bwidth, 2);  
 | |
|   if (first)
 | |
|   {
 | |
|     RCT e_rct; ef.get_rect(e_rct);   // Rettangolo cerca
 | |
|     RCT b_rct; bf.get_rect(b_rct);   // Rettangolo bottone
 | |
|     b_rct.left = e_rct.left-2;       // Aggiusta rettangolo
 | |
|     b_rct.right = e_rct.right+2;
 | |
|     bf.set_rect(b_rct);              // Modifica bottone
 | |
|     menu.add_button(DLG_CANCEL, 0, "Menu precedente", -22, -1, bwidth, 2);  
 | |
|   }
 | |
|   
 | |
|   if (_find_button && _last_button > first) 
 | |
|     menu.first_focus(100+_last_button-first);
 | |
|   
 | |
|   _last_button = _find_button = 0;  
 | |
| 
 | |
|   const int k = menu.run();
 | |
|   _mask = NULL;
 | |
|   
 | |
|   int m = 0;
 | |
|   switch (k)
 | |
|   {       
 | |
|   case K_ESC:
 | |
|     m = -1; 
 | |
|     break;
 | |
|   case K_QUIT:
 | |
|     menu.reset();
 | |
|     m = -2; 
 | |
|     break;    
 | |
|   case K_CTRL+'R':
 | |
|     m = 0;
 | |
|     break;  
 | |
|   default:
 | |
|     if (_find_button)
 | |
|       m = -1;
 | |
|     else  
 | |
|       m = first+_last_button-100; 
 | |
|     break;
 | |
|   }
 | |
|   return m;
 | |
| }
 | |
| 
 | |
| 
 | |
| void TMenu_application::test_temp()
 | |
| {                   
 | |
|   begin_wait();
 | |
|   
 | |
|   TFilename dir; dir.tempdir();                     // Directory temporanea
 | |
|   dir << '/' << '*';
 | |
|   TToken_string files(dir);
 | |
|   const int count = list_files(files);
 | |
|   
 | |
|   end_wait();
 | |
|   
 | |
|   if (count > 0 && yesno_box("Cancellare %d file temporane%c in %s?", 
 | |
|                              count, (count > 1) ? 'i' : 'o', dir.path()))
 | |
|   {  
 | |
|     TProgind bar(count, "Cancellazione file temporanei", TRUE, TRUE);
 | |
|     for (const char* e = files.get(0); e; e = files.get())
 | |
|     { 
 | |
|       if (bar.iscancelled()) break;                   
 | |
|       remove(e);
 | |
|       bar.addstatus(1);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| bool TMenu_application::check_user()
 | |
| {
 | |
|   TMask m("ba0100a");
 | |
|   TLocalisamfile users(LF_USER);
 | |
|   TString utente(user()), pwd; 
 | |
|   
 | |
|   bool ok = FALSE;
 | |
|   for (int i = 0 ; i < 3 && !ok; i++)
 | |
|   {          
 | |
|     if (utente.not_empty() && utente != "PRASSI")
 | |
|     {
 | |
|       m.set(F_USER, utente);
 | |
|       m.first_focus(F_PASSWORD);
 | |
|     }
 | |
|     
 | |
|     if (m.run() == K_ESC)
 | |
|       break;
 | |
|     
 | |
|     utente = m.get(F_USER);
 | |
|     users.zero();
 | |
|     users.put("USERNAME", utente);
 | |
|     
 | |
|     pwd = "";
 | |
|     
 | |
|     int err = users.read(_isequal, _lock);
 | |
|     if (err == NOERR)
 | |
|     {
 | |
|       pwd = decode(users.get("PASSWORD"));
 | |
|     }  
 | |
|     else
 | |
|       if (utente == "PRASSI")
 | |
|       {
 | |
|         pwd = "pr.assi";  
 | |
|         users.zero();
 | |
|         users.put("USERNAME", utente);
 | |
|         users.put("USERDESC", utente);
 | |
|         users.put("PASSWORD", encode(pwd));
 | |
|         users.write();
 | |
|         err = users.read(_isequal, _lock);
 | |
|       }  
 | |
|     
 | |
|     ok = utente.not_empty() && pwd.not_empty() && pwd == m.get(F_PASSWORD);
 | |
|     
 | |
|     if (ok) 
 | |
|     {
 | |
|       ok = !users.get_bool("CONNECTED");
 | |
|       if (!ok)
 | |
|       {
 | |
|         ok = yesno_box("L'utente %s risulta essere gia' collegato\n"
 | |
|                        "Si desidera continuare ugualmente?", (const char*)utente);
 | |
|       }
 | |
|       if (ok)
 | |
|         user() = utente;
 | |
|     }  
 | |
|     else 
 | |
|     {
 | |
|       error_box("Utente e/o password errata:\nfare attenzione alle maiuscole");
 | |
|       m.set(F_PASSWORD,"");
 | |
|     }  
 | |
|     
 | |
|     if (err == NOERR)
 | |
|     {
 | |
|       if (ok) 
 | |
|       {
 | |
|         users.put("CONNECTED", "X");
 | |
|         users.rewrite();
 | |
|         
 | |
|         enable_menu_item(M_FONT);
 | |
|         
 | |
|         customize_colors();                       // Aggiorna set di colori
 | |
|         xvt_dwin_invalidate_rect(TASK_WIN, NULL); // Ridisegna sfondo
 | |
|       }
 | |
|       else 
 | |
|         users.read(_isequal, _unlock);
 | |
|     }  
 | |
|   }         
 | |
| 
 | |
| #if XVT_OS == XVT_OS_WIN
 | |
|   if (ok && utente != "PRASSI")
 | |
|   {     
 | |
| /*  
 | |
|     TDDE dde;
 | |
|     if (dde.initiate("PROGMAN", "PROGMAN"))
 | |
|     {
 | |
|       dde.execute("[ReplaceItem(PR.A.S.S.I.)]");
 | |
|       TString cmd(80); 
 | |
|       cmd << "[AddItem(" << argv(0) << " /u"  << utente << ",PR.A.S.S.I.)]";
 | |
|       dde.execute(cmd);
 | |
|     }  
 | |
| */
 | |
|     WritePrivateProfileString("User", "Name", utente, "prassi.ini");
 | |
|   }  
 | |
| #endif
 | |
| 
 | |
|   return ok;
 | |
| }
 | |
| 
 | |
| bool TMenu_application::create()
 | |
| {
 | |
|   TApplication::create();
 | |
|   
 | |
|   if (!check_user()) 
 | |
|     return FALSE;
 | |
|   
 | |
|   set_perms();
 | |
|   test_temp();
 | |
| 
 | |
|   TScanner scanner("prassi.aut");
 | |
|   
 | |
|   for (int aut = 0; scanner.line() != ""; aut++)
 | |
|     _modules.add(scanner.token());
 | |
| 
 | |
|   load_menu();
 | |
|   dispatch_e_menu(MENU_ITEM(1));
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| bool TMenu_application::destroy()
 | |
| {                      
 | |
|   TLocalisamfile users(LF_USER);
 | |
|   users.put("USERNAME", user());
 | |
|   int err = users.read(_isequal, _lock);
 | |
|   if (err == NOERR)
 | |
|   {
 | |
|     users.zero("CONNECTED");
 | |
|     users.rewrite();
 | |
|   }
 | |
|   
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| bool TMenu_application::main_loop()
 | |
| {
 | |
|   int refarray[256];
 | |
|   memset(refarray, 0, sizeof(refarray)); 
 | |
|   
 | |
|   int i = 0;
 | |
| 
 | |
|   _level = 0;
 | |
|   while (i >= 0)
 | |
|   {
 | |
|     const int m = do_level();
 | |
|     if (m >= 0)
 | |
|     {
 | |
|       TToken_string& row = (TToken_string&)_menu[m];
 | |
|       const TFilename option(row.get(2));
 | |
|       
 | |
|       if (option.not_empty())
 | |
|       {
 | |
|         bool ok = TRUE;
 | |
|         const int l = atoi(option);
 | |
|         if (l > 0 && l < MAXLEVEL)
 | |
|         {
 | |
|           const TString16 flags(row.get());
 | |
|           if (flags.find('F') >= 0) 
 | |
|             ok = set_firm();
 | |
|           if (ok)
 | |
|           {
 | |
|             refarray[i++] = _level;
 | |
|             if (l < _max) _level = l;
 | |
|           }
 | |
|         }
 | |
|         else
 | |
|         {  
 | |
|           const TString16 flags(row.get());
 | |
|           if (flags.find('P') >= 0) 
 | |
|           {
 | |
|             TMask mask("ba0100a");
 | |
|             mask.disable(F_USER);
 | |
|             mask.set(F_USER, "SERVIZIO");
 | |
|             ok = FALSE;
 | |
|             if (mask.run() == K_ENTER)
 | |
|             {                    
 | |
|               const TDate oggi(TODAY);
 | |
|               TString16 pwd; pwd << "PRASSI" << (oggi.month() + oggi.day());
 | |
|               ok = pwd == mask.get(F_PASSWORD);
 | |
|             }
 | |
|             if (!ok) error_box("Password di servizio errata!\nAccesso negato.");
 | |
|           }
 | |
|           
 | |
|           if (ok)
 | |
|           {
 | |
|             const TString16 module(cmd2name(option));
 | |
|             if (get_firm() == 0 && module.compare("cg", 2, TRUE) == 0)   // Chiede ditta se necessario
 | |
|               ok = set_firm();
 | |
|           }
 | |
|           
 | |
|           if (ok)
 | |
|           {
 | |
|             prefix().set(NULL);                      // Chiude prefix
 | |
|             TFilename opt_cmd(option);
 | |
| #if XVT_OS == XVT_OS_WIN            
 | |
|             opt_cmd.lower();
 | |
| #endif            
 | |
|             bool maintenance_app = (opt_cmd == "ba1 -0" || opt_cmd == "ba1");
 | |
|             TExternal_app a(option);
 | |
|             a.run();
 | |
|             if (maintenance_app)
 | |
|             { 
 | |
|               FILE* fp;
 | |
|               char line1[16],line2[16];
 | |
|               if (opt_cmd == "ba1") opt_cmd << " -0";
 | |
|               opt_cmd << " C";
 | |
|               
 | |
|               while  (fexist("conv.his"))
 | |
|               {
 | |
|                 fp = fopen("conv.his","r");
 | |
|                 fgets(line1,15,fp);
 | |
|                 fclose(fp);
 | |
|                 // Ora aspetta...
 | |
|                 time_t old_time ;
 | |
|                 time( &old_time) ;
 | |
|                 while (  time( (time_t *) 0 ) <= old_time ) do_events();
 | |
|                 TExternal_app auto_conv(opt_cmd);
 | |
|                 auto_conv.run();
 | |
|                 fp = fopen("conv.his","r");
 | |
|                 if (fp != NULL)
 | |
|                 {
 | |
|                   fgets(line2,15,fp);
 | |
|                   fclose(fp);
 | |
|                 }
 | |
|                 else strcpy(line2,"");
 | |
|                 if (strcmp(line1,line2) == 0)
 | |
|                   if (!yesno_box("La conversione non sembra procedere. Continuo?"))
 | |
|                     break; 
 | |
|               }
 | |
|             }
 | |
|             prefix().set("DEF");                     // Aggiorna prefix
 | |
|           }  
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|     else 
 | |
|     {
 | |
|       if (m < -1) break;
 | |
|       if (_find_button)
 | |
|       {
 | |
|         TToken_string& row = (TToken_string&)_menu[_last_button];
 | |
|         _level = row.get_int(0);
 | |
|       }  
 | |
|       else  
 | |
|       {
 | |
|         _level = (i > 0) ? refarray[--i] : 0;
 | |
|         if (_level == 0) i = 0;
 | |
|       }  
 | |
|     }  
 | |
|   }
 | |
|   return FALSE;
 | |
| }                                                
 | |
| 
 | |
| bool TMenu_application::choose_colors()
 | |
| {                                
 | |
|   disable_menu_item(M_FONT);
 | |
|   TColor_mask * cm = new TColor_mask();
 | |
|   if (cm->run() == K_ENTER)
 | |
|   {
 | |
|     cm->save_colors();         // Aggiorna config
 | |
|     customize_colors();       // Aggiorna set di colori
 | |
|     
 | |
|     reload_images();          // Aggiorna bitmaps del menu
 | |
|     
 | |
|     // Ridisegna sfondo
 | |
|     TTemp_window tw(TASK_WIN);                
 | |
|     tw.force_update();
 | |
|     
 | |
|     // Provoca chiusura forzata del menu
 | |
|     if (_mask != NULL) 
 | |
|       _mask->stop_run(K_CTRL + 'R');
 | |
|   }
 | |
|   enable_menu_item(M_FONT);
 | |
|   delete cm;
 | |
|   return TRUE;
 | |
| } 
 | |
| 
 | |
| HIDDEN bool browse_file_handler(TMask_field& f, KEY k)
 | |
| {
 | |
|   if (k == K_F9)
 | |
|   {  
 | |
|     FILE_SPEC fs; memset(&fs, 0, sizeof(FILE_SPEC));
 | |
|     strcpy(fs.type, "EXE");
 | |
|     strcpy(fs.name, f.get());
 | |
|     strcpy(fs.creator, "ba0");
 | |
|     xvt_fsys_get_default_dir(&fs.dir);
 | |
|     xvt_fsys_save_dir();
 | |
|     if (xvt_dm_post_file_open(&fs, "Selezione programma") == FL_OK)
 | |
|     {       
 | |
|       TFilename n;
 | |
|       xvt_fsys_convert_dir_to_str(&fs.dir, (char*)(const char*)n, n.size());
 | |
|       n.add(fs.name);
 | |
|       f.set(n);
 | |
|       xvt_fsys_restore_dir();
 | |
|     }
 | |
|   }
 | |
|   
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| bool TMenu_application::choose_editors()
 | |
| { 
 | |
|   disable_menu_item(M_FONT);
 | |
|   TConfig link(CONFIG_USER, "Link");
 | |
|   TMask editor("ba0300a");
 | |
|   
 | |
|   editor.set_handler(101, browse_file_handler);
 | |
|   editor.set(101, link.get("Editor"));
 | |
|   
 | |
|   if (editor.run() == K_ENTER)
 | |
|   {
 | |
|     link.set("Editor", editor.get(101));
 | |
|   }
 | |
|   enable_menu_item(M_FONT);
 | |
|   
 | |
|   return TRUE;
 | |
| }
 | |
| 
 | |
| long TMenu_application::handler(WINDOW win, EVENT* ep)
 | |
| {
 | |
|   long ret = TApplication::handler(win, ep);
 | |
|   if (ep->type == E_FONT)
 | |
|   {
 | |
|     if (_mask != NULL) 
 | |
|       _mask->stop_run(K_CTRL + 'R');
 | |
|   }  
 | |
|   return ret;  
 | |
| }
 | |
| 
 | |
| bool TMenu_application::menu(MENU_TAG mt)
 | |
| {
 | |
|   bool ok = TRUE;
 | |
|   switch (mt)
 | |
|   {
 | |
|   case MENU_ITEM(1): ok = main_loop(); break;
 | |
|   case MENU_ITEM(2): choose_colors(); break; 
 | |
|   case MENU_ITEM(3): choose_editors(); break;
 | |
|   default: break;
 | |
|   }
 | |
|   return  ok;
 | |
| }
 | |
| 
 | |
| 
 | |
| int main(int argc, char** argv)
 | |
| {  
 | |
|   TApplication::check_parameters(argc, argv);
 | |
|   
 | |
|   if (user().blank())
 | |
|   {
 | |
|     char u[16];
 | |
|     GetPrivateProfileString("User", "Name", "PRASSI", u, sizeof(u), "prassi.ini");
 | |
|     user() = u;
 | |
|   }
 | |
| 
 | |
|   const char* menu = (argc < 2) ? "prassi.mnu" : argv[1];
 | |
|   
 | |
|   TMenu_application ma(menu);
 | |
|   ma.run(argc, argv, "Menu Principale");
 | |
|   return TRUE;
 | |
| }
 |