Páginas filhas
  • ER_PCREQ-9046_Troca_de_Propriedade_Fase_II_Onda_de_Separacao

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.
Comentário: Migration of unmigrated content due to installation of a new plugin

 Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico.                                                             

  

(Obrigatório)

Troca de Propriedade - Fase II - Onda de Separação

Informações Gerais

 

<Caso necessário informe outras referências que sejam pertinentes a esta especificação. Exemplo: links de outros documentos ou subtarefas relacionadas>.

Especificação

Produto

Logix

Módulo

WMS

Segmento Executor

D&LLogística

Projeto1 

L_DL_WMS002.MPP

IRM1 

PCREQ-4909

Requisito1 

PCREQ-9046

Subtarefa1 

PDRDL-2316

Chamado2

 

Release de Entrega Planejada

 

Réplica

 

País

(x) Brasil  (  ) Argentina  (  ) Mexico  (  ) Chile  (  ) Paraguai  (  ) Equador

(  ) USA  (  ) Colombia   (  ) Outro _____________.

12.1.12

Réplica

12.1.12

Outros

   Legenda: 1 – Inovação 2 – Manutenção (Os demais campos devem ser preenchidos para ambos os processos). 

Objetivo

Gerar as informações iniciais do processo de expediçãorecebimento, no momento em que for gerada a Onda. Deverão , sendo que deverão ser geradas informações de CESV e planejamento de embarquedo recebimento.


Definição da Regra de Negócio

O processo de transferência de propriedade sempre ocorrerá durante a separação, para isso, deverão ser geradas as informações iniciais da expedição, CESV e planejamento de embarque, após a geração das Ondas de separação.

Ao gerar as ondas de coleta deverá ser verificado se a solicitação de carga vinculada ao plano é de troca de propriedade.

Caso atenda a esta condição, após a geração das Ondas, deverão ser gerados o CESV/documental e o plano de recebimento para o depositante destinatário do processo.

O endereço a ser utilizado para conferência do recebimento deverá ser o mesmo endereço destino do plano de separação, que por sua vez deverá estar parametrizado no Contrato do depositante origem.

Ao efetuar o cancelamento de uma onda de coleta deverá ser verificado se a mesma contém solicitação de carga de troca de propriedade. Tendo esta condição atendida, deverão ser excluídos os dados do CESV e do plano de recebimento do depositante destino da solicitação de carga. 


Rotina

Tipo de Operação

Opção de Menu

Regras de Negócio

[ACAA040 – Parâmetros]WMS60003 - Ondas de separação

[Alteração]

[Atualizações -> Acadêmico-> Tesouraria]

-

[ACAA050 – Negociação Financeira]

[Envolvida]

[Atualizações -> Acadêmico-> Tesouraria]

-

[ACAA060 – Cadastro de Pedidos]

[Criação]

[Atualizações -> Acadêmico-> Cadastros]

-

 

Exemplo de Aplicação:

  • Criar o campo “% Mínimo Espécie” (AAA_PERESP) onde o usuário informará o % que o aluno pagará em dinheiro. Esse % poderá ser alterado durante a negociação.
  • Criar o campo “Referência Mínima para Cálculo” (AAA_REFCAL) onde o usuário informará um dos 4 valores disponíveis para pagamento das mensalidades  como a referência mínima para calcular o débito total do aluno.
  • Criar o parâmetro MV_ACPARNE que definirá se as informações de “% Mínimo Espécie” e “Referência Mínima para Cálculo” serão obrigatórias.
  • O parâmetro MV_ACPARNE deve ter as seguintes opções: 1=Obrigatório e 2=Opcional. Deve ser inicializado como opcional>.

 

Tabelas Utilizadas

  • SE2 – Cadastro de Contas a Pagar
  • FI9 – Controle de Emissão de DARF>.

Opcional

Protótipo de Tela

 

<Caso necessário inclua protótipos de telas com o objetivo de facilitar o entendimento do requisito, apresentar conceitos e funcionalidades do software>.

 

Protótipo 01

 

 

 Image Removed

 

 

 

 

 

 

Opcional

Fluxo do Processo

 

<Nesta etapa incluir representações gráficas que descrevam o problema a ser resolvido e o sistema a ser desenvolvido. Exemplo: Diagrama - Caso de Uso, Diagrama de Atividades, Diagrama de Classes, Diagrama de Entidade e Relacionamento e Diagrama de Sequência>. 

Opcional

Dicionário de Dados

 

Arquivo ou Código do Script: AAA – Negociação Financeira / *Versao=CP.2014.12_03*/

  

Índice

Chave

01

<FI9_FILIAL+FI9_IDDARF+FI9_STATUS>

02

<FI9_FILIAL+FI9_FORNEC+ FI9_LOJA+FI9_EMISS+FI9_IDDARF>

03

<FI9_FILIAL+FI9_FORNEC+ FI9_LOJA+FI9_PREFIX+FI9_NUM+FI9_PARCEL+FI9_TIPO>

Campo

<AAA_PERESP>

Tipo

<N>

Tamanho

<6>

Valor Inicial

<Varia de acordo com o tipo informado. Por exemplo, quando o campo “tipo” for date, neste campo pode ser informado uma data>. 

Mandatório

Sim (  ) Não (  )

Descrição

<Referência Mínima para Cálculo>

Título

<Ref.Calc.>

Picture

<@E999.99>

Help de Campo

<Informar o % que o aluno pagará em dinheiro. Esse % poderá ser alterado durante a negociação>

 

(Opcional)

Grupo de Perguntas

 

<Informações utilizadas na linha Protheus>.

 

Nome: FINSRF2

X1_ORDEM

01

X1_PERGUNT

Emissão De

X1_TIPO

D

X1_TAMANHO

8

X1_GSC

G

X1_VAR01

MV_PAR01

X1_DEF01

Comum

X1_CNT01

'01/01/08'

X1_HELP

Data inicial do intervalo de emissões das guias de DARF a serem consideradas na seleção dos dados para o relatório 

 

(Opcional)

Consulta Padrão

<Informações utilizadas na linha Protheus>

 

Consulta: AMB

Descrição

Configurações de Planejamento

Tipo

Consulta Padrão

Tabela

“AMB”

Índice

“Código”

Campo

“Código”; ”Descrição”

Retorno

AMB->AMB_CODIGO

 

 

-

WMS60006 - Ondas de separação[Alteração]  
WMS6325 - Solicitação de cargaAlteração  

 

WMS60003 - Onda de Separação

Alterar a função wms60003_gerar_onda_tt_plano(). 

Antes do RETURN TRUE no final da função deverá chamar a função wms60003_inicia_recebimento_auto(), detalhada a seguir, se o retorno da função for FALSE, deverá retornar FALSE.

Criar a função WMS60003_inicia_recebimento_auto() - esta função será responsável por iniciar o processo de expedição para solicitações de carga, com a finalidade de troca de propriedade entre depositantes.

  • Verificar se a onda de separação contém solicitação de carga de troca de propriedade. Para isso deverá executar o select abaixo:

    SELECT DISTINCT(trans_solicitacao_carga_mestre)  INTO l_trans_solicitacao_carga_mestre
    FROM wms_plano_separacao_carga a
    INNER JOIN wms_onda_separacao o
    ON o.empresa = a.empresa
    AND o.plano_separacao = a.plano_separacao
    WHERE a.empresa = p_cod_empresa
    AND o.onda_separacao = ma_ondas_tela[l_arr_curr].onda_separacao
    AND a.trans_solicitacao_carga_mestre IN (SELECT b.solicitacao_carga
                                                                 FROM wms_solic_carga_parametro b
                                                              WHERE a.empresa = b.empresa
                                                                   AND a.trans_solicitacao_carga_mestre = b.solicitacao_carga
                                                                   AND b.parametro = 'troca_propriedade'
                                                                   AND val_texto = 'S' AND ( val_numerico IS NOT NULL AND val_numerico > 0))

                          

  • Se não encontrar registro, deve retornar TRUE.
  • Buscar o depositante da solicitação de carga efetuando select na tabela wms_solicitacao_carga_mestre utilizando a l_trans_solicitacao_carga_mestre retornada no select anterior.
  • Chamar a função para geração do processo de recebimento, seguindo os passos a seguir:
    • Chamar a função wmsr95_set_empresa(p_cod_empresa).
    • Chamar a função wmsr95_set_depositante(depositante).
    • Chamar a função wmsr95_set_cesv(null).
    • Chamar a função wmsr95_set_gera_cesv_docum(TRUE).
    • Chamar a função wmsr95_set_relaciona_cesv_docum(TRUE).
    • Chamar a função wmsr95_set_libera_entrada_veic(TRUE).
    • Chamar a função wmsr95_set_valida_veiculo(TRUE).
    • Chamar a função wmsr95_set_libera_saida_veiculo(FALSE).
    • Chamar a função wmsr95_set_endereco_desembarque(buscar do select abaixo):

SELECT wms_parametro_complementar.val_decimal
FROM wms_parametro_complementar
WHERE wms_parametro_complementar.empresa = p_cod_emprsa 
AND wms_parametro_complementar.depositante = l_deposit
AND wms_parametro_complementar.nom_parametro = 'end_troca_propried'
AND wms_parametro_complementar.contrato = {buscar o contrato ativo do depositante}

    • Chamar a função wmsr95_set_docum_recebimento(l_nota, l_serie, l_sub_serie, l_especie, l_emitente) - receberá os dados da nota fiscal de recebimento, os valores deverão ser armazenados em variáveis modulares: m_nota, m_serie, m_sub_serie, m_especie, m_emitente)
      • Para obter os dados da nota fiscal de recebimento deverá buscar o número do AR na tabela wms_solic_carga_parametro (parâmetro troca_propriedade, campo val_numerico) e efetuar o select da tabela NF_SUP.
    • Chamar a função wmsr95_set_modo_exibicao(TRUE).

    • Chamar a função wmsr95_cria_temporarias().

    • Chamar a função WMSR95_processa_recebimento().

    • Se o retorno for FALSE deverá exibir a seguinte mensagem em tela: "Onda de separação geradas, porém ocorreu erro na geração dos dados da expedição de transferência de propriedade. Excluir as ondas e tentar novamente."
    • Caso retorne com sucesso, exibir a mensagem atual.

Função WMS60006

Ao efetuar a exclusão de uma onda, quando o processo envolver uma solicitação de carga de troca de propriedade, deverá também excluir os dados gerados para o recebimento.

Para isso deverá ser alterada a função wms60006_exclui_ondas_selecionadas(), após o retorno da função wmsr71_exclui_onda() deverá ser incluída a lógica abaixo:

  • Efetuar select para identificar se o plano está relacionado a uma troca de propriedade e buscar a solicitação de carga:

SELECT DISTINCT(trans_solicitacao_carga_mestre)

FROM wms_plano_separacao_carga a

WHERE a.empresa = p_cod_empresa

AND a.plano_separacao = l_plano_separacao

AND a.trans_solicitacao_carga_mestre IN

(SELECT b.solicitacao_carga

FROM wms_solic_carga_parametro b

WHERE a.empresa = b.empresa

AND a.trans_solicitacao_carga_mestre = b.solicitacao_carga

AND b.parametro = 'troca_propriedade'

AND val_texto = 'S' AND (val_numerico is not null AND val_numerico > 0))

INTO l_trans_solicitacao_carga_mestre

  • Se o sqlcode for menor que zero deve processar mensagem de erro e retornar FALSE.
  • Se encontrou o registro, deve efetuar o select abaixo para buscar aviso de recebimento relacionado ao processo:

SELECT val_numerico

INTO l_num_aviso_rec

FROM wms_solic_carga_parametro

WHERE empresa = p_cod_empresa

AND solicitacao_carga = l_trans_solicitacao_carga_mestre

AND parametro = 'troca_propriedade'

  • Se o sqlcode for menor que zero deve processar mensagem de erro e retornar FALSE.
  • Se encontrou registro, deve buscar os dados da nota na NF_SUP:

SELECT num_nf,

ser_nf,

ssr_nf,

cod_fornecedor 

INTO l_num_nf,

l_ser_nf,

l_ssr_nf,

l_deposit

FROM nf_sup

WHERE cod_empresa = p_cod_empresa

AND num_aviso_rec = l_num_aviso_rec

  • Se o sqlcode for menor que zero deve processar mensagem de erro e retornar FALSE.
  • Se encontrou registro deve buscar a entrada de veículo planejada na WMS_CESV_DOCUM_NOTA_FISCAL:

SELECT ctr_ent_sai_veic_docum

INTO l_ctr_ent_sai_veic_docum

FROM wms_cesv_docum_nota_fiscal

WHERE empresa = p_cod_empresa

AND nota_fiscal = l_num_nf

AND serie_nota_fiscal = l_ser_nf

AND subserie_nota_fiscal = l_ssr_nf

AND deposit = l_deposit

  • Se o sqlcode for diferente de zero deve processar mensagem de erro e retornar FALSE.
  • Se encontrou o registro deve:
    • Chamar a função wmsr95_set_empresa(p_cod_empresa).
    • Chamar a função wmsr95_set_cesv(l_ctr_ent_sai_veic_docum).
    • Chamar a função wmsr95_exclusao_dados_gerados_troca_propriedade(). Se o retorno for FALSE deve retornar FALSE.

 

WMS6325 - Solicitação de Carga

Aplicar a mesma regra para geração dos dados de recebimento automático, quando estiver configurado para geração de plano e onda automáticos no WMS6325.

Após a chamada da função wmsr71_gera_onda("WMS6325",1), incluir a chamada da WMSR128_processa_recebimento.

 

 

(Opcional)

Estrutura de Menu

 

<Informações utilizadas na linha Datasul>.

 

Procedimentos

 

Procedimento

 

 

 

Descrição

(Max 40 posições)

(Max 40 posições)

(Max 40 posições)

Módulo

 

 

 

Programa base

 

 

 

Nome Menu

(Max 32 posições)

(Max 32 posições)

(Max 32 posições)

Interface

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

Registro padrão

Sim

Sim

Sim

Visualiza Menu

Sim/Não

Sim/Não

Sim/Não

Release de Liberação

 

 

 

 

 

 

Programas

 

Programa

 

 

 

Descrição

(Max 40 posições)

(Max 40 posições)

(Max 40 posições)

Nome Externo

 

 

 

Nome Menu/Programa

(Max 32 posições)

(Max 32 posições)

(Max 32 posições)

Nome Verbalizado[1]

(Max 254 posições)

(Max 254 posições)

(Max 254 posições)

Procedimento

 

 

 

Template

(Verificar lista de opções no man01211)

(Verificar lista de opções no man01211)

(Verificar lista de opções no man01211)

Tipo[2]

Consulta/Manutenção/ Relatório/Tarefas

Consulta/Manutenção/ Relatório/Tarefas

Consulta/Manutenção/ Relatório/Tarefas

Interface

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

Categoria[3]

 

 

 

Executa via RPC

Sim/Não

Sim/Não

Sim/Não

Registro padrão

Sim

Sim

Sim

Outro Produto

Não

Não

Não

Visualiza Menu

Sim/Não

Sim/Não

Sim/Não

Query on-line

Sim/Não

Sim/Não

Sim/Não

Log Exec.

Sim/Não

Sim/Não

Sim/Não

Rotina (EMS)

 

 

 

Sub-Rotina (EMS)

 

 

 

Localização dentro da Sub Rotina (EMS)

 

 

 

Compact[4]

Sim/Não

Sim/Não

Sim/Não

Home[5]

Sim/Não

Sim/Não

Sim/Não

Posição do Portlet[6]

0 – Top Left

1 – Top Right

2 – Bottom Left

3 – Bottom Right

0 – Top Left

1 – Top Right

2 – Bottom Left

3 – Bottom Right

0 – Top Left

1 – Top Right

2 – Bottom Left

3 – Bottom Right

Informar os papeis com os quais o programa deve ser vinculado

 

 

 

 

Cadastro de Papéis

<O cadastro de papéis é obrigatório para os projetos de desenvolvimento FLEX a partir do Datasul 10>.

<Lembrete: o nome dos papeis em inglês descrito neste ponto do documento, devem ser homologados pela equipe de tradução>.

 

Código Papel

(máx 3 posições)

Descrição em Português*

 

Descrição em Inglês*

 

[1] Nome Verbalizado é obrigatório para desenvolvimentos no Datasul 10 em diante.

[2] Tipo é obrigatório para desenvolvimento no Datasul 10 em diante

[3] Categorias são obrigatórias para os programas FLEX.

[4] Obrigatório quando o projeto for FLEX

[5] Obrigatório quando o projeto for FLEX

[6] Obrigatório quando o projeto for FLEX

 Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico.