예제 #1
0
        public static void Cancelar(TRegistro_Movimentacao val, BancoDados.TObjetoBanco banco)
        {
            bool             st_transacao = false;
            TCD_Movimentacao qtb_mov      = new TCD_Movimentacao();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_mov.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_mov.Banco_Dados = banco;
                }
                if (val.Tp_movimento.Trim().ToUpper().Equals("E"))
                {
                    decimal saldo = TCN_SaldoAlmoxarifado.ConsultaSaldoAlmox(val.Cd_empresa,
                                                                             val.Id_almoxstr,
                                                                             val.Cd_produto,
                                                                             qtb_mov.Banco_Dados);
                    if (saldo < val.Quantidade)
                    {
                        throw new Exception("Não existe saldo suficiente para cancelar movimentação.\r\n" +
                                            "Saldo Atual: " + saldo.ToString("N3", new System.Globalization.CultureInfo("pt-BR")) + "\r\n" +
                                            "Qtde Requerida: " + val.Quantidade.ToString("N3", new System.Globalization.CultureInfo("pt-BR")));
                    }
                }
                val.St_registro = "C";
                Gravar(val, qtb_mov.Banco_Dados);
                if (st_transacao)
                {
                    qtb_mov.Banco_Dados.Commit_Tran();
                }
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_mov.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro cancelar movimentação: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_mov.deletarBanco_Dados();
                }
            }
        }
예제 #2
0
        private void BB_Alterar_Click(object sender, EventArgs e)
        {
            if (bsPneus.Current == null)
            {
                return;
            }

            using (TFCadPneu fPneu = new TFCadPneu())
            {
                fPneu.pTitle = "Alteração de Pneu";
                fPneu.rPneu  = (bsPneus.Current as TRegistro_LanPneu);
                if (fPneu.ShowDialog() == DialogResult.OK)
                {
                    if (fPneu.rPneu != null)
                    {
                        try
                        {
                            if (fPneu.rPneu.GerarAlmoxarifado)
                            {
                                TRegistro_Movimentacao _Movimentacao = new TRegistro_Movimentacao();
                                _Movimentacao.Cd_empresa    = fPneu.rPneu.Cd_empresa;
                                _Movimentacao.Id_almox      = fPneu.rPneu.Id_almox;
                                _Movimentacao.Cd_produto    = fPneu.rPneu.Cd_produto;
                                _Movimentacao.Dt_movimento  = CamadaDados.UtilData.Data_Servidor();
                                _Movimentacao.Tp_movimento  = "E";
                                _Movimentacao.Quantidade    = 1;
                                _Movimentacao.Vl_unitario   = _Movimentacao.Vl_subtotal = fPneu.rPneu.CustoPneuAlmoxarifado;
                                _Movimentacao.St_registro   = "A";
                                _Movimentacao.Ds_observacao = "ENTRADA POR CADASTRO DE PNEUS NOVOS";
                                CamadaNegocio.Almoxarifado.TCN_Movimentacao.Gravar(_Movimentacao, null);
                            }

                            TCN_LanPneu.Gravar(fPneu.rPneu, null);
                            if (fPneu.rPneu.GerarAlmoxarifado)
                            {
                                MessageBox.Show("Gerado movimentação de entrada no almoxarifado para o produto informado. Pneu gravado com sucesso!", "Mensagem", MessageBoxButtons.OK, MessageBoxIcon.Information);
                            }
                            else
                            {
                                MessageBox.Show("Pneu gravado com sucesso!", "Mensagem", MessageBoxButtons.OK, MessageBoxIcon.Information);
                            }
                            LimparFiltros();
                            afterBusca();
                        }
                        catch (Exception ex)
                        { MessageBox.Show(ex.Message, "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error); }
                    }
                }
            }
        }
예제 #3
0
        public static string Excluir(TRegistro_Movimentacao val, BancoDados.TObjetoBanco banco)
        {
            bool             st_transacao = false;
            TCD_Movimentacao qtb_mov      = new TCD_Movimentacao();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_mov.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_mov.Banco_Dados = banco;
                }
                qtb_mov.Excluir(val);
                if (st_transacao)
                {
                    qtb_mov.Banco_Dados.Commit_Tran();
                }
                return(val.Id_movimentostr);
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_mov.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro excluir movimentação: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_mov.deletarBanco_Dados();
                }
            }
        }
예제 #4
0
        public static string Gravar(TRegistro_Movimentacao val, BancoDados.TObjetoBanco banco)
        {
            bool             st_transacao = false;
            TCD_Movimentacao qtb_mov      = new TCD_Movimentacao();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_mov.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_mov.Banco_Dados = banco;
                }
                if (val.Tp_movimento.Trim().ToUpper().Equals("S"))
                {
                    decimal saldo = TCN_SaldoAlmoxarifado.ConsultaSaldoAlmox(val.Cd_empresa,
                                                                             val.Id_almoxstr,
                                                                             val.Cd_produto,
                                                                             qtb_mov.Banco_Dados);
                    if (saldo < val.Quantidade)
                    {
                        throw new Exception("Não existe saldo suficiente para gravar movimentação.\r\n" +
                                            "Saldo Atual: " + saldo.ToString("N3", new System.Globalization.CultureInfo("pt-BR")) + "\r\n" +
                                            "Qtde Requerida: " + val.Quantidade.ToString("N3", new System.Globalization.CultureInfo("pt-BR")));
                    }
                }
                val.LoginAlmoxarife = Utils.Parametros.pubLogin;
                val.Id_movimentostr = CamadaDados.TDataQuery.getPubVariavel(qtb_mov.Gravar(val), "@P_ID_MOVIMENTO");
                if (val.rNFItem != null)
                {
                    val.rNFItem.Id_movimento = val.Id_movimento;
                    TCN_Mov_X_NFItem.Gravar(val.rNFItem, qtb_mov.Banco_Dados);
                }
                if (val.rRequisicao != null)
                {
                    val.rRequisicao.Id_movimento = val.Id_movimento;
                    val.rRequisicao.Cd_empresa   = val.Cd_empresa;
                    TCN_Mov_X_Requisicao.Gravar(val.rRequisicao, qtb_mov.Banco_Dados);
                }
                if (st_transacao)
                {
                    qtb_mov.Banco_Dados.Commit_Tran();
                }
                return(val.Id_movimentostr);
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_mov.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro gravar movimentação: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_mov.deletarBanco_Dados();
                }
            }
        }