/// <summary> /// Launcher dell'aggiornamento dati. /// </summary> /// <returns>True se l'aggiornamento è andato a buon fine.</returns> public override bool Dati(bool marketUpdate = true) { if (DataBase.OpenConnection()) { if (marketUpdate) SetMercatoAttivo(); SplashScreen.Show(); bool wasProtected = Sheet.Protected; if (wasProtected) Sheet.Protected = false; Workbook.ScreenUpdating = false; try { CaricaDatiDalDB(); Workbook.Application.Calculation = Excel.XlCalculation.xlCalculationManual; SplashScreen.UpdateStatus("Aggiorno dati Riepilogo"); DatiRiepilogo(); SplashScreen.UpdateStatus("Aggiorno dati Fogli"); DatiFogli(); SplashScreen.UpdateStatus("Abilito calcolo automatico"); Workbook.Application.Calculation = Excel.XlCalculation.xlCalculationAutomatic; SplashScreen.UpdateStatus("Invio modifiche al server"); Workbook.ScreenUpdating = false; Sheet.SalvaModifiche(); DataBase.SalvaModificheDB(); if (wasProtected) Sheet.Protected = true; Workbook.ScreenUpdating = true; SplashScreen.Close(); CancellaTabelle(); } catch { Workbook.ScreenUpdating = true; SplashScreen.Close(); CancellaTabelle(); return false; } return true; } else { System.Windows.Forms.MessageBox.Show("Impossibile aggiornare i dati: ci sono problemi di connessione o la funzione Forza Emergenza è attiva.", Simboli.NomeApplicazione + " - ERRORE!!!", System.Windows.Forms.MessageBoxButtons.OK, System.Windows.Forms.MessageBoxIcon.Error); return false; } }
/// <summary> /// Inizializza il foglio dopo l'apertura. Restituisce false se il foglio è in emergenza, true se la condizione è normale. /// </summary> /// <returns>Restituisce false se il foglio è in emergenza, true se la condizione è normale.</returns> private static bool Initialize() { if (DataBase.OpenConnection()) { InitUtente(); //forzo aggiornamento dei parametri del DB che altrimenti sono sicronizzati con quelli del workbook DataBase.IdApplicazione = Workbook.IdApplicazione; DataBase.DataAttiva = Workbook.DataAttiva; DataBase.IdUtente = Workbook.IdUtente; //Se non ci sono tabelle, inizializzo il repository allo stato attuale if (Workbook.Repository.TablesCount == 0) { SplashScreen.Show(); Workbook.Repository.Aggiorna(); DaAggiornare = true; } Workbook.AggiornaParametriApplicazione(false); if (Workbook.Repository.Applicazione != null) { Simboli.rgbSfondo = Workbook.GetRGBFromString(Workbook.Repository.Applicazione["BackColorApp"].ToString()); Simboli.rgbTitolo = Workbook.GetRGBFromString(Workbook.Repository.Applicazione["BackColorFrameApp"].ToString()); Simboli.rgbLinee = Workbook.GetRGBFromString(Workbook.Repository.Applicazione["BorderColorApp"].ToString()); } InitLog(); return(false); } else //Emergenza { if (Repository.TablesCount == 0) { System.Windows.Forms.MessageBox.Show("Il foglio non è inizializzato e non c'è connessione ad DB... Impossibile procedere! L'applicazione verrà chiusa.", "ERRORE!!!", System.Windows.Forms.MessageBoxButtons.OK, System.Windows.Forms.MessageBoxIcon.Error); _wb.Base.Close(); return(false); } DataBase.DataAttiva = Workbook.DataAttiva; Simboli.NomeApplicazione = Workbook.Repository.Applicazione["DesApplicazione"].ToString(); Struct.intervalloGiorni = Workbook.Repository.Applicazione["IntervalloGiorniEntita"] is DBNull ? 0 : (int)Workbook.Repository.Applicazione["IntervalloGiorniEntita"]; Struct.visualizzaRiepilogo = Workbook.Repository.Applicazione["VisRiepilogo"] is DBNull ? true : Workbook.Repository.Applicazione["VisRiepilogo"].Equals("1"); return(true); } }
/// <summary> /// Launcher dell'aggiornamento in emergenza. /// </summary> public override void Emergenza() { SplashScreen.Show(); bool wasProtected = Sheet.Protected; if (wasProtected) Sheet.Protected = false; Workbook.ScreenUpdating = false; SplashScreen.UpdateStatus("Riepilogo in emergenza"); EmergenzaRiepilogo(); SplashScreen.UpdateStatus("Aggiorno le date"); EmergenzaFogli(); if (wasProtected) Sheet.Protected = true; Workbook.ScreenUpdating = true; SplashScreen.Close(); }
/// <summary> /// Launcher dell'aggiornamento della struttura. /// </summary> /// <returns>True se l'aggiornamento è andato a buon fine.</returns> public override bool Struttura(bool avoidRepositoryUpdate) { if (DataBase.OpenConnection() || avoidRepositoryUpdate) { SetMercatoAttivo(); //aggiorno i parametri di base dell'applicazione Workbook.AggiornaParametriApplicazione(avoidRepositoryUpdate); SplashScreen.Show(); bool wasProtected = Sheet.Protected; if (wasProtected) Sheet.Protected = false; Workbook.ScreenUpdating = false; if (!avoidRepositoryUpdate) { SplashScreen.UpdateStatus("Carico struttura dal DB"); Workbook.Repository.Aggiorna(); } else { //resetto la struttura nomi che verrà ricreata nelle prossime righe Workbook.Repository.InitStrutturaNomi(); } SplashScreen.UpdateStatus("Controllo se tutti i fogli sono presenti"); DataView categorie = Workbook.Repository[DataBase.TAB.CATEGORIA].DefaultView; categorie.RowFilter = "Operativa = 1 AND IdApplicazione = " + Workbook.IdApplicazione; //cancello i fogli che non ci sono più come categorie if (Workbook.CategorySheets != null) { foreach (Excel.Worksheet categorySheet in Workbook.CategorySheets) { if ((from DataRowView r in categorie where r["DesCategoria"].Equals(categorySheet.Name) select r).Count() == 0) { bool isactive = Workbook.Application.DisplayAlerts; try { if(isactive) Workbook.Application.DisplayAlerts = false; Workbook.Sheets[categorySheet.Name].Delete(); if(isactive) Workbook.Application.DisplayAlerts = true; } catch { if (isactive) Workbook.Application.DisplayAlerts = true; } } } } //creo fogli che si sono aggiunti alle categorie foreach (DataRowView categoria in categorie) { Excel._Worksheet ws; try { ws = Workbook.Sheets[categoria["DesCategoria"].ToString()]; ws.Activate(); if(_freezePanes.ContainsKey(ws.Name)) _freezePanes[ws.Name] = Tuple.Create<int,int>(Workbook.Application.ActiveWindow.SplitRow + 1, Workbook.Application.ActiveWindow.SplitColumn + 1); else _freezePanes.Add(ws.Name, Tuple.Create<int,int>(Workbook.Application.ActiveWindow.SplitRow + 1, Workbook.Application.ActiveWindow.SplitColumn + 1)); } catch { ws = (Excel.Worksheet)Workbook.Sheets.Add(Workbook.Log); ws.Name = categoria["DesCategoria"].ToString(); ws.Select(); Workbook.Application.Windows[1].DisplayGridlines = false; #if !DEBUG Workbook.Application.ActiveWindow.DisplayHeadings = false; #endif } } Workbook.ScreenUpdating = false; try { if(DataBase.OpenConnection()) CaricaDatiDalDB(); Workbook.Application.Calculation = Excel.XlCalculation.xlCalculationManual; SplashScreen.UpdateStatus("Aggiorno struttura Riepilogo"); StrutturaRiepilogo(); SplashScreen.UpdateStatus("Aggiorno struttura Fogli"); StrutturaFogli(); SplashScreen.UpdateStatus("Abilito calcolo automatico"); Workbook.Application.Calculation = Excel.XlCalculation.xlCalculationAutomatic; SplashScreen.UpdateStatus("Invio modifiche al server"); Workbook.ScreenUpdating = false; Sheet.SalvaModifiche(); DataBase.SalvaModificheDB(); SplashScreen.UpdateStatus("Azzero selezioni"); foreach (Excel._Worksheet ws in Workbook.Sheets) { if (ws.Visible == Excel.XlSheetVisibility.xlSheetVisible) { ws.Activate(); ws.Range["A1"].Select(); } } Workbook.Main.Select(); Workbook.Application.WindowState = Excel.XlWindowState.xlMaximized; if (wasProtected) Sheet.Protected = true; SplashScreen.Close(); CancellaTabelle(); return true; } catch { SplashScreen.Close(); CancellaTabelle(); return false; } } else { System.Windows.Forms.MessageBox.Show("Impossibile aggiornare la struttura: ci sono problemi di connessione o la funzione Forza Emergenza è attiva.", Simboli.NomeApplicazione + " - ERRORE!!!", System.Windows.Forms.MessageBoxButtons.OK, System.Windows.Forms.MessageBoxIcon.Error); return false; } }