Árvore de páginas

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

...

Algumas partes do fonte mostram a representação da data ou soma de periodos para determinar o limite de envio para o governo, a melhor forma de alteração seria ajustar as regras simples direto no trecho do fonte ou criar uma função parametrizada para este calculo de data.


Função dataValida e tabela 63 :

...

Utilizando a função dataValida :

Paasando Passando a data cadastrada na tabela 63 ele irá julgar se o dia é valido ou não, em caso de proximo dia util apenas colocar o parametro para .T. e caso seja o dia anterior para .F. .

Exibindo image.png

...

borderColorwhite
bgColorblack
titleColorwhite
borderWidth0
borderStylesolid

                  

...

Atentar ao Swagger anexado pois utilizaremos o level 3 para o relatório analítico.

Neste ponto é possível reaproveitar o código que já esta implementado:

Hoje no fonte WSTAF010 na função FilIRRFSynthetic() onde esta a query principal estas informações já são retornadas na parte do TAF no campo V3N_ITIRRF e Governo no campo V3N_TPVLR.

Na função CalcIRRFVal() deve ser criada novas variáveis de controle para carregar os valores dos novos atributos que serão usados para gravar os valores na função que monta a HASH (LoadIRRFHash).

Outra alternativa é a criação de uma nova função, para que seja colhido os valores que vão compor os valores analíticos, a variáveis de controle dessa função também devem ser passadas na HASH.

Hoje na função CalcIRRFVal() temos a seguinte quebra de informações:

...

borderColorwhite
bgColorblack
titleColorwhite
borderWidth0
borderStylesolid

...

As quebras por tipo no trecho acima estão de uma forma genérica, pois o foco da função sintética era mostrar apenas valores retidos. Para a adaptar a função na parte analítica a quebra deve ser feita conforme tipo de <tpInfoIR>.

Pseudo código:

...

borderColorwhite
bgColorblack
titleColorwhite
borderWidth0
borderStylesolid

cIncidRRF =( cAlias )->V3N_ITIRRF
cIRRFGov = ( cAlias )->V3N_TPVLR

...

Para função LoadIRRFHash() deve ser implementado a lógica para a parte ANALITICA montando o JSON de resposta.

Atentar ao fato que dentro das quebras por tipo pode ter mais de um código para o mesmo tipo, neste caso tendo um JSON da seguinte maneira: 

Painel
borderColorwhite
bgColorblack
titleColorwhite
borderWidth0
borderStylesolid

"typesIrrfValues": {
                  "taxableIncome": {
                    "total": {
                      "tafValue": 57.00,
                      "erpValue": 57.00,
                      "retValue": 57.00
                    },
                    "items": [
                      {
                        "type": "11",
                        "descriptionType": "Rendimentos Tributáveis",
                        "tafValue": 35.00,
                        "erpValue": 35.00,
                        "retValue": 35.00
                      },
                      {
                        "type": "12",
                        "descriptionType": "13º salário",
                        "tafValue": 22.00,
                        "erpValue": 22.00,
                        "retValue": 22.00
                      }
                    ]

Será necessário fazer um DE/PARA para preencher descriptionType de acordo com o tipo.

Para os valores Analíticos da parte de RH na função do novo método criado, deve ser recuperado os valores da tabela V5H através da função V5HGetRhValues(), para depois ser gravados no HASH. Para isto deve ser implementado no HASH a condição de quando o processo for do RH.

Exemplo do caso a cima para analítico INSS:

...

borderColorwhite
bgColorblack
titleColorwhite
borderWidth0
borderStylesolid

...

Para execução desta ação na função é necessário reavaliar a execução da função CreateV5H(), pois será necessário a criação de campos novos para gravar os valores correspondentes as novas quebras de tipo e valores para a parte analítica, e ajuste das funções V5HByTicket(), V5HGetRhValues() com os campos novos se necessário.

Pontos de Ajuste:

...

Criação do campo V3N_CRMEN gravação da tag totApurMen\CRMen na V3N

Sugestão para o campo:

X3_CAMPO

X3_TIPO

X3_TAMANHO

X3_DECIMAL

X3_TITULO

X3_DESCRIC

X3_PICTURE

V3N_CRMENC60Cod. ReceitaCódigo de Receita      @!                     

A tag que ira alimentar o campo é <CRMen> V3N_CRMEN recebendo os valores:

056107 - IRRF mensal, 13° salário e férias sobre trabalho assalariado no país ou ausente no exterior a serviço do país, exceto se contratado por empregador doméstico ou por segurado especial sujeito a recolhimento unificado
056108 - IRRF mensal e férias - Empregado doméstico
056109 - IRRF 13° salário na rescisão de contrato de trabalho - Empregado doméstico
056110 - IRRF - Empregado doméstico 13º salário
056111 - IRRF - Empregado/Trabalhador rural - Segurado especial
056112 - IRRF - Empregado/Trabalhador rural - Segurado especial 13° salário
056113 - IRRF - Empregado/Trabalhador rural - Segurado especial 13° salário rescisório
058806 - IRRF sobre rendimento do trabalho sem vínculo empregatício
061001 - IRRF sobre rendimentos relativos a prestação de serviços de transporte rodoviário internacional de carga, pagos a transportador autônomo PF residente no Paraguai
353301 - Proventos de aposentadoria, reserva, reforma ou pensão pagos por previdência pública
356201 - IRRF sobre participação dos trabalhadores em lucros ou resultados - PLR
188901 - Rendimentos Recebidos Acumuladamente - RRA

 

A Tag que ira alimentar o campo V3N_VLRCRM <vlrCRMen>

...

Criação de uma nova #DEFINE para ser passado no array aAnalitico com o valor das TAG de código receita.

Ajuste do array passado para função upsert para alimentar os novos campos da V3N

...

Ajustar a função para que faça o INSERT do valor no campo novo criado na V3N.

...

WSTAF010

FilIRRFSynthetic : Necessário incluir os campos novos na query, pois será possível filtrar pelo código <CRMen> tendo um visão similar com a DCTFWEB (Avaliar com o Evandro informação não esta no MOCK).

CalcIRRFVal e LoadIRRFHash: Implementação da parte analítica.

Criar DE/PARA para preencher descriptionType de acordo com o tipo.

CreateV5H, V5HByTicket e V5HGetRhValues: Ajustes para criação da parte analítica e adequação com os novos campos que serão criados.

...

Criação dos campo necessários para adequar a tabela V5H.

...

TAFA250

TAFA266
TAFA280

TAFA423

TAFCHARGERPT

Avaliar se a mudança do UPSERT não afetara os processos das rotinas que fazem uso deste método e se não será necessário alteração no tamanho do array nas funções 
de grv(), xml() e SaveModel().

Avaliar todos os processos de CRUD destas rotinas por meio de integração e de modo manual, pois todo o processo para este evento é relacionado com a V3N para garantir
a persistência dos dados.

...

Documentação 

...

 A melhor forma de alteração seria ajustar as regras simples direto no trecho do fonte ou criar uma função parametrizada para este calculo de data.