예제 #1
0
        public static string Gravar(TRegistro_LoteCustodia val, BancoDados.TObjetoBanco banco)
        {
            bool             st_transacao = false;
            TCD_LoteCustodia qtb_lote     = new TCD_LoteCustodia();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_lote.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_lote.Banco_Dados = banco;
                }
                string retorno = qtb_lote.Gravar(val);
                val.Id_lote = Convert.ToDecimal(CamadaDados.TDataQuery.getPubVariavel(retorno, "@P_ID_LOTE"));
                //Excluir titulos lote
                val.lChCustodiaDel.ForEach(p => TCN_LoteCustodia_X_Titulo.Excluir(new TRegistro_LoteCustodia_X_Titulo()
                {
                    Nr_lanctocheque = p.Nr_lanctocheque,
                    Cd_banco        = p.Cd_banco,
                    Cd_empresa      = p.Cd_empresa,
                    Id_lote         = val.Id_lote
                }, qtb_lote.Banco_Dados));
                //Gravar titulo lote
                val.lChCustodia.ForEach(p =>
                {
                    TCN_LoteCustodia_X_Titulo.Gravar(new TRegistro_LoteCustodia_X_Titulo()
                    {
                        Nr_lanctocheque = p.Nr_lanctocheque,
                        Cd_banco        = p.Cd_banco,
                        Cd_empresa      = p.Cd_empresa,
                        Id_lote         = val.Id_lote
                    }, qtb_lote.Banco_Dados);
                });
                if (st_transacao)
                {
                    qtb_lote.Banco_Dados.Commit_Tran();
                }
                return(retorno);
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_lote.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro gravar lote custodia: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_lote.deletarBanco_Dados();
                }
            }
        }
예제 #2
0
        public static string Excluir(TRegistro_LoteCustodia val, BancoDados.TObjetoBanco banco)
        {
            bool             st_transacao = false;
            TCD_LoteCustodia qtb_lote     = new TCD_LoteCustodia();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_lote.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_lote.Banco_Dados = banco;
                }
                //Excluir titulos do lote
                val.lChCustodia.ForEach(p => TCN_LoteCustodia_X_Titulo.Excluir(new TRegistro_LoteCustodia_X_Titulo()
                {
                    Cd_banco        = p.Cd_banco,
                    Cd_empresa      = p.Cd_empresa,
                    Nr_lanctocheque = p.Nr_lanctocheque,
                    Id_lote         = val.Id_lote
                }, qtb_lote.Banco_Dados));
                val.lChCustodiaDel.ForEach(p => TCN_LoteCustodia_X_Titulo.Excluir(new TRegistro_LoteCustodia_X_Titulo()
                {
                    Cd_banco        = p.Cd_banco,
                    Cd_empresa      = p.Cd_empresa,
                    Nr_lanctocheque = p.Nr_lanctocheque,
                    Id_lote         = val.Id_lote
                }, qtb_lote.Banco_Dados));
                qtb_lote.Excluir(val);
                if (st_transacao)
                {
                    qtb_lote.Banco_Dados.Commit_Tran();
                }
                return("OK");
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_lote.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro excluir lote custodia: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_lote.deletarBanco_Dados();
                }
            }
        }
예제 #3
0
        public static void EnviarLote(TRegistro_LoteCustodia val, BancoDados.TObjetoBanco banco)
        {
            bool             st_transacao = false;
            TCD_LoteCustodia qtb_lote     = new TCD_LoteCustodia();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_lote.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_lote.Banco_Dados = banco;
                }
                val.St_registro = "E";//Lote enviado
                Gravar(val, qtb_lote.Banco_Dados);
                //Trocar status dos titulo para custodiados
                val.lChCustodia.ForEach(p =>
                {
                    //Verificar se titulo devolvido
                    if (p.Status_compensado.Trim().ToUpper().Equals("V"))
                    {
                        new CamadaDados.Financeiro.Titulo.TCD_DevolucaoCheque(qtb_lote.Banco_Dados).Select(
                            new Utils.TpBusca[]
                        {
                            new Utils.TpBusca()
                            {
                                vNM_Campo = "a.cd_empresa",
                                vOperador = "=",
                                vVL_Busca = "'" + p.Cd_empresa.Trim() + "'"
                            },
                            new Utils.TpBusca()
                            {
                                vNM_Campo = "a.nr_lanctocheque",
                                vOperador = "=",
                                vVL_Busca = p.Nr_lanctocheque.ToString()
                            },
                            new Utils.TpBusca()
                            {
                                vNM_Campo = "a.cd_banco",
                                vOperador = "=",
                                vVL_Busca = "'" + p.Cd_banco.Trim() + "'"
                            },
                            new Utils.TpBusca()
                            {
                                vNM_Campo = "a.dt_reapresentacao",
                                vOperador = "is",
                                vVL_Busca = "null"
                            }
                        }, 1, string.Empty, string.Empty).ForEach(v =>
                        {
                            v.Dt_reapresentacao = CamadaDados.UtilData.Data_Servidor(qtb_lote.Banco_Dados);
                            CamadaNegocio.Financeiro.Titulo.TCN_DevolucaoCheque.GravarDevolucaoCheque(v, qtb_lote.Banco_Dados);
                        });
                    }
                    p.Status_compensado = val.Tp_registro.Trim().ToUpper().Equals("C") ? "U" : "L";
                    TCN_LanTitulo.AlterarTitulo(p, qtb_lote.Banco_Dados);
                });
                if (st_transacao)
                {
                    qtb_lote.Banco_Dados.Commit_Tran();
                }
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_lote.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro enviar lote: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_lote.deletarBanco_Dados();
                }
            }
        }