Ir para conteúdo
  • Cadastre-se

dev botao

Nota Fiscal De Cancelamento


cavalomarinho
  • Este tópico foi criado há 4096 dias atrás.
  • Talvez seja melhor você criar um NOVO TÓPICO do que postar uma resposta aqui.

Recommended Posts

Olá pessoal

Antigamente o acbrnfemonitor tinha uma pasta que gravava os xmls das notas fiscais canceladas, exp: D:\NFE\201212\CAN após esta mudança para cancelamento da nota tem que gerar um evento o xml de retorno de autorização da homologacao do cancelamento fica numa pasta de status, nao mais ficando organizado na pasta de cancelamento como era antigamente.

Alguem sabe como resolver este problema, acontece tambem com a cce.

Obrigado

Link para o comentário
Compartilhar em outros sites

Boa noite Regis, não entendir muito bem, o xml autorizado está em uma pasta d:\nfe\201301\nfe\?????????-nfe.xml, o protocolo referente a autorização da nfe está localizado na pasta d:\nfe\status\?????????-procEventoNFE.xml e este xml que me informa que o cancelamento foi homologado certo? daí surge algumas duvidas:

1 - como fazer para que o acbrnfemonitor reconheca que esta nota está cancelada, pois fiz uma impressao do danfe e nao colocou aquela tarja informando que a nfe está cancelada como fazia antigamente.

2 - antes as nfes canceladas ia para uma pasta especifica exp.: D:\NFE\201301\CAN\????????????-ProcCancNfe.xml

3 - Outro detalhe que está me tirando o sono, apos o cancelamento e o recebimento do arquivo xml ?????procEventoNfe.xml informando que a nota tinha sido homologado o cancelamento fui fazer uma consulta no site da receita federal e a nota continuava como AUTORIZADA. fique sem entender.

Agradeço desde já.

Link para o comentário
Compartilhar em outros sites

CavaloMarinho,

 

Lhe recomendo sempre gravar no BD o XML cancelado e o XML autorizado, veja abaixo a minha rotina, eu busco o XML salvo no HD e insiro no BD:

 

Assim, você organiza e tem mais segurança.

 

 

procedure TfrmNotaFiscal.CancelarNFe1Click(Sender: TObject);
var
  idLote, CNPJ, Justificativa : string;
  quGeral, quCrTit: TADOQuery;
begin
  quCrTit := TADOQuery.Create(Self);
  quCrTit.Connection := frmPrincipal.BD;
  quCrTit.SQL.Add('SELECT 1 FROM NOTAVENPARCEL T0');
  quCrTit.SQL.Add('WHERE T0.CODIGO = '+Codigo.Text);
  quCrTit.SQL.Add('AND T0.CODEMP = '+frmPrincipal.EmpAtiva);
  quCrTit.SQL.Add('AND T0.VALORPARCELA <> T0.VALORABERTO');
  quCrTit.Open;
  if quCrTit.IsEmpty then
  begin
    IniciaComponente;
    CNPJ := copy(ChaveNFe.Text,7,14);
    Justificativa := 'Justificativa do Cancelamento';
    if not(InputQuery('WebServices Eventos: Cancelamento', 'Justificativa do Cancelamento', Justificativa)) then
       exit;
 
    ACBNF.EventoNFe.Evento.Clear;
    with ACBNF.EventoNFe.Evento.Add do
     begin
       infEvento.chNFe := ChaveNFe.Text;
       infEvento.CNPJ   := copy(ChaveNFe.Text,7,14);
       infEvento.dhEvento := now;
       infEvento.tpEvento := teCancelamento;
       infEvento.detEvento.xJust := Justificativa;
       infEvento.detEvento.nProt := Protocolo.Text;
     end;
    try
      ACBNF.EnviarEventoNFe(StrToInt(Codigo.Text));
      //verificar ainda se foi baixado o titulo
      CodigoNFe.Text := IntToStr(ACBNF.WebServices.EnvEvento.EventoRetorno.retEvento.Items[0].RetInfEvento.cStat);
      MsgSefaz.Lines.Add('Justificativa: '+Justificativa);
      MsgSefaz.Lines.Add(
      DateTimeToStr(ACBNF.WebServices.EnvEvento.EventoRetorno.retEvento.Items[0].RetInfEvento.dhRegEvento) + ': ' +
      ACBNF.WebServices.EnvEvento.EventoRetorno.retEvento.Items[0].RetInfEvento.xMotivo);
      if CodigoNFe.Text = '135' then
      begin
        Status.ItemIndex := 6;
        EstornaEstoque;
        InserirXMLdaNFe(ChaveNFe.Text + '1101111-ProcEventoNFe.xml', 'Can');
        ACBNF.Free;
        ShowMessage('Nota Fiscal Cancelada com Exito.');
      end
      else
      begin
        quGeral := TADOQuery.Create(Self);
        quGeral.Connection := frmPrincipal.BD;
        quGeral.SQL.Add('UPDATE NOTAVENCAB');
        quGeral.SQL.Add('SET MSGSEFAZ = :MSGSEFAZ');
        quGeral.SQL.Add('WHERE CODIGO = '+Codigo.Text);
        quGeral.SQL.Add('AND CODEMP = '+frmPrincipal.EmpAtiva);
        quGeral.Parameters.ParamByName('MSGSEFAZ').Value := MsgSefaz.Text;
        quGeral.ExecSQL;
        quGeral.Free;
        ACBNF.Free;
        MessageDlg('Erro ao cancelar a NF:  '+#13+ACBNF.WebServices.EnvEvento.EventoRetorno.retEvento.Items[0].RetInfEvento.xMotivo, mtError, [mbOK], 0);
      end;
 
    Except
      on e:exception do
      begin
        CodigoNFe.Text := IntToStr(ACBNF.WebServices.EnvEvento.cStat);
        MsgSefaz.Lines.Add(DateTimeToStr(now) + ': '+ACBNF.WebServices.EnvEvento.xMotivo);
        MsgSefaz.Lines.Add(DateTimeToStr(now) + ': '+E.Message);
        ACBNF.Free;
        MessageDlg('Erro ao cancelar a NF:  '+#13+E.Message, mtError, [mbOK], 0);
      end;
    end;
  end
  else
  begin
    MessageDlg('Erro ao cancelar a nota fiscal já possui baixas.'+sLineBreak+'Cancele a baixa e tente baixar novamente.', mtError, [mbOK], 0);
  end;
end;
Link para o comentário
Compartilhar em outros sites

  • Este tópico foi criado há 4096 dias atrás.
  • Talvez seja melhor você criar um NOVO TÓPICO do que postar uma resposta aqui.

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora
×
×
  • Criar Novo...

Informação Importante

Colocamos cookies em seu dispositivo para ajudar a tornar este site melhor. Você pode ajustar suas configurações de cookies, caso contrário, assumiremos que você está bem para continuar.

The popup will be closed in 10 segundos...