public static string GravarCondPgto(TRegistro_CadCondPgto val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_CadCondPgto qtb_cond = new TCD_CadCondPgto(); try { if (banco == null) { st_transacao = qtb_cond.CriarBanco_Dados(true); } else { qtb_cond.Banco_Dados = banco; } val.Cd_condpgto = CamadaDados.TDataQuery.getPubVariavel(qtb_cond.GravarCondPgto(val), "@P_CD_CONDPGTO"); val.lCondParcDel.ForEach(p => TCN_CadCondPgto_X_Parcelas.DeletarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados)); val.lCondPgto_X_Parcelas.ForEach(p => { p.Cd_condpgto = val.Cd_condpgto; TCN_CadCondPgto_X_Parcelas.GravarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados); }); if (st_transacao) { qtb_cond.Banco_Dados.Commit_Tran(); } return(val.Cd_condpgto); } catch (Exception ex) { if (st_transacao) { qtb_cond.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro gravar condicao: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_cond.deletarBanco_Dados(); } } }
public static string DeletarCondPgto(TRegistro_CadCondPgto val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_CadCondPgto qtb_cond = new TCD_CadCondPgto(); try { if (banco == null) { st_transacao = qtb_cond.CriarBanco_Dados(true); } else { qtb_cond.Banco_Dados = banco; } val.lCondParcDel.ForEach(p => TCN_CadCondPgto_X_Parcelas.DeletarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados)); val.lCondPgto_X_Parcelas.ForEach(p => TCN_CadCondPgto_X_Parcelas.DeletarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados)); qtb_cond.DeletarCondPgto(val); if (st_transacao) { qtb_cond.Banco_Dados.Commit_Tran(); } return("OK"); } catch { if (st_transacao) { qtb_cond.Banco_Dados.RollBack_Tran(); } val.St_registro = "C";//Cancelado return(GravarCondPgto(val, null)); } finally { if (st_transacao) { qtb_cond.deletarBanco_Dados(); } } }