4118 lines
241 KiB
C#
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();
|
|
}
|
|
}
|
|
}
|