#ifndef __MSKSHEET_H #define __MSKSHEET_H #ifndef __MASK_H #include #endif #define FIRST_FIELD 101 #define K_ROWEDIT ( K_CTRL + 'I' ) class TSheet_field; // @doc EXTERNAL // @type SPREADSHEET_NOTIFY | Prototipo funzione che gestisce l'ingresso, l'uscita e la modifica da una riga dello sheet typedef bool (*SPREADSHEET_NOTIFY)(TSheet_field& s, int r, KEY k); // @doc EXTERNAL // @class TSheet_field | Classe per la gestione dei campi di uno spreadsheet // // @base public | TMask_field class TSheet_field : public TOperable_field { // @author:(INTERNAL) Guido // @cfriend TSpreadsheet friend class TSpreadsheet; // @access:(INTERNAL) Private Member // @cmember:(INTERNAL) Indica se aggiungere a fondo dello spreadsheet o nella riga in cui ti trovi bool _append; // @access Protected Member protected: // @cmember:(INTERNAL) Identificatore dell' ultima colonna dello sheet short _last_column_id; // @cmember Ritorna l'identificatore della classe virtual word class_id() const; virtual bool is_kind_of(word cid) const; // @cmember Gestisce la chiamata all'handler del campo virtual bool on_hit(); // @cmember Legge la testata dello spreadsheet da

virtual void parse_head(TScanner& scanner); // @cmember Legge gli item dello spreadsheet da

virtual bool parse_item(TScanner& scanner); // @cmember Crea lo spreadsheet virtual void create(WINDOW parent); // @cmember Setta il focus sul campo virtual void highlight() const; // @cmember Permette di settare il valore del cambio del campo virtual void exchange(bool show_value, const real& n); // @cmember Ricopia i campi della maschera nel record

-esimo virtual void mask2row(int n, TToken_string & rec); // @cmember Ricopia i campi del record

-esimo nella maschera virtual void row2mask(int n, TToken_string & rec); // @access Public Member public: // @cmember Gestisce la pressione del tasto (TRUE se la gestione ha avuto successo) virtual bool on_key(KEY k); // @cmember Ritorna una riga dello spreadsheet TToken_string& row(int n); // @cmember Ritorna un array con tutte le righe dello spreadsheet TString_array& rows_array() const; // @cmember Ritrna l'elemento

-esimo della riga

const char* cell(int r, int c) { return row(r).get(c); } // @cmember Ritorna la prima riga vuota nello spreadsheet int first_empty() const; // @cmember Ritorna il numero di righe presenti nello spreadsheet int items() const; // @cmember Ritorna il numero della riga corrente int selected() const; // @cmember Seleziona la riga

come quella corrente void select(int r, bool scrollto = FALSE); // @cmember Vuota tutto lo spreadsheet virtual void reset(); // @cmember Abilita/disabilita tutto lo spreadsheet (vedi ) virtual void enable(bool on); // @cmember Ritorna lo stato di abilitazione dello spreadsheet (vedi ) virtual bool enabled() const; // @cmember Aggiorna le righe dello spreadsheet con i valori salvati una volta che non ci sono // piu' processi attivi void on_idle(); // @cmember Elimina una riga void destroy(int r = -1, bool update_sheet = TRUE); // @cmember Forza l'aggiornamento dei dati della riga sullo schermo void force_update(int r = -1); // @cmember Ritorna la maschera corrispondente ad una riga dello spreadsheet virtual TMask& sheet_mask() const; // @cmember esegue la maschera di edit dello speadsheet; virtual KEY run_editmask(int ) { return sheet_mask().run();} // @cmember Setta il membro

della classe void set_notify(SPREADSHEET_NOTIFY n); // @cmember Trasforma l'identificatore di un campo

in un numero di colonna logica int cid2index(short cid) const; // @cmember Abilita/disabilita una colonna dello spreadsheet (vedi ) void enable_column(int col, bool on = TRUE); // @cmember Abilita/disabilita una cella dello spreadsheet (vedi ) void enable_cell(int row, int column, bool on = TRUE); // @cmember Disabilta una cella dello spreadsheet (chiama ) void disable_cell(int row, int column) { enable_cell(row, column, FALSE); } // @cmember Controlla se una cella e' disabilitata (vedi ) bool cell_disabled(int row, int column) const; // @cmember Controlla se una colonna e' abilitata (vedi ) bool column_enabled(int column) const; // @cmember Controlla se una colonna e' disabilitata (vedi ) bool column_disabled(int column) const; // @cmember Permette di eliminare una colonna dallo spreadsheet void delete_column( const int col ) const; // @cmember Sposta la colonna dalla posizione

alla posizione //

void move_column( const int fromindex, const int toindex ) const; // @cmember Permette di invertire la posizione di due colonne void swap_columns(const int fromid, const int toid) const; // @cmember Permette di invertire la posizione di due righe void swap_rows( const int fromindex, const int toindex ) ; // @cmember Setta la larghezza della colonna void set_column_width( const int col, const int width ) const; // @cmember Setta il titolo della colonna void set_column_header( const int col, const TString& header ) const; // @cmember Setta l'allineamento della colonna void set_column_justify(int col, bool right); // @cmember Setta il colore dello sfondo e del testo di una o tutte le righe void set_back_and_fore_color(COLOR back, COLOR fore, int row); // @cmember Memorizza la disposizione delle colonne void save_columns_order(); // @cmember Dispone le colonne come all'atto del caricamento void reset_columns_order(); // @cmember Setta il member

con il valore di

void set_append(bool on = TRUE) { _append = on;} // @cmember Ritorna il valore del mebro

bool append() const { return _append;} // @cmember Funzione eseguita dopo ogni insert virtual void post_insert(int) { } // @cmember Costruttore TSheet_field(TMask* m); // @cmember Distruttore virtual ~TSheet_field(); }; #endif