Exferia/Exferia_Ventas/Exferia_Ventas/3_Vistas/P_FacturaCabecera.cs

4118 lines
241 KiB
C#

using Exferia_Aplicacion.General;
using Exferia_Aplicacion.Visualizacion;
using Exferia_Controles;
using Exferia_EntityFramework;
using Exferia_General;
using Exferia_Ventas.General;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Linq;
using static Exferia_Aplicacion.General.Enumerados;
using System.Globalization;
using Exferia_Ventas._0_Modelos;
using Exferia_Aplicacion.Modelos_Listado_Filtros;
using Exferia_Formularios;
using static Exferia_Ventas.General.Enumerados_Ventas;
using Exferia_Aplicacion.Modelos_Generales;
using Exferia_Ventas._3_Vistas.Controladoras;
using Exferia_Ventas._3_Vistas.ListadosSeleccion;
using System.Reflection;
using Exferia_Ventas._3_Vistas.Listados;
using Exferia_Controles.ControlesAuxiliares;
namespace Exferia_Ventas._3_Vistas
{
public partial class P_FacturaCabecera : Exferia_Formularios.P_Base_Mantenimientos
{
#region Variables General
private P_FacturaCabecera_Controladora g_obj_Controladora;
private int g_int_CentroInformacion_Ancho = 150;
private bool g_bol_ConstructorPantalla_Terminado_Correctamente = true;
public PRV_OpcionesDetalle g_mdl_PRV_OpcionesDetalle = null;
internal List<INTERNO_Permisos_Modelo> g_lst_INTERNO_Permisos_Modelo = null;
private bool g_bol_Cambio_Fecha = false;
//Variables paginador
public Funciones_Paginador g_obj_Funciones_Paginador;
private System.Windows.Forms.Timer g_timer_Paginar = new System.Windows.Forms.Timer();
//Lineas
private INTERNO_ConfiguracionPantalla_Modelo g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA = null;
//Resumen
private INTERNO_ConfiguracionPantalla_Modelo g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN = null;
//Comentarios
private INTERNO_ConfiguracionPantalla_Modelo g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS = null;
//Trazabilidad
private INTERNO_ConfiguracionPantalla_Modelo g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD = null;
#endregion
#region Objetos en Pantalla
// CTU_Cartera_Ventas
internal CTU_Cartera_Ventas CTU_Cartera_Ventas_FacturaCabecera { get { return ctu_P_FacturaCabecera_CarteraVenta; } }
// Exferia_ArbolSecundarioSeleccion
internal Exferia_ArbolSecundarioSeleccion Exferia_ArbolSecundarioSeleccion_FacturaCabecera { get { return ex_trv_P_FacturaCabecera_ArbolSecundarioSeleccion; } }
//Exferia_BarraProgreso
internal Exferia_BarraProgreso Exferia_BarraProgreso_Lineas { get { return ex_pgb_BarraProgreso_Lineas; } }
//Exferia_Button
internal Exferia_Button Exferia_Button_Borrar { get { return ex_btn_P_FacturaCabecera_Borrar; } }
internal Exferia_Button Exferia_Button_CerrarAbrir { get { return ex_btn_P_FacturaCabecera_CerrarAbrir; } }
internal Exferia_Button Exferia_Button_Volcado { get { return ex_btn_P_FacturaCabecera_Volcado; } }
internal Exferia_Button Exferia_Button_Cuentas { get { return ex_btn_P_FacturaCabecera_Cuentas; } }
internal Exferia_Button Exferia_Button_Anexo_Actualizar { get { return ex_btn_P_FacturaCabecera_Anexo_Actualizar; } }
internal Exferia_Button Exferia_Button_Otros_Actualizar { get { return ex_btn_P_FacturaCabecera_Otros_Actualizar; } }
internal Exferia_Button Exferia_Button_DatosViaje_Actualizar { get { return ex_btn_P_FacturaCabecera_DatosViaje_Actualizar; } }
internal Exferia_Button Exferia_Button_Observaciones_Actualizar { get { return ex_btn_P_FacturaCabecera_Observaciones_Actualizar; } }
internal Exferia_Button Exferia_Button_factura_electonica { get { return ex_btn_P_FacturaCabecera_FacturaE; } }
//Exferia_Button_Situacion
internal Exferia_Button_Situacion Exferia_Button_Situacion_PagoPendiente { get { return ex_btn_P_FacturaCabecera_SituacionPago_Pendiente; } }
internal Exferia_Button_Situacion Exferia_Button_Situacion_PagoPagado { get { return ex_btn_P_FacturaCabecera_SituacionPago_Pagado; } }
internal Exferia_Button_Situacion Exferia_Button_Situacion_PagoPartePendiente { get { return ex_btn_P_FacturaCabecera_SituacionPago_PartePendiente; } }
//Exferia_CheckBox
internal Exferia_CheckBox Exferia_CheckBox_RecargoEquivalencia { get { return ex_chk_P_FacturaCabecera_RecargoEquivalencia; } }
internal Exferia_CheckBox Exferia_CheckBox_CriterioCaja { get { return ex_chk_P_FacturaCabecera_CriterioCaja; } }
//Exferia_DataGridView
internal Exferia_DataGridView Exferia_DataGridView_Lineas { get { return ex_dgv_P_FacturaCabecera_Lineas; } }
internal Exferia_DataGridView Exferia_DataGridView_Resumen { get { return ex_dgv_P_FacturaCabecera_Resumen; } }
internal Exferia_DataGridView Exferia_DataGridView_LineasComentarios { get { return ex_dgv_P_FacturaCabecera_LineasComentarios; } }
internal Exferia_DataGridView Exferia_DataGridView_LineasTrazabilidad { get { return ex_dgv_P_FacturaCabecera_LineasTrazabilidad; } }
// Exferia_FechaSeleccion
internal Exferia_FechaSeleccion Exferia_FechaSeleccion_Fecha { get { return ex_usc_P_FacturaCabecera_Fecha; } }
internal Exferia_FechaSeleccion Exferia_FechaSeleccion_DatosViaje_FechaCarga { get { return ex_usc_P_FacturaCabecera_DatosViaje_FechaCarga; } }
internal Exferia_FechaSeleccion Exferia_FechaSeleccion_FechaIntroduccion { get { return ex_usc_P_FacturaCabecera_FechaIntroduccion; } }
//Exferia_F3_SoloSeleccion
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Moneda { get { return ex_usc_F3_P_FacturaCabecera_Moneda; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_FormaPago { get { return ex_usc_F3_P_FacturaCabecera_FormaPago; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_ImpuestoCabecera { get { return ex_usc_F3_P_FacturaCabecera_ImpuestoCabecera; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Empleado { get { return ex_usc_F3_P_FacturaCabecera_Empleado; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Vendedor_Preventa { get { return ex_usc_F3_P_FacturaCabecera_Vendedor_Preventa; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Vendedor_PreventaHabitual { get { return ex_usc_F3_P_FacturaCabecera_Vendedor_PreventaHabitual; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Vendedor_Repartidor { get { return ex_usc_F3_P_FacturaCabecera_Vendedor_Repartidor; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Vendedor_Cobrador { get { return ex_usc_F3_P_FacturaCabecera_Vendedor_Cobrador; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Vendedor_CobradorHabitual { get { return ex_usc_F3_P_FacturaCabecera_Vendedor_CobradorHabitual; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_Vendedor_Autoventa { get { return ex_usc_F3_P_FacturaCabecera_Vendedor_Autoventa; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_ClavePredefinida_Factura { get { return ex_usc_F3_P_FacturaCabecera_ClavePredefinida_Factura; } }
internal Exferia_F3_SoloSeleccion Exferia_F3_SoloSeleccion_ClaveAnalitica { get { return ex_usc_F3_P_FacturaCabecera_ClaveAnalitica; } }
//Exferia_F3
internal Exferia_F3 Exferia_F3_Delegacion { get { return ex_usc_F3_P_FacturaCabecera_Delegacion; } }
internal Exferia_F3 Exferia_F3_Cliente { get { return ex_usc_F3_P_FacturaCabecera_Cliente; } }
internal Exferia_F3 Exferia_F3_Anexo_Pais { get { return ex_usc_F3_P_FacturaCabecera_Anexo_Pais; } }
internal Exferia_F3 Exferia_F3_Anexo_Provincia { get { return ex_usc_F3_P_FacturaCabecera_Anexo_Provincia; } }
internal Exferia_F3 Exferia_F3_Anexo_Municipio { get { return ex_usc_F3_P_FacturaCabecera_Anexo_Municipio; } }
internal Exferia_F3 Exferia_F3_Anexo_Poblacion { get { return ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion; } }
// Exferia_Label
internal Exferia_Label Exferia_Label_NumeroDocumento { get { return ex_lbl_P_FacturaCabecera_NumeroDocumento; } }
internal Exferia_Label Exferia_Label_DescuentoProntoPago { get { return ex_lbl_P_FacturaCabecera_DescuentoProntoPago; } }
internal Exferia_Label Exferia_Label_DescuentoFinalFactura { get { return ex_lbl_P_FacturaCabecera_DescuentoFinalFactura; } }
// Exferia_Label_SinColor
internal Exferia_Label_SinColor Exferia_Label_SinColor_Advertencia_Ejercicio { get { return ex_lbl_Advertencia_Ejercicio; } }
internal Exferia_Label_SinColor Exferia_Label_SinColor_Total_Valor { get { return ex_lbl_P_FacturaCabecera_Total_Valor; } }
internal Exferia_Label_SinColor Exferia_Label_SinColor_TotalFinal_Valor { get { return ex_lbl_P_FacturaCabecera_TotalFinal_Valor; } }
//Exferia_Label_Total
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_TipoEmbalaje_Principal { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_TipoEmbalaje_Principal; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_Movimiento_Principal { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_Movimiento_Principal; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_Trazado_Principal { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_Trazado_Principal; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_Diferencia_Principal { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_Diferencia_Principal; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_TipoEmbalaje_Relacionado { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_TipoEmbalaje_Relacionado; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_Movimiento_Relacionado { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_Movimiento_Relacionado; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_Trazado_Relacionado { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_Trazado_Relacionado; } }
internal Exferia_Label_Total Exferia_Label_Trazabilidad_Total_ResumenTotales_Diferencia_Relacionado { get { return ex_lbl_P_FacturaCabecera_Trazabilidad_ResumenTotales_Diferencia_Relacionado; } }
// Exferia_Paginador
internal Exferia_Paginador Exferia_Paginador_FacturaCabecera { get { return ex_Paginador; } }
// Exferia_TextBox
internal Exferia_TextBox Exferia_TextBox_NumeroDocumento { get { return ex_txt_P_FacturaCabecera_NumeroDocumento; } }
internal Exferia_TextBox Exferia_TextBox_Descripcion { get { return ex_txt_P_FacturaCabecera_Descripcion; } }
internal Exferia_TextBox Exferia_TextBox_DescuentoProntoPago { get { return ex_txt_P_FacturaCabecera_DescuentoProntoPago; } }
internal Exferia_TextBox Exferia_TextBox_DescuentoFinalFactura { get { return ex_txt_P_FacturaCabecera_DescuentoFinalFactura; } }
internal Exferia_TextBox Exferia_TextBox_Observaciones { get { return ex_txt_P_FacturaCabecera_Observaciones; } }
internal Exferia_TextBox Exferia_TextBox_Referencia { get { return ex_txt_P_FacturaCabecera_Referencia; } }
internal Exferia_TextBox Exferia_TextBox_Servicio_DatosViaje_MatriculaVehiculo { get { return ex_txt_P_FacturaCabecera_DatosViaje_MatriculaVehiculo; } }
internal Exferia_TextBox Exferia_TextBox_Servicio_DatosViaje_MatriculaRemolque { get { return ex_txt_P_FacturaCabecera_DatosViaje_MatriculaRemolque; } }
internal Exferia_TextBox Exferia_TextBox_Servicio_DatosViaje_Origen { get { return ex_txt_P_FacturaCabecera_DatosViaje_Origen; } }
internal Exferia_TextBox Exferia_TextBox_Servicio_DatosViaje_Destino { get { return ex_txt_P_FacturaCabecera_DatosViaje_Destino; } }
internal Exferia_TextBox Exferia_TextBox_Servicio_DatosViaje_Referencia { get { return ex_txt_P_FacturaCabecera_DatosViaje_Referencia; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_NumeroPedidoCliente { get { return ex_txt_P_FacturaCabecera_Anexo_NumeroPedidoCliente; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_Cliente { get { return ex_txt_P_FacturaCabecera_Anexo_Cliente; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_Direccion { get { return ex_txt_P_FacturaCabecera_Anexo_Direccion; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_Telefono1 { get { return ex_txt_P_FacturaCabecera_Anexo_Telefono1; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_Telefono2 { get { return ex_txt_P_FacturaCabecera_Anexo_Telefono2; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_Fax { get { return ex_txt_P_FacturaCabecera_Anexo_Fax; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_Observaciones { get { return ex_txt_P_FacturaCabecera_Anexo_Observaciones; } }
internal Exferia_TextBox Exferia_TextBox_Anexo_CodigoPostal { get { return ex_txt_P_FacturaCabecera_Anexo_CodigoPostal; } }
//Exferia_TextBox_CIFNIF
internal Exferia_TextBox_CIFNIF Exferia_TextBox_CIFNIF_Anexo_NIF { get { return ex_usc_P_FacturaCabecera_Anexo_CIFNIF; } }
// Panel
internal Panel Panel_LineasTrazabilidad_ResumenTotales_Principal { get { return pnl_P_FacturaCabecera_LineasTrazabilidad_ResumenTotales_Principal; } }
internal Panel Panel_LineasTrazabilidad_ResumenTotales_Relacional { get { return pnl_P_FacturaCabecera_LineasTrazabilidad_ResumenTotales_Relacional; } }
#endregion
#region Constructor
public P_FacturaCabecera(INTERNO_ValoresGenerales_Modelo _mdl_INTERNO_ValoresGenerales_Modelo,
DateTime _dtt_FechaTrabajo,
PRV_OpcionesDetalle _mdl_PRV_OpcionesDetalle)
{
InitializeComponent();
try
{
Repintar.Empezar(this);
CheckForIllegalCrossThreadCalls = false;
//Empresa seleccionada y fecha de trabajo ....................................................
P_Base_ValoresGenerales = _mdl_INTERNO_ValoresGenerales_Modelo;
P_Base_FechaTrabajo = _dtt_FechaTrabajo;
//Datos de Opciones detalle
g_mdl_PRV_OpcionesDetalle = _mdl_PRV_OpcionesDetalle;
//Instanciar Controladora
g_obj_Controladora = new P_FacturaCabecera_Controladora(this);
//Buscar los Permisos
g_lst_INTERNO_Permisos_Modelo = Datos_Generales.Permisos_Buscar(g_mdl_PRV_OpcionesDetalle.opcion);
//Poner los Botones que no se Spueden poner bloqueados o de solo lectura .....................
ex_btn_P_FacturaCabecera_Borrar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Grabar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Resfrecar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Lineas_Add.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Lineas_Ver.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Lineas_Filtros.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Lineas_Borrar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Exferia_Button_Bloqueable = false;
ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.Exferia_ComboBox_Bloqueable = false;
ex_btn_P_FacturaCabecera_CerrarAbrir.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Comentarios_Borrar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Exferia_Button_Bloqueable = false;
ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.Exferia_ComboBox_Bloqueable = false;
ex_btn_P_FacturaCabecera_Resumen_Filtros.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Trazabilidad_Add.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Trazabilidad_Ver.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Trazabilidad_Borrar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Exferia_Button_Bloqueable = false;
ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Exferia_ComboBox_Bloqueable = false;
ex_btn_P_FacturaCabecera_ArbolSecundarioSeleccion_MostrarOcultar.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Imprimir.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Volcado.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_Cuentas.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_RecalcularResumen.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_EnviarMensajes.Exferia_Button_Bloqueable = false;
ex_btn_P_FacturaCabecera_FacturaE.Exferia_Button_Bloqueable = false;
//Anexo
ex_btn_P_FacturaCabecera_Anexo_Actualizar.Exferia_Button_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_NumeroPedidoCliente.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_Cliente.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_Direccion.Exferia_TextBox_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Anexo_Pais.Exferia_F3_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_Bloqueable = false;
ex_usc_P_FacturaCabecera_Anexo_CIFNIF.Exferia_TextBox_CIFNIF_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_Telefono1.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_Telefono2.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_Fax.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_Observaciones.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_Anexo_CodigoPostal.Exferia_TextBox_Bloqueable = false;
//Otros
ex_btn_P_FacturaCabecera_Otros_Actualizar.Exferia_Button_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Moneda.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Empleado.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Vendedor_Preventa.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Vendedor_PreventaHabitual.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Vendedor_Repartidor.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Vendedor_Cobrador.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Vendedor_CobradorHabitual.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_usc_F3_P_FacturaCabecera_Vendedor_Autoventa.Exferia_F3_SoloSeleccion_Bloqueable = false;
ex_txt_P_FacturaCabecera_Referencia.Exferia_TextBox_Bloqueable = false;
//Datos Viaje
ex_btn_P_FacturaCabecera_DatosViaje_Actualizar.Exferia_Button_Bloqueable = false;
ex_usc_P_FacturaCabecera_DatosViaje_FechaCarga.Exferia_FechaSeleccion_Bloqueable = false;
ex_txt_P_FacturaCabecera_DatosViaje_MatriculaVehiculo.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_DatosViaje_MatriculaRemolque.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_DatosViaje_Origen.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_DatosViaje_Destino.Exferia_TextBox_Bloqueable = false;
ex_txt_P_FacturaCabecera_DatosViaje_Referencia.Exferia_TextBox_Bloqueable = false;
//Observaciones
ex_btn_P_FacturaCabecera_Observaciones_Actualizar.Exferia_Button_Bloqueable = false;
ex_txt_P_FacturaCabecera_Observaciones.Exferia_TextBox_Bloqueable = false;
//............................................................................................
//Mirar si hay que bloquear los controles, si solo puede ver los datos
if ((P_Base_TipoAperturaPantalla != 0 && Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Modificar, false)) == false)
{
//Bloqueo los Controles
SoloLectura.Empezar(this, true);
}
//Titulo de la Pantalla .............................................................................
P_Base_TituloPantalla = _mdl_PRV_OpcionesDetalle.descripcion_TituloMantenimiento;
if (Variables.G_DCT_CONFIGURACIONPANTALLA != null && Variables.G_DCT_CONFIGURACIONPANTALLA.Count > 0)
{
//Lineas
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA = Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION()];
}
//Comentarios
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS = Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.NOMBRELISTADO_ALMACENARCONFIGURACION()];
}
//Trazabilidad
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD = Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION()];
}
//Resumen
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN = Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION()];
}
//centro informacion
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(nameof(P_FacturaCabecera)))
{
g_int_CentroInformacion_Ancho = Variables.G_DCT_CONFIGURACIONPANTALLA[nameof(P_FacturaCabecera)].CENTROINFORMACION_Ancho;
}
}
// Label con Empresa Seleccionada
if (P_Base_ValoresGenerales != null)
{
try
{
P_Base_Mantenimientos_InformacionEmpresaSeleccionada = P_Base_ValoresGenerales.str_Empresa_Descripcion + " - " +
"(" + P_Base_FechaTrabajo.ToString("dd/MM/yyyy") + ")";
}
catch (Exception ex)
{
//No se muestra mensaje pero se guarda en el log
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(P_FacturaCabecera));
}
}
//....................................................................................................
//Bloquear pantalla hasta que termine la carga por defecto .....
Enabled = false;
//.............................................................
//Instanciar Funcions de paginador
g_obj_Funciones_Paginador = new Funciones_Paginador();
//Rellenar para los F3 .......................................
//DELEGACION
ex_usc_F3_P_FacturaCabecera_Delegacion.Exferia_F3_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_DELEGACION;
ex_usc_F3_P_FacturaCabecera_Delegacion.Exferia_F3_PantallaContenedora = this;
//FORMA DE PAGO
ex_usc_F3_P_FacturaCabecera_FormaPago.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_FORMADEPAGO;
ex_usc_F3_P_FacturaCabecera_FormaPago.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
//EMPLEADO
ex_usc_F3_P_FacturaCabecera_Empleado.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_EMPLEADO;
ex_usc_F3_P_FacturaCabecera_Empleado.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
//VENDEDOR(PREVENTA)
ex_usc_F3_P_FacturaCabecera_Vendedor_Preventa.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_VENDEDOR;
ex_usc_F3_P_FacturaCabecera_Vendedor_Preventa.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_Vendedor_Preventa.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//VENDEDOR(PREVENTA HABITUAL)
ex_usc_F3_P_FacturaCabecera_Vendedor_PreventaHabitual.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_VENDEDOR;
ex_usc_F3_P_FacturaCabecera_Vendedor_PreventaHabitual.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_Vendedor_PreventaHabitual.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//VENDEDOR(REPARTIDOR)
ex_usc_F3_P_FacturaCabecera_Vendedor_Repartidor.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_VENDEDOR;
ex_usc_F3_P_FacturaCabecera_Vendedor_Repartidor.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_Vendedor_Repartidor.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//VENDEDOR(COBRADOR)
ex_usc_F3_P_FacturaCabecera_Vendedor_Cobrador.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_VENDEDOR;
ex_usc_F3_P_FacturaCabecera_Vendedor_Cobrador.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_Vendedor_Cobrador.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//VENDEDOR(COBRADORHABITUAL)
ex_usc_F3_P_FacturaCabecera_Vendedor_CobradorHabitual.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_VENDEDOR;
ex_usc_F3_P_FacturaCabecera_Vendedor_CobradorHabitual.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_Vendedor_CobradorHabitual.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//VENDEDOR(AUTOVENTA)
ex_usc_F3_P_FacturaCabecera_Vendedor_Autoventa.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_VENDEDOR;
ex_usc_F3_P_FacturaCabecera_Vendedor_Autoventa.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_Vendedor_Autoventa.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//CLIENTE
ex_usc_F3_P_FacturaCabecera_Cliente.Exferia_F3_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_MAE_CLIENTE;
ex_usc_F3_P_FacturaCabecera_Cliente.Exferia_F3_PantallaContenedora = this;
//MONEDA
ex_usc_F3_P_FacturaCabecera_Moneda.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_MONEDA;
ex_usc_F3_P_FacturaCabecera_Moneda.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
//IMPUESTO CABECERA
ex_usc_F3_P_FacturaCabecera_ImpuestoCabecera.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_IMPUESTOCABECERA;
ex_usc_F3_P_FacturaCabecera_ImpuestoCabecera.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
//PREDEFINIDOCABECERA (Factura)
ex_usc_F3_P_FacturaCabecera_ClavePredefinida_Factura.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_CTA_PREDEFINIDOCABECERA;
ex_usc_F3_P_FacturaCabecera_ClavePredefinida_Factura.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_ClavePredefinida_Factura.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
ex_usc_F3_P_FacturaCabecera_ClavePredefinida_Factura.Exferia_F3_SoloSeleccion_RELACIONADOS_Padre_OPCION = Variables.G_STR_OPCION_CTA_PREDEFINIDOFICHERO;
ex_usc_F3_P_FacturaCabecera_ClavePredefinida_Factura.Exferia_F3_SoloSeleccion_RELACIONADOS_Padre_ID = Variables.G_PREDEFINIDOFICHEROS_FACTURASDEVENTA.Id;
//CLAVE ANALITICA
ex_usc_F3_P_FacturaCabecera_ClaveAnalitica.Exferia_F3_SoloSeleccion_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_CTA_CLAVEANALITICA;
ex_usc_F3_P_FacturaCabecera_ClaveAnalitica.Exferia_F3_SoloSeleccion_PantallaContenedora = this;
ex_usc_F3_P_FacturaCabecera_ClaveAnalitica.Exferia_F3_SoloSeleccion_PRINCIPAL_BUSCARTITULO = false;
//PAIS_ANEXO
ex_usc_F3_P_FacturaCabecera_Anexo_Pais.Exferia_F3_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_PAIS;
ex_usc_F3_P_FacturaCabecera_Anexo_Pais.Exferia_F3_PantallaContenedora = this;
//PROVINCIA_ANEXO
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_PROVINCIA;
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_PantallaContenedora = this;
//MUNICIPIO_ANEXO
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_MUNICIPIO;
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_PantallaContenedora = this;
//POBLACION_ANEXO
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_PRINCIPAL_Opcion_BuscarDatos = Variables.G_STR_OPCION_GEN_POBLACION;
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_PantallaContenedora = this;
}
catch (Control_Errores)
{
g_bol_ConstructorPantalla_Terminado_Correctamente = false;
}
catch (Exception ex)
{
g_bol_ConstructorPantalla_Terminado_Correctamente = false;
//No se muestra mensaje pero se guarda en el log
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(P_FacturaCabecera));
}
finally
{
//Bloquear pantalla hasta que termine la carga por defecto .....
Enabled = true;
//.............................................................
}
}
#endregion
#region Inicio de pantalla
private void P_FacturaCabecera_Load(object sender, EventArgs e)
{
try
{
#region TIMER PAGINACION
g_timer_Paginar.Interval = 1000;
g_timer_Paginar.Tick += delegate (object s, EventArgs ee)
{
g_timer_Paginar.Stop();
try
{
g_obj_Controladora.RecargarDatos();
}
catch (Control_Errores)
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_ERROR_CARGARDATOSPANTALLA());
Salir_P_Base();
}
};
#endregion
#region CONFIGURAR Factura LINEAS
//Crear Columnas Listado
CrearColumnas_Listado_FacturaLinea();
//Poner el tipo de orden si lo hubiera por defecto ###################################################################################
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_ORDEN_DIRECCION_PORDEFECTO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_ORDEN_DIRECCION_PORDEFECTO.Trim().Length > 0)
{
//Descendente
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_ORDEN_DIRECCION_PORDEFECTO.Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag = "1";
}
//Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag = "0";
}
}
else
{
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_TIPO_PORDEFECTO().Trim().Length > 0)
{
//Descendente
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_TIPO_PORDEFECTO().Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag = "1";
}
//Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag = "0";
}
}
}
//Seleccionar Orden por Defecto en Combo ###########################################################################################################
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_ORDEN_COLUMNA_PORDEFECTO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_ORDEN_COLUMNA_PORDEFECTO.Trim().Length > 0)
{
ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Descripcion.Equals(g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_ORDEN_COLUMNA_PORDEFECTO)).FirstOrDefault();
}
else
{
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_NOMBRECOLUMNA_PORDEFECTO().Trim().Length > 0)
{
ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Identificador.Equals(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_NOMBRECOLUMNA_PORDEFECTO())).FirstOrDefault();
}
else
{
ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().FirstOrDefault();
}
}
#endregion
#region CONFIGURAR Factura RESUMEN
//Crear Columnas Listado
CrearColumnas_Listado_FacturaResumen();
#endregion
#region CONFIGURAR Factura COMENTARIOS
//Crear Columnas Listado
CrearColumnas_Listado_AlbaranesFacturasLineasComentarios();
//Poner el tipo de orden si lo hubiera por defecto ###################################################################################
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_ORDEN_DIRECCION_PORDEFECTO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_ORDEN_DIRECCION_PORDEFECTO.Trim().Length > 0)
{
//Descendente
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_ORDEN_DIRECCION_PORDEFECTO.Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag = "1";
}
//Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag = "0";
}
}
else
{
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.ORDENACION_TIPO_PORDEFECTO().Trim().Length > 0)
{
//Descendente
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.ORDENACION_TIPO_PORDEFECTO().Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag = "1";
}
//Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag = "0";
}
}
}
//Seleccionar Orden por Defecto en Combo ###########################################################################################################
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_ORDEN_COLUMNA_PORDEFECTO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_ORDEN_COLUMNA_PORDEFECTO.Trim().Length > 0)
{
ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Descripcion.Equals(g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_ORDEN_COLUMNA_PORDEFECTO)).FirstOrDefault();
}
else
{
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.ORDENACION_NOMBRECOLUMNA_PORDEFECTO().Trim().Length > 0)
{
ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Identificador.Equals(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.ORDENACION_NOMBRECOLUMNA_PORDEFECTO())).FirstOrDefault();
}
else
{
ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().FirstOrDefault();
}
}
#endregion
#region CONFIGURAR Factura LINEATRAZABILIDAD
//Crear Columnas Listado
CrearColumnas_Listado_FacturaLineaTrazabilidad();
//Poner el tipo de orden si lo hubiera por defecto ######################################
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_ORDEN_DIRECCION_PORDEFECTO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_ORDEN_DIRECCION_PORDEFECTO.Trim().Length > 0)
{
//Descendente
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_ORDEN_DIRECCION_PORDEFECTO.Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag = "1";
}
//Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag = "0";
}
}
else
{
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.ORDENACION_TIPO_PORDEFECTO().Trim().Length > 0)
{
//Descendente
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.ORDENACION_TIPO_PORDEFECTO().Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag = "1";
}
//Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag = "0";
}
}
}
//########################################################################################
//Seleccionar Orden por Defecto en Combo #################################################
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_ORDEN_COLUMNA_PORDEFECTO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_ORDEN_COLUMNA_PORDEFECTO.Trim().Length > 0)
{
ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Descripcion.Equals(g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_ORDEN_COLUMNA_PORDEFECTO)).FirstOrDefault();
}
else
{
if (g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.ORDENACION_NOMBRECOLUMNA_PORDEFECTO().Trim().Length > 0)
{
ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Identificador.Equals(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.ORDENACION_NOMBRECOLUMNA_PORDEFECTO())).FirstOrDefault();
}
else
{
ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().FirstOrDefault();
}
}
#endregion
#region Resumen Facturas
ctu_P_FacturaCabecera_CarteraVenta.Inicializar_Control(P_Base_ValoresGenerales, P_Base_FechaTrabajo, this);
#endregion
}
catch (Exception ex)
{
//No se muestra mensaje pero se guarda en el log
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(P_FacturaCabecera_Load));
g_bol_ConstructorPantalla_Terminado_Correctamente = false;
}
}
private void P_FacturaCabecera_Shown(object sender, EventArgs e)
{
try
{
if (g_bol_ConstructorPantalla_Terminado_Correctamente)
{
// Si el Tipo de Apertura de Pantalla es Añadir(g_int_tipoAperturaPantalla = 0), se desactivan los botones correspondientes
// Añadir
if (this.P_Base_TipoAperturaPantalla == 0)
{
P_Base_TituloPantalla = P_Base_TituloPantalla + " - Añadir";
ActivarBotones(false);
g_obj_Controladora.Datos_Pordefecto();
//Se cambia el valor de la variable para no salte el evento de se modifico algo
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial = false;
//Poner Texto predeterminado y foco
ex_usc_F3_P_FacturaCabecera_Cliente.Exferia_F3_Foco();
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial = true;
}
// Modificar
else
{
ActivarBotones(true);
//Paginacion
if (P_Base_PantallaOrigen != null &&
P_Base_PantallaOrigen.P_Base_Objetos_Filtrados != null &&
P_Base_PantallaOrigen.P_Base_Objetos_Filtrados.Count > 0)
{
g_obj_Funciones_Paginador.Listado_ARecorrer(P_Base_PantallaOrigen.P_Base_Objetos_Filtrados.ToList(), 1);
// Asignando las paginas totales
Exferia_Paginador_FacturaCabecera.PaginasTotales = g_obj_Funciones_Paginador.Numero_Paginas_Totales;
}
else
{
Exferia_Paginador_FacturaCabecera.Visible = false;
}
g_obj_Controladora.RecargarDatos();
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_ERROR_CARGARDATOSPANTALLA());
Salir_P_Base();
}
}
catch (Control_Errores)
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_ERROR_CARGARDATOSPANTALLA());
Salir_P_Base();
}
catch (Exception ex)
{
//No se muestra mensaje pero se guarda en el log
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(P_FacturaCabecera_Shown));
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_ERROR_CARGARDATOSPANTALLA());
Salir_P_Base();
}
}
private void P_FacturaCabecera_Enter(object sender, EventArgs e)
{
this.Activate();
}
public void ActivarBotones(bool _bol_Activar)
{
if (Exferia_Paginador_FacturaCabecera.Visible)
{
Exferia_Paginador_FacturaCabecera.Visible = _bol_Activar;
}
if (ex_btn_P_FacturaCabecera_Borrar.Enabled)
{
ex_btn_P_FacturaCabecera_Borrar.Enabled = _bol_Activar;
}
}
#endregion
#region Botones Grabar,Borrar, Buscar codigo siguiente
private void ex_btn_P_FacturaCabecera_Grabar_Click(object sender, EventArgs e)
{
Grabar();
}
private void Grabar()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if (//Añadir
(P_Base_TipoAperturaPantalla == 0 && Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Anadir, true)) ||
//Modificar
(P_Base_TipoAperturaPantalla != 0 && Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Modificar, true)))
{
//Si el Documento esta cerrado no puedo grabar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
g_obj_Controladora.GrabarDatos();
if (g_obj_Controladora.g_bol_GrabarDatos_TerminoCorrectamente)
{
//Actualizar el control de Resumen de Facturas
ctu_P_FacturaCabecera_CarteraVenta.Rellenar_DataGrid(G_ENUM_CTU_CARTERA_VENTAS_TIPODOCUMENTOFILTRO.FacturasCabeceraVenta, g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo.id, true);
}
}
}
}
}
private void ex_btn_P_FacturaCabecera_Borrar_Click(object sender, EventArgs e)
{
Borrar();
}
private void Borrar()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if (Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Borrar, true))
{
//Si el Documento esta cerrado no puedo borrar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
g_obj_Controladora.BorrarDatos();
}
}
}
}
private void ex_btn_P_FacturaCabecera_BuscarCodigoSiguiente_Click(object sender, EventArgs e)
{
BuscarCodigoSiguiente();
}
private void BuscarCodigoSiguiente()
{
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = g_obj_Controladora.Buscar_CodigoSiguiente();
if (mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto == false && mdl_INTERNO_ValorDevuelto_Modelo.Mensaje.Trim().Length > 0)
{
Mensajes.MostrarMensaje(mdl_INTERNO_ValorDevuelto_Modelo.Mensaje);
}
else
{
P_Base_SeModificoDatosPantalla = true;
}
}
#endregion
#region FacturaLinea
private void CrearColumnas_Listado_FacturaLinea()
{
ex_dgv_P_FacturaCabecera_Lineas.AutoGenerateColumns = false;
g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_Modelo_FacturaLineas_Columnas = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.LISTADO_COLUMNAS().Values.ToList();
foreach (INTERNO_ABS_Listado_ColumnasDatos_Modelo mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo in g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_Modelo_FacturaLineas_Columnas)
{
DataGridViewTextBoxColumn dgv_Columna = new DataGridViewTextBoxColumn();
dgv_Columna.DataPropertyName = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.Name = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.HeaderText = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar;
//Poner visible o no .........................................................................
bool bol_Visible = true;
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.NoOcultable == false)
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto)
{
bol_Visible = false;
}
else if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNASAMOSTRAR != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNASAMOSTRAR.Count > 0)
{
if (!g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNASAMOSTRAR.Contains(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
bol_Visible = false;
}
}
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Mostrado_PorDefecto == false)
{
bol_Visible = false;
}
}
dgv_Columna.Visible = bol_Visible;
if (bol_Visible)
{
g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas.Add(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna);
}
//.....................................................................................................
//Tipo de Formateo si fuera Fecha
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
dgv_Columna.DefaultCellStyle.Format = "d";
}
//Poner Ancho Columna ................................................................................
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ANCHO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ANCHO.Count > 0 &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ANCHO.ContainsKey(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
dgv_Columna.Width = g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ANCHO[mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna];
}
else
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho > 0)
{
dgv_Columna.Width = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho;
}
}
//................................................................................................................
dgv_Columna.ReadOnly = true;
//Poner alineado segun tipo de datos ......................................................................................
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT))
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight;
}
else
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleLeft;
}
//..............................................................................................................................
ex_dgv_P_FacturaCabecera_Lineas.Columns.Add(dgv_Columna);
//RELLENAR EL ORDEN EN COMBO
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto == false)
{
ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.Items.Add(new INTERNO_ComboBox_Modelo(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna, mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar, null));
}
}
//Cambiar el orden de las columnas ........
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA != null && g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ORDEN != null && g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ORDEN.Count > 0)
{
foreach (KeyValuePair<string, int> kvp_Valores in g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURALINEA.LISTADO_COLUMNAS_ORDEN)
{
ex_dgv_P_FacturaCabecera_Lineas.Columns[kvp_Valores.Key].DisplayIndex = kvp_Valores.Value;
}
}
//.........................................
}
#region Cambio Seleccion Linea
private void ex_dgv_P_FacturaCabecera_Lineas_SelectionChanged(object sender, EventArgs e)
{
try
{
if (g_obj_Controladora != null && g_obj_Controladora.g_bol_Borrar_Registro_FacturaLinea_EnBaseDatos_TerminoCorrectamente)
{
Linea_CambioSeleccion();
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(ex_dgv_P_FacturaCabecera_Lineas_SelectionChanged));
}
}
public void Linea_CambioSeleccion()
{
try
{
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0 &&
ex_dgv_P_FacturaCabecera_Lineas.SelectedRows.Count > 0)
{
long lng_idLinea = long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString());
g_obj_Controladora.Rellenar_DataGrid_FacturaLineasComentarios(lng_idLinea);
g_obj_Controladora.Rellenar_DataGrid_FacturaLineaTrazabilidad(lng_idLinea);
//Se añade el id del articulo ara el listado secundario
if (ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value != null &&
!ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString().Equals("-1"))
{
long lng_idFacturaLinea = long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString());
if (g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null && g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo mdl_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(x => x.id.Equals(lng_idFacturaLinea)).FirstOrDefault();
if (mdl_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null)
{
//idArticulo
ex_trv_P_FacturaCabecera_ArbolSecundarioSeleccion.Exferia_ArbolSecundarioSeleccion_IDARTICULO = mdl_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idArticulo != null ? mdl_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idArticulo.Value : -1;
//idArticuloComodin
ex_trv_P_FacturaCabecera_ArbolSecundarioSeleccion.Exferia_ArbolSecundarioSeleccion_IDARTICULOCOMODIN = mdl_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idArticuloComodin != null ? mdl_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idArticuloComodin.Value : -1;
ex_trv_P_FacturaCabecera_ArbolSecundarioSeleccion.RecargarSeleccionNodo();
}
else
{
g_obj_Controladora.Rellenar_DataGrid_FacturaLineasComentarios(-1);
g_obj_Controladora.Rellenar_DataGrid_FacturaLineaTrazabilidad(-1);
}
}
else
{
g_obj_Controladora.Rellenar_DataGrid_FacturaLineasComentarios(-1);
g_obj_Controladora.Rellenar_DataGrid_FacturaLineaTrazabilidad(-1);
}
}
}
else
{
g_obj_Controladora.Rellenar_DataGrid_FacturaLineasComentarios(-1);
g_obj_Controladora.Rellenar_DataGrid_FacturaLineaTrazabilidad(-1);
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(Linea_CambioSeleccion));
}
}
#endregion
private void ex_dgv_P_FacturaCabecera_Lineas_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
{
string str_NombreColumna = ex_dgv_P_FacturaCabecera_Lineas.Columns[e.ColumnIndex].Name;
INTERNO_ABS_Listado_ColumnasDatos_Modelo mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.LISTADO_COLUMNAS().Values.Where(m => m.DescripcionInterna_CampoAPintar.Equals(str_NombreColumna)).FirstOrDefault();
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo != null)
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.CondicionesColores != null && mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.CondicionesColores.Count > 0)
{
bool bol_Entro = false;
Color clr_Letra = Color.Black;
Color clr_Fondo = Color.White;
string str_ColumnaAPintar = "";
//Valor Actual ...........................
dynamic dnm_ValorAComparar = null;
object obj_Valor = ex_dgv_P_FacturaCabecera_Lineas.Rows[e.RowIndex].Cells[mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna].Value;
if (obj_Valor != null)
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{ dnm_ValorAComparar = DateTime.ParseExact(obj_Valor.ToString(), "dd/MM/yyyy", CultureInfo.InvariantCulture); }
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL))
{ dnm_ValorAComparar = decimal.Parse(obj_Valor.ToString().Replace(",", ".")); }
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT))
{ dnm_ValorAComparar = int.Parse(obj_Valor.ToString()); }
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG))
{ dnm_ValorAComparar = long.Parse(obj_Valor.ToString()); }
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT))
{ dnm_ValorAComparar = long.Parse(obj_Valor.ToString()); }
else
{ dnm_ValorAComparar = ex_dgv_P_FacturaCabecera_Lineas.Rows[e.RowIndex].Cells[mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna].Value; }
}
foreach (INTERNO_ABS_Listado_CondicionesColores_Modelo mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo in mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.CondicionesColores)
{
clr_Letra = mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.COLOR_LETRA;
clr_Fondo = mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.COLOR_FONDO;
str_ColumnaAPintar = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.DescripcionInterna_CampoAPintar;
//Igual que
if (mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA.Codigo.Equals(Variables.G_MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA_GENERAL_IGUALA.Codigo))
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.BOOLEAN))
{
if (dnm_ValorAComparar.Equals("X"))
{
bol_Entro = true;
break;
}
}
else
{
if (dnm_ValorAComparar.Equals(mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.VALOR_DECOMPRACION))
{
bol_Entro = true;
break;
}
}
}
//Menor que
else if (mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA.Codigo.Equals(Variables.G_MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA_GENERAL_MENORA.Codigo))
{
//Solo los tipos de datos numericos y datetime
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
if (dnm_ValorAComparar < mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.VALOR_DECOMPRACION)
{
bol_Entro = true;
break;
}
}
}
//Menor Igual que
else if (mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA.Codigo.Equals(Variables.G_MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA_GENERAL_MENORIGUALA.Codigo))
{
//Solo los tipos de datos numericos y datetime
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
if (dnm_ValorAComparar <= mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.VALOR_DECOMPRACION)
{
bol_Entro = true;
break;
}
}
}
//Mayor que
else if (mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA.Codigo.Equals(Variables.G_MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA_GENERAL_MAYORA.Codigo))
{
//Solo los tipos de datos numericos y datetime
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
if (dnm_ValorAComparar > mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.VALOR_DECOMPRACION)
{
bol_Entro = true;
break;
}
}
}
//Mayor Igual que
else if (mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA.Codigo.Equals(Variables.G_MDL_INTERNO_CODIGODESCRIPCION_TIPOBUSQUEDA_GENERAL_MAYORIGUALA.Codigo))
{
//Solo los tipos de datos numericos y datetime
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
if (dnm_ValorAComparar >= mdl_INTERNO_ABS_Listado_CondicionesColores_Modelo.VALOR_DECOMPRACION)
{
bol_Entro = true;
break;
}
}
}
}
if (bol_Entro && str_ColumnaAPintar.Trim().Length > 0)
{
//Color Fondo
ex_dgv_P_FacturaCabecera_Lineas.Rows[e.RowIndex].Cells[str_ColumnaAPintar].Style.BackColor = clr_Fondo;
ex_dgv_P_FacturaCabecera_Lineas.Rows[e.RowIndex].Cells[str_ColumnaAPintar].Style.SelectionBackColor = clr_Fondo;
//Color Letra
ex_dgv_P_FacturaCabecera_Lineas.Rows[e.RowIndex].Cells[str_ColumnaAPintar].Style.ForeColor = clr_Letra;
ex_dgv_P_FacturaCabecera_Lineas.Rows[e.RowIndex].Cells[str_ColumnaAPintar].Style.SelectionForeColor = clr_Letra;
}
}
}
}
private void ex_cbo_P_FacturaCabecera_Lineas_PrecioAMostrar_SelectedIndexChanged(object sender, EventArgs e)
{
if (g_obj_Controladora != null && g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial)
{
g_obj_Controladora.Rellenar_DataGrid_FacturaLinea();
}
}
#region Botones
private void ex_btn_P_FacturaCabecera_Lineas_Add_Click(object sender, EventArgs e)
{
Add_FacturaLinea();
}
private void Add_FacturaLinea()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if ((Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Anadir, true)))
{
//Si el Documento esta cerrado no puedo grabar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
//Saber si hay que guardar primero la linea
if (g_obj_Controladora.ComprobarCambios_AfectaLineas())
{
INTERNO_OpcionesDetalle_Modelo mdl_INTERNO_OpcionesDetalle_Modelo = Datos_Generales.PRV_Opciones_Buscar_Detalles(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA);
//Poner el Listado para el paginado ....................................................
List<INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo> lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = g_obj_Controladora.Filtrar_FacturaLinea();
if (lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null && lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
string str_CampoOrdenar = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_NOMBRECOLUMNA_PORDEFECTO();
if (ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem != null && ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador.Trim().Length > 0)
{
str_CampoOrdenar = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador;
}
//Descendente
if (ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag.ToString().Equals("1"))
{
lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.OrderByDescending(m => m.GetType().GetProperty(str_CampoOrdenar).GetValue(m, null)).ToList();
}
//Ascendente
else
{
lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.OrderBy(m => m.GetType().GetProperty(str_CampoOrdenar).GetValue(m, null)).ToList();
}
P_Base_Objetos_Filtrados = lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(m => m.idAlbaranFacturaLinea_Padre == null).Select(m => new INTERNO_Listado_CamposClave_Modelo { ID = m.id }).ToList();
}
else
{
P_Base_Objetos_Filtrados = null;
}
//......................................................................................
//Poner el Listado de las lineas sin Filtrar ...........................................
if (g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null &&
g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
P_Base_Objetos_Listado = g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(m => m.idAlbaranFacturaLinea_Padre == null).Select(m => new INTERNO_Listado_CamposClave_Modelo
{
ID = m.id,
ID_Aux1 = (m.idArticulo != null ? m.idArticulo.Value : -1),
Dato_Auxiliar = (m.Articulo_Codigo + " - " + m.Articulo_Descripcion),
ID_Aux2 = (m.idArticuloComodin != null ? m.idArticuloComodin.Value : -1),
Dato_Auxiliar2 = (m.ArticuloComodin_Codigo + " - " + m.descripcionArticuloComodin)
}).ToList();
}
else
{
P_Base_Objetos_Listado = null;
}
//......................................................................................
//Buscar Opciones Modelo
P_FacturaLinea frm_P_FacturaLinea = new P_FacturaLinea(P_Base_ValoresGenerales,
P_Base_FechaTrabajo,
mdl_INTERNO_OpcionesDetalle_Modelo,
g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo,
g_obj_Controladora.g_lst_INTERNO_ImportesImpuestos_Modelo,
g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE,
g_obj_Controladora.g_str_Estado,
(g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null ? g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count : 0),
g_obj_Controladora.g_lst_Ids_Articulos_Servicio,
false);
//Se llamo desde una pantalla
frm_P_FacturaLinea.P_Base_TipoAperturaPantalla = 0;
frm_P_FacturaLinea.P_Base_PantallaPadre_IdentificadorTAG = this.Tag.ToString();
frm_P_FacturaLinea.P_Base_PantallaOrigen = this;
frm_P_FacturaLinea.P_Base_TituloPantalla_CaminoHormigas = mdl_INTERNO_OpcionesDetalle_Modelo.descripcion_TituloMantenimiento.ToUpper() + " -> Alta";
Funciones_PanelPrincipal.Cargar_PantallaEmpotrada(frm_P_FacturaLinea, Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA);
}
}
}
}
}
private void ex_btn_P_FacturaCabecera_Lineas_Ver_Click(object sender, EventArgs e)
{
Ver_FacturaLinea();
}
private void ex_dgv_P_FacturaCabecera_Lineas_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
{
Ver_FacturaLinea();
}
private void Ver_FacturaLinea()
{
if ((Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Ver, true)))
{
//Ver si hay alguno seleccionado
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0 && ex_dgv_P_FacturaCabecera_Lineas.SelectedRows.Count > 0)
{
//Saber si hay que guardar primero la linea
if (g_obj_Controladora.ComprobarCambios_AfectaLineas())
{
INTERNO_OpcionesDetalle_Modelo mdl_INTERNO_OpcionesDetalle_Modelo = Datos_Generales.PRV_Opciones_Buscar_Detalles(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA);
//Poner el Listado para el paginado ....................................................
List<INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo> lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = g_obj_Controladora.Filtrar_FacturaLinea();
if (lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null && lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
string str_CampoOrdenar = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_NOMBRECOLUMNA_PORDEFECTO();
if (ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem != null && ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador.Trim().Length > 0)
{
str_CampoOrdenar = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador;
}
//Descendente
if (ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag.ToString().Equals("1"))
{
lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.OrderByDescending(m => m.GetType().GetProperty(str_CampoOrdenar).GetValue(m, null)).ToList();
}
//Ascendente
else
{
lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo = lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.OrderBy(m => m.GetType().GetProperty(str_CampoOrdenar).GetValue(m, null)).ToList();
}
P_Base_Objetos_Filtrados = lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(m => m.idAlbaranFacturaLinea_Padre == null).Select(m => new INTERNO_Listado_CamposClave_Modelo { ID = m.id }).ToList();
}
else
{
P_Base_Objetos_Filtrados = null;
}
//......................................................................................
//Poner el Listado de las lineas sin Filtrar ...........................................
if (g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null &&
g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
P_Base_Objetos_Listado = g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(m => m.idAlbaranFacturaLinea_Padre == null).Select(m => new INTERNO_Listado_CamposClave_Modelo
{
ID = m.id,
ID_Aux1 = (m.idArticulo != null ? m.idArticulo.Value : -1),
Dato_Auxiliar = (m.Articulo_Codigo + " - " + m.Articulo_Descripcion),
ID_Aux2 = (m.idArticuloComodin != null ? m.idArticuloComodin.Value : -1),
Dato_Auxiliar2 = (m.ArticuloComodin_Codigo + " - " + m.descripcionArticuloComodin)
}).ToList();
}
else
{
P_Base_Objetos_Listado = null;
}
//......................................................................................
//Buscar Opciones Modelo
//Ver si la linea esta en un albaran cobrado
bool bol_AlbaranCobrado = false;
if (g_obj_Controladora != null && g_obj_Controladora.g_lst_idAlbaranCabecera_Cobrados != null && g_obj_Controladora.g_lst_idAlbaranCabecera_Cobrados.Count > 0)
{
if (ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranCabecera)].Value != null &&
long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranCabecera)].Value.ToString()) > 0 &&
g_obj_Controladora.g_lst_idAlbaranCabecera_Cobrados.Exists(m => m == long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranCabecera)].Value.ToString())))
{
bol_AlbaranCobrado = true;
}
}
P_FacturaLinea frm_P_FacturaLinea = new P_FacturaLinea(P_Base_ValoresGenerales,
P_Base_FechaTrabajo, mdl_INTERNO_OpcionesDetalle_Modelo,
g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo,
g_obj_Controladora.g_lst_INTERNO_ImportesImpuestos_Modelo,
g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE,
g_obj_Controladora.g_str_Estado,
(g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null ? g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count : 0),
g_obj_Controladora.g_lst_Ids_Articulos_Servicio,
bol_AlbaranCobrado);
//Si es un articulo en prmocion, se abre el articulo principal
long lng_idFacturaLinea = long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString());
if (ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranFacturaLinea_Padre)].Value != null &&
!ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranFacturaLinea_Padre)].Value.ToString().Equals("-1"))
{
lng_idFacturaLinea = long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranFacturaLinea_Padre)].Value.ToString());
}
frm_P_FacturaLinea.P_Base_TipoAperturaPantalla = 1;
frm_P_FacturaLinea.P_Base_PantallaPadre_IdentificadorTAG = this.Tag.ToString();
frm_P_FacturaLinea.P_Base_PantallaOrigen = this;
frm_P_FacturaLinea.P_Base_id = lng_idFacturaLinea;
frm_P_FacturaLinea.P_Base_TituloPantalla_CaminoHormigas = mdl_INTERNO_OpcionesDetalle_Modelo.descripcion_TituloMantenimiento.ToUpper() + " -> Alta";
Funciones_PanelPrincipal.Cargar_PantallaEmpotrada(frm_P_FacturaLinea, Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA);
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_LISTADOS_NOHAYREGISTROSSELECCIONADOS());
}
}
}
private void ex_btn_P_FacturaCabecera_Lineas_Borrar_Click(object sender, EventArgs e)
{
Borrar_FacturaLinea();
}
private void Borrar_FacturaLinea()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if (Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Borrar, true))
{
//Ver si hay algunbo seleccionado
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0 && ex_dgv_P_FacturaCabecera_Lineas.SelectedRows.Count > 0)
{
//Si el Documento esta cerrado no puedo borrar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
List<long> lst_ids_ABorrar = new List<long>();
List<long> lst_ids_ABorrar_RELACIONADO = new List<long>();
string str_MensajesLineaNoSePuedeBorrar = "";
bool bol_Borrar = true;
foreach (DataGridViewRow dgvr in ex_dgv_P_FacturaCabecera_Lineas.SelectedRows)
{
bol_Borrar = true;
//Ver si la linea esta en un albaran cobrado
if (g_obj_Controladora!=null && g_obj_Controladora.g_lst_idAlbaranCabecera_Cobrados!=null && g_obj_Controladora.g_lst_idAlbaranCabecera_Cobrados.Count>0)
{
if (dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranCabecera)].Value != null &&
long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranCabecera)].Value.ToString()) > 0 &&
g_obj_Controladora.g_lst_idAlbaranCabecera_Cobrados.Exists(m=>m== long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranCabecera)].Value.ToString())))
{
str_MensajesLineaNoSePuedeBorrar += " - La línea '" + dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.numeroLineaFactura)].Value.ToString() + "' es de un albarán cobrado y no se puede modificar" + System.Environment.NewLine;
bol_Borrar = false;
}
}
if (bol_Borrar)
{
// Promocion por unidad
if (dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranFacturaLinea_Padre)].Value != null &&
long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.idAlbaranFacturaLinea_Padre)].Value.ToString()) > 0)
{
lst_ids_ABorrar_RELACIONADO.Add(long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString()));
}
// El Resto
else
{
lst_ids_ABorrar.Add(long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString()));
}
}
}
if (str_MensajesLineaNoSePuedeBorrar.Trim().Length>0)
{
Mensajes.MostrarMensaje_Y_EsperarRespuesta(str_MensajesLineaNoSePuedeBorrar);
}
//Borrar lineas sobrantes
if (lst_ids_ABorrar != null && lst_ids_ABorrar.Count > 0)
{
g_obj_Controladora.Borrar_Registro_FacturaLinea_EnBaseDatos(lst_ids_ABorrar, lst_ids_ABorrar_RELACIONADO);
}
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_LISTADOS_NOHAYREGISTROSSELECCIONADOS());
}
}
}
}
#endregion
#region Ordenar
private void ex_btn_P_FacturaCabecera_Linea_OrdenListado_Click(object sender, EventArgs e)
{
//Esta Descedente
if (ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag.ToString().Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
}
//Esta Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
}
Ordenar_DataGridView_FacturaLinea();
}
private void ex_dgv_P_FacturaCabecera_Lineas_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
try
{
//Mostrar u Ocultar las columnas
if (e.Button == MouseButtons.Left)
{
string str_CambioOrdenAnterior = "";
if (ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem != null)
{
str_CambioOrdenAnterior = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador;
}
//Seleccionar la columna en el Combo de orden
ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Identificador.Equals(ex_dgv_P_FacturaCabecera_Lineas.Columns[e.ColumnIndex].Name)).FirstOrDefault();
if (str_CambioOrdenAnterior.Equals(((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador))
{
//Si estaba Ascendente lo pongo descendente
if (ex_dgv_P_FacturaCabecera_Lineas.SortOrder == SortOrder.Ascending)
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
}
//Si estaba descendente lo pongo Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_Lineas_OrdenListado);
}
}
Ordenar_DataGridView_FacturaLinea();
}
}
catch
{ }
}
private void ex_cbo_P_FacturaCabecera_Lineas_OrdenListado_SelectedIndexChanged(object sender, EventArgs e)
{
//Saber el Tipo de Ordenacion .................................
ListSortDirection obj_ListSortDirection = ListSortDirection.Ascending;
if (ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag.ToString().Equals("1"))
{
obj_ListSortDirection = ListSortDirection.Descending;
}
//..............................................................
//Cambiar el tipo Orden en Listado
ex_dgv_P_FacturaCabecera_Lineas.Sort(ex_dgv_P_FacturaCabecera_Lineas.Columns[((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador], obj_ListSortDirection);
Ordenar_DataGridView_FacturaLinea();
}
public void Ordenar_DataGridView_FacturaLinea()
{
try
{
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0)
{
//Saber el Tipo de Ordenacion .................................
ListSortDirection obj_ListSortDirection = ListSortDirection.Ascending;
if (ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag.ToString().Equals("1"))
{
obj_ListSortDirection = ListSortDirection.Descending;
}
//..............................................................
if (ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem != null && ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador.Trim().Length > 0)
{
ex_dgv_P_FacturaCabecera_Lineas.Sort(ex_dgv_P_FacturaCabecera_Lineas.Columns[((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Identificador], obj_ListSortDirection);
}
else
{
ex_dgv_P_FacturaCabecera_Lineas.Sort(ex_dgv_P_FacturaCabecera_Lineas.Columns[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.ORDENACION_NOMBRECOLUMNA_PORDEFECTO()], obj_ListSortDirection);
}
}
}
catch (Exception)
{ }
}
#endregion
#region Filtros
private void ex_btn_P_FacturaCabecera_Lineas_Filtros_Click(object sender, EventArgs e)
{
MostrarOcultar_Columnas_Y_Fitros_FacturaLinea(ex_btn_P_FacturaCabecera_Lineas_Filtros.Location.X, 0);
}
private void MostrarOcultar_Columnas_Y_Fitros_FacturaLinea(int _int_PosicionX, int _int_PosicionY)
{
PE_Listados_Filtros frm_PE_Listados_Filtros = new PE_Listados_Filtros(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas, ex_dgv_P_FacturaCabecera_Lineas.Columns, g_obj_Controladora.g_dct_ListadoFiltros_VTA_AlbaranesFacturasLineas);
frm_PE_Listados_Filtros.ShowDialog();
if (frm_PE_Listados_Filtros.g_bol_BotonAceptar)
{
//Mostrar/Ocultar las Columnas que no esten en el Listado
g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas = frm_PE_Listados_Filtros.g_lst_ColumnasAMostrar;
foreach (DataGridViewColumn dgvc_ColumnasActuales in ex_dgv_P_FacturaCabecera_Lineas.Columns)
{
//Mostrar
if (g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas.Contains(dgvc_ColumnasActuales.Name))
{
dgvc_ColumnasActuales.Visible = true;
}
//Ocultar
else
{
dgvc_ColumnasActuales.Visible = false;
}
}
//Rellenar los nuevos filtros
g_obj_Controladora.g_dct_ListadoFiltros_VTA_AlbaranesFacturasLineas = frm_PE_Listados_Filtros.g_dct_ListadoFiltros.ToDictionary(entry => entry.Key, entry => entry.Value);
//Recargar el Listado
g_obj_Controladora.Rellenar_DataGrid_FacturaLinea();
}
}
#endregion
#endregion
#region FacturaLineas Comentarios
private void CrearColumnas_Listado_AlbaranesFacturasLineasComentarios()
{
ex_dgv_P_FacturaCabecera_LineasComentarios.AutoGenerateColumns = false;
g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_Modelo_Comentarios_Columnas = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.LISTADO_COLUMNAS().Values.ToList();
foreach (INTERNO_ABS_Listado_ColumnasDatos_Modelo mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo in g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_Modelo_Comentarios_Columnas)
{
DataGridViewTextBoxColumn dgv_Columna = new DataGridViewTextBoxColumn();
dgv_Columna.DataPropertyName = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.Name = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.HeaderText = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar;
//Poner visible o no .........................................................................
bool bol_Visible = true;
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto)
{
bol_Visible = false;
}
else if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNASAMOSTRAR != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNASAMOSTRAR.Count > 0)
{
if (!g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNASAMOSTRAR.Contains(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
bol_Visible = false;
}
}
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Mostrado_PorDefecto == false)
{
bol_Visible = false;
}
dgv_Columna.Visible = bol_Visible;
if (bol_Visible)
{
g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas_Comentarios.Add(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna);
}
//.....................................................................................................
//Tipo de Formateo si fuera Fecha
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
dgv_Columna.DefaultCellStyle.Format = "d";
}
//Poner Ancho Columna ................................................................................
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ANCHO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ANCHO.Count > 0 &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ANCHO.ContainsKey(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
dgv_Columna.Width = g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ANCHO[mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna];
}
else
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho > 0)
{
dgv_Columna.Width = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho;
}
}
//................................................................................................................
dgv_Columna.ReadOnly = true;
//Poner alineado segun tipo de datos ......................................................................................
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT))
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight;
}
else
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleLeft;
}
//..............................................................................................................................
ex_dgv_P_FacturaCabecera_LineasComentarios.Columns.Add(dgv_Columna);
//RELLENAR EL ORDEN EN COMBO
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto == false)
{
ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.Items.Add(new INTERNO_ComboBox_Modelo(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna, mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar, null));
}
//Ajustamos la celda a su contenido.
dgv_Columna.DefaultCellStyle.WrapMode = DataGridViewTriState.True;
}
//Cambiar el orden de las columnas ........
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ORDEN != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ORDEN.Count > 0)
{
foreach (KeyValuePair<string, int> kvp_Valores in g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEACOMENTARIOS.LISTADO_COLUMNAS_ORDEN)
{
ex_dgv_P_FacturaCabecera_LineasComentarios.Columns[kvp_Valores.Key].DisplayIndex = kvp_Valores.Value;
}
}
//.........................................
}
private void ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios_Click(object sender, EventArgs e)
{
//Si tiene un 1 en el tag significa que se esta mostrando y hay que ocultarlo
if (ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Tag.ToString().Equals("1"))
{
spc_P_FacturaCabecera_Lineas.Panel2Collapsed = true;
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Text = "5";
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Exferia_Button_ToolTip = "Mostrar comentarios";
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Tag = "0";
}
//Si tiene un 0 en el tag significa que esta oculto y hay que mostrarlo
else
{
spc_P_FacturaCabecera_Lineas.Panel2Collapsed = false;
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Text = "6";
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Exferia_Button_ToolTip = "Ocultar comentarios";
ex_btn_P_FacturaCabecera_MostrarOcultar_Comentarios.Tag = "1";
}
}
#region Borrar
private void ex_btn_P_FacturaCabecera_Comentarios_Borrar_Click(object sender, EventArgs e)
{
Borrar_FacturaCabecera_Comentarios();
}
private void Borrar_FacturaCabecera_Comentarios()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if (Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_COMENTARIOS, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Borrar, true))
{
//Ver si hay algunbo seleccionado
if (ex_dgv_P_FacturaCabecera_LineasComentarios.Rows.Count > 0 &&
ex_dgv_P_FacturaCabecera_LineasComentarios.SelectedRows.Count > 0)
{
//Si el Documento esta cerrado no puedo borrar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
List<long> lst_ids_ABorrar = new List<long>();
foreach (DataGridViewRow dgvr in ex_dgv_P_FacturaCabecera_LineasComentarios.SelectedRows)
{
lst_ids_ABorrar.Add(long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Comentarios_Listado_Modelo.id)].Value.ToString()));
}
g_obj_Controladora.BorrarDatos_FacturaLineaComentarios(lst_ids_ABorrar);
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_LISTADOS_NOHAYREGISTROSSELECCIONADOS());
}
}
}
}
#endregion
#region Ordenar
private void ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado_Click(object sender, EventArgs e)
{
//Esta Descedente
if (ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag.ToString().Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
}
//Esta Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
}
AlbaranesFacturasLineasComentarios_Ordenar_DataGridView();
}
private void ex_dgv_P_FacturaCabecera_LineasComentarios_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
try
{
//Mostrar u Ocultar las columnas
if (e.Button == MouseButtons.Left)
{
string str_CambioOrdenAnterior = "";
if (ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem != null)
{
str_CambioOrdenAnterior = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem).Identificador;
}
//Seleccionar la columna en el Combo de orden
ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Identificador.Equals(ex_dgv_P_FacturaCabecera_LineasComentarios.Columns[e.ColumnIndex].Name)).FirstOrDefault();
if (str_CambioOrdenAnterior.Equals(((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem).Identificador))
{
//Si estaba Ascendente lo pongo descendente
if (ex_dgv_P_FacturaCabecera_LineasComentarios.SortOrder == SortOrder.Ascending)
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
}
//Si estaba descendente lo pongo Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado);
}
}
AlbaranesFacturasLineasComentarios_Ordenar_DataGridView();
}
}
catch
{ }
}
private void ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado_SelectedIndexChanged(object sender, EventArgs e)
{
//Saber el Tipo de Ordenacion .................................
ListSortDirection obj_ListSortDirection = ListSortDirection.Ascending;
if (ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag.ToString().Equals("1"))
{
obj_ListSortDirection = ListSortDirection.Descending;
}
//..............................................................
//Cambiar el tipo Orden en Listado
ex_dgv_P_FacturaCabecera_LineasComentarios.Sort(ex_dgv_P_FacturaCabecera_LineasComentarios.Columns[((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem).Identificador], obj_ListSortDirection);
AlbaranesFacturasLineasComentarios_Ordenar_DataGridView();
}
public void AlbaranesFacturasLineasComentarios_Ordenar_DataGridView()
{
try
{
if (ex_dgv_P_FacturaCabecera_LineasComentarios.Rows.Count > 0)
{
//Saber el Tipo de Ordenacion .................................
ListSortDirection obj_ListSortDirection = ListSortDirection.Ascending;
if (ex_btn_P_FacturaCabecera_LineasComentarios_OrdenListado.Tag.ToString().Equals("1"))
{
obj_ListSortDirection = ListSortDirection.Descending;
}
//..............................................................
if (ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem != null && ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem).Identificador.Trim().Length > 0)
{
ex_dgv_P_FacturaCabecera_LineasComentarios.Sort(ex_dgv_P_FacturaCabecera_LineasComentarios.Columns[((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasComentarios_OrdenListado.SelectedItem).Identificador], obj_ListSortDirection);
}
else
{
ex_dgv_P_FacturaCabecera_LineasComentarios.Sort(ex_dgv_P_FacturaCabecera_LineasComentarios.Columns[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Comentarios.ORDENACION_NOMBRECOLUMNA_PORDEFECTO()], obj_ListSortDirection);
}
}
}
catch (Exception)
{ }
}
#endregion
#endregion
#region FacturasLineas Trazabilidad
private void CrearColumnas_Listado_FacturaLineaTrazabilidad()
{
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.AutoGenerateColumns = false;
g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_Modelo_FacturaLineas_Trazabilidad_Columnas = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.LISTADO_COLUMNAS().Values.ToList();
foreach (INTERNO_ABS_Listado_ColumnasDatos_Modelo mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo in g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_Modelo_FacturaLineas_Trazabilidad_Columnas)
{
DataGridViewTextBoxColumn dgv_Columna = new DataGridViewTextBoxColumn();
dgv_Columna.DataPropertyName = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.Name = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.HeaderText = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar;
//Poner visible o no .........................................................................
bool bol_Visible = true;
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto)
{
bol_Visible = false;
}
else if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNASAMOSTRAR != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNASAMOSTRAR.Count > 0)
{
if (!g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNASAMOSTRAR.Contains(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
bol_Visible = false;
}
}
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Mostrado_PorDefecto == false)
{
bol_Visible = false;
}
dgv_Columna.Visible = bol_Visible;
if (bol_Visible)
{
g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas_Trazabilidad.Add(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna);
}
//.....................................................................................................
//Tipo de Formateo si fuera Fecha
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DATETIME))
{
dgv_Columna.DefaultCellStyle.Format = "d";
}
//Poner Ancho Columna ................................................................................
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ANCHO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ANCHO.Count > 0 &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ANCHO.ContainsKey(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
dgv_Columna.Width = g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ANCHO[mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna];
}
else
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho > 0)
{
dgv_Columna.Width = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho;
}
}
//................................................................................................................
dgv_Columna.ReadOnly = true;
//Poner alineado segun tipo de datos ......................................................................................
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT))
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight;
}
else
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleLeft;
}
//..............................................................................................................................
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns.Add(dgv_Columna);
//RELLENAR EL ORDEN EN COMBO
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto == false)
{
ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Items.Add(new INTERNO_ComboBox_Modelo(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna, mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar, null));
}
}
//Cambiar el orden de las columnas ........
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD != null && g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ORDEN != null && g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ORDEN.Count > 0)
{
foreach (KeyValuePair<string, int> kvp_Valores in g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FacturaLINEATRAZABILIDAD.LISTADO_COLUMNAS_ORDEN)
{
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns[kvp_Valores.Key].DisplayIndex = kvp_Valores.Value;
}
}
//.........................................
}
private void ex_dgv_P_FacturaCabecera_LineasTrazabilidad_SelectionChanged(object sender, EventArgs e)
{
if (ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Rows.Count > 0 &&
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.SelectedRows.Count > 0)
{
g_obj_Controladora.ArbolSecundario_Cambiar_ClienteArticulo(Exferia_F3_Cliente.Exferia_F3_Id);
}
}
#region Botones
private void ex_btn_P_FacturaCabecera_Trazabilidad_Add_Click(object sender, EventArgs e)
{
Add_FacturaLinea_Trazabilidad();
}
private void Add_FacturaLinea_Trazabilidad()
{
try
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null)
{
if ((Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Anadir, true)))
{
//Ver si hay alguno seleccionado
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0 && ex_dgv_P_FacturaCabecera_Lineas.SelectedRows.Count > 0)
{
//Si el Documento esta cerrado no puedo grabar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
long lng_idAlbaranFacturaLinea = long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString());
INTERNO_OpcionesDetalle_Modelo mdl_INTERNO_OpcionesDetalle_Modelo = Datos_Generales.PRV_Opciones_Buscar_Detalles(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD);
List<INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo> lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo = g_obj_Controladora.Obtener_FacturaLineas_Trazabilidad_Listado_PorLinea(lng_idAlbaranFacturaLinea);
//Buscar el Modelo de la Linea
object[] arr_ObjetosDevueltos = g_obj_Controladora.Obtener_Datos_ParaTrazabilidad(long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.id)].Value.ToString()));
if (arr_ObjetosDevueltos != null)
{
//Si no tiene FacturaLinea no abre la pantalla
if (arr_ObjetosDevueltos[0] == null)
{
Mensajes.MostrarMensaje(Mensajes.G_STR_FACTURAS_VALIDACION_FACTURASLINEA_NOEXISTE());
}
else
{
if ((((INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0]).MAE_Articulos.tipoTrazabilidad_Salidas.Equals(Variables.G_MDL_TIPOSTRAZABILIDAD_OPCIONAL.Codigo) ||
((INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0]).MAE_Articulos.tipoTrazabilidad_Salidas.Equals(Variables.G_MDL_TIPOSTRAZABILIDAD_OBLIGATORIA.Codigo)))
{
//Buscar Opciones Modelo
P_FacturaLinea_Trazabilidad frm_P_FacturaLinea_Trazabilidad = new P_FacturaLinea_Trazabilidad(P_Base_ValoresGenerales,
P_Base_FechaTrabajo,
mdl_INTERNO_OpcionesDetalle_Modelo,
g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo,
(INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0],
lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo,
g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE,
g_obj_Controladora.g_str_Estado,
(((INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0]).idAlbaranFacturaLinea_Padre != null ? true : false));
//Se llamo desde una pantalla
frm_P_FacturaLinea_Trazabilidad.P_Base_TipoAperturaPantalla = 0;
frm_P_FacturaLinea_Trazabilidad.P_Base_PantallaPadre_IdentificadorTAG = this.Tag.ToString();
frm_P_FacturaLinea_Trazabilidad.P_Base_PantallaOrigen = this;
frm_P_FacturaLinea_Trazabilidad.P_Base_TituloPantalla_CaminoHormigas = mdl_INTERNO_OpcionesDetalle_Modelo.descripcion_TituloMantenimiento.ToUpper() + " -> Alta";
Funciones_PanelPrincipal.Cargar_PantallaEmpotrada(frm_P_FacturaLinea_Trazabilidad, Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD);
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_TRAZABILIDAD_SINTRAZABILIDAD());
}
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_FACTURAS_VALIDACION_FACTURASLINEA_NOEXISTE());
}
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_LISTADOS_NOHAYREGISTROSSELECCIONADOS());
}
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_DEBEGRABARPRIMERO(g_mdl_PRV_OpcionesDetalle.descripcion_Singular));
}
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(Add_FacturaLinea_Trazabilidad));
}
}
private void ex_btn_P_FacturaCabecera_Trazabilidad_Ver_Click(object sender, EventArgs e)
{
Ver_FacturaLinea_Trazabilidad();
}
private void ex_dgv_P_FacturaCabecera_LineasTrazabilidad_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
{
Ver_FacturaLinea_Trazabilidad();
}
private void Ver_FacturaLinea_Trazabilidad()
{
try
{
if ((Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Ver, true)))
{
//Ver si hay alguno seleccionado
if (ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Rows.Count > 0 && ex_dgv_P_FacturaCabecera_LineasTrazabilidad.SelectedRows.Count > 0)
{
INTERNO_OpcionesDetalle_Modelo mdl_INTERNO_OpcionesDetalle_Modelo = Datos_Generales.PRV_Opciones_Buscar_Detalles(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD);
long lng_idAlbaranFacturaLinea = long.Parse(ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.id)].Value.ToString());
List<INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo> lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo = g_obj_Controladora.Obtener_FacturaLineas_Trazabilidad_Listado_PorLinea(lng_idAlbaranFacturaLinea);
//Poner el Listado para el paginado ....................................................
if (lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo != null && lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.Count > 0)
{
string str_CampoOrdenar = g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.ORDENACION_NOMBRECOLUMNA_PORDEFECTO();
if (ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem != null && ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador.Trim().Length > 0)
{
str_CampoOrdenar = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador;
}
//Descendente
if (ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag.ToString().Equals("1"))
{
lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo = lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.OrderByDescending(m => m.GetType().GetProperty(str_CampoOrdenar).GetValue(m, null)).ToList();
}
//Ascendente
else
{
lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo = lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.OrderBy(m => m.GetType().GetProperty(str_CampoOrdenar).GetValue(m, null)).ToList();
}
P_Base_Objetos_Filtrados_AUX1 = lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.Select(m => new INTERNO_Listado_CamposClave_Modelo { ID = m.id }).ToList();
}
else
{
P_Base_Objetos_Filtrados_AUX1 = null;
}
//......................................................................................
//Buscar el Modelo de la Linea
object[] arr_ObjetosDevueltos = g_obj_Controladora.Obtener_Datos_ParaTrazabilidad(lng_idAlbaranFacturaLinea);
if (arr_ObjetosDevueltos != null)
{
//Si no tiene FacturaLinea no abre la pantalla
if (arr_ObjetosDevueltos[0] == null)
{
Mensajes.MostrarMensaje(Mensajes.G_STR_FACTURAS_VALIDACION_FACTURASLINEA_NOEXISTE());
}
else
{
if ((((INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0]).MAE_Articulos.tipoTrazabilidad_Salidas.Equals(Variables.G_MDL_TIPOSTRAZABILIDAD_OPCIONAL.Codigo) ||
((INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0]).MAE_Articulos.tipoTrazabilidad_Salidas.Equals(Variables.G_MDL_TIPOSTRAZABILIDAD_OBLIGATORIA.Codigo)))
{
//Buscar Opciones Modelo
P_FacturaLinea_Trazabilidad frm_P_FacturaLinea_Trazabilidad = new P_FacturaLinea_Trazabilidad(P_Base_ValoresGenerales,
P_Base_FechaTrabajo,
mdl_INTERNO_OpcionesDetalle_Modelo,
g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo,
(INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0],
lst_INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo,
g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE,
g_obj_Controladora.g_str_Estado,
(((INTERNO_VTA_AlbaranesFacturasLineas_Modelo)arr_ObjetosDevueltos[0]).idAlbaranFacturaLinea_Padre != null ? true : false));
//Se llamo desde una pantalla
frm_P_FacturaLinea_Trazabilidad.P_Base_TipoAperturaPantalla = 1;
frm_P_FacturaLinea_Trazabilidad.P_Base_PantallaPadre_IdentificadorTAG = this.Tag.ToString();
frm_P_FacturaLinea_Trazabilidad.P_Base_PantallaOrigen = this;
frm_P_FacturaLinea_Trazabilidad.P_Base_id = long.Parse(ex_dgv_P_FacturaCabecera_LineasTrazabilidad.SelectedRows[0].Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.id)].Value.ToString());
frm_P_FacturaLinea_Trazabilidad.P_Base_TituloPantalla_CaminoHormigas = mdl_INTERNO_OpcionesDetalle_Modelo.descripcion_TituloMantenimiento.ToUpper() + " -> Modificacion";
Funciones_PanelPrincipal.Cargar_PantallaEmpotrada(frm_P_FacturaLinea_Trazabilidad, Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD);
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_TRAZABILIDAD_SINTRAZABILIDAD());
}
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_FACTURAS_VALIDACION_FACTURASLINEA_NOEXISTE());
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_LISTADOS_NOHAYREGISTROSSELECCIONADOS());
}
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(Ver_FacturaLinea_Trazabilidad));
}
}
private void ex_btn_P_FacturaCabecera_Trazabilidad_Borrar_Click(object sender, EventArgs e)
{
Borrar_FacturaLinea_Trazabilidad();
}
private void Borrar_FacturaLinea_Trazabilidad()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if (Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Borrar, true))
{
//Ver si hay algunbo seleccionado
if (ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Rows.Count > 0 && ex_dgv_P_FacturaCabecera_LineasTrazabilidad.SelectedRows.Count > 0)
{
//Si el Documento esta cerrado no puedo borrar
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) || g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
List<long> lst_ids_ABorrar = new List<long>();
foreach (DataGridViewRow dgvr in ex_dgv_P_FacturaCabecera_LineasTrazabilidad.SelectedRows)
{
lst_ids_ABorrar.Add(long.Parse(dgvr.Cells[nameof(INTERNO_VTA_AlbaranesFacturasLineas_Trazabilidad_Listado_Modelo.id)].Value.ToString()));
}
g_obj_Controladora.BorrarDatos_FacturaLineasTrazabilidad(lst_ids_ABorrar);
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_LISTADOS_NOHAYREGISTROSSELECCIONADOS());
}
}
}
}
#endregion
#region Ordenar
private void ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado_Click(object sender, EventArgs e)
{
//Esta Descedente
if (ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag.ToString().Equals("1"))
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
}
//Esta Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
}
FacturaLinea_Trazabilidad_Ordenar_DataGridView();
}
private void ex_dgv_P_FacturaCabecera_LineasTrazabilidad_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
try
{
//Mostrar u Ocultar las columnas
if (e.Button == MouseButtons.Left)
{
string str_CambioOrdenAnterior = "";
if (ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem != null)
{
str_CambioOrdenAnterior = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador;
}
//Seleccionar la columna en el Combo de orden
ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem = ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Items.Cast<INTERNO_ComboBox_Modelo>().Where(m => m.Identificador.Equals(ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns[e.ColumnIndex].Name)).FirstOrDefault();
if (str_CambioOrdenAnterior.Equals(((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador))
{
//Si estaba Ascendente lo pongo descendente
if (ex_dgv_P_FacturaCabecera_LineasTrazabilidad.SortOrder == SortOrder.Ascending)
{
Funciones.Cambiar_Imagen_Boton_Orden(1, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
}
//Si estaba descendente lo pongo Ascendente
else
{
Funciones.Cambiar_Imagen_Boton_Orden(0, ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado);
}
}
FacturaLinea_Trazabilidad_Ordenar_DataGridView();
}
}
catch
{ }
}
private void ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado_SelectedIndexChanged(object sender, EventArgs e)
{
//Saber el Tipo de Ordenacion .................................
ListSortDirection obj_ListSortDirection = ListSortDirection.Ascending;
if (ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag.ToString().Equals("1"))
{
obj_ListSortDirection = ListSortDirection.Descending;
}
//..............................................................
//Cambiar el tipo Orden en Listado
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Sort(ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns[((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador], obj_ListSortDirection);
FacturaLinea_Trazabilidad_Ordenar_DataGridView();
}
public void FacturaLinea_Trazabilidad_Ordenar_DataGridView()
{
try
{
if (ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Rows.Count > 0)
{
//Saber el Tipo de Ordenacion .................................
ListSortDirection obj_ListSortDirection = ListSortDirection.Ascending;
if (ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag.ToString().Equals("1"))
{
obj_ListSortDirection = ListSortDirection.Descending;
}
//..............................................................
if (ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem != null && ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador.Trim().Length > 0)
{
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Sort(ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns[((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Identificador], obj_ListSortDirection);
}
else
{
ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Sort(ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.ORDENACION_NOMBRECOLUMNA_PORDEFECTO()], obj_ListSortDirection);
}
}
}
catch (Exception)
{ }
}
#endregion
#endregion
#region FacturaResumen
private void CrearColumnas_Listado_FacturaResumen()
{
ex_dgv_P_FacturaCabecera_Resumen.AutoGenerateColumns = false;
g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_ModeloFacturaCabeceraResumen_Columnas = g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.LISTADO_COLUMNAS().Values.ToList();
foreach (INTERNO_ABS_Listado_ColumnasDatos_Modelo mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo in g_obj_Controladora.g_lst_INTERNO_ABS_Listado_ColumnasDatos_ModeloFacturaCabeceraResumen_Columnas)
{
DataGridViewTextBoxColumn dgv_Columna = new DataGridViewTextBoxColumn();
dgv_Columna.DataPropertyName = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.Name = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna;
dgv_Columna.HeaderText = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_AMostrar;
dgv_Columna.SortMode = DataGridViewColumnSortMode.NotSortable;
//Poner visible o no .........................................................................
bool bol_Visible = true;
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.NoOcultable == false)
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Oculto)
{
bol_Visible = false;
}
else if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNASAMOSTRAR != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNASAMOSTRAR.Count > 0)
{
if (!g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNASAMOSTRAR.Contains(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
bol_Visible = false;
}
}
else if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Mostrado_PorDefecto == false)
{
bol_Visible = false;
}
}
dgv_Columna.Visible = bol_Visible;
if (bol_Visible)
{
g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_FacturasCabecera_Resumen.Add(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna);
}
//.....................................................................................................
//Poner Ancho Columna ................................................................................
if (g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNAS_ANCHO != null &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNAS_ANCHO.Count > 0 &&
g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNAS_ANCHO.ContainsKey(mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna))
{
dgv_Columna.Width = g_mdl_INTERNO_ConfiguracionPantalla_Modelo_FACTURARESUMEN.LISTADO_COLUMNAS_ANCHO[mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Descripcion_Interna];
}
else
{
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho > 0)
{
dgv_Columna.Width = mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.Ancho;
}
}
//................................................................................................................
dgv_Columna.ReadOnly = true;
//Poner alineado segun tipo de datos ......................................................................................
if (mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.DECIMAL) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.LONG_TEXT) ||
mdl_INTERNO_ABS_Listado_ColumnasDatos_Modelo.TipoDato.Equals(G_ENUM_TIPOSDATOS.INT))
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight;
}
else
{
dgv_Columna.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleLeft;
}
//..............................................................................................................................
ex_dgv_P_FacturaCabecera_Resumen.Columns.Add(dgv_Columna);
}
//.........................................
}
#region Filtros
private void ex_btn_P_FacturaCabecera_Resumen_Filtros_Click(object sender, EventArgs e)
{
MostrarOcultar_Columnas_Y_Fitros_FacturaResumen(ex_btn_P_FacturaCabecera_Resumen_Filtros.Location.X, 0);
}
private void MostrarOcultar_Columnas_Y_Fitros_FacturaResumen(int _int_PosicionX, int _int_PosicionY)
{
PE_Listados_Filtros frm_PE_Listados_Filtros = new PE_Listados_Filtros(g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen, ex_dgv_P_FacturaCabecera_Resumen.Columns, g_obj_Controladora.g_dct_ListadoFiltros_VTA_FacturasCabecera_Resumen,false);
frm_PE_Listados_Filtros.ShowDialog();
if (frm_PE_Listados_Filtros.g_bol_BotonAceptar)
{
//Mostrar/Ocultar las Columnas que no esten en el Listado
g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_FacturasCabecera_Resumen = frm_PE_Listados_Filtros.g_lst_ColumnasAMostrar;
foreach (DataGridViewColumn dgvc_ColumnasActuales in ex_dgv_P_FacturaCabecera_Resumen.Columns)
{
//Mostrar
if (g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_FacturasCabecera_Resumen.Contains(dgvc_ColumnasActuales.Name))
{
dgvc_ColumnasActuales.Visible = true;
}
//Ocultar
else
{
dgvc_ColumnasActuales.Visible = false;
}
}
//Rellenar los nuevos filtros
g_obj_Controladora.g_dct_ListadoFiltros_VTA_FacturasCabecera_Resumen = frm_PE_Listados_Filtros.g_dct_ListadoFiltros.ToDictionary(entry => entry.Key, entry => entry.Value);
}
}
#endregion
private void ex_dgv_P_FacturaCabecera_Resumen_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
{
//Si es linea de total
if (ex_dgv_P_FacturaCabecera_Resumen.Rows[e.RowIndex].Cells[nameof(INTERNO_ImportesImpuestos_Modelo.EsLineaTotal)].Value.ToString().Equals("X"))
{
//Si al celda es el total Final
if (ex_dgv_P_FacturaCabecera_Resumen.Columns[e.ColumnIndex].Name == nameof(INTERNO_ImportesImpuestos_Modelo.Total) ||
ex_dgv_P_FacturaCabecera_Resumen.Columns[e.ColumnIndex].Name == nameof(INTERNO_ImportesImpuestos_Modelo.Total_Final))
{
//Color Fondo
e.CellStyle.BackColor = Colores.G_COLOR_LISTADO_TOTALES_FONDO;
e.CellStyle.SelectionBackColor = Colores.G_COLOR_LISTADO_TOTALES_FONDO;
//Color Letra
e.CellStyle.ForeColor = Colores.G_COLOR_TOTAL;
e.CellStyle.SelectionForeColor = Colores.G_COLOR_TOTAL;
//Fuente
e.CellStyle.Font = Fuentes.G_FONT_TEXTOS_NEGRITA;
}
else
{
//Color Fondo
e.CellStyle.BackColor = Colores.G_COLOR_LISTADO_TOTALES_FONDO;
e.CellStyle.SelectionBackColor = Colores.G_COLOR_LISTADO_TOTALES_FONDO;
//Color Letra
e.CellStyle.ForeColor = Colores.G_COLOR_LISTADO_TOTALES_LETRA;
e.CellStyle.SelectionForeColor = Colores.G_COLOR_LISTADO_TOTALES_LETRA;
//Fuente
e.CellStyle.Font = Fuentes.G_FONT_TEXTOS_NEGRITA;
}
}
else
{
//Color Fondo
e.CellStyle.SelectionBackColor = e.CellStyle.BackColor;
//Color Letra
e.CellStyle.SelectionForeColor = e.CellStyle.ForeColor;
//Fuente
e.CellStyle.Font = Fuentes.G_FONT_TEXTOS;
}
}
#endregion
#region Actualizacion de listado desde otra pantalla
public override void P_Base_ActualizarRegistro_ConObjeto(object _obj, G_ENUM_TIPOACCION _enum_TipoAccion)
{
try
{
if (_obj != null)
{
if (_obj.GetType().Name.Equals("String"))
{
//VENCIMIENTO/COBRO/DEVOLUCIONCOBRO
if (_obj.ToString().Equals(Variables.G_STR_OPCION_VTA_VENCIMIENTO) ||
_obj.ToString().Equals(Variables.G_STR_OPCION_VTA_COBRO) ||
_obj.ToString().Equals(Variables.G_STR_OPCION_VTA_DEVOLUCIONCOBRO))
{
//Actualizar el control de Resumen de Facturas
ctu_P_FacturaCabecera_CarteraVenta.Rellenar_DataGrid(G_ENUM_CTU_CARTERA_VENTAS_TIPODOCUMENTOFILTRO.FacturasCabeceraVenta, (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo!=null ? g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo.id : -1), true);
g_obj_Controladora.Actualizar_SituacionPago();
}
}
else
{
List<object> lst_obj = (List<object>)_obj;
//FacturaLinea
if (lst_obj[0].Equals(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA))
{
long lng_idFacturalinea_Modificada = -1;
//Insertar o modificar
if (_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_NADA))
{
List<object> lst_Argumentos = (List<object>)lst_obj[1];
//Argumentos ...............................................
//LINEA PRINCIPAL
// 0 -> idFacturaLinea
// 1 -> TipoAccion
//LINEA PROMOCION POR UNIDAD(RELACIONADA)
// 2 -> idFacturaLinea Relacionada
// 3 -> TipoAccion
//NUMEROLINEA
// 4 -> Numero de linea modificado
//LINEA PRINCIPAL
if (lst_Argumentos[1].Equals(G_ENUM_TIPOACCION.INT_INSERTAR) ||
lst_Argumentos[1].Equals(G_ENUM_TIPOACCION.INT_MODIFICAR))
{
lng_idFacturalinea_Modificada = (long)lst_Argumentos[0];
g_obj_Controladora.Actualizar_Registro_FacturaLinea(lng_idFacturalinea_Modificada, (G_ENUM_TIPOACCION)lst_Argumentos[1], true, true, true);
//LINEA PROMOCION POR UNIDAD(RELACIONADA)
if (lst_Argumentos[3].Equals(G_ENUM_TIPOACCION.INT_INSERTAR) ||
lst_Argumentos[3].Equals(G_ENUM_TIPOACCION.INT_MODIFICAR))
{
g_obj_Controladora.Actualizar_Registro_FacturaLinea((long)lst_Argumentos[2], (G_ENUM_TIPOACCION)lst_Argumentos[3], true, true, true);
}
else if (lst_Argumentos[3].Equals(G_ENUM_TIPOACCION.INT_ELIMINAR))
{
List<long> lst_ids = new List<long>();
lst_ids.Add((long)lst_Argumentos[2]);
g_obj_Controladora.Borrar_Registro_FacturaLinea(lst_ids);
}
//NumeroLinea
if (((int)lst_Argumentos[4]) > -1)
{
g_obj_Controladora.Reordenar_NumeroLineas_FacturaLinea(lng_idFacturalinea_Modificada, (int)lst_Argumentos[4]);
}
}
}
//Borrar
else if (_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_ELIMINAR))
{
List<long> lst_Ids = (List<long>)lst_obj[1];
lng_idFacturalinea_Modificada = lst_Ids.OrderBy(m => m).FirstOrDefault();
g_obj_Controladora.Borrar_Registro_FacturaLinea(lst_Ids);
//NumeroLinea
if (((int)lst_obj[2]) > -1)
{
g_obj_Controladora.Reordenar_NumeroLineas_FacturaLinea(lng_idFacturalinea_Modificada, (int)lst_obj[2]);
}
}
}
//Comentarios
else if (lst_obj[0].Equals(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_COMENTARIOS))
{
if (_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_INSERTAR) ||
_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_MODIFICAR))
{
string obj_Opcion = (string)lst_obj[0];
g_obj_Controladora.Actualizar_Registro_FacturaLinea((long)lst_obj[1], G_ENUM_TIPOACCION.INT_MODIFICAR, true, true, false);
}
else if (_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_ELIMINAR))
{
string obj_Opcion = (string)lst_obj[0];
g_obj_Controladora.Actualizar_Registro_FacturaLinea((long)lst_obj[1], G_ENUM_TIPOACCION.INT_MODIFICAR, true, true, false);
}
}
//Trazabilidad
else if (lst_obj[0].Equals(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA_TRAZABILIDAD))
{
if (_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_INSERTAR) ||
_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_MODIFICAR))
{
string obj_Opcion = (string)lst_obj[0];
g_obj_Controladora.Actualizar_Registro_FacturaLinea((long)lst_obj[1], G_ENUM_TIPOACCION.INT_MODIFICAR, false, true, true);
}
else if (_enum_TipoAccion.Equals(G_ENUM_TIPOACCION.INT_ELIMINAR))
{
string obj_Opcion = (string)lst_obj[0];
g_obj_Controladora.Actualizar_Registro_FacturaLinea((long)lst_obj[1], G_ENUM_TIPOACCION.INT_MODIFICAR, false, true, true);
}
}
}
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(P_Base_ActualizarRegistro_ConObjeto));
}
}
#endregion
#region Cerrar/Abrir
private void ex_btn_P_FacturaCabecera_CerrarAbrir_Click(object sender, EventArgs e)
{
CerrarAbrir();
}
private void CerrarAbrir()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
//Tiene que tener Permisos para cerrar o abrir FacturaCabecera
if (Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Bloquear, true, nameof(ex_btn_P_FacturaCabecera_CerrarAbrir)))
{
//Esta Cerrado
if (ex_btn_P_FacturaCabecera_CerrarAbrir.Tag.ToString().Equals("1"))
{
//Ver si en verdad esta cerrado
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO))
{
g_obj_Controladora.Abrir_Documento();
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_NOCERRADO());
}
}
//Esta Abierto
else
{
//Ver si esta Devolucion ya ha sido Volcada
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_ABIERTO))
{
if (g_obj_Controladora.ComprobarCambios_SinPreguntar())
{
g_obj_Controladora.Cerrar_Documento();
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
}
}
}
}
#endregion
#region Cuentas
private void ex_btn_P_FacturaCabecera_Cuentas_Click(object sender, EventArgs e)
{
Ver_Volcado();
}
private void Ver_Volcado()
{
try
{
//Ver si esta factura no ha sido Volcado
if (!Variables.G_BOL_MODULO_CONTABILIDAD_ACTIVA)
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_NOTIENEMODULOCONTABILIDADACTIVO());
}
else
{
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO) ||
g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_VOLCADO))
{
INTERNO_OpcionesDetalle_Modelo mdl_INTERNO_OpcionesDetalle_Modelo = Datos_Generales.PRV_Opciones_Buscar_Detalles(Variables.G_STR_OPCION_CTA_VOLCADOCABECERA);
//Cargamos el ensamblado
Assembly m_assembly = Assembly.LoadFrom(Variables.G_STR_LIBRERIA_RUTAINICIAL + @"\" + mdl_INTERNO_OpcionesDetalle_Modelo.nombreLibreria + ".dll");
//Obtenemos el tipo de la clase
Type m_type = m_assembly.GetType(mdl_INTERNO_OpcionesDetalle_Modelo.nombreLibreria + "." + Variables.G_STR_LIBRERIA_OPCIONES);
//creamos la instancia
var obj_Clase = Activator.CreateInstance(m_type);
//Cargamos el metodo solicitado
MethodInfo obj_MethodInfo = obj_Clase.GetType().GetMethod(Variables.G_STR_LIBRERIA_OPCIONES_PROCEDIMIENTO_MOSTRAR_EN_MANTENIMIENTO, BindingFlags.Instance | BindingFlags.NonPublic);
//Obtener idVolcadoCabecera segun Fichero
CTA_VolcadoCabecera mdl_CTA_VolcadoCabecera = mdl_CTA_VolcadoCabecera = g_obj_Controladora.g_lst_CTA_VolcadoCabecera.Where(m => m.idPredefinidoFichero.Equals(Variables.G_PREDEFINIDOFICHEROS_FACTURASDEVENTA.Id)).FirstOrDefault();
if (mdl_CTA_VolcadoCabecera != null)
{
//Obtener valores
object[] arr_Parametros = { Variables.G_STR_OPCION_CTA_VOLCADOCABECERA,
this,
null,
this.P_Base_ValoresGenerales,
this.P_Base_FechaTrabajo,
mdl_INTERNO_OpcionesDetalle_Modelo,
mdl_CTA_VolcadoCabecera.id,
"",
"",
null,
null};
//Pasamos los parametros al metodo y lo ejecutamos
obj_MethodInfo.Invoke(obj_Clase, arr_Parametros);
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_ERROR_ABRIR_DOCUMENTO());
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_NOCERRADO());
}
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(Ver_Volcado));
}
}
#endregion
#region Volcar/Desvolcar
private void ex_btn_P_FacturaCabecera_Volcado_Click(object sender, EventArgs e)
{
VolcarDesvolcar();
}
private void VolcarDesvolcar()
{
if (!Variables.G_BOL_MODULO_CONTABILIDAD_ACTIVA)
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_NOTIENEMODULOCONTABILIDADACTIVO());
}
else
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
//Si no existe Factura no se puede Volcar
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null)
{
//Tiene que tener Permisos para volcar/desvolcar el factura
if (Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Bloquear, true, nameof(ex_btn_P_FacturaCabecera_Volcado)))
{
//Esta Volcado
if (ex_btn_P_FacturaCabecera_Volcado.Tag.ToString().Equals("1"))
{
g_obj_Controladora.Desvolcar_Documento();
}
//Esta Desvolcado
else
{
//Primero Grabo los datos y actualizo el Modelo
g_obj_Controladora.GrabarDatos();
//Te quedas esperando a que termine la tarea asincrona de grabar
while (g_obj_Controladora.g_obj_TareaAsincrona_GrabarDatos.IsBusy)
Application.DoEvents();
if (g_obj_Controladora.g_bol_GrabarDatos_TerminoCorrectamente)
{
g_obj_Controladora.Volcar_Documento();
}
}
}
}
else
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_GENERAL_DEBEGRABARPRIMERO(g_mdl_PRV_OpcionesDetalle.descripcion_Singular));
}
}
}
}
#endregion
#region Validar Fecha que este dentro de Ejercicio
private void ex_usc_P_FacturaCabecera_Fecha_Exferia_FechaSeleccion_TextBox_KeyPress(object sender, KeyPressEventArgs e)
{
g_bol_Cambio_Fecha = true;
}
private void ex_usc_P_FacturaCabecera_Fecha_Exferia_FechaSeleccion_LostFocus(object sender, EventArgs e)
{
if (g_obj_Controladora.g_bol_TareaAsincrona_Cambio_Fecha_PerdioFoco == false)
{
//Sino esta Bloqueado valido
if (ex_usc_P_FacturaCabecera_Fecha.Exferia_FechaSeleccion_ReadOnly == false)
{
if (g_bol_Cambio_Fecha)
{
g_bol_Cambio_Fecha = false;
if (ex_usc_P_FacturaCabecera_Fecha.Exferia_FechaSeleccion_Fecha.Trim(' ', '/') != "" &&
Funciones.Fecha_Validacion(ex_usc_P_FacturaCabecera_Fecha.Exferia_FechaSeleccion_Fecha) == 0)
{
DateTime dtt_Fecha = DateTime.ParseExact(ex_usc_P_FacturaCabecera_Fecha.Exferia_FechaSeleccion_Fecha, "dd/MM/yyyy", CultureInfo.InvariantCulture);
//validar la Fecha para Ejercicio
INTERNO_ValidacionFechas_Modelo mdl_INTERNO_ValidacionFechas_Modelo = Datos_Generales.GEN_EjerciciosActivos_Empresa_Validar_Por_FechaEjercicio(dtt_Fecha,
P_Base_ValoresGenerales.EjercicioActivo,
P_Base_ValoresGenerales.Ejercicios_Listado.ToList());
//Si no es Correcto
if (!mdl_INTERNO_ValidacionFechas_Modelo.Accion.Equals(G_ENUM_VALIDACIONFECHAS.Correcto))
{
//Mostrar Mensaje
Mensajes.MostrarMensaje(mdl_INTERNO_ValidacionFechas_Modelo.Mensaje);
//Si es Error o Incorrecto debe poner el Foco la Fecha
if (mdl_INTERNO_ValidacionFechas_Modelo.Accion.Equals(G_ENUM_VALIDACIONFECHAS.Error) ||
mdl_INTERNO_ValidacionFechas_Modelo.Accion.Equals(G_ENUM_VALIDACIONFECHAS.Incorrecta))
{
//Poner el Foco en el objeto que tuvo el problema en validar
ex_lbl_Advertencia_Ejercicio.Text = "";
ex_usc_P_FacturaCabecera_Fecha.g_bol_Activo = false;
ex_usc_P_FacturaCabecera_Fecha.Focus();
}
else
{
ex_lbl_Advertencia_Ejercicio.Text = Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_FUERAEJERCICIO();
ex_usc_P_FacturaCabecera_Fecha.g_bol_Activo = false;
ex_tbc_Principal.Focus();
}
}
else
{
ex_lbl_Advertencia_Ejercicio.Text = "";
}
//Ejercicio Seleccionado
GEN_EjerciciosActivos_Empresa mdl_GEN_EjerciciosActivos_Empresa = (GEN_EjerciciosActivos_Empresa)mdl_INTERNO_ValidacionFechas_Modelo.Objeto;
//Comprobar que el ejercicio seleccionado es diferente al que ya estaba
if (
(
mdl_GEN_EjerciciosActivos_Empresa != null &&
g_obj_Controladora.g_mdl_GEN_EjerciciosActivos_Empresa_SEGUNFECHA != null &&
!mdl_GEN_EjerciciosActivos_Empresa.id.Equals(g_obj_Controladora.g_mdl_GEN_EjerciciosActivos_Empresa_SEGUNFECHA.id)
)
||
(
mdl_GEN_EjerciciosActivos_Empresa != null &&
g_obj_Controladora.g_mdl_GEN_EjerciciosActivos_Empresa_SEGUNFECHA == null
)
||
(
mdl_GEN_EjerciciosActivos_Empresa == null &&
g_obj_Controladora.g_mdl_GEN_EjerciciosActivos_Empresa_SEGUNFECHA != null
)
)
{
//Ver si se puede seleccionar el recargo equivalencia o no, segun ejercicio (despues habria que mirar el Cliente)
if (mdl_GEN_EjerciciosActivos_Empresa != null)
{
g_obj_Controladora.g_mdl_GEN_EjerciciosActivos_Empresa_SEGUNFECHA = mdl_GEN_EjerciciosActivos_Empresa;
}
else
{
g_obj_Controladora.g_mdl_GEN_EjerciciosActivos_Empresa_SEGUNFECHA = null;
}
//Activar o desactivar el recargo Equivalencia
g_obj_Controladora.Recargo_ActivarDesactivar();
}
//Validar el cambio de fecha
//Si la fecha ya esta guardado, y se cambio por otro, hay que avisar por si se tiene que recalcular las tarifas y promociones
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null &&
!g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo.fecha.Equals(dtt_Fecha))
{
if (Mensajes.MostrarMensaje_Pregunta(Mensajes.G_STR_MENSAJES_GENERAL_PREGUNTA_CAMBIO_RECALCULARTARIFASPROMOCIONES("fecha")))
{
g_obj_Controladora.Cambio_Fecha(G_ENUM_CAMBIOFECHA.SI_RECALCULARLINEAS);
}
else
{
g_obj_Controladora.Cambio_Fecha(G_ENUM_CAMBIOFECHA.NO_RECALCULARLINEAS);
}
}
}
else
{
ex_lbl_Advertencia_Ejercicio.Text = "";
}
}
g_bol_Cambio_Fecha = false;
}
}
}
#endregion
#region ImpuestoCabecera
private void ex_usc_F3_P_FacturaCabecera_ImpuestoCabecera_Exferia_F3_SoloSeleccion_Evento_TerminoBusqueda(object sender, EventArgs e)
{
//Si tiene un Cliente Seleccionado correcto, busco los datos auxiliares relacionados
if (ex_usc_F3_P_FacturaCabecera_ImpuestoCabecera.Exferia_F3_SoloSeleccion_Id > -1)
{
g_obj_Controladora.Cambio_ImpuestoCabecera();
}
}
#endregion
#region Cliente (Rellenar datos auxiliares relacionados con el cliente)
private void ex_usc_F3_P_FacturaCabecera_Cliente_Exferia_F3_Evento_TerminoBusqueda(object sender, EventArgs e)
{
//Si tiene un Cliente Seleccionado correcto, busco los datos auxiliares relacionados
if (ex_usc_F3_P_FacturaCabecera_Cliente.Exferia_F3_Id > -1)
{
//Si es Cliente ya esta guardado, y se cambio por otro, hay que avisar por si se tiene que recalcular las tarifas y promociones
G_ENUM_CAMBIOCLIENTE obj_Enum_CAMBIOCLIENTE = G_ENUM_CAMBIOCLIENTE.NO_ACTUALIZARCLIENTE;
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null &&
!g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo.idCliente.Value.Equals(ex_usc_F3_P_FacturaCabecera_Cliente.Exferia_F3_Id))
{
if (Mensajes.MostrarMensaje_Pregunta(Mensajes.G_STR_MENSAJES_GENERAL_PREGUNTA_CAMBIO_RECALCULARTARIFASPROMOCIONES("Cliente")))
{
obj_Enum_CAMBIOCLIENTE = G_ENUM_CAMBIOCLIENTE.SI_RECALCULARLINEAS;
}
else
{
obj_Enum_CAMBIOCLIENTE = G_ENUM_CAMBIOCLIENTE.NO_RECALCULARLINEAS;
}
}
g_obj_Controladora.Cambio_Cliente(ex_usc_F3_P_FacturaCabecera_Cliente.Exferia_F3_Id, obj_Enum_CAMBIOCLIENTE);
}
//Si esta Vacio, se vacia los campos de Servicios
else
{
g_obj_Controladora.VaciarDatos_Servicios();
}
}
#endregion
#region Descuento por Pronto Pago
private string g_str_DescuentoProntoPago_GOTFOCUS = "";
private void ex_txt_P_FacturaCabecera_DescuentoProntoPago_Exferia_TextBox_Evento_GotFocus(object sender, EventArgs e)
{
g_str_DescuentoProntoPago_GOTFOCUS = ex_txt_P_FacturaCabecera_DescuentoProntoPago.Text;
}
private void ex_txt_P_FacturaCabecera_DescuentoProntoPago_Exferia_TextBox_Evento_LostFocus(object sender, EventArgs e)
{
try
{
if (ex_txt_P_FacturaCabecera_DescuentoProntoPago.Exferia_TextBox_ReadOnly == false)
{
string str_DescuentoProntoPago_LOSTFOCUS = ex_txt_P_FacturaCabecera_DescuentoProntoPago.Text;
//Convertir a decimal
decimal? dcm_Descuento_ProntoPago = null;
if (str_DescuentoProntoPago_LOSTFOCUS.Trim().Length > 0)
{
dcm_Descuento_ProntoPago = decimal.Parse(str_DescuentoProntoPago_LOSTFOCUS.Trim());
}
//Validar que este por encima de 0 y que sea igual o inferior a 100
if (dcm_Descuento_ProntoPago != null &&
(dcm_Descuento_ProntoPago.Value < 0 || dcm_Descuento_ProntoPago.Value > 100)
)
{
Mensajes.MostrarMensaje_Y_EsperarRespuesta(Mensajes.G_STR_GENERAL_VALIDACIONES_RANGOVALORINCORRECTO(ex_lbl_P_FacturaCabecera_DescuentoProntoPago.Text, "mayor que 0", "igual o menor que 100"));
//Volver a poner el Foco y Seleccionar el texto
ex_txt_P_FacturaCabecera_DescuentoProntoPago.Exferia_TextBox_SelectionStart = 0;
ex_txt_P_FacturaCabecera_DescuentoProntoPago.Exferia_TextBox_SelectionLength = ex_txt_P_FacturaCabecera_DescuentoProntoPago.Text.Length;
Funciones.Poner_Foco_Objeto(this, ex_txt_P_FacturaCabecera_DescuentoProntoPago);
return;
}
//Si se cambio algo
if (g_str_DescuentoProntoPago_GOTFOCUS != str_DescuentoProntoPago_LOSTFOCUS)
{
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo == null ||
(g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null &&
g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo.descuentoProntoPago != dcm_Descuento_ProntoPago)
)
{
g_obj_Controladora.Actualizar_ImportesImpuestos(false, false);
}
}
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(ex_txt_P_FacturaCabecera_DescuentoProntoPago_Exferia_TextBox_Evento_LostFocus));
}
}
#endregion
#region Descuento Final Factura
private string g_str_DescuentoFinalFactura_GOTFOCUS = "";
private void ex_txt_P_FacturaCabecera_DescuentoFinalFactura_Exferia_TextBox_Evento_GotFocus(object sender, EventArgs e)
{
g_str_DescuentoFinalFactura_GOTFOCUS = ex_txt_P_FacturaCabecera_DescuentoFinalFactura.Text;
}
private void ex_txt_P_FacturaCabecera_DescuentoFinalFactura_Exferia_TextBox_Evento_LostFocus(object sender, EventArgs e)
{
try
{
if (ex_txt_P_FacturaCabecera_DescuentoFinalFactura.Exferia_TextBox_ReadOnly == false)
{
string str_DescuentoFinalFactura_LOSTFOCUS = ex_txt_P_FacturaCabecera_DescuentoFinalFactura.Text;
//Convertir a decimal
decimal? dcm_Descuento_FinalFactura = null;
if (str_DescuentoFinalFactura_LOSTFOCUS.Trim().Length > 0)
{
dcm_Descuento_FinalFactura = decimal.Parse(str_DescuentoFinalFactura_LOSTFOCUS.Trim());
}
//Validar que este por encima de 0 y que sea igual o inferior a 100
if (dcm_Descuento_FinalFactura != null &&
(dcm_Descuento_FinalFactura.Value < 0 || dcm_Descuento_FinalFactura.Value > 100)
)
{
Mensajes.MostrarMensaje_Y_EsperarRespuesta(Mensajes.G_STR_GENERAL_VALIDACIONES_RANGOVALORINCORRECTO(ex_lbl_P_FacturaCabecera_DescuentoFinalFactura.Text, "mayor que 0", "igual o menor que 100"));
//Volver a poner el Foco y Seleccionar el texto
ex_txt_P_FacturaCabecera_DescuentoFinalFactura.Exferia_TextBox_SelectionStart = 0;
ex_txt_P_FacturaCabecera_DescuentoFinalFactura.Exferia_TextBox_SelectionLength = ex_txt_P_FacturaCabecera_DescuentoFinalFactura.Text.Length;
Funciones.Poner_Foco_Objeto(this, ex_txt_P_FacturaCabecera_DescuentoFinalFactura);
return;
}
//Si se cambio algo
if (g_str_DescuentoFinalFactura_GOTFOCUS != str_DescuentoFinalFactura_LOSTFOCUS)
{
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo == null ||
(g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null &&
g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo.descuentoFinalFactura != dcm_Descuento_FinalFactura)
)
{
g_obj_Controladora.Actualizar_ImportesImpuestos(false, false);
}
}
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(ex_txt_P_FacturaCabecera_DescuentoFinalFactura_Exferia_TextBox_Evento_LostFocus));
}
}
#endregion
#region Recargo
private void ex_chk_P_FacturaCabecera_RecargoEquivalencia_CheckedChanged(object sender, EventArgs e)
{
if (g_obj_Controladora != null &&
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial &&
g_obj_Controladora.g_bol_CargarDatos_Termino)
{
g_obj_Controladora.Actualizar_ImportesImpuestos(false, false);
}
}
#endregion
#region Refrescar
private void ex_btn_P_FacturaCabecera_Resfrecar_Click(object sender, EventArgs e)
{
if (g_obj_Controladora != null && g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo != null)
{
g_obj_Controladora.RecargarDatos();
}
}
#endregion
#region Imprimir
private void ex_btn_P_FacturaCabecera_Imprimir_Click(object sender, EventArgs e)
{
if (g_obj_Controladora != null)
{
if (Datos_Generales.Permisos_Comprobar(g_mdl_PRV_OpcionesDetalle.opcion, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Imprimir, true))
{
//Si el Documento no esta cerrado no se puedo imprimir
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_ABIERTO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_NOCERRADO());
}
else
{
g_obj_Controladora.Imprimir();
}
}
}
}
#endregion
#region Recalcular Resumen
private void ex_btn_P_FacturaCabecera_RecalcularResumen_Click(object sender, EventArgs e)
{
try
{
bool bol_TodoCorrecto = true;
//Tiene que estar ya grabado el registro
if (g_obj_Controladora.g_mdl_INTERNO_VTA_FacturasCabecera_Modelo==null)
{
//Saber si hay que guardar primero la cabecera
if (!g_obj_Controladora.ComprobarCambios_AfectaLineas())
{
bol_TodoCorrecto = false;
}
}
if (bol_TodoCorrecto)
{
g_obj_Controladora.Actualizar_ImportesImpuestos(false, false);
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(ex_btn_P_FacturaCabecera_RecalcularResumen_Click));
}
}
#endregion
#region Anexo
private void ex_usc_F3_P_FacturaCabecera_Anexo_Pais_Exferia_F3_Evento_TerminoBusqueda(object sender, EventArgs e)
{
Actualizar_Provincia(true);
}
private void ex_usc_F3_P_FacturaCabecera_Anexo_Provincia_Exferia_F3_Evento_TerminoBusqueda(object sender, EventArgs e)
{
Actualizar_Municipio(true);
}
private void ex_usc_F3_P_FacturaCabecera_Anexo_Municipio_Exferia_F3_Evento_TerminoBusqueda(object sender, EventArgs e)
{
Actualizar_Poblacion(true);
}
public void Actualizar_Provincia(bool _bol_Vaciar)
{
//Vaciar el Provincia
if (_bol_Vaciar)
{
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_Id = -1;
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_Codigo = "";
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_Descripcion = "";
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_FechaBorrado = null;
}
if (ex_usc_F3_P_FacturaCabecera_Anexo_Pais.Exferia_F3_Id > 0)
{
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Enabled = true;
//Poner Filtro
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_RELACIONADOS_Padre_OPCION = Variables.G_STR_OPCION_GEN_PAIS;
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_RELACIONADOS_Padre_ID = ex_usc_F3_P_FacturaCabecera_Anexo_Pais.Exferia_F3_Id;
}
else
{
ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Enabled = false;
}
Actualizar_Municipio(_bol_Vaciar);
}
public void Actualizar_Municipio(bool _bol_Vaciar)
{
//Vaciar el Municipio
if (_bol_Vaciar)
{
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_Id = -1;
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_Codigo = "";
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_Descripcion = "";
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_FechaBorrado = null;
}
if (ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_Id > 0)
{
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Enabled = true;
//Poner Filtro
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_RELACIONADOS_Padre_OPCION = Variables.G_STR_OPCION_GEN_PROVINCIA;
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_RELACIONADOS_Padre_ID = ex_usc_F3_P_FacturaCabecera_Anexo_Provincia.Exferia_F3_Id;
}
else
{
ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Enabled = false;
}
Actualizar_Poblacion(_bol_Vaciar);
}
public void Actualizar_Poblacion(bool _bol_Vaciar)
{
//Vaciar el Poblacion
if (_bol_Vaciar)
{
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_Id = -1;
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_Codigo = "";
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_Descripcion = "";
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_FechaBorrado = null;
}
if (ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_Id > 0)
{
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Enabled = true;
//Poner Filtro
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_RELACIONADOS_Padre_OPCION = Variables.G_STR_OPCION_GEN_MUNICIPIO;
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Exferia_F3_RELACIONADOS_Padre_ID = ex_usc_F3_P_FacturaCabecera_Anexo_Municipio.Exferia_F3_Id;
}
else
{
ex_usc_F3_P_FacturaCabecera_Anexo_Poblacion.Enabled = false;
}
}
private void ex_btn_P_FacturaCabecera_Anexo_Actualizar_Click(object sender, EventArgs e)
{
try
{
g_obj_Controladora.Actualizar_Anexo();
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(ex_btn_P_FacturaCabecera_Anexo_Actualizar_Click));
}
}
#endregion
#region Otros
private void ex_btn_P_FacturaCabecera_Otros_Actualizar_Click(object sender, EventArgs e)
{
try
{
g_obj_Controladora.Actualizar_Otros();
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_AlbaranCabecera) + "/" + nameof(ex_btn_P_FacturaCabecera_Otros_Actualizar_Click));
}
}
#endregion
#region Datos del Viaje
private void ex_btn_P_FacturaCabecera_DatosViaje_Actualizar_Click(object sender, EventArgs e)
{
try
{
g_obj_Controladora.Actualizar_DatosViaje();
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_AlbaranCabecera) + "/" + nameof(ex_btn_P_FacturaCabecera_DatosViaje_Actualizar_Click));
}
}
#endregion
#region Observaciones
private void ex_btn_P_FacturaCabecera_Observaciones_Actualizar_Click(object sender, EventArgs e)
{
try
{
g_obj_Controladora.Actualizar_Observaciones();
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_AlbaranCabecera) + "/" + nameof(ex_btn_P_FacturaCabecera_Observaciones_Actualizar_Click));
}
}
#endregion
#region Agregar pedidos de venta
private void ex_btn_P_FacturaCabecera_AgregarPedidosVenta_Click(object sender, EventArgs e)
{
AgregarPedidosVenta();
}
private void AgregarPedidosVenta()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if ((Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Bloquear, true, nameof(ex_btn_P_FacturaCabecera_AgregarPedidosVenta))))
{
//Si el Documento esta cerrado no puedo Agregar las lineas
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
try
{
//Saber si hay que guardar primero la cabecera
if (g_obj_Controladora.ComprobarCambios_AfectaLineas())
{
//Cargamos el ensamblado
Assembly m_assembly = Assembly.LoadFrom(Variables.G_STR_LIBRERIA_RUTAINICIAL + @"\" + Variables.G_STR_LIBRERIA_VENTAS + ".dll");
//Obtenemos el tipo de la clase
Type m_type = m_assembly.GetType(Variables.G_STR_LIBRERIA_VENTAS + "." + Variables.G_STR_LIBRERIA_OPCIONES);
//creamos la instancia
var obj_Clase = Activator.CreateInstance(m_type);
//Cargamos el metodo solicitado
MethodInfo obj_MethodInfo = obj_Clase.GetType().GetMethod(Variables.G_STR_LIBRERIA_OPCIONES_PROCEDIMIENTO_CARGAR_LISTADO, BindingFlags.Instance | BindingFlags.NonPublic);
//Evento Registro Seleccionado .........................................
MethodInfo obj_EventoAlqueSeRedirige_RegistroSeleccionado = typeof(P_FacturaCabecera).GetMethod("Evento_PedidosSeleccionado", BindingFlags.NonPublic | BindingFlags.Instance);
EventInfo obj_Evento_Publico_RegistroSeleccionado = obj_Clase.GetType().GetEvent(Variables.G_STR_LIBRERIA_OPCIONES_EVENTO_REGISTROSELECCIONADO);
Type obj_TipoEventoPublico_RegistroSeleccionado = obj_Evento_Publico_RegistroSeleccionado.EventHandlerType;
Delegate obj_Delegado_RegistroSeleccionado = Delegate.CreateDelegate(obj_TipoEventoPublico_RegistroSeleccionado, this, obj_EventoAlqueSeRedirige_RegistroSeleccionado);
obj_Evento_Publico_RegistroSeleccionado.AddEventHandler(obj_Clase, obj_Delegado_RegistroSeleccionado);
//..................................................................
//Instanciar la Variable
List<INTERNO_Filtro_OpcionPadre_Modelo> lst_INTERNO_Filtro_OpcionPadre_Modelo = new List<INTERNO_Filtro_OpcionPadre_Modelo>();
//idCliente
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(Variables.G_STR_OPCION_MAE_CLIENTE, Exferia_F3_Cliente.Exferia_F3_Id));
//Pedidos ya Utilizados
List<long> lst_idsPedidosVentaLinea_YaUtilizados = null;
if (g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null && g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
lst_idsPedidosVentaLinea_YaUtilizados = g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(m => m.idPedidoLinea != null).Select(x => x.idPedidoLinea.Value).ToList();
}
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(Variables_Ventas.G_STR_FILTRO_LISTADOSELECCION_PEDIDOS_YAUTILIZADOS, -1, lst_idsPedidosVentaLinea_YaUtilizados));
//Quitar los albaranes de servicio
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(Variables_Ventas.G_STR_FILTRO_LISTADOSELECCION_PEDIDOS_SERVICIO, -1,false));
//Solo Autorizados
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(nameof(INTERNO_VTA_PedidosCabecera_Listado_Modelo.autorizado), -1,true));
//Obtener valores
object[] arr_Parametros = {
Variables.G_STR_OPCION_VTA_PEDIDOCABECERA,
true,
110,
this,
Variables.G_MDL_INTERNO_VALORESGENERALES_MODELO,
this.P_Base_FechaTrabajo,
"",
"",
false,
false,
lst_INTERNO_Filtro_OpcionPadre_Modelo,
null,
null,
"1",
null,
null
};
//Pasamos los parametros al metodo y lo ejecutamos
obj_MethodInfo.Invoke(obj_Clase, arr_Parametros);
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(AgregarPedidosVenta));
}
}
}
}
}
private void Evento_PedidosSeleccionado(object sender, INTERNO_EventArgs_Listado e)
{
try
{
if (e.REGISTRO_SELECCIONADO != null)
{
g_obj_Controladora.Agregar_Lineas_Desde_Pedidos(((List<dynamic>)e.REGISTRO_SELECCIONADO).Select(m => m.GetType().GetProperty(nameof(INTERNO_VTA_PedidosCabecera_Listado_Modelo.id)).GetValue(m)).Cast<long>().ToList());
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(Evento_PedidosSeleccionado));
}
}
#endregion
#region Agregar albaranes
private void ex_btn_P_FacturaCabecera_AgregarAlbaranes_Click(object sender, EventArgs e)
{
AgregarAlbaranes();
}
private void AgregarAlbaranes()
{
if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreAdministrativo))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERREADMINISTRATIVO());
}
else if (g_obj_Controladora.g_obj_ENUM_VALIDACIONFECHAS_TIPOCIERRE.Equals(G_ENUM_VALIDACIONFECHAS_TIPOCIERRE.CierreContable))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_FECHASEJERCICIOS_ETIQUETA_TIENECIERRECONTABLE());
}
else
{
if ((Datos_Generales.Permisos_Comprobar(Variables.G_STR_OPCION_VTA_ALBARANESFACTURASLINEA, g_lst_INTERNO_Permisos_Modelo, (int)G_ENUM_PERMISOS.Bloquear, true, nameof(ex_btn_P_FacturaCabecera_AgregarAlbaranes))))
{
//Si el Documento esta cerrado no puedo Agregar las lineas
if (g_obj_Controladora.g_str_Estado.Equals(Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO))
{
Mensajes.MostrarMensaje(Mensajes.G_STR_MENSAJES_DOCUMENTO_CERRADO());
}
else
{
try
{
//Saber si hay que guardar primero la cabecera
if (g_obj_Controladora.ComprobarCambios_AfectaLineas())
{
//Cargamos el ensamblado
Assembly m_assembly = Assembly.LoadFrom(Variables.G_STR_LIBRERIA_RUTAINICIAL + @"\" + Variables.G_STR_LIBRERIA_VENTAS + ".dll");
//Obtenemos el tipo de la clase
Type m_type = m_assembly.GetType(Variables.G_STR_LIBRERIA_VENTAS + "." + Variables.G_STR_LIBRERIA_OPCIONES);
//creamos la instancia
var obj_Clase = Activator.CreateInstance(m_type);
//Cargamos el metodo solicitado
MethodInfo obj_MethodInfo = obj_Clase.GetType().GetMethod(Variables.G_STR_LIBRERIA_OPCIONES_PROCEDIMIENTO_CARGAR_LISTADO, BindingFlags.Instance | BindingFlags.NonPublic);
//Evento Registro Seleccionado .........................................
MethodInfo obj_EventoAlqueSeRedirige_RegistroSeleccionado = typeof(P_FacturaCabecera).GetMethod("Evento_AlbaranesSeleccionado", BindingFlags.NonPublic | BindingFlags.Instance);
EventInfo obj_Evento_Publico_RegistroSeleccionado = obj_Clase.GetType().GetEvent(Variables.G_STR_LIBRERIA_OPCIONES_EVENTO_REGISTROSELECCIONADO);
Type obj_TipoEventoPublico_RegistroSeleccionado = obj_Evento_Publico_RegistroSeleccionado.EventHandlerType;
Delegate obj_Delegado_RegistroSeleccionado = Delegate.CreateDelegate(obj_TipoEventoPublico_RegistroSeleccionado, this, obj_EventoAlqueSeRedirige_RegistroSeleccionado);
obj_Evento_Publico_RegistroSeleccionado.AddEventHandler(obj_Clase, obj_Delegado_RegistroSeleccionado);
//..................................................................
//Instanciar la Variable
List<INTERNO_Filtro_OpcionPadre_Modelo> lst_INTERNO_Filtro_OpcionPadre_Modelo = new List<INTERNO_Filtro_OpcionPadre_Modelo>();
//estado (Cerrado)
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(nameof(INTERNO_VTA_AlbaranesCabecera_Listado_Modelo.estado) + "_Igual", -1, Variables.G_STR_ESTADO_CONTABILIDAD_CERRADO));
//idCliente
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(nameof(INTERNO_VTA_AlbaranesCabecera_Listado_Modelo.idCliente), Exferia_F3_Cliente.Exferia_F3_Id));
//Albaranes ya Utilizados
List<long> lst_idsAlbaranLinea_YaUtilizados = null;
if (g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo != null && g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Count > 0)
{
lst_idsAlbaranLinea_YaUtilizados = g_obj_Controladora.g_lst_INTERNO_VTA_AlbaranesFacturasLineas_Listado_Modelo.Where(m => m.idAlbaranCabecera != null).Select(x => x.idAlbaranCabecera.Value).ToList();
}
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(Variables_Ventas.G_STR_FILTRO_LISTADOSELECCION_ALBARANES_YAUTILIZADOS,-1, lst_idsAlbaranLinea_YaUtilizados));
//Quitar los albaranes de servicio
lst_INTERNO_Filtro_OpcionPadre_Modelo.Add(new INTERNO_Filtro_OpcionPadre_Modelo(Variables.G_STR_VENTAS_FILTRO_LISTADOSELECCION_ALBARANES_SERVICIO, -1,false));
//Obtener valores
object[] arr_Parametros = {
Variables.G_STR_OPCION_VTA_ALBARANESCABECERA,
true,
111,
this,
Variables.G_MDL_INTERNO_VALORESGENERALES_MODELO,
this.P_Base_FechaTrabajo,
"",
"",
false,
false,
lst_INTERNO_Filtro_OpcionPadre_Modelo,
null,
null,
"1",
null,
null
};
//Pasamos los parametros al metodo y lo ejecutamos
obj_MethodInfo.Invoke(obj_Clase, arr_Parametros);
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(AgregarAlbaranes));
}
}
}
}
}
private void Evento_AlbaranesSeleccionado(object sender, INTERNO_EventArgs_Listado e)
{
try
{
if (e.REGISTRO_SELECCIONADO != null)
{
g_obj_Controladora.Agregar_Lineas_Desde_Albaranes(((List<dynamic>)e.REGISTRO_SELECCIONADO).Select(m => m.GetType().GetProperty(nameof(INTERNO_VTA_AlbaranesCabecera_Listado_Modelo.id)).GetValue(m)).Cast<long>().ToList());
}
}
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(Evento_AlbaranesSeleccionado));
}
}
#endregion
#region Arbol Secundario Seleccion
private void ex_btn_P_FacturaCabecera_ArbolSecundarioSeleccion_MostrarOcultar_Click(object sender, EventArgs e)
{
if (spl_P_FacturaCabecera_Principal.Panel2Collapsed)
{
spl_P_FacturaCabecera_Principal.Panel2Collapsed = false;
}
else
{
spl_P_FacturaCabecera_Principal.Panel2Collapsed = true;
}
}
private void ex_trv_P_FacturaCabecera_ArbolSecundarioSeleccion_Exferia_ArbolSecundarioSeleccion_NodoSeleccion(object sender, EventArgs e)
{
spl_P_FacturaCabecera_Principal.Panel2Collapsed = true;
}
#endregion
#region Controlar si se modifica algo
private void ex_txt_P_FacturaCabecera_Descripcion_Exferia_TextBox_Evento_TextChanged(object sender, EventArgs e)
{
Controlar_Modificaciones();
if (g_obj_Controladora != null &&
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial &&
g_obj_Controladora.g_bol_CargarDatos_Termino)
{
g_obj_Controladora.g_bol_ModificacionDatosAfectaLineas = true;
}
}
private void ex_txt_P_FacturaCabecera_Observaciones_Exferia_TextBox_Evento_TextChanged(object sender, EventArgs e)
{
Controlar_Modificaciones();
if (g_obj_Controladora != null &&
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial &&
g_obj_Controladora.g_bol_CargarDatos_Termino)
{
g_obj_Controladora.g_bol_ModificacionDatosAfectaLineas = true;
}
}
private void ex_usc_P_FacturaCabecera_Fecha_Exferia_FechaSeleccion_TextBox_TextChanged(object sender, EventArgs e)
{
Controlar_Modificaciones();
if (g_obj_Controladora != null &&
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial &&
g_obj_Controladora.g_bol_CargarDatos_Termino)
{
g_obj_Controladora.g_bol_ModificacionDatosAfectaLineas = true;
}
}
private void ex_usc_F3_P_FacturaCabecera_Delegacion_Exferia_F3_Evento_TerminoBusqueda(object sender, EventArgs e)
{
if (g_obj_Controladora != null &&
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial &&
g_obj_Controladora.g_bol_CargarDatos_Termino)
{
g_obj_Controladora.g_bol_ModificacionDatosAfectaLineas = true;
if (ex_usc_F3_P_FacturaCabecera_Delegacion.Exferia_F3_Id > -1)
{
g_obj_Controladora.Cambio_Delegacion();
}
}
}
private void ex_usc_F3_P_FacturaCabecera_Almacen_Exferia_F3_SoloSeleccion_Evento_TerminoBusqueda(object sender, EventArgs e)
{
if (g_obj_Controladora != null &&
g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial &&
g_obj_Controladora.g_bol_CargarDatos_Termino)
{
g_obj_Controladora.g_bol_ModificacionDatosAfectaLineas = true;
}
}
private void Controlar_Modificaciones_CheckBox_CheckedChanged(object sender, EventArgs e)
{
Controlar_Modificaciones();
}
private void Controlar_Modificaciones_Exferia_FechaSeleccion_TextChanged(object sender, EventArgs e)
{
Controlar_Modificaciones();
}
private void Controlar_Modificaciones_Exferia_TextBox_TextChanged(object sender, EventArgs e)
{
Controlar_Modificaciones();
}
private void Controlar_Modificaciones()
{
if (Enabled && g_obj_Controladora != null && g_obj_Controladora.g_bol_Termino_CargaDatos_Inicial)
{
P_Base_SeModificoDatosPantalla = true;
}
}
#endregion
#region Eventos del Paginador
protected void ctu_Paginacion_Primera_Click(object sender, EventArgs e)
{
if (g_obj_Controladora.ComprobarCambios()) // Si no han habido contratiempos pasamos a la pagina indicada
{
if (g_obj_Funciones_Paginador.Primera())
{
// Asignando al control la pagina actual.
Exferia_Paginador_FacturaCabecera.PaginaActual = g_obj_Funciones_Paginador.GetPaginaActual();
// Refrescamos el listado a mostrar en el form.
P_Base_id = g_obj_Funciones_Paginador.Objeto_Devuelto.FirstOrDefault().ID;
g_timer_Paginar.Stop();
g_timer_Paginar.Start();
}
}
}
protected void ctu_Paginacion_Anterior_Click(object sender, EventArgs e)
{
if (g_obj_Controladora.ComprobarCambios()) // Si no han habido contratiempos pasamos a la pagina indicada
{
if (g_obj_Funciones_Paginador.Anterior())
{
// Asignando al control la pagina actual.
Exferia_Paginador_FacturaCabecera.PaginaActual = g_obj_Funciones_Paginador.GetPaginaActual();
// Refrescamos el listado a mostrar en el form.
P_Base_id = g_obj_Funciones_Paginador.Objeto_Devuelto.FirstOrDefault().ID;
g_timer_Paginar.Stop();
g_timer_Paginar.Start();
}
}
}
protected void ctu_Paginacion_Siguiente_Click(object sender, EventArgs e)
{
if (g_obj_Controladora.ComprobarCambios()) // Si no han habido contratiempos pasamos a la pagina indicada
{
if (g_obj_Funciones_Paginador.Siguiente())
{
// Asignando al control la pagina actual.
Exferia_Paginador_FacturaCabecera.PaginaActual = g_obj_Funciones_Paginador.GetPaginaActual();
// Refrescamos el listado a mostrar en el form.
P_Base_id = g_obj_Funciones_Paginador.Objeto_Devuelto.FirstOrDefault().ID;
g_timer_Paginar.Stop();
g_timer_Paginar.Start();
}
}
}
protected void ctu_Paginacion_Ultima_Click(object sender, EventArgs e)
{
if (g_obj_Controladora.ComprobarCambios()) // Si no han habido contratiempos pasamos a la pagina indicada
{
if (g_obj_Funciones_Paginador.Ultima())
{
// Asignando al control la pagina actual.
Exferia_Paginador_FacturaCabecera.PaginaActual = g_obj_Funciones_Paginador.GetPaginaActual();
// Refrescamos el listado a mostrar en el form.
P_Base_id = g_obj_Funciones_Paginador.Objeto_Devuelto.FirstOrDefault().ID;
g_timer_Paginar.Stop();
g_timer_Paginar.Start();
}
}
}
protected void txt_PaginaActual_KeyPress(object sender, KeyPressEventArgs e)
{
// Si pulsamos Enter.
if (e.KeyChar.Equals('\r'))
{
if (g_obj_Controladora.ComprobarCambios()) // Si no han habido contratiempos pasamos a la pagina indicada
{
// Asignamos a la paginacion el valor del textbox
g_obj_Funciones_Paginador.SetPaginaActual(Exferia_Paginador_FacturaCabecera.txt_ValorPaginaActual - 1);
// Asignando al control la pagina actual.
Exferia_Paginador_FacturaCabecera.PaginaActual = g_obj_Funciones_Paginador.GetPaginaActual();
// Refrescamos el listado a mostrar en el form.
P_Base_id = g_obj_Funciones_Paginador.Objeto_Devuelto.FirstOrDefault().ID;
g_timer_Paginar.Stop();
g_obj_Controladora.RecargarDatos();
}
}
}
#endregion
#region Teclas de acceso rapido
protected override bool ProcessCmdKey(ref Message msg, Keys keyData)
{
// Salir sin Seleccionar
if (keyData == Keys.F10)
{
Salir_P_Base();
return true;
}
// Grabar
else if (keyData == Keys.F2)
{
Grabar();
return true;
}
// Borrar
else if (keyData == Keys.F5)
{
Borrar();
return true;
}
// Añadir Linea
else if (keyData == (Keys.F4))
{
Add_FacturaLinea();
return true;
}
// Ver Linea
else if (keyData == (Keys.F6))
{
Ver_FacturaLinea();
return true;
}
// Mostrar/Filtrar campos Linea
else if (keyData == (Keys.F7))
{
MostrarOcultar_Columnas_Y_Fitros_FacturaLinea(ex_btn_P_FacturaCabecera_Lineas_Filtros.Location.X, 0);
return true;
}
// Borrar Linea
else if (keyData == (Keys.Control | Keys.F5))
{
Borrar_FacturaLinea();
return true;
}
//Cerrar/Abrir
else if (keyData == Keys.F9)
{
CerrarAbrir();
return true;
}
//Mover Arriba en el Grid de Lineas
else if (keyData == Keys.Up)
{
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0 &&
ex_dgv_P_FacturaCabecera_Lineas.SelectedRows.Count > 0 &&
ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Index > 0)
{
int _int_Index = ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Index - 1;
ex_dgv_P_FacturaCabecera_Lineas.ClearSelection();
ex_dgv_P_FacturaCabecera_Lineas.Rows[_int_Index].Selected = true;
//Mover el Scroll para Arriba
if (ex_dgv_P_FacturaCabecera_Lineas.FirstDisplayedScrollingRowIndex > _int_Index)
{
ex_dgv_P_FacturaCabecera_Lineas.FirstDisplayedScrollingRowIndex -= 1;
}
}
return true;
}
//Mover Abajo en el Grid de Lineas
else if (keyData == Keys.Down)
{
if (ex_dgv_P_FacturaCabecera_Lineas.Rows.Count > 0 &&
ex_dgv_P_FacturaCabecera_Lineas.SelectedRows.Count > 0 &&
ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Index < ex_dgv_P_FacturaCabecera_Lineas.Rows.Count - 1)
{
int _int_Index = ex_dgv_P_FacturaCabecera_Lineas.SelectedRows[0].Index + 1;
ex_dgv_P_FacturaCabecera_Lineas.ClearSelection();
ex_dgv_P_FacturaCabecera_Lineas.Rows[_int_Index].Selected = true;
try
{
//Mover el Scroll para Abajo
if (((ex_dgv_P_FacturaCabecera_Lineas.DisplayedRowCount(false) - 1) + ex_dgv_P_FacturaCabecera_Lineas.FirstDisplayedScrollingRowIndex) < _int_Index)
{
ex_dgv_P_FacturaCabecera_Lineas.FirstDisplayedScrollingRowIndex += 1;
}
}
catch (Exception)
{ }
}
return true;
}
return base.ProcessCmdKey(ref msg, keyData);
}
#endregion
#region Cierre de Pantalla
private void P_FacturaCabecera_FormClosed(object sender, FormClosedEventArgs e)
{
try
{
#region DATOS DEL MANTENIMIENTO
//Guardar el fichero xml de configuracion de la pantalla
INTERNO_ConfiguracionPantalla_Modelo mdl_INTERNO_ConfiguracionPantalla_Modelo = new INTERNO_ConfiguracionPantalla_Modelo();
//Centro de Informacion Ancho
mdl_INTERNO_ConfiguracionPantalla_Modelo.CENTROINFORMACION_Ancho = g_int_CentroInformacion_Ancho;
//Actualizar la Variables General
if (Variables.G_DCT_CONFIGURACIONPANTALLA != null && Variables.G_DCT_CONFIGURACIONPANTALLA.Count > 0)
{
//Ver si ya existia
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(nameof(P_FacturaCabecera)))
{
Variables.G_DCT_CONFIGURACIONPANTALLA[nameof(P_FacturaCabecera)] = mdl_INTERNO_ConfiguracionPantalla_Modelo;
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(nameof(P_FacturaCabecera), mdl_INTERNO_ConfiguracionPantalla_Modelo);
}
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA = new Dictionary<string, INTERNO_ConfiguracionPantalla_Modelo>();
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(nameof(P_FacturaCabecera), mdl_INTERNO_ConfiguracionPantalla_Modelo);
}
//Actualizar el fichero XML
Exferia_Aplicacion.General.Funciones_FicherosXML.ModificarXML_ConfiguracionPantallas(Variables.G_STR_CONFIGURACIONPANTALLA_TIPOPANTALLA_MANTENIMIENTO, nameof(P_FacturaCabecera), mdl_INTERNO_ConfiguracionPantalla_Modelo);
#endregion
#region LINEAS
INTERNO_ConfiguracionPantalla_Modelo mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS = new INTERNO_ConfiguracionPantalla_Modelo();
Dictionary<string, int> dct_ColumnasOrden_LINEAS = new Dictionary<string, int>();
Dictionary<string, int> dct_ColumnasAncho_LINEAS = new Dictionary<string, int>();
foreach (DataGridViewColumn dgv_Columnas in ex_dgv_P_FacturaCabecera_Lineas.Columns)
{
//Campos a Mostrar
if (dgv_Columnas.Visible)
{
//Columnas Orden
dct_ColumnasOrden_LINEAS.Add(dgv_Columnas.Name, dgv_Columnas.DisplayIndex);
//Columnas Ancho
dct_ColumnasAncho_LINEAS.Add(dgv_Columnas.Name, dgv_Columnas.Width);
}
}
mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS.LISTADO_COLUMNASAMOSTRAR = g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas;
mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS.LISTADO_COLUMNAS_ORDEN = dct_ColumnasOrden_LINEAS;
mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS.LISTADO_COLUMNAS_ANCHO = dct_ColumnasAncho_LINEAS;
//Orden
if (ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem != null)
{
mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS.LISTADO_ORDEN_COLUMNA_PORDEFECTO = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_Lineas_OrdenListado.SelectedItem).Descripcion;
}
mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS.LISTADO_ORDEN_DIRECCION_PORDEFECTO = ex_btn_P_FacturaCabecera_Lineas_OrdenListado.Tag.ToString();
//Actualizar la Variables General
if (Variables.G_DCT_CONFIGURACIONPANTALLA != null && Variables.G_DCT_CONFIGURACIONPANTALLA.Count > 0)
{
//Ver si ya existia
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION()] = mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS;
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS);
}
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA = new Dictionary<string, INTERNO_ConfiguracionPantalla_Modelo>();
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS);
}
//Actualizar el fichero XML
Funciones_FicherosXML.ModificarXML_ConfiguracionPantallas(Variables.G_STR_CONFIGURACIONPANTALLA_TIPOPANTALLA_LISTADOS, g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Facturas.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_LINEAS);
#endregion
#region LINEAS DE TRAZABILIDAD
INTERNO_ConfiguracionPantalla_Modelo mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD = new INTERNO_ConfiguracionPantalla_Modelo();
Dictionary<string, int> dct_ColumnasOrden_TRAZABILIDAD = new Dictionary<string, int>();
Dictionary<string, int> dct_ColumnasAncho_TRAZABILIDAD = new Dictionary<string, int>();
foreach (DataGridViewColumn dgv_Columnas in ex_dgv_P_FacturaCabecera_LineasTrazabilidad.Columns)
{
//Campos a Mostrar
if (dgv_Columnas.Visible)
{
//Columnas Orden
dct_ColumnasOrden_TRAZABILIDAD.Add(dgv_Columnas.Name, dgv_Columnas.DisplayIndex);
//Columnas Ancho
dct_ColumnasAncho_TRAZABILIDAD.Add(dgv_Columnas.Name, dgv_Columnas.Width);
}
}
mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD.LISTADO_COLUMNASAMOSTRAR = g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_AlbaranesFacturasLineas_Trazabilidad;
mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD.LISTADO_COLUMNAS_ORDEN = dct_ColumnasOrden_TRAZABILIDAD;
mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD.LISTADO_COLUMNAS_ANCHO = dct_ColumnasAncho_TRAZABILIDAD;
//Orden
if (ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem != null)
{
mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD.LISTADO_ORDEN_COLUMNA_PORDEFECTO = ((INTERNO_ComboBox_Modelo)ex_cbo_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.SelectedItem).Descripcion;
}
mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD.LISTADO_ORDEN_DIRECCION_PORDEFECTO = ex_btn_P_FacturaCabecera_LineasTrazabilidad_OrdenListado.Tag.ToString();
//Actualizar la Variables General
if (Variables.G_DCT_CONFIGURACIONPANTALLA != null && Variables.G_DCT_CONFIGURACIONPANTALLA.Count > 0)
{
//Ver si ya existia
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION()] = mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD;
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD);
}
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA = new Dictionary<string, INTERNO_ConfiguracionPantalla_Modelo>();
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD);
}
//Actualizar el fichero XML
Funciones_FicherosXML.ModificarXML_ConfiguracionPantallas(Variables.G_STR_CONFIGURACIONPANTALLA_TIPOPANTALLA_LISTADOS, g_obj_Controladora.g_obj_ABS_Listado_VTA_AlbaranesFacturasLineas_Trazabilidad.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_TRAZABILIDAD);
#endregion
#region RESUMEN
INTERNO_ConfiguracionPantalla_Modelo mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN = new INTERNO_ConfiguracionPantalla_Modelo();
Dictionary<string, int> dct_ColumnasOrden_RESUMEN = new Dictionary<string, int>();
Dictionary<string, int> dct_ColumnasAncho_RESUMEN = new Dictionary<string, int>();
foreach (DataGridViewColumn dgv_Columnas in ex_dgv_P_FacturaCabecera_Resumen.Columns)
{
//Campos a Mostrar
if (dgv_Columnas.Visible)
{
//Columnas Orden
dct_ColumnasOrden_RESUMEN.Add(dgv_Columnas.Name, dgv_Columnas.DisplayIndex);
//Columnas Ancho
dct_ColumnasAncho_RESUMEN.Add(dgv_Columnas.Name, dgv_Columnas.Width);
}
}
mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN.LISTADO_COLUMNASAMOSTRAR = g_obj_Controladora.g_lst_ColumnasAMostrar_VTA_FacturasCabecera_Resumen;
mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN.LISTADO_COLUMNAS_ORDEN = dct_ColumnasOrden_RESUMEN;
mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN.LISTADO_COLUMNAS_ANCHO = dct_ColumnasAncho_RESUMEN;
//Actualizar la Variables General
if (Variables.G_DCT_CONFIGURACIONPANTALLA != null && Variables.G_DCT_CONFIGURACIONPANTALLA.Count > 0)
{
//Ver si ya existia
if (Variables.G_DCT_CONFIGURACIONPANTALLA.ContainsKey(g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION()))
{
Variables.G_DCT_CONFIGURACIONPANTALLA[g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION()] = mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN;
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN);
}
}
else
{
Variables.G_DCT_CONFIGURACIONPANTALLA = new Dictionary<string, INTERNO_ConfiguracionPantalla_Modelo>();
Variables.G_DCT_CONFIGURACIONPANTALLA.Add(g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN);
}
//Actualizar el fichero XML
Funciones_FicherosXML.ModificarXML_ConfiguracionPantallas(Variables.G_STR_CONFIGURACIONPANTALLA_TIPOPANTALLA_LISTADOS, g_obj_Controladora.g_obj_ABS_Listado_VTA_FacturasCabecera_Resumen.NOMBRELISTADO_ALMACENARCONFIGURACION(), mdl_INTERNO_ConfiguracionPantalla_Modelo_RESUMEN);
#endregion
}
catch (Control_Errores)
{ }
catch (Exception ex)
{
Control_Errores.Errores_Log("", ex, nameof(P_FacturaCabecera) + "/" + nameof(P_FacturaCabecera_FormClosed));
}
}
#endregion
#region Centro de Informacion
private void P_FacturaCabecera_SizeChanged(object sender, EventArgs e)
{
//calcular distancia del splitter
spl_P_FacturaCabecera_Principal.SplitterDistance = spl_P_FacturaCabecera_Principal.Width - g_int_CentroInformacion_Ancho;
}
private void spl_P_FacturaCabecera_Principal_Panel2_SizeChanged(object sender, EventArgs e)
{
try
{
if (spl_P_FacturaCabecera_Principal.Panel2.Width > 0 &&
spl_P_FacturaCabecera_Principal.Panel2.Height > 0)
{
ex_trv_P_FacturaCabecera_ArbolSecundarioSeleccion.Size = new Size(spl_P_FacturaCabecera_Principal.Panel2.Width - 2, spl_P_FacturaCabecera_Principal.Panel2.Height - 2);
}
g_int_CentroInformacion_Ancho = spl_P_FacturaCabecera_Principal.Width - spl_P_FacturaCabecera_Principal.SplitterDistance;
}
catch (Exception)
{ }
}
#endregion
private void ex_btn_P_FacturaCabecera_EnviarMensajes_Click(object sender, EventArgs e)
{
g_obj_Controladora.Proceso_EnviarMensajes();
}
private void ex_btn_P_FacturaCabecera_FacturaE_Click(object sender, EventArgs e)
{
g_obj_Controladora.Proceso_FacturaE();
}
}
}