Histórico da Página
Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico. |
---|
Troca de Propriedade - Fase II - Onda de Separação
Informações Gerais
(Obrigatório)
Informações Gerais
Especificação | ||||
Produto | Logix | Módulo | WMS | |
Segmento Executor | D&LLogística | |||
Projeto1 | IRM1 | |||
Requisito1 | PCREQ-9046 | Subtarefa1 | ||
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 | <Caso necessário informe outras referências que sejam pertinentes a esta especificação. Exemplo: links de outros documentos ou subtarefas relacionadas>.
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 | ||
WMS60006 WMS60003 - Onda Ondas de separação | [Alteração] |
| - | ||
WMS60006 - | Ondas de separação | [Alteração] | |||
WMS6325 - Solicitação de carga | Alteração |
WMS60003 - Onda de Separação
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
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 |
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.
- 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)
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
Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico. |
---|