Histórico da Página
Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico. |
---|
Informações Gerais
Especificação | |||
Produto | Logix | Módulo | WMS |
Segmento Executor | Supply Chain - Logística | ||
Projeto1 | IRM1 | ||
Requisito1 | Subtarefa1 | ||
Chamado2 |
| ||
País | ( x ) Brasil ( ) Argentina ( ) México ( ) Chile ( ) Paraguai ( ) EquadorEquador ( ) USA ( ) Colômbia ( ) Outro _____________. |
Legenda: 1 – Inovação 2 – Manutenção (Os demais campos devem ser preenchidos para ambos os processos).
Objetivo Geral
Possibilitar a execução dos que os processos de separação, conferência, pesagem e embarque sejam executados paralelamente.
Objetivo Específico
Possibilitar a visualização dos percentuais de execução dos processos de separação, conferência, pesagem e embarque; quando processado paralelamente.
Mapa Mental
Na sequência é apresentada a imagem do Mapa Mental utilizado como base para a definição desse processo.:
Definição da Regra de Negócio
Rotina | Tipo de Operação | Opção de Menu | Regras de Negócio |
LOG00086 - Menu de Parâmetros | [Alteração] | Manutenção de parâmetros | - |
WMSR136 - Regra de negócio referente a expedição paralela | [Criação] | - | - |
WMS6325 - Solicitação de Carga | [Alteração] | - | - |
WMS60013 - Contrato do Depositante | [Alteração] | - | - |
WMS60018 - Contrato - Expedição - Separação/Conferência | [Alteração] | - | - |
WMS60029 - Contrato - Expedição - Pesagem | [Alteração] | - | - |
WMS60019 - Contrato - Expedição - Embarque/Fiscal | [Alteração] | - | - |
WMS6242 - Conferência de Expedição - Coletor de dados | [Alteração] | - | - |
WMS6258 - Conferência de Expedição - Desktop | [Alteração] | - | - |
Para atingir o resultado esperado detalhado acima, as seguintes alterações de funções e programas são necessárias:
LOG00086 - Menu de Parâmetros
Manutenção de Parâmetros > Logix WMS > Logix WMS > Expedição
Criar um novo parâmetro no LOG00086, da seguinte forma:
- Descrição: Exibe o percentual disponível para a conferência?
- Informação do parâmetro: Indica se será exibido o percentual de mercadorias disponíveis para a conferência da expedição.
- Valor padrão: N (Não).
Valores: S (Sim) ou N (Não).
Criar um novo parâmetro no LOG00086, da seguinte forma:
Descrição: Exibe o percentual disponível para o embarque?
Informação do parâmetro: Indica se será exibido o percentual de mercadorias disponíveis para o embarque.
Valor padrão: N (Não).
Valores: S (Sim) ou N (Não).
WMSR136 - Regra de Negócio Para a Expedição Paralela
Função wmsr136_calcula_percentual_disponível_conferencia().
Responsável por calcular o percentual de estoque disponível para conferir.
Receberá: Empresa, Solicitação de Carga e Modo de exibição.
Retornará: Percentual de estoque disponível para conferir.
No início desta função, o sistema deverá consultar a quantidade de itens que já foram separados:
Bloco de código | ||||||
---|---|---|---|---|---|---|
| ||||||
SELECT SUM(estoque_loc_reser.qtd_reservada) FROM wms_solic_carga_item_reserva ,wms_item_onda_plano ,estoque_loc_reser ,wms_processo_moviment WHERE wms_solic_carga_item_reserva.empresa = [empresa] AND wms_solic_carga_item_reserva.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_item_onda_plano.empresa = wms_solic_carga_item_reserva.empresa AND wms_item_onda_plano.reserva = wms_solic_carga_item_reserva.reserva AND estoque_loc_reser.cod_empresa = wms_item_onda_plano.empresa AND estoque_loc_reser.num_reserva = wms_item_onda_plano.reserva AND wms_processo_moviment.empresa = wms_item_onda_plano.empresa AND wms_processo_moviment.processo_moviment = wms_item_onda_plano.processo_moviment AND wms_processo_moviment.tip_processo_moviment = 'C' AND wms_processo_moviment.sit_processo_moviment = 'FI' |
- Após consultar a quantidade de itens separados, o sistema deverá pesquisar a quantidade de itens conferidos:
Bloco de código | ||||||
---|---|---|---|---|---|---|
| ||||||
SELECT SUM(wms_conferencia_separacao_item.qtd_conferida) FROM wms_conferencia_separacao_item WHERE wms_conferencia_separacao_item.empresa = [empresa] AND wms_conferencia_separacao_item.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_conferencia_separacao_item.sequencial_conferencia = (SELECT MAX(wms_conferencia_separacao.sequencial_conferencia) FROM wms_conferencia_separacao WHERE wms_conferencia_separacao.empresa = [empresa] AND wms_conferencia_separacao.trans_solicitacao_carga_mestre = [Solicitação de carga]) |
- Após consultar a quantidade de itens conferidos, o sistema deverá pesquisar a quantidade de itens solicitados:
Bloco de código | ||||||
---|---|---|---|---|---|---|
| ||||||
SELECT SUM(wms_solicitacao_carga_item.qtd_solicitada) FROM wms_solicitacao_carga_item WHERE wms_solicitacao_carga_item.empresa = [empresa] AND wms_solicitacao_carga_item.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_solicitacao_carga_item.sit_item <> ‘C’ |
- Depois de consultar as quantidades, o sistema deverá calcular o percentual de mercadorias pendentes de conferência, da seguinte forma:
(((Quantidade de itens separados - Quantidade de itens que já foram conferidos) x 100) / (Quantidade de itens solicitados - Quantidade de itens que já foram conferidos))
WMS6325 - Solicitação de Carga
Criar 4 novos campos na pasta Dados Complementares, na qual serão apresentados os status dos seguintes processos: Separação, Conferência, Pesagem e Embarque.
Criar 3 novos campos na pasta Dados Complementares, para que seja informado se permite executar paralelamente a expedição ou não. Ao incluir uma Solicitação de Carga, o sistema deverá carregar os valores padrão cadastrados no Contrato do depositante. Após confirmar a inclusão da Solicitação de Carga, esses campos deverão ser armazenados na tabela wms_solicitacao_carga_mestre.
Função wms6325_carrega_status_processos()
Função responsável por carregar o status de cada processo de expedição.
Receberá: Empresa, Solicitação de Carga, Sequencial do item e Modo de exibição.
Retornará: status (TRUE ou FALSE).
Observação: Essa função deverá estar preparada para receber o campo Sequencial do Item; caso a informação não seja enviada, deverá ser considerado todos os itens da solicitação de carga.
Durante o processamento dessa função, o sistema deverá consultar o percentual de execução de cada etapa da expedição:
Nota | ||
---|---|---|
| ||
|
Se a situação da solicitação de carga for igual a S, o sistema deverá realizar a seguinte pesquisa (Separação):
Consultar a quantidade total de itens que devem ser separados:
Se a Solicitação de Carga possuir controle de granel:
Se o documento for mestre:
Bloco de código language js title SQL - Granel mestre collapse true SELECT SUM(wms_solicitacao_carga_item.qtd_solicitada) FROM wms_expedicao_granel ,wms_expedicao_granel_veiculo ,wms_solicitacao_carga_item WHERE wms_expedicao_granel.empresa = [empresa] AND wms_expedicao_granel.solicitacao_carga = [Solicitação de carga] AND wms_expedicao_granel_veiculo.empresa = wms_expedicao_granel.empresa AND wms_expedicao_granel_veiculo.transacao_expedicao_granel = wms_expedicao_granel.transacao_expedicao_granel AND wms_solicitacao_carga_item.empresa = wms_expedicao_granel_veiculo.empresa AND wms_solicitacao_carga_item.trans_solicitacao_carga_mestre = wms_expedicao_granel_veiculo.solicitacao_carga_liberacao
Se o documento for filho:
Bloco de código language js title SQL - Granel filho collapse true SELECT SUM(wms_solicitacao_carga_item.qtd_solicitada) FROM wms_expedicao_granel_veiculo ,wms_solicitacao_carga_item WHERE wms_expedicao_granel_veiculo.empresa = [empresa] AND wms_expedicao_granel_veiculo.solicitacao_carga_liberacao = [Solicitação de carga] AND wms_solicitacao_carga_item.empresa = wms_expedicao_granel_veiculo.empresa AND wms_solicitacao_carga_item.trans_solicitacao_carga_mestre = wms_expedicao_granel_veiculo.solicitacao_carga_liberacao
Se a Solicitação de Carga não possuir controle de granel:
Bloco de código language js title SQL - Quantidade de itens que devem ser separados. collapse true SELECT SUM(wms_solicitacao_carga_item.qtd_solicitada) FROM wms_solicitacao_carga_item WHERE wms_solicitacao_carga_item.empresa = [empresa] AND wms_solicitacao_carga_item.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_solicitacao_carga_item.sit_item <> ‘C’
- Consultar a quantidade de itens que foram separados:
Se a Solicitação de Carga possuir controle de granel:
Se o documento for mestre:
Bloco de código language js title SQL - Granel mestre collapse true SELECT SUM(wms_expedicao_granel_endereco.qtd_real_separacao) FROM wms_expedicao_granel ,wms_expedicao_granel_veiculo ,wms_expedicao_granel_endereco WHERE wms_expedicao_granel.empresa = [empresa] AND wms_expedicao_granel.solicitacao_carga = [Solicitação de carga] AND wms_expedicao_granel_veiculo.empresa = wms_expedicao_granel.empresa AND wms_expedicao_granel_veiculo.transacao_expedicao_granel = wms_expedicao_granel.transacao_expedicao_granel AND wms_expedicao_granel_endereco .empresa = wms_expedicao_granel_veiculo.empresa AND wms_expedicao_granel_endereco .trans_expedicao_granel_veiculo= wms_expedicao_granel_veiculo.trans_expedicao_granel_veiculo
Se o documento for filho:
Bloco de código language js title SQL - Granel filho collapse true SELECT SUM(wms_expedicao_granel_endereco.qtd_real_separacao) FROM wms_expedicao_granel_veiculo ,wms_expedicao_granel_endereco WHERE wms_expedicao_granel_veiculo.empresa = [empresa] AND wms_expedicao_granel_veiculo.solicitacao_carga_liberacao = [Solicitação de carga] AND wms_expedicao_granel_endereco .empresa = wms_expedicao_granel_veiculo.empresa AND wms_expedicao_granel_endereco .trans_expedicao_granel_veiculo= wms_expedicao_granel_veiculo.trans_expedicao_granel_veiculo
Se a Solicitação de Carga não possuir controle de granel:
Bloco de código language js title SQL - Quantidade de itens que já foram separados. collapse true SELECT SUM(estoque_loc_reser.qtd_reservada) FROM wms_solic_carga_item_reserva ,wms_item_onda_plano ,estoque_loc_reser ,wms_processo_moviment WHERE wms_solic_carga_item_reserva.empresa = [empresa] AND wms_solic_carga_item_reserva.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_item_onda_plano.empresa = wms_solic_carga_item_reserva.empresa AND wms_item_onda_plano.reserva = wms_solic_carga_item_reserva.reserva AND estoque_loc_reser.cod_empresa = wms_item_onda_plano.empresa AND estoque_loc_reser.num_reserva = wms_item_onda_plano.reserva AND wms_processo_moviment.empresa = wms_item_onda_plano.empresa AND wms_processo_moviment.processo_moviment = wms_item_onda_plano.processo_moviment AND wms_processo_moviment.tip_processo_moviment = 'C' AND wms_processo_moviment.sit_processo_moviment = 'FI'
Após consultar os dois valores, o sistema deverá calcular o percentual de produtos separados.
- Caso a situação seja igual a: F, P, Q, V, X, N, Z; o sistema deverá considerar o status da separação igual a 100% (Concluído).
- Se a situação da solicitação de carga for igual a S ou F, deverá ser verificado se o documento possui controle de granel:
- Se controlar granel, deverá ser considerado o o status da conferência igual a -%, exibindo a cor cinza conforme o Protótipo 1.
- Se não controlar granel, o sistema deverá realizar a seguinte pesquisa (Conferência):
- Utilizar a mesma quantidade consultada no item 1.A.
- Consultar a quantidade de itens que já foram conferidos:
Bloco de código language js title SQL - Quantidade de itens que já foram conferidos. collapse true SELECT SUM(wms_conferencia_separacao_item.qtd_conferida) FROM wms_conferencia_separacao_item WHERE wms_conferencia_separacao_item.empresa = [empresa] AND wms_conferencia_separacao_item.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_conferencia_separacao_item.sequencial_conferencia = (SELECT MAX(wms_conferencia_separacao.sequencial_conferencia) FROM wms_conferencia_separacao WHERE wms_conferencia_separacao.empresa = [empresa] AND wms_conferencia_separacao.trans_solicitacao_carga_mestre = [Solicitação de carga])
Após consultar os dois valores, o sistema deverá calcular o percentual de produtos conferidos.
Caso a situação seja igual a: P, Q, V, X, N, Z; o sistema deverá considerar o status da conferência igual a 100% (Concluído).
Se a situação da solicitação de carga for igual a: S, F, P; deverá ser verificado se o documento possui controle de granel:
- Se controlar granel, deverá ser considerado o status da pesagem igual a -%, exibindo a cor cinza conforme Protótipo 1.
- Se não controlar granel, o sistema deverá realizar a seguinte pesquisa (Pesagem):
- Verificar se na tabela wms_pesagem, possui registro para a solicitação de carga consultada:
- Se tiver, o sistema deverá executar o item B, C e D.
- Se não tiver, o sistema deverá apresentar o seguinte valor -%, exibindo a cor cinza conforme Protótipo 1, passando para o item 7.
- Utilizar a mesma quantidade consultada no item 1.A.
- Consultar a quantidade de itens que foram pesados:
Bloco de código language js title SQL - Quantidade de itens que já foram pesados. collapse true SELECT SUM(wms_volume_item_exped.qtd_item) FROM wms_volume_exped ,wms_volume_item_exped WHERE wms_volume_exped.empresa = [empresa] AND wms_volume_exped.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_volume_exped.peso_balanca IS NOT NULL AND wms_volume_item_exped.empresa = wms_volume_exped.empresa AND wms_volume_item_exped.volume_exped = wms_volume_exped.volume_exped
Após consultar os dois valores, o sistema deverá calcular o percentual de produtos pesados.
- Verificar se na tabela wms_pesagem, possui registro para a solicitação de carga consultada:
- Caso a situação seja igual a: Q, V, X, N, Z; o sistema deverá considerar o status da pesagem igual a 100% (Concluído).
- Se a situação da solicitação de carga for igual a: S, F, P, Q, V, X, N, Z; deverá ser verificado se o documento possui controle de granel:
- Se controlar granel, deverá ser considerado o o status do embarque igual ao status da separação.
- Se não controlar granel, o sistema deverá realizar a seguinte pesquisa (Embarque):
- Utilizar a mesma quantidade consultada no item 1.A.
- Consultar a quantidade de itens que já foram embarcados:
Bloco de código language js title SQL - Quantidade de itens que já foram embarcados (Volume). collapse true SELECT SUM(wms_volume_item_exped.qtd_item) FROM wms_volume_exped ,wms_volume_item_exped ,wms_processo_moviment WHERE wms_volume_exped.empresa = [empresa] AND wms_volume_exped.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_volume_exped.volume_palete IS NULL AND wms_processo_moviment.empresa = wms_volume_exped.empresa AND wms_processo_moviment.volume_exped = wms_volume_exped.volume_exped AND wms_processo_moviment.tip_processo_moviment = 'E' AND wms_processo_moviment.sit_processo_moviment = 'FI' AND wms_volume_item_exped.empresa = wms_volume_exped.empresa AND wms_volume_item_exped.volume_exped = wms_volume_exped.volume_exped
Bloco de código language js title SQL - Quantidade de itens que já foram embarcados (Palete). collapse true SELECT SUM(wms_volume_item_exped.qtd_item) FROM wms_volume_palete,wms_volume_exped ,wms_volume_item_exped ,wms_processo_moviment WHERE wms_volume_palete.empresa = [empresa] AND wms_volume_palete.trans_solicitacao_carga_mestre = [Solicitação de carga] AND wms_volume_exped.empresa = wms_volume_palete.empresa AND wms_volume_exped.trans_solicitacao_carga_mestre = wms_volume_palete.trans_solicitacao_carga_mestre AND wms_volume_exped.volume_palete = wms_volume_palete.volume_palete AND wms_volume_item_exped.empresa = wms_volume_exped.empresa AND wms_volume_item_exped.volume_exped = wms_volume_exped.volume_exped AND wms_processo_moviment.empresa = wms_volume_exped.empresa AND wms_processo_moviment.volume_exped = wms_volume_exped.volume_exped AND wms_processo_moviment.tip_processo_moviment = 'E' AND wms_processo_moviment.sit_processo_moviment = 'FI'
Após consultar os dois valores, o sistema deverá calcular o percentual de produtos embarcados.
Função wms6325_exibe_dados()
Função responsável por carregar as variáveis e apresentar os seus valores em tela, durante a pesquisa da Solicitação de Carga.
Ao final desta função, o sistema deverá chamar a função wms6325_carrega_status_processos, para que as situações da Solicitação de Carga sejam carregadas.
WMS60013 - Contrato do Depositante
Alterar a descrição da opção Pesagem para Expedição-Pesagem.
Na cópia do Contrato do depositante (WMS60030), prever a inclusão destes novos parâmetros para o depositante destino.
WMS60018 - Contrato - Expedição - Separação/Conferência
Criar um novo campo, que permita indicar qual o valor padrão para o parâmetro: Permite conferir antes de finalizar a separação?.
Este campo deverá ser armazenado na tabela wms_parametro_complementar, onde será carregado automaticamente na inclusão de uma Solicitação de Carga, na rotina WMS6325.
WMS60029 - Contrato - Expedição - Pesagem
Criar um novo campo, que permita indicar qual o valor padrão para o parâmetro: Permite pesar antes de finalizar a conferência?.
Este campo deverá ser armazenado na tabela wms_parametro_complementar, onde será carregado automaticamente na inclusão de uma Solicitação de Carga, na rotina WMS6325.
WMS60019 - Contrato - Expedição - Embarque/Fiscal
Criar um novo campo, que permita indicar qual o valor padrão, para o parâmetro: Permite embarcar antes de finalizar conf/pesagem?.
Este campo deverá ser armazenado na tabela wms_parametro_complementar, onde será carregado automaticamente na inclusão de uma Solicitação de Carga, na rotina WMS6325.
WMS6242 - Conferência de Expedição - Coletor de Dados
Alterar o campo que apresenta o documento pendente de conferência de expedição, para que seja exibido o percentual de estoque disponível para conferir, conforme o Protótipo 02.
Função wms6242_tela_inicial()
- Função responsável por apresentar a tela principal da rotina de conferência via coletor de dados.
- No inicio dessa função, o sistema deverá pesquisar o valor do parâmetro Exibe o percentual disponível para a conferência?, armazenando essa informação em uma variável modular.
Função wms6242_carrega_solicitacao_carga()
Função responsável por carregar os documentos pendentes de conferência da expedição.
Ao montar o cursor cq_conferencias deverá ser verificado se o parâmetro Permite iniciar a conferência antes de finalizar a separação? está ativo.
Durante a execução do cursor cq_conferencias, o sistema deverá chamar a função wmsr136_calcula_percentual_disponivel_conferencia.
Se o parâmetro Exibe o percentual disponível para a conferência? estiver habilitado será retornado o percentual de estoque disponível para conferir.
Este percentual deverá ser armazenado em uma tabela temporária, para que seja realizada uma ordenação dos documentos pelo seu percentual, da mesma forma como é realizado na rotina WMS6214:
- Se estiver, além de buscar as Solicitações de Carga com a situação em Conferência (F), o sistema deverá encontrar documentos com a situação em Separação (S), caso o documento possua itens que não foram conferidos.
- Se não estiver, deverá continuar com o processamento padrão.
Ao executar a função DISPLAY ARRAY dos documentos pendentes, o sistema deverá verificar o valor do parâmetro Exibe o percentual disponível para a conferência?:
- Se estiver igual a N, o sistema não deverá realizar a ordenação e nem apresentar o percentual calculado.
- Se estiver igual a S, o sistema deverá ordenar os documentos, apresentando o percentual de estoque disponível para conferir.
WMS6258 - Conferência de Expedição - Desktop
Criar um novo campo na tela principal, que apresente o percentual de estoque disponível para conferir, conforme Protótipo 03.
Função wms6258_before_menu()
Função responsável por inicializar as variáveis antes da execução da rotina.
No fim desta função, o sistema deverá pesquisar o valor do parâmetro Exibe o percentual disponível para a conferência?, armazenando essa informação em uma variável modular.
Função wms6258_carrega_solicitacao_carga()
Função responsável por carregar os documentos pendentes de conferência da expedição.
Ao montar o cursor cq_conferencias, deverá ser verificado se o parâmetro Permite iniciar a conferência antes de finalizar a separação? está ativo.
Durante a execução do cursor cq_conferencias, o sistema deverá chamar a função wmsr136_calcula_percentual_disponivel_conferencia, se o parâmetro Exibe o percentual disponível para a conferência? estiver habilitado, onde será retornado o percentual de estoque disponível para conferir. Este percentual deverá ser armazenado em uma tabela temporária, para que seja realizada uma ordenação dos documentos pelo seu percentual, da mesma forma como é realizado na rotina WMS6214.
- Se estiver, além de buscar solicitações de carga com a situação em conferência (F), o sistema deverá encontrar documentos com a situação em separação (S), caso o documento possua itens que não foram conferidos.
- Se não estiver, deverá continuar com o processamento padrão.
Ao executar a função DISPLAY ARRAY dos documentos pendentes, o sistema deverá verificar o valor do parâmetro Exibe o percentual disponível para a conferência?:
Se estiver igual a N, o sistema não deverá realizar a ordenação e nem apresentar o percentual calculado.
Se estiver igual a S, o sistema deverá ordenar os documentos, apresentando o percentual de estoque disponível para conferir.
Protótipo de Tela
Protótipo 01
Tela principal da Solicitação de Carga, onde será apresentado o status de cada processo de expedição.
Protótipo 02
Tela principal da conferência de expedição via coletor de dados, onde será apresentado o percentual de mercadorias disponíveis para conferir, se o parâmetro no LOG00086 estiver ativo.
Protótipo 03
Tela principal da conferência de expedição via desktop, onde será apresentado o percentual de mercadorias disponíveis para conferir, se o parâmetro no LOG00086 estiver ativo.
Protótipo 04
Tela principal do Contrato do depositante, na qual será incluída a descrição Expedição na opção Pesagem.
Protótipo 05
Tela do Contrato, opção Expedição - Separação/Conferência, onde será incluído o campo: Permite conferir antes de finalizar a separação?.
Protótipo 06
Tela do Contrato, opção Expedição - Pesagem, onde será incluído o campo: Permite pesar antes de finalizar a conferência?.
Protótipo 07
- Tela do Contrato, opção Expedição - Embarque/Fiscal, onde será incluído o campo: Permite embarcar antes de finalizar a conf/pesagem?.
Dicionário de Dados
Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico. |
---|