Exemplo n.º 1
0
        /// <summary>Este método permite cargar las facturas seleccionadas en el pago.</summary>
        /// <param name="_P_Obj_Combo">Combo donde se van a mostrar las facturas seleccionadas.</param>
        /// <param name="_P_Str_Compañia">Código de la compañía para efecutar el filtro.</param>
        private void _Mtd_CargarComboFacturas(ComboBox _P_Obj_Combo, string _P_Str_Compañia)
        {
            string _Str_SQL, _Str_WHERE = "";

            //Valor por defecto
            _Str_SQL = "select '0' as cfactura, '...' as cdescripcion UNION ";

            //Consutamos
            _Str_SQL += "select distinct convert(varchar, TFACTURAM.cfactura) as cfactura, ('Factura: ' + convert(varchar, TFACTURAM.cfactura) + ' - Bs F. ' + dbo.Fnc_Formatear(Abs(cmontosaldo))) as cdescripcion from TFACTURAM";
            _Str_SQL += " inner join TTRCDOCUMENTO on TFACTURAM.ccompany = TTRCDOCUMENTO.ccompany and TFACTURAM.cfactura = TTRCDOCUMENTO.cfactura";

            foreach (DataGridViewRow oFactura in _G_Obj_Facturas.Rows)
            {
                var _Bol_EsContribuyenteEspecial = Frm_RC_Pago._Mtd_ClienteEsContribuyenteEspecial(oFactura.Cells["colClienteFactura"].Value.ToString());

                if ((oFactura.Cells[0].Value != null) && ((bool)oFactura.Cells[0].Value) && _Bol_EsContribuyenteEspecial)
                {
                    _Str_WHERE += ((_Str_WHERE == "") ? " where (" : " or ") + "((TFACTURAM.cfactura=" + oFactura.Cells[2].Value.ToString() + "))";
                }
            }
            _Str_SQL += " AND (cmontodocumentoimpuesto > 0.00) ";

            //QUE NO EXISTA EN EL GRID NI EN LA BD
            _G_Obj_Retenciones.Rows.Cast <DataGridViewRow>().ToList().ForEach(_Row =>
            {
                _Str_SQL += "AND (TFACTURAM.cfactura <> " + _Row.Cells["colRetencionFactura"].Value.ToString() + ") ";
            });

            //QUE NO EXISTAN  EN LA BD
            if (_G_Str_IdPago != "")
            {
                _Str_SQL += "AND NOT EXISTS (SELECT TTRCRETENCION.cfactura FROM TTRCRETENCION WHERE ISNULL(TTRCRETENCION.cdelete,0)=0 AND TTRCRETENCION.cfactura=TFACTURAM.cfactura AND cidpago <> " + _G_Str_IdPago + ") ";
            }
            else
            {
                _Str_SQL += "AND NOT EXISTS (SELECT TTRCRETENCION.cfactura FROM TTRCRETENCION WHERE ISNULL(TTRCRETENCION.cdelete,0)=0 AND TTRCRETENCION.cfactura=TFACTURAM.cfactura) ";
            }

            if (_Str_WHERE != "")
            {
                var _SQL = _Str_SQL + _Str_WHERE + " and (TFACTURAM.ccompany='" + _P_Str_Compañia.Trim() + "'));";

                DataSet oResultado = Program._MyClsCnn._mtd_conexion._Mtd_RetornarDataset(_SQL);

                _P_Obj_Combo.DataSource    = oResultado.Tables[0];
                _P_Obj_Combo.DisplayMember = "cdescripcion";
                _P_Obj_Combo.ValueMember   = "cfactura";
                _P_Obj_Combo.SelectedIndex = 0; //Seleccionamos el valor por defecto
            }
        }