using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using System.Collections; using ceTe.DynamicPDF; using ceTe.DynamicPDF.Text; using PDFGenerator.Presentation.Section.Tables; using PDFGenerator.BusinessLayer.DataSection; using PDFGenerator.BusinessLayer; using System.Threading; using System.Globalization; using System.Collections.Generic; using Dundas.Charting.WebControl; using ContrattoSei.Utilities; namespace PDFGenerator.Presentation.Section { class S147 : ISezione { private static NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger(); public S147() { } private string _testointroduttivo; private string _testointroduttivoAlternativo; /// /// Testo introduttivo della sezione /// public string TestoIntroduttivo { get { return _testointroduttivo; } set { _testointroduttivo = value; } } /// /// Testo introduttivo della sezione /// public string TestoIntroduttivoAlternativo { get { return _testointroduttivoAlternativo; } set { _testointroduttivoAlternativo = value; } } public void writeSezione(DataThread dataThread) { DocumentPDF document = dataThread.DocumentPDF; //DataSectionParameter dataSectionParameter = paramSez.getParam(); FormatNum conv = new FormatNum(); DatiTabella datitab = new DatiTabella(); DataSetS147 set = (DataSetS147)dataThread.Data.DatiSezione; ceTe.DynamicPDF.Merger.ImportedPage page = document.getCurrentPage(); double copertura = Convert.ToDouble(set.PesiValuteTotali.Rows[0]["Copertura"]) * 100; //document.setHeaderSpace(40); int hCellTab = 23;//30--25 int sFont = 8; int hBottRett = 18;//22 int wBottRett = 258;//254 int hBott = 10;//10 int wBott = 40;//40 document.setSezTitolo(dataThread.SezioneReport.Titolo.Replace("/$Banca$/", dataThread.NomeRete)); document.setChapterHeader(dataThread.SezioneReport.TestoIntroduttivo.Replace("/$Banca$/", dataThread.NomeRete), 0, 520, 8); #region Tabella a destra della piramide // disegno la tabella a destra della piramide. #region datasource tabella //setta la datatable datitab.table = set.PesiValuteTotali; #endregion Tabella tabella = new Tabella(); tabella.LineeTabella = false; tabella.Y = document.getLastPos(); tabella.X = document.getMargineLeft(); tabella.Header = true; tabella.SaltoPagina = false; tabella.AltezzaCella = hCellTab;// 30; tabella.Datasource = datitab.table; datitab.setHeaderDim(hCellTab); datitab.setHeaderFont(sFont); tabella.Colonne.Add(new Colonna("Pallino", "Valuta", 40, TipoAllineamento.SINISTRA, false, sFont, false, TipoColonna.IMMAGINE_E_TESTO)); tabella.Colonne.Add(new Colonna("Bandiera", "", 30, TipoAllineamento.SINISTRA, false, sFont, false, TipoColonna.IMMAGINE_E_TESTO)); tabella.Colonne.Add(new Colonna("Valuta", "", 100, TipoAllineamento.SINISTRA, false, sFont, false)); tabella.Colonne.Add(new Colonna("Peso", "Peso %" + (copertura <100 ? " *" : ""), 80, TipoAllineamento.DESTRA, false, sFont, false)); tabella.Draw(datitab, document); #region Pallini Valute e Bandierine float xLabelCtv = document.getMargineLeft(); float yLabelCtv = document.getLastPos() + 40; Dictionary colori = this.getColorCurrencies(); System.Drawing.Color colore; string pathImage = @UtilityManager.getAppSetting("pathGraf") + @"\Flags\"; int numSimboli = 21; //float yPallino = 0; float yPallino = tabella.Y + 7 + numSimboli; foreach (DataRow drSimbolo in set.PesiValuteTotali.Rows) { try { if (drSimbolo["VALUTA"].ToString().ToUpper() == "EUR") { colore = colori[drSimbolo["VALUTA"].ToString().ToUpper()]; } else { colore = colori["ALTRE"]; } } catch (Exception e) { logger.Error(String.Concat("colori", e.Message, dataThread.CodiceFiscale, dataThread.Rete)); colore = colori["ALTRE"]; } RgbColor theColor = new RgbColor(colore.R, colore.G, colore.B); ceTe.DynamicPDF.PageElements.Circle simboloAI = new ceTe.DynamicPDF.PageElements.Circle(document.getMargineLeft() + 2, yPallino - 5, 8 / 1.414F, theColor, theColor); page.Elements.Add(simboloAI); try { page.Elements.Add(new ceTe.DynamicPDF.PageElements.Image(pathImage + drSimbolo["VALUTA"].ToString().ToUpper() + ".png", document.getMargineLeft() + 25, yPallino - 10, 0.41F)); } catch (Exception e) { logger.Error(String.Concat(e.Message, "1", dataThread.CodiceFiscale, dataThread.Rete)); } yPallino += hCellTab; } #endregion #endregion tabella a destra della piramide if (copertura< 100) page.Elements.Add(new ceTe.DynamicPDF.PageElements.Label("(*) Grado di copertura: " + conv.ConvertNum(copertura) + "%", document.getMargineLeft(), yPallino, 180, 10, Globals.OpenTypeFontVerdana, 7)); document.setLastPos(0); #region Grafico a Farfalla #region Recupero i valori da assegnare alle serie del grafico List listaValoriPesoNegativo = new List(); List listaValoriPesoPositivo = new List(); bool presenzaValoriNegativi = false; foreach (DataRow row in set.PesiValuteNegative.Rows) { IValoriSerie IvaloriSeriePesoNegativo = new IValoriSerie(); IvaloriSeriePesoNegativo.chiave = row["VALUTA"].ToString(); IvaloriSeriePesoNegativo.valore = Convert.ToDecimal(row["Peso"]); if (IvaloriSeriePesoNegativo.valore > 0) presenzaValoriNegativi = true; System.Drawing.Color c = colori["ALTRE"]; try { if (IvaloriSeriePesoNegativo.chiave == "EUR") { c = colori[IvaloriSeriePesoNegativo.chiave]; } //else //{ // colore = colori["ALTRE"]; //} //c = colori[IvaloriSeriePesoNegativo.chiave]; } catch (Exception e) { logger.Error(String.Concat(e.Message, " ", IvaloriSeriePesoNegativo.chiave)); } IvaloriSeriePesoNegativo.colore = c;//System.Drawing.Color.FromArgb(Convert.ToInt32(row["Red"]), Convert.ToInt32(row["Green"]), Convert.ToInt32(row["Blue"])); listaValoriPesoNegativo.Add(IvaloriSeriePesoNegativo); } double maxValue = 0; foreach (DataRow row in set.PesiValutePositive.Rows) { IValoriSerie IvaloriSeriePesoPositivo = new IValoriSerie(); IvaloriSeriePesoPositivo.chiave = row["VALUTA"].ToString(); IvaloriSeriePesoPositivo.valore = Convert.ToDecimal(row["Peso"]); if (Convert.ToDouble(IvaloriSeriePesoPositivo.valore) > maxValue) maxValue = Convert.ToDouble(IvaloriSeriePesoPositivo.valore); System.Drawing.Color c = colori["ALTRE"]; try { //c = colori[IvaloriSeriePesoPositivo.chiave]; if (IvaloriSeriePesoPositivo.chiave == "EUR") { c = colori[IvaloriSeriePesoPositivo.chiave]; } } catch (Exception e) { logger.Error(String.Concat(e.Message, " ", IvaloriSeriePesoPositivo.chiave, dataThread.CodiceFiscale, dataThread.Rete)); } IvaloriSeriePesoPositivo.colore = c;//System.Drawing.Color.FromArgb(Convert.ToInt32(row["Red"]), Convert.ToInt32(row["Green"]), Convert.ToInt32(row["Blue"])); listaValoriPesoPositivo.Add(IvaloriSeriePesoPositivo); } #endregion //double altezzaGraficoPesoRischio_Prodotto = 31 * (tabella.Datasource.Rows.Count + 0.5); double altezzaGraficoPesoRischio_Prodotto = 24 * (tabella.Datasource.Rows.Count + 0.5); //double altezzaGraficoPesoRischio_Prodotto = 180; double larghezzaGrafico = 500; if (presenzaValoriNegativi) larghezzaGrafico = 250; IstoFarfallaS110 graficoPesoRischio_Prodotto = graficoPesoRischio_Prodotto = new IstoFarfallaS110(larghezzaGrafico, altezzaGraficoPesoRischio_Prodotto); graficoPesoRischio_Prodotto.DocumentPDF = document; graficoPesoRischio_Prodotto.PositionX = 290; graficoPesoRischio_Prodotto.PositionY = Convert.ToInt32(tabella.Y + 15);//17 //graficoPesoRischio_Prodotto.AxisY_LineColor = false; graficoPesoRischio_Prodotto.AxisY_Hide = false; graficoPesoRischio_Prodotto.AxysX_Increment = Convert.ToDecimal(0.5); SerieIstoFarfallaS110 seriePesoNegativo = new SerieIstoFarfallaS110(); if (presenzaValoriNegativi) { seriePesoNegativo.Name = "PesoNegativo"; seriePesoNegativo.Values = listaValoriPesoNegativo; seriePesoNegativo.ElementPosition = new Dundas.Charting.WebControl.ElementPosition(1F, -2F, 50.7F, 105F); seriePesoNegativo.ReverseAxisY = true; seriePesoNegativo.ShowLabelAsValue = false; seriePesoNegativo.AxisY_MaximumValue = 100; seriePesoNegativo.Axisy_Interval = 20; } SerieIstoFarfallaS110 seriePesoPositivo = new SerieIstoFarfallaS110(); seriePesoPositivo.Name = "PesoPositivo"; seriePesoPositivo.Values = listaValoriPesoPositivo; if (presenzaValoriNegativi) seriePesoPositivo.ElementPosition = new Dundas.Charting.WebControl.ElementPosition(49.3F, -2, 50.7F, 105F); else seriePesoPositivo.ElementPosition = new Dundas.Charting.WebControl.ElementPosition(1F, -2, 50.7F, 105F); seriePesoPositivo.Axisy_Interval = 20; seriePesoPositivo.AxisY_MaximumValue = 100; // maxValue + 10 > 100 ? maxValue : maxValue + 10; seriePesoPositivo.ShowLabelAsValue = false; if (presenzaValoriNegativi) graficoPesoRischio_Prodotto.SerieList.Add(seriePesoNegativo); graficoPesoRischio_Prodotto.SerieList.Add(seriePesoPositivo); // Disegno il grafico graficoPesoRischio_Prodotto.Draw(); //rettangolo giusto page.Elements.Add(new ceTe.DynamicPDF.PageElements.Rectangle(290.5F, (float)(tabella.Y + altezzaGraficoPesoRischio_Prodotto), wBottRett, hBottRett, RgbColor.LightGrey, RgbColor.LightGrey)); float passo = 23.5F; //label negative if (presenzaValoriNegativi) for (int i = -1; i >= -5; --i) page.Elements.Add(new ceTe.DynamicPDF.PageElements.Label((seriePesoNegativo.Axisy_Interval * i).ToString(), 407.5F + (passo * i), (float)(tabella.Y + altezzaGraficoPesoRischio_Prodotto), wBott, hBott, Globals.OpenTypeFontVerdana, sFont, ceTe.DynamicPDF.TextAlign.Left, ceTe.DynamicPDF.RgbColor.Black)); if (presenzaValoriNegativi) page.Elements.Add(new ceTe.DynamicPDF.PageElements.Label("0", 414.5F, (float)(tabella.Y + altezzaGraficoPesoRischio_Prodotto), wBott, hBott, Globals.OpenTypeFontVerdana, sFont, ceTe.DynamicPDF.TextAlign.Left, ceTe.DynamicPDF.RgbColor.Black)); else { page.Elements.Add(new ceTe.DynamicPDF.PageElements.Label("0", 294.5F, (float)(tabella.Y + altezzaGraficoPesoRischio_Prodotto), wBott, hBott, Globals.OpenTypeFontVerdana, sFont, ceTe.DynamicPDF.TextAlign.Left, ceTe.DynamicPDF.RgbColor.Black)); passo *= 2; } //label positive for (int i = 1; i <= 5; ++i) if (presenzaValoriNegativi) page.Elements.Add(new ceTe.DynamicPDF.PageElements.Label((seriePesoPositivo.Axisy_Interval * i).ToString(), 414.5F + (passo * i), (float)(tabella.Y + altezzaGraficoPesoRischio_Prodotto),wBott , hBott, Globals.OpenTypeFontVerdana, sFont, ceTe.DynamicPDF.TextAlign.Left, ceTe.DynamicPDF.RgbColor.Black)); else page.Elements.Add(new ceTe.DynamicPDF.PageElements.Label((seriePesoPositivo.Axisy_Interval * i).ToString(), 294.5F + (passo * i), (float)(tabella.Y + altezzaGraficoPesoRischio_Prodotto), wBott, hBott, Globals.OpenTypeFontVerdana, sFont, ceTe.DynamicPDF.TextAlign.Left, ceTe.DynamicPDF.RgbColor.Black)); #endregion } private Dictionary getColorCurrencies() { Dictionary colori = new Dictionary(); colori.Add("EUR", System.Drawing.Color.FromArgb(217, 81, 33)); //colori.Add("USD", System.Drawing.Color.FromArgb(82, 135, 197)); //colori.Add("CHF", System.Drawing.Color.FromArgb(255, 200, 0)); //colori.Add("GBP", System.Drawing.Color.FromArgb(255, 0, 255)); //colori.Add("CNY", System.Drawing.Color.FromArgb(255, 0, 0)); //colori.Add("JPY", System.Drawing.Color.FromArgb(0, 0, 0)); colori.Add("ALTRE", System.Drawing.Color.FromArgb(131, 188, 180)); return colori; } } }