using System;
using Consulenza.ReportWriter.Business;
using Consulenza.ReportWriter.Business.OBJ_PDF;
using Consulenza.ReportWriter.Business.Entity;
using System.Collections.Generic;
using System.Data;
using Consulenza.ReportCommon;
using System.Linq;
namespace Consulenza.ReportWriter.Manager.Section.Unica
{
///
/// S36.PatrimonioAltriIstitutiProdottiNonRappresentabili idSezione = 79
///
public class S36 : Entity.Section
{
public S36(EnvironmentFacade environmentFacade, int idSection)
: base(environmentFacade, idSection)
{
try
{
Draw();
}
catch (Exception ex)
{
SectionLogger.Write("S36", ex.Message, SectionLoggerMessageLevel.E, EnvironmentFacade.ReportEnvironment);
}
}
//protected override sealed void OLD_Draw()
//{
// var dati = GetDataSet();
// if (dati.Tables["prodotti"].Rows.Count > 0)
// {
// AddElement(new SpacePDF(20));
// AddElement(new FormattedTextAreaPDF(getTesto(), EnvironmentFacade.RendererFacade.XLeftLimit) { FontSize = 7, TextHorizontalAlign = ceTe.DynamicPDF.TextAlign.Justify });
// AddElement(new SpacePDF(15));
// #region Tabella dei prodotti non rappresentabili
// var tabella = new TablePDF(EnvironmentFacade.RendererFacade.XLeftLimit, dati.Tables["prodotti"], dati.Tables["prodottiFooter"])
// {
// Style = Style.ConsulenzaUnica,
// AlternateRow = false,
// HeaderHeight = 30
// };
// //tabella.Columns.Add(new ColumnPDF("Datasottoscrizione", 90, HorizontalAlignmentType.Sinistra, false, false,7, ColumnType.Testo, "Datasottoscrizione", "Data
sottoscrizione") { HeaderFontSize = 7 });
// tabella.Columns.Add(new ColumnPDF("Intermediario", 120+90, HorizontalAlignmentType.Sinistra, false, false, 7, ColumnType.Testo, "Intermediario", "Intermediario") { HeaderFontSize =7 });
// tabella.Columns.Add(new ColumnPDF("Prodotto", 160, HorizontalAlignmentType.Sinistra, false, false, 7, ColumnType.Testo, "Prodotto", "Descrizione") { HeaderFontSize = 7 });
// tabella.FooterColumns.Add(new ColumnPDF("Totale", 370, HorizontalAlignmentType.Sinistra, true, true, 7, ColumnType.Testo));
// tabella.Columns.Add(new ColumnPDF("Controvalore", 90, HorizontalAlignmentType.Destra, false, false,7, ColumnType.Decimale, "Controvalore", "Controvalore (€)") { HeaderFontSize = 7 });
// tabella.FooterColumns.Add(new ColumnPDF("Controvalore", 90, HorizontalAlignmentType.Destra, true, true, 7, ColumnType.Decimale));
// tabella.Columns.Add(new ColumnPDF("VaR", 60, HorizontalAlignmentType.Destra, false, false,7, ColumnType.Testo, "VaR", "VaR (%)") { HeaderFontSize = 7 });
// tabella.FooterColumns.Add(new ColumnPDF("vuoto", 60, HorizontalAlignmentType.Destra, true, true, 7, ColumnType.Testo));
// AddElement(tabella);
// #endregion
// }
//}
protected override sealed void Draw()
{
var dati = GetDataSet();
if (dati.Tables["prodotti"].Rows.Count > 0)
{
AddElement(new SpacePDF(20));
AddElement(new FormattedTextAreaPDF(getTesto(), EnvironmentFacade.RendererFacade.XLeftLimit) { FontSize = 7, TextHorizontalAlign = ceTe.DynamicPDF.TextAlign.Justify });
AddElement(new SpacePDF(15));
#region Tabella dei prodotti non rappresentabili
var tabella = new TablePDF(EnvironmentFacade.RendererFacade.XLeftLimit, dati.Tables["prodotti"], dati.Tables["prodottiFooter"])
{
Style = Style.ConsulenzaUnica,
AlternateRow = false,
HeaderHeight = 30
};
//tabella.Columns.Add(new ColumnPDF("Datasottoscrizione", 90, HorizontalAlignmentType.Sinistra, false, false,7, ColumnType.Testo, "Datasottoscrizione", "Data
sottoscrizione") { HeaderFontSize = 7 });
tabella.Columns.Add(new ColumnPDF("Intermediario", 120 + 90, HorizontalAlignmentType.Sinistra, false, false, 7, ColumnType.Testo, "Intermediario", "Intermediario") { HeaderFontSize = 7 });
tabella.Columns.Add(new ColumnPDF("Prodotto", 160, HorizontalAlignmentType.Sinistra, false, false, 7, ColumnType.Testo, "Prodotto", "Descrizione") { HeaderFontSize = 7 });
tabella.FooterColumns.Add(new ColumnPDF("Totale", 370, HorizontalAlignmentType.Sinistra, true, true, 7, ColumnType.Testo));
tabella.Columns.Add(new ColumnPDF("Controvalore", 90, HorizontalAlignmentType.Destra, false, false, 7, ColumnType.Decimale, "Controvalore", "Controvalore (€)") { HeaderFontSize = 7 });
tabella.FooterColumns.Add(new ColumnPDF("Controvalore", 90, HorizontalAlignmentType.Destra, true, true, 7, ColumnType.Decimale));
tabella.Columns.Add(new ColumnPDF("VaR", 60, HorizontalAlignmentType.Destra, false, false, 7, ColumnType.Testo, "VaR", "VaR (%)") { HeaderFontSize = 7 });
tabella.FooterColumns.Add(new ColumnPDF("vuoto", 60, HorizontalAlignmentType.Destra, true, true, 7, ColumnType.Testo));
AddElement(tabella);
#endregion
#region Modifiche 20190628 per Evolutiva
string sVerticalText;
if (EnvironmentFacade.ReportEnvironment.ReportType.Equals(ReportType.Unica_Nucleo))
{
sVerticalText = "";
}
else
{
sVerticalText = "Le eventuali informazioni riguardanti investimenti da lei detenuti presso altri intermediari vengono elaborate secondo le indicazioni da lei ";
if (EnvironmentFacade.ReportEnvironment.PrivateBanker.CodiceRete.Equals("F"))
{
sVerticalText = sVerticalText + "fornite e/ o disponibili sul mercato, per le quali Fideuram non garantisce la completezza e la veridicità. ";
sVerticalText = sVerticalText + "La preghiamo di comunicare a Fideuram ogni successiva variazione a tali informazioni, al fine di consentire a Fideuram la correzione e l’aggiornamento dei dati contenuti ";
sVerticalText = sVerticalText + "nel presente report.Gli investimenti detenuti presso altri intermediari vengono utilizzati da Fideuram con finalità meramente informative e secondo le indicazioni da lei fornite, ";
sVerticalText = sVerticalText + "in modo da offrire una rappresentazione unitaria degli investimenti, senza con ciò formare oggetto di raccomandazioni personalizzate o di rendicontazione ufficiale.";
}
else
{
sVerticalText = sVerticalText + "fornite e/ o disponibili sul mercato, per le quali Sanpaolo Invest SIM non garantisce la completezza e la veridicità. ";
sVerticalText = sVerticalText + "La preghiamo di comunicare a Sanpaolo Invest SIM ogni successiva variazione a tali informazioni, al fine di consentire a Sanpaolo Invest SIM la correzione e l’aggiornamento dei dati contenuti ";
sVerticalText = sVerticalText + "nel presente report.Gli investimenti detenuti presso altri intermediari vengono utilizzati da Sanpaolo Invest SIM con finalità meramente informative e secondo le indicazioni da lei fornite, ";
sVerticalText = sVerticalText + "in modo da offrire una rappresentazione unitaria degli investimenti, senza con ciò formare oggetto di raccomandazioni personalizzate o di rendicontazione ufficiale.";
}
}
FormattedTextAreaPDF testoPaginaVerticale = null;
testoPaginaVerticale = new FormattedTextAreaPDF(sVerticalText, EnvironmentFacade.RendererFacade.XLeftLimit - 35, 620)
{
TextHorizontalAlign = ceTe.DynamicPDF.TextAlign.Justify,
FontSize = 5,
TextVerticalDirection = true,
Y = 745
};
var listaOggettiDaRipetere = new List { testoPaginaVerticale };
AddElement(listaOggettiDaRipetere);
AddElement(new RepeaterPDF(listaOggettiDaRipetere));
#endregion
}
}
///
/// Recupera i dati necessari alla Section restituendo un DataTable.
///
///
protected sealed override DataTable GetDataTable()
{
return null;
}
///
/// Recupera i dati necessari alla Section restituendo un DataSet.
///
///
protected sealed override DataSet GetDataSet()
{
var ds = new DataSet();
ds.Tables.Add(new DataTable("prodotti"));
ds.Tables.Add(new DataTable("prodottiFooter"));
var patrimonioTerzi = datiSeiUnico.patrimonioUnit().patrimonioTerzi; //new DataServices.PatrimonioTerzi(chiaveClientePb);
var prodottiNonRappresentabiliPerAsset = patrimonioTerzi.assetClass.distribuzionePerProdotti.listaProdotti.Where(o => o.rappresentabile == false).ToList();
#region Prodotti
//ds.Tables["prodotti"].Columns.Add(new DataColumn("Datasottoscrizione", typeof(string)));
ds.Tables["prodotti"].Columns.Add(new DataColumn("Intermediario", typeof(string)));
ds.Tables["prodotti"].Columns.Add(new DataColumn("Prodotto", typeof(string)));
ds.Tables["prodotti"].Columns.Add(new DataColumn("Controvalore", typeof(decimal)));
ds.Tables["prodotti"].Columns.Add(new DataColumn("VaR", typeof(string)));
foreach (var item in prodottiNonRappresentabiliPerAsset)
{
var itemPosizione = patrimonioTerzi.dettaglioProdotti.dettaglioProdotti.FirstOrDefault(o => o.chiaveProdottoTerzi.Equals(item.chiaveAggregazione));
ds.Tables["prodotti"].Rows.Add(
//itemPosizione.dtSottoscrizione.ToShortDateString(), //Datasottoscrizione //TODO
itemPosizione.nomeIntermediario, //Intermediario
itemPosizione.prodotto.nomeProdotto, //Prodotto
itemPosizione.ctv, //Controvalore
itemPosizione.prodotto.varDecodificato); //VaR
}
#endregion
#region Totale prodotti
ds.Tables["prodottiFooter"].Columns.Add(new DataColumn("Totale", typeof(string)));
ds.Tables["prodottiFooter"].Columns.Add(new DataColumn("Controvalore", typeof(decimal)));
ds.Tables["prodottiFooter"].Columns.Add(new DataColumn("vuoto", typeof(string)));
if (ds.Tables["prodotti"].Rows.Count != 0)
{
ds.Tables["prodottiFooter"].Rows.Add(
"Totale prodotti non rappresentabili",
Helper.FormatCurrency(patrimonioTerzi.assetClass.distribuzione.totaleNonRappr.ToString()),
""//"n.c." // TODO;
);
}
#endregion
return ds;
}
public virtual string getTesto()
{
return "Nella tabella sottostante sono riportati i prodotti che lei detiene presso altri Istituti, che non è stato possibile rappresentare in termini di asset allocation.";
}
}
}