Funcionalidad de mardar mails hecha

This commit is contained in:
fedpo
2024-12-03 12:25:53 +00:00
parent b2143821d2
commit 57c16542c6
6 changed files with 158 additions and 63 deletions

View File

@@ -59,6 +59,14 @@ namespace Controladora
// Utiliza la instancia singleton de InformeEmail para enviar el correo // Utiliza la instancia singleton de InformeEmail para enviar el correo
return InformeEmail.Instance.EnviarEmailFactura(titulo, detalles); return InformeEmail.Instance.EnviarEmailFactura(titulo, detalles);
} }
public string EnviarEmail(string titulo, List<Factura> facturas)
{
if (facturas == null || facturas.Count == 0)
return "La lista de facturas está vacía o es nula.";
return InformeEmail.Instance.EnviarEmailFacturas(titulo, facturas);
}
public bool Informa public bool Informa
{ {
get get

View File

@@ -20,71 +20,65 @@ namespace Informes
get { return instance; } get { return instance; }
} }
private InformeEmail()
{
}
public string EnviarEmailFactura(string titulo, List<DetalleFactura> desc) public string EnviarEmailFactura(string titulo, List<DetalleFactura> desc)
{ {
string? ret = null; string body = GenerarTablaDetalle(desc);
string json; return SendMail(titulo, body);
ConfigEmail config;
try
{ // leemos el archivo de configuracion para obtener los certificados y mails destino de los informes
json = File.ReadAllText("settings.json");
config = JsonSerializer.Deserialize<ConfigEmail>(json);
} }
catch (IOException) public string EnviarEmailFacturas(string titulo, List<Factura> facturas)
{ {
ret = "No se pudo leer el archivo \"settings.json\""; string body = GenerarTablaFacturas(facturas);
throw; return SendMail(titulo, body);
} }
foreach (var i in config.EmailTarget) private string GenerarTablaFacturas(List<Factura> facturas)
{ {
if (String.IsNullOrWhiteSpace(i)) return "Hay Emails mal cargados"; string body = @"
<style>
table, td, th {
border: 1px solid black;
} }
</style>
SmtpClient smtp = new SmtpClient(); ";
smtp.Host = "smtp.gmail.com"; foreach (var item in facturas)
smtp.Port = 587;
smtp.Credentials = new NetworkCredential(config.EmailAddr, config.EmailPass);
smtp.DeliveryMethod = SmtpDeliveryMethod.Network;
smtp.EnableSsl = true;
MailMessage mail = new MailMessage();
mail.Subject = titulo;
mail.IsBodyHtml = true;
mail.Body = GenerarTabla(desc);
mail.Sender = new MailAddress(config.EmailAddr);
foreach (var i in config.EmailTarget) mail.To.Add(i);
mail.From = new MailAddress(config.EmailAddr);
try
{ {
#if DEBUG body += $"""
Console.WriteLine($"From: {config.EmailAddr}, Title: {titulo}"); <hr>
#endif <h3>Factura del {item.Fecha}, cliente: {item.NombreCliente}</h3>
smtp.Send(mail); <table>
mail.Dispose(); <tr>
} <th>Producto</td>
catch (Exception) <th>Cantidad</td>
<th>Precio CU</td>
<th>Subtotal</td>
</tr>
""";
foreach (var i in item.Detalles)
{ {
ret = "No se pudo comunicar con el server SMTP"; body += $"""
throw; <tr>
<td>{i.Producto.Nombre}</td>
<td>{i.Cantidad}</td>
<td>{i.Producto.Precio}</td>
<td>{i.Producto.Precio * i.Cantidad}</td>
</tr>
""";
}
body += $"""
<tr>
<td>Total</td>
<td></td>
<td></td>
<td>{CalcularTotal(item.Detalles)}</td>
</tr>
</table>
""";
}
return body;
} }
//Decimos que se envio el email correctamente si el valor del retorno sigue siendo nulo en otro caso tendra la descripcion del error. private string GenerarTablaDetalle(List<DetalleFactura> desc)
return (ret == null) ?
"Se envio el Email Correctamente":
ret;
//
}
private string GenerarTabla(List<DetalleFactura> desc)
{ {
// Esta seccion es el armado del mail html // Esta seccion es el armado del mail html
string body = string body =
@@ -122,8 +116,8 @@ namespace Informes
<td></td> <td></td>
<td>{CalcularTotal(desc)}</td> <td>{CalcularTotal(desc)}</td>
</tr> </tr>
</table> </table>";
";
return body; return body;
} }
private double CalcularTotal(List<DetalleFactura> desc) private double CalcularTotal(List<DetalleFactura> desc)
@@ -136,5 +130,61 @@ namespace Informes
return total; return total;
} }
private string SendMail(string titulo, string body)
{
string? ret = null;
string json;
ConfigEmail config;
try
{ // leemos el archivo de configuracion para obtener los certificados y mails destino de los informes
json = File.ReadAllText("settings.json");
config = JsonSerializer.Deserialize<ConfigEmail>(json);
}
catch (IOException)
{
ret = "No se pudo leer el archivo \"settings.json\"";
throw;
}
foreach (var i in config.EmailTarget)
{
if (String.IsNullOrWhiteSpace(i)) return "Hay Emails mal cargados";
}
SmtpClient smtp = new SmtpClient();
smtp.Host = "smtp.gmail.com";
smtp.Port = 587;
smtp.Credentials = new NetworkCredential(config.EmailAddr, config.EmailPass);
smtp.DeliveryMethod = SmtpDeliveryMethod.Network;
smtp.EnableSsl = true;
MailMessage mail = new MailMessage();
mail.Subject = titulo;
mail.IsBodyHtml = true;
mail.Body = body;
mail.Sender = new MailAddress(config.EmailAddr);
foreach (var i in config.EmailTarget) mail.To.Add(i);
mail.From = new MailAddress(config.EmailAddr);
try
{
smtp.Send(mail);
mail.Dispose();
}
catch (Exception)
{
ret = "No se pudo comunicar con el server SMTP";
throw;
}
//Decimos que se envio el email correctamente si el valor del retorno sigue siendo nulo en otro caso tendra la descripcion del error.
return (ret == null) ?
"Se envio el Email Correctamente" :
ret;
//
}
} }
} }

View File

@@ -136,12 +136,13 @@
// //
// btnEnviarEmail // btnEnviarEmail
// //
btnEnviarEmail.Location = new Point(26, 364); btnEnviarEmail.Location = new Point(26, 143);
btnEnviarEmail.Name = "btnEnviarEmail"; btnEnviarEmail.Name = "btnEnviarEmail";
btnEnviarEmail.Size = new Size(200, 26); btnEnviarEmail.Size = new Size(200, 26);
btnEnviarEmail.TabIndex = 9; btnEnviarEmail.TabIndex = 9;
btnEnviarEmail.Text = "Enviar Informe Por Email"; btnEnviarEmail.Text = "Enviar Informe Por Email";
btnEnviarEmail.UseVisualStyleBackColor = true; btnEnviarEmail.UseVisualStyleBackColor = true;
btnEnviarEmail.Click += btnEnviarEmail_Click;
// //
// FrmInformeFacturaPorFecha // FrmInformeFacturaPorFecha
// //

View File

@@ -16,9 +16,11 @@ namespace Vista.Informes
public partial class FrmInformeFacturaPorFecha : Form public partial class FrmInformeFacturaPorFecha : Form
{ {
private ReadOnlyCollection<Factura>? facturas; private ReadOnlyCollection<Factura>? facturas;
private DateTime fecini, fecfin;
public FrmInformeFacturaPorFecha() public FrmInformeFacturaPorFecha()
{ {
InitializeComponent(); InitializeComponent();
if (ControladoraInformes.Instance.RecuperarConfig().Informar == false) btnEnviarEmail.Enabled = false;
} }
private void btnBuscar_Click(object sender, EventArgs e) private void btnBuscar_Click(object sender, EventArgs e)
@@ -29,6 +31,10 @@ namespace Vista.Informes
return; return;
} }
//es por si mandas un email mantener el state de las fechas
fecini = dateInicio.Value;
fecfin = dateFin.Value;
facturas = ControladoraInformes.Instance.MostrarFacturasEnRangoDeFechas(dateInicio.Value, dateFin.Value); facturas = ControladoraInformes.Instance.MostrarFacturasEnRangoDeFechas(dateInicio.Value, dateFin.Value);
@@ -79,5 +85,16 @@ namespace Vista.Informes
column.Visible = column.Name == "Subtotal" || column.Name == "NombreProducto" || column.Name == "Cantidad"; column.Visible = column.Name == "Subtotal" || column.Name == "NombreProducto" || column.Name == "Cantidad";
} }
} }
private void btnEnviarEmail_Click(object sender, EventArgs e)
{
if (facturas == null || facturas.Count <= 0)
{
MessageBox.Show("No hay facturas para mandar email");
return;
}
string msg = ControladoraInformes.Instance.EnviarEmail($"Facturas del {fecini.ToString()} hasta {fecfin.ToString()}", facturas.ToList());
MessageBox.Show(msg);
}
} }
} }

View File

@@ -53,6 +53,7 @@
btnEnviarEmail.TabIndex = 19; btnEnviarEmail.TabIndex = 19;
btnEnviarEmail.Text = "Enviar Informe Por Email"; btnEnviarEmail.Text = "Enviar Informe Por Email";
btnEnviarEmail.UseVisualStyleBackColor = true; btnEnviarEmail.UseVisualStyleBackColor = true;
btnEnviarEmail.Click += btnEnviarEmail_Click;
// //
// label4 // label4
// //

View File

@@ -17,10 +17,13 @@ namespace Vista.Informes
public partial class FrmInformeFacturasPorCliente : Form public partial class FrmInformeFacturasPorCliente : Form
{ {
private ReadOnlyCollection<Factura> facturas; private ReadOnlyCollection<Factura> facturas;
private DateTime fecini, fecfin;
public FrmInformeFacturasPorCliente() public FrmInformeFacturasPorCliente()
{ {
InitializeComponent(); InitializeComponent();
IniciarTablaClientes(); IniciarTablaClientes();
if (ControladoraInformes.Instance.RecuperarConfig().Informar == false) btnEnviarEmail.Enabled = false;
} }
private void IniciarTablaClientes() private void IniciarTablaClientes()
@@ -37,6 +40,10 @@ namespace Vista.Informes
if (Check()) if (Check())
{ {
Cliente cli = (Cliente)dgvCliente.SelectedRows[0].DataBoundItem; Cliente cli = (Cliente)dgvCliente.SelectedRows[0].DataBoundItem;
//es por si mandas un email mantener el state de las fechas
fecini = dateInicio.Value;
fecfin = dateFin.Value;
var lista = ControladoraInformes.Instance.MostrarFacturasDeClienteEnRangoDeFechas(cli, dateInicio.Value, dateFin.Value); var lista = ControladoraInformes.Instance.MostrarFacturasDeClienteEnRangoDeFechas(cli, dateInicio.Value, dateFin.Value);
if (lista == null) if (lista == null)
@@ -104,5 +111,16 @@ namespace Vista.Informes
column.Visible = column.Name == "Subtotal" || column.Name == "NombreProducto" || column.Name == "Cantidad"; column.Visible = column.Name == "Subtotal" || column.Name == "NombreProducto" || column.Name == "Cantidad";
} }
} }
private void btnEnviarEmail_Click(object sender, EventArgs e)
{
if (facturas == null || facturas.Count <= 0)
{
MessageBox.Show("No hay facturas para mandar email");
return;
}
string msg = ControladoraInformes.Instance.EnviarEmail($"Facturas cliente: {facturas[0].NombreCliente} del {fecini.ToString()} hasta {fecfin.ToString()}", facturas.ToList());
MessageBox.Show(msg);
}
} }
} }