quinta-feira, 17 de julho de 2014

Atualizar mensagens NF 3.10

Programa para rodar no PI para atualizar as mensagens de erro da NF-e /XNFE/GOVERMENT_STATUS_LOAD

 

Na solução SAP NFE, é possível definir os códigos de status do governo através de uma tabela de customizing.
Para acessá-la, vá para SPRO -> IMG Referência SAP -> SAP GRC Nota Fiscal Eletrônica -> Definir código do status da SEFAZ.

As descrições dos códigos de status serão associadas ao idioma em que se está logado (mas também é possível traduzir as descrições através do menu Ir Para -> Tradução).

Alternativamente, é possível carregar os códigos de status e descrições no SAP NFE a partir de um arquivo .txt pré-definido, através do programa /XNFE/GOVERMENT_STATUS_LOAD.
Para isso, o arquivo .txt previsa conter uma linha de cabeçalho e, para cada código de status, uma linha com o código (3 dígitos) e a descrição, separados por tabulação.
Quando se executa o programa, é necessário entrar com dois parâmetros: o caminho do arquivo .txt (pode estar na sua máquina local) e o idioma das descrições dos códigos de status.

Os códigos de status do governo estão incluídos no Manual de Integração do Contribuinte , seção 5.1.1.
É possível pode copiá-los de lá e colá-los no arquivo .txt. Contudo, ainda será necessário separar os códigos e as descrições com uma tabulação. É possível utilizar o Microsoft Excel para isso.

O seguinte link contém um arquivo .txt pronto com os códigos e descrições de status em português (PT): NFe_status_codes_-_PT.zip.
Karsten Kötter enviou um link para um arquivo com as descrições em inglês (EN): NFe_status_codes_-_EN.zip.

Para transportar os códigos de status para outros sistemas, você pode adicionar o conteúdo de customizing relevante em uma request.
Para isso, siga estes passos:

·         No sistema NFE, vá para SPRO -> IMG Referência SAP -> SAP GRC Nota Fiscal Eletrônica -> Definir código do status da SEFAZ

·         No menu, vá para On the menu, go to Visão de Tabelas -> Transporte;

·         Crie ou selecione a request que se quer usar para transportar esses valores;

·         Selecione todas as entradas ( F7 );

·         Clique no botão "Incluir na ordem";

·         Clique no botão "Salvar".

Obs: esta visão é dependente de idioma, então você precisa repetir esses passos para cada idioma que se quer usar no sistema NFE

 

AVISO LEGAL

"As informações existentes nesta mensagem e nos arquivos anexados têm caráter confidencial e são para uso restrito. A utilização, divulgação, cópia ou distribuição desta mensagem, ou parte dela, por qualquer pessoa diferente do destinatário é proibida, sujeitando o infrator às sanções legais. Se esta mensagem foi recebida por engano, favor excluí-la e informar ao remetente pelo endereço eletrônico acima. Agradecemos sua cooperação."

DISCLAIMER

"This email and its attachments may contain privileged and/or confidential information. Use, disclosure, copying or distribution of this message, or part thereof, by anyone other than the intended recipient is strictly prohibited, and will submit the infractor to the legal sanctions. If you have received this email in error, please notify the sender by reply email and destroy all copies of this message. Thank you for your cooperation."

terça-feira, 15 de julho de 2014

Exit....

Fórum ABAP Zombie

 

Publicado em 19 de julho de 2012 | por Daiane Zigiotto

 

BADI de,-sai do usuário, aprimoramentos ... como Encontra-los?

Faaaala Zumbizada! ESTOU de Volta nenhuma Modo "zumbi = ON" por Causa fazer o Projeto, testículos Integrados Opaco estao acabando com a Minha Vida (e Opaco Nunca acabam!) Bom, mas Chega de mimimi e Vamos lá! Neste pós Vou FALAR sobre alguns methods parágrafo encontrar Melhorias,-sai de usuários, de BADI e etc Aposto Que ISSO PODE ajudar Muito, principalmente parágrafo OS zumbis Mais novinhos.

NAO, ISSO E UMA Localidade: Não user-exit ...

 

FUNÇÃO DO CLIENTE CHAMADA

Você. PODE colocar hum BREAK-POINT Comando Nesse, Opaco E USADO parágrafo Chamar-sai como usuário. Ja falamos DELE Aqui no blogue e se Quiser Saber Mais, Clique Aqui .

 

BADI'S

Método 1: V_EXT_ACT e V_EXT_IMP

A BADI FAZ UMA NAS Seleção Tabelas de visões V_EXT_ACT e V_EXT_IMP. Entao PODEMOS IR na transação ST05 -> Select "SQL trace" e "Tabela buffer de rastreamento" -> Ativar Trace -> Executar uma transação -> Desativar Trace -> Tela Trace.

Ira aparecer um abaixo Tela:

 

Vamos Select OS seguintes Objetos:

 

Nenhum Resultado Ira Mostrar Todas final como BADI de na Ordem los Opaco ELAS FORAM executadas:

 

Método 2: CL_EXITHANDLER => GET_CLASS_NAME_BY_INTERFACE

Na transação SE24, Vamos Select um CL_EXITHANDLER classe, ir par o Método get_instance e colocar hum BREAK-POINT.

Atraves fazer Parâmetro de Exportação EXIT_NAME E Possível sabre o nomo da BADI Que Sera Chamada.

 

Método 3: FM SXV_GET_CLIF_BY_NAME.

Um Outro Método E colocando hum break point na função SXV_GET_CLIF_BY_NAME, Opaco E Chamada Toda Vez Que alguma BADI E executada.

O Parâmetro de Exportação NOME Ira mostrar o nomo da BADI.

 

E aí, Achou Difícil, chato, deprimente? Localidade: Não se assuste, Vou mostrar algumas Ferramentas that PODEM facilitar a SUA vida!

A Há sândalo ritmo Atrás precisei encontrar UMA user-exit de UMA transação X, e no Meio de hum fórum não encontrei SCN hum Programa Bastante Útil! Lista Ele. Todas como de UMA transação UO Programa usuário sai-e de Badi.

 

Abaixo ESTA o Código-Fonte. Nao sei QUEM É O autor e Localidade: Não Será, será Coincidência encontrar ESSE MESMO EM PROGRAMA To Us Link fóruns (e Bem manjado).

Default

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

REPORT z_enhancement_finder NO STANDARD PAGE HEADING LINE-SIZE 201.

 

TABLES :  tstc,

          tadir,

          modsapt,

          modact,

          trdir,

          tfdir,

          enlfdir,

          sxs_attrt ,

          tstct.

 

DATA : jtab LIKE tadir OCCURS 0 WITH HEADER LINE.

DATA : field1(30).

DATA : v_devclass LIKE tadir-devclass.

 

PARAMETERS : p_tcode LIKE tstc-tcode,

p_pgmna LIKE tstc-pgmna .

 

DATA wa_tadir TYPE tadir.

 

START-OF-SELECTION.

 

  IF NOT p_tcode IS INITIAL.

    SELECT SINGLE * FROM tstc WHERE tcode EQ p_tcode.

 

  ELSEIF NOT p_pgmna IS INITIAL.

    tstc-pgmna = p_pgmna.

  ENDIF.

 

  IF sy-subrc EQ 0.

    SELECT SINGLE * FROM tadir

    WHERE pgmid = 'R3TR'

    AND object = 'PROG'

    AND obj_name = tstc-pgmna.

 

    MOVE : tadir-devclass TO v_devclass.

 

    IF sy-subrc NE 0.

      SELECT SINGLE * FROM trdir

      WHERE name = tstc-pgmna.

      IF trdir-subc EQ 'F'.

        SELECT SINGLE * FROM tfdir

        WHERE pname = tstc-pgmna.

 

        SELECT SINGLE * FROM enlfdir

        WHERE funcname = tfdir-funcname.

 

        SELECT SINGLE * FROM tadir

        WHERE pgmid = 'R3TR'

        AND object = 'FUGR'

        AND obj_name EQ enlfdir-area.

 

        MOVE : tadir-devclass TO v_devclass.

      ENDIF.

    ENDIF.

 

    SELECT * FROM tadir INTO TABLE jtab

    WHERE pgmid = 'R3TR'

    AND object IN ('SMOD', 'SXSD')

    AND devclass = v_devclass.

 

    SELECT SINGLE * FROM tstct

    WHERE sprsl EQ sy-langu

    AND tcode EQ p_tcode.

 

    FORMAT COLOR COL_POSITIVE INTENSIFIED OFF.

    WRITE:/(19) 'Transaction Code - ',

    20(20) p_tcode,

    45(50) tstct-ttext.

    SKIP.

    IF NOT jtab[] IS INITIAL.

      WRITE:/(105) sy-uline.

      FORMAT COLOR COL_HEADING INTENSIFIED ON.

 

*      sorting the internal table

      SORT jtab BY object.

      DATA : wf_txt(60) TYPE c,

      wf_smod TYPE i ,

      wf_badi TYPE i ,

      wf_object2(30) TYPE c.

      CLEAR : wf_smod, wf_badi , wf_object2.

 

*GET the total smod.

      LOOP AT jtab INTO wa_tadir.

        AT FIRST.

          FORMAT COLOR COL_HEADING INTENSIFIED ON.

 

          WRITE:/1 sy-vline,

          2 'Enhancement/ Business Add-in',

          41 sy-vline ,

          42 'Description',

          105 sy-vline.

          WRITE:/(105) sy-uline.

        ENDAT.

        CLEAR wf_txt.

        AT NEW object.

          IF wa_tadir-object = 'SMOD'.

            wf_object2 = 'Enhancement' .

          ELSEIF wa_tadir-object = 'SXSD'.

            wf_object2 = ' Business Add-in'.

 

          ENDIF.

          FORMAT COLOR COL_GROUP INTENSIFIED ON.

 

          WRITE:/1 sy-vline,

 

          2 wf_object2,

          105 sy-vline.

        ENDAT.

 

        CASE wa_tadir-object.

          WHEN 'SMOD'.

            wf_smod = wf_smod + 1.

            SELECT SINGLE modtext INTO wf_txt

            FROM modsapt

            WHERE sprsl = sy-langu

            AND name = wa_tadir-obj_name.

            FORMAT COLOR COL_NORMAL INTENSIFIED OFF.

 

          WHEN 'SXSD'.

*        for badis

            wf_badi = wf_badi + 1 .

            SELECT SINGLE text INTO wf_txt

            FROM sxs_attrt

            WHERE sprsl = sy-langu

            AND exit_name = wa_tadir-obj_name.

            FORMAT COLOR COL_NORMAL INTENSIFIED ON.

        ENDCASE.

 

        WRITE:/1 sy-vline,

        2 wa_tadir-obj_name HOTSPOT ON,

        41 sy-vline ,

        42 wf_txt,

        105 sy-vline.

        AT END OF object.

          WRITE : /(105) sy-uline.

        ENDAT.

      ENDLOOP.

 

      WRITE:/(105) sy-uline.

 

      SKIP.

      FORMAT COLOR COL_TOTAL INTENSIFIED ON.

      WRITE:/ 'No.of Exits:' , wf_smod.

      WRITE:/ 'No.of BADis:' , wf_badi.

 

    ELSE.

      FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.

      WRITE:/(105) 'No userexits or BADis exist'.

    ENDIF.

  ELSE.

    FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.

    WRITE:/(105) 'Transaction does not exist'.

  ENDIF.

 

AT LINE-SELECTION.

 

  DATA : wf_object TYPE tadir-object.

  CLEAR wf_object.

 

  GET CURSOR FIELD field1.

  CHECK field1(8) EQ 'WA_TADIR'.

  READ TABLE jtab WITH KEY obj_name = sy-lisel+1(20).

  MOVE jtab-object TO wf_object.

 

  CASE wf_object.

    WHEN 'SMOD'.

      SET PARAMETER ID 'MON' FIELD sy-lisel+1(10).

 

      CALL TRANSACTION 'SMOD' AND SKIP FIRST SCREEN.

    WHEN 'SXSD'.

      SET PARAMETER ID 'EXN' FIELD sy-lisel+1(20).

      CALL TRANSACTION 'SE18' AND SKIP FIRST SCREEN.

  ENDCASE.

 

Encontrei also ESSE Outro Relatório abaixo. O Código-Fonte ESTA Aqui . Basicamente, a temperatura MESMA functionality, mas eu particularmente Prefiro o anterior.

 

OUTRAS Ferramentas

SNIF

E voce PODE Estar se perguntando: "Localidade: Não existe nenhum Relatório padrão?".Sim, existe! A SAP disponibiliza o SNIF (ESSE É O Nome do Programa, Nao da transação) Opaco Lista de Todos os Costumer Melhorias Ativos:

 

 

ABAP RAIO X DOS OLHOS

Pesquisando hum Pouco Mais encontrei hum "SNIF melhorado", Que inclui algumas opções, Como POR Exemplo, sai parágrafo Validação e Substituição, fórmulas (VOFM), ecrã de saídas e Campo-saídas. ESSE ligação Projeto ESTA DISPONÍVEL Neste:http://code.google.com/p/abapexitrayeye/ e parágrafo implementa-lo Você. precisará USAR o SAP ligação .

 

 

AVISO LEGAL

"As informações existentes nesta mensagem e nos arquivos anexados têm caráter confidencial e são para uso restrito. A utilização, divulgação, cópia ou distribuição desta mensagem, ou parte dela, por qualquer pessoa diferente do destinatário é proibida, sujeitando o infrator às sanções legais. Se esta mensagem foi recebida por engano, favor excluí-la e informar ao remetente pelo endereço eletrônico acima. Agradecemos sua cooperação."

DISCLAIMER

"This email and its attachments may contain privileged and/or confidential information. Use, disclosure, copying or distribution of this message, or part thereof, by anyone other than the intended recipient is strictly prohibited, and will submit the infractor to the legal sanctions. If you have received this email in error, please notify the sender by reply email and destroy all copies of this message. Thank you for your cooperation."

quarta-feira, 11 de junho de 2014

SCREEM ITM_EXPORT

Programa SAPLJ1BB2 Tela 2000 Opaco Deveria.

 

subtela 'ITM_EXPORT'.

 

Incluíndo ESTA referencia Desenvolvimento, habilitou from that o CFOP SEJA Relevante parágrafo Exportação (7 ...)

 

Ex:

 

com ESSA alteração o Programa Passa na Lógica:

      IF-screen name = 'ITM_EXPORT'. "1933985

        executar check_export_relevance "1933985

          mudando gx_export_relevant. "1933985

        se gx_export_relevant = abap_false. "1933985

          tela invisível = 1 ". 1933985

        outra coisa. "1933985

          tela invisível = 0. "1933985

        endif. "1933985

        MODIFICAR SCREEN. "1933985

      ENDIF.   

 

E habilita necessário.

 

Verifique a aplicação da Nota SAP OSS  2003392

 

quarta-feira, 4 de junho de 2014

terça-feira, 3 de junho de 2014

Tabela Bacen - Código de Países

Nfe-Código de Países

Em projetos de Nfe, uma das necessidades é o Código do Pais Emitente e Destinatário.

A primeira parte deste processo é onde colocar esta informação, em meus projetos, utilizei as seguintes definições :

A tabela T005I, que tem como finalidade a parametrização do Prefixo internacional de TELEX, um meio de comunicação que já não se utiliza mais nas empresas, conforme o Help da SAP abaixo:

Caso não seja possível a utilização desta tabela na sua empresa, pode-se estender T005(Países ) com um Apend de tabela com um campo Z, uma View com o Pais e Campo Z e finalmente uma SM30 desta VIEW para a manutenção dos dados e lembre-se: tabela "Z", neste caso, para mim, na minha opinião, esta fora de questão.

Para os casos de Exportação, o código do País é obrigatório no arquivo XML.

Para as demais operações, esse código é opcional, porém, recomendo alguma implementação para que este dado seja passado sempre.

 

Exemplo de cadastramento para o Brasil, pais emitente.., que deve ser utilizado para todos os países destinatários ( no caso de exportações ).

 

Como chegar:

Caso você não encontre o caminho correto na sua versão:

Execute a transação SM30, Digite a tabela T005I e clique no botão customizing

para localizar o caminho correto para o IMG desta tabela na sua versão.

Basta deixar a informação "Para" em branco e gravar os registros dos países em que a sua empresa faz exportações, que será a grande necessidade do momento.

Abaixo um passo a Passo para Baixar a Tabela de Países do Banco Central :

• País: Código ISO do País (BR para Brasil, US para Estados Unidos, etc);

• Código País: Código do país de acordo com tabela do Banco Central, constante em

http://www.bcb.gov.br/rex/ftp/paises.txt

Caso não funcionar o endereço acima, o jeito é navegar mesmo, veja a navegação atual:

Endereço Inicial: http://www.bcb.gov.br/

Clicar em cambio e Capitais Estrangeiros

Clicar em Sistemas

Clicar em Tabela de países

Clicar em Download (TXT - 11 kb)

Link direto para Baixar a tabela de países:

http://www.bcb.gov.br/rex/ftp/paises.txt

A segunda parte deste processo é levar para o XML o dois códigos de países, emitente e destinatário:

 

Na implementação da BAdI CL_NFE_PRINT, via transação SE19, inserir a definição abaixo no método FILL_HEADER:

NA FUNCTION 'J_1B_BRANCH_READ' se faz a leitura da filial emitente e seus dados de endereço.

Ler a tabela T005I para recuperar o pais do emitente.

NA FUNCTION 'J_1B_NF_PARTNER_READ' se faz a leitura do parceiro destinatário.

Ler a tabela T005I para recuperar o pais do destinatário.

 

Consultar o seu manual da SEFAZ para saber em que TAG estes campos devem ser atualizados e solicitar a movimentação para o campo correto da BADI ao desenvolvedor ABAP.