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(); } } }
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(); } } }
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(); } } }