protected override void Execute(string itemClicked, AutomazioneParameters parameters, IList<PersonaContattoDTO> personeSelezionate) { var document = new BilancioAnnuale(_dataSource, _condominio, _esercizio, _parameters, _impostazioneReportDTO, _reportKey); switch (itemClicked) { case "PDF": var fileName = string.Format(@"{0}\{1} - {2}.pdf", parameters.SelectedPath, _condominio.Codice, Conversione.ToFileName(_condominio.Descrizione)); try { document.ExportToPdf(fileName); } catch (IOException ex) { fileName = string.Format(@"{0}\{1} - {2}_{3}.pdf", parameters.SelectedPath, _condominio.Codice, Conversione.ToFileName(_condominio.Descrizione), Guid.NewGuid()); document.ExportToPdf(fileName); throw; } 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 = string.Format("RipartoConsuntivo_{0}", 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 AnteprimaReportBilancio(IList<ReportBilancioDTO> dataSource, CondominioDTO condominio, EsercizioDTO esercizio, BilancioConsuntivoReportParameters parameters, ImpostazioneReportDTO impostazioneReportDTO, string reportKey) { InitializeComponent(); _dataSource = dataSource; _condominio = condominio; _esercizio = esercizio; _parameters = parameters; _impostazioneReportDTO = impostazioneReportDTO; _reportKey = reportKey; Text = $"Bilancio {_impostazioneReportDTO.Descrizione}"; try { var document = new BilancioAnnuale(dataSource, _condominio, _esercizio, _parameters, _impostazioneReportDTO, _reportKey); SetDataSource(document.GetReport(), _impostazioneReportDTO); } catch (Exception ex) { _log.ErrorFormat("Errore nell'apertura della maschera di anteprima per bilacio annuale - {0} - condominio:{1} - azienda:{2}", ex, Utility.GetMethodDescription(), _condominio != null ? _condominio.ID.ToString() : "<NULL>", Login.Instance.CurrentLogin().Azienda); throw; } }