/// <summary> /// Carica tutti i valori dal DB. /// </summary> protected void CaricaDatiDalDB() { Workbook.Repository.CaricaParametri(); CancellaTabelle(); DataTable entitaProprieta = Workbook.Repository[DataBase.TAB.ENTITA_PROPRIETA]; DateTime dataFine = Workbook.DataAttiva.AddDays(Math.Max( (from r in entitaProprieta.AsEnumerable() where r["IdApplicazione"].Equals(Workbook.IdApplicazione) && r["SiglaProprieta"].ToString().EndsWith("GIORNI_STRUTTURA") select int.Parse(r["Valore"].ToString())).DefaultIfEmpty().Max(), Struct.intervalloGiorni)); SplashScreen.UpdateStatus("Carico informazioni dal DB"); DataTable datiApplicazione = DataBase.Select(DataBase.SP.APPLICAZIONE_INFORMAZIONE, "@SiglaCategoria=ALL;@SiglaEntita=ALL;@DateFrom=" + Workbook.DataAttiva.ToString("yyyyMMdd") + ";@DateTo=" + dataFine.ToString("yyyyMMdd")) ?? new DataTable(); datiApplicazione.TableName = DataBase.TAB.DATI_APPLICAZIONE; Workbook.Repository.Add(datiApplicazione); SplashScreen.UpdateStatus("Carico commenti dal DB"); DataTable insertManuali = DataBase.Select(DataBase.SP.APPLICAZIONE_INFORMAZIONE_COMMENTO, "@SiglaCategoria=ALL;@SiglaEntita=ALL;@DateFrom=" + Workbook.DataAttiva.ToString("yyyyMMdd") + ";@DateTo=" + dataFine.ToString("yyyyMMdd")) ?? new DataTable(); insertManuali.TableName = DataBase.TAB.DATI_APPLICAZIONE_COMMENTO; Workbook.Repository.Add(insertManuali); SplashScreen.UpdateStatus("Carico informazioni giornaliere dal DB"); //TODO se dati giornalieri ancora presenti riabilitare //DataTable datiApplicazioneD = DataBase.Select(DataBase.SP.APPLICAZIONE_INFORMAZIONE_D, "@SiglaCategoria=ALL;@SiglaEntita=ALL;@DateFrom=" + Workbook.DataAttiva.ToString("yyyyMMdd") + ";@DateTo=" + Workbook.DataAttiva.AddDays(Struct.intervalloGiorni).ToString("yyyyMMdd")) ?? new DataTable(); //datiApplicazioneD.TableName = DataBase.TAB.DATI_APPLICAZIONE_D; //Workbook.Repository.Add(datiApplicazioneD); }
/// <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; } }
public void Aggiorna() { SplashScreen.UpdateStatus("Aggiornamento repository interno"); //_isMultiApplication = appIDs != null; //_appIDs = appIDs; InitStrutturaNomi(); //CaricaApplicazioni(); CaricaApplicazione(_wb.IdApplicazione); CaricaMercati(); //decido se è necessario caricare più applicazioni o solo una _isMultiApplication = this[DataBase.TAB.MERCATI].AsEnumerable() .Select(r => (int)r["IdApplicazioneMercato"]) .Contains(Workbook.IdApplicazione); _appIDs = this[DataBase.TAB.MERCATI].AsEnumerable() .Select(r => (int)r["IdApplicazioneMercato"]) .ToArray(); CaricaAzioni(); CaricaCategorie(); CaricaAzioneCategoria(); CaricaCategoriaEntita(); CaricaEntitaAzione(); CaricaEntitaAzioneCalcolo(); CaricaEntitaInformazione(); CaricaEntitaAzioneInformazione(); CaricaCalcolo(); CaricaCalcoloInformazione(); //CaricaEntitaCalcolo(); CaricaEntitaGrafico(); CaricaEntitaGraficoInformazione(); CaricaEntitaCommitment(); CaricaEntitaRampa(); CaricaEntitaAssetto(); CaricaEntitaProprieta(); CaricaEntitaInformazioneFormattazione(); CaricaParametri(); CaricaStagioni(); CaricaDefinzioneOfferteMI(); //_wb.RepositoryDataSet.AcceptChanges(); }
/// <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; } }
/// <summary> /// Inizializza i valori di default e imposta tutte le informazioni che devono essere "trascinate" dai giorni precedenti /// </summary> public static void ExecuteSPApplicazioneInit(DateTime giorno) { SplashScreen.UpdateStatus("Inizializzazione valori di default"); Select(SP.APPLICAZIONE_INIT, "@Data=" + giorno.ToString("yyyyMMdd")); }