protected override void Execute(string itemClicked, AutomazioneParameters parameters, IList<PersonaContattoDTO> personeSelezionate) { var document = new RiepilogoContoEconomicoSubReport(getDataSource(), _condominio, _esercizio, _dataIniziale, _dataFinale, _impostazioneReportDTO, _reportKey); switch (itemClicked) { case "PDF": var fileName = $@"{parameters.SelectedPath}\{_condominio.Codice} - {Conversione.ToFileName(_condominio.Descrizione)}.pdf"; document.ExportToPdf(fileName); break; case "Messaggio": PersoneMessaggio = new List<PersonaMessaggioDTO>(personeSelezionate.Count); foreach (var persona in personeSelezionate) { var stream = new MemoryStream(); document.ExportToPdf(stream); var personaMessaggio = new PersonaMessaggioDTO { ID = persona.ID, NomeMessaggio = $"RiepilogoContoEconomico_{DateTime.Now.ToString("dd-mm-yyyy")}", OggettoMessaggio = parameters.OggettoMessaggio, DocumentoMessaggio = stream.ToArray(), TestoMessaggio = parameters.TestoMessaggio, TipoIndirizzo = TipoIndirizzo.Recapito, Contatti = new List<ContattoDTO>() }; var email = persona.EmailCertificata; if (string.IsNullOrEmpty(email)) email = persona.Email; personaMessaggio.Contatti.Add(new ContattoDTO { SelectColumn = true, TipoContatto = "Email", Valore = email }); personaMessaggio.Contatti.Add(new ContattoDTO { SelectColumn = true, TipoContatto = "Fax", Valore = persona.Fax }); personaMessaggio.Contatti.Add(new ContattoDTO { SelectColumn = true, TipoContatto = "Cellulare", Valore = persona.Cellulare }); PersoneMessaggio.Add(personaMessaggio); } break; } }
public AnteprimaReportRiepilogoContoEconomico(IList<ReportRiepilogoContoEconomicoDTO> dataSource, CondominioDTO condominio, EsercizioDTO esercizio, DateTime dataIniziale, DateTime dataFinale, ImpostazioneReportDTO impostazioneReportDTO, string reportKey) { InitializeComponent(); _dataSource = dataSource; _condominio = condominio; _esercizio = esercizio; _dataIniziale = dataIniziale; _dataFinale = dataFinale; _impostazioneReportDTO = impostazioneReportDTO; _reportKey = reportKey; try { var document = new RiepilogoContoEconomicoSubReport(getDataSource(), _condominio, _esercizio, dataIniziale, dataFinale, _impostazioneReportDTO, _reportKey); SetDataSource(document.GetReport(), _impostazioneReportDTO); } catch (Exception ex) { _log.ErrorFormat("Errore nell'apertura della maschera di anteprima per riepilogo conto economico - {0} - condominio:{1} - azienda:{2}", ex, Utility.GetMethodDescription(), _condominio?.ID.ToString() ?? "<NULL>", Login.Instance.CurrentLogin().Azienda); throw; } }