Histórico da Página
Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico. |
---|
(Obrigatório)
Informações Gerais
Especificação | |||
Produto | DATASUL | Módulo | Controle de Produção |
Segmento Executor |
| ||
Projeto1 |
| IRM1 | PCREQ-9134 - DATASUL - ITEM CONFIGURADO |
Requisito1 | PCREQ-9135 - Reaproveitar Item Configurado | Subtarefa1 |
|
Chamado2 |
| ||
Release de Entrega Planejada | 12.1.10 | Réplica |
|
País | ( ) Brasil ( ) Argentina ( ) Mexico ( ) Chile ( ) Paraguai ( ) Equador ( ) USA ( ) Colombia ( ) Outro _____________. | ||
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).
(Obrigatório)Objetivo
<Nesta etapa informar o objetivo da especificação do requisito, ou seja, o que a funcionalidade deve fazer. Exemplo: Permitir que o usuário defina o percentual mínimo em espécie (dinheiro), a referência mínima para calculo dos débitos do aluno e o período de validade do parâmetro de negociação>.
(Obrigatório)Permitir reaproveitar um item configurado final(ACABADO) já fabricado e em estoque, como componente em uma outra Ordem de Produção.
Definição da Regra de Negócio
<Regra de negócio é o que define a forma de fazer o negócio, o processo definido e/ou as regras que devem ser contempladas. Devem ser descritas restrições, validações, condições e exceções do processo. Caso necessário, incluir neste capítulo também regras de integridade que devem ser observadas no momento do desenvolvimento>.
Quando o item configurado for o pai, não é necessário guardar Saldo de OP para Itens Configurados(saldo-op-config). Assim, estes itens poderão ser consumidos em outras ordens.
O saldo-op-config, continuará necessário para os itens configurados filhos, sem alteração de regras<Na tabela abaixo informe quais são as rotinas envolvidas, o tipo de operação, a opção de menu e se necessário uma breve descrição das regras de negócio relacionadas a rotina>.
Rotina | Tipo de Operação | Opção de Menu | Regras de Negócio |
[ACAA040 – Parâmetros] | [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
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 |
CPAPI022 - Saldo da OP Configurada | Alteração |
| - |
CPAPI012 - Requisição Materiais | Alteração |
Fluxo do Processo
Fazer esta primeira execução sem a alteração nos programas
1- Criar uma estrutura no modelo(CF0101) para um item A (Política Configurado no CD1112), onde um de seus componentes B seja também configurado, e tenha ao menos um componente comprado C.
2 - Realizar a configuração do item A(CF0201) e B.
3 - Marcar parâmetro "Gera Reserva Configurado" (CP0106)
4 - Gerar uma Ordem de Produção do configurado A e versão (CF0501). Como resultado serão criadas duas OPs, uma para o configurado A e outra para o configurado B.
5 - Sumarizar as OPs dos itens A e B (CP0304).
6 - Caso não tenha saldo para o item comprado C, então inserir uma entrada (CE0220)
7 - Realizar o apontamento da OP do item B. Como resultado deste apontamento, deverá aparecer um novo registro <saldo-op-config> para o item B.
8 - Realizar o apontamento da OP do item A. Como resultado deste apontamento, deverá aparecer um novo registro <saldo-op-config> para o item A.
9 - Criar uma nova OP tipo Reaproveitamento, para linha de Serviço manualmente (CP0301) para um outro item D (este item pode ser fabricado ou comprado também, e pode até ser configurado, podem ser feitas várias combinações). E selecionar o item configurado A e sua referência. (Pode também ser variado o tipo da ordem, como interna, bastando inserir depois o item configurado na reserva manualmente.
10 - Requisitar para a OP do item D o componente configurado A(CP0309). Como resultado, não será possível a requisição, pois existe <saldo-op-config> do item A e sua referência.
Fazer esta segunda execução com a alteração nos programas
1 - Gerar uma Ordem de Produção do configurado A e versão (CF0501). Como resultado serão criadas duas OPs, uma para o configurado A e outra para o configurado B.
2 - Sumarizar as OPs dos itens A e B (CP0304).
3 - Realizar o apontamento da OP do item B. Como resultado deste apontamento, deverá aparecer um novo registro <saldo-op-config> para o item B.
4 - Realizar o apontamento da OP do item A. Como resultado deste apontamento, não deverá aparecer um novo registro <saldo-op-config> para o item A.
5 - Criar uma nova OP tipo Reaproveitamento, para linha de Serviço manualmente (CP0301) para um outro item D (este item pode ser fabricado ou comprado também, e pode até ser configurado, podem ser feitas várias combinações). E selecionar o item configurado A e sua referência.
6 - Requisitar para a OP do item D o componente configurado A(CP0309). Como resultado, será possível a requisição, pois não existe <saldo-op-config> do item A e sua referência.
7 - Como último teste, Requisitar para a OP gerada no primeiro Teste para o item D (CP0309). Como resultado, mesmo existindo <saldo-op-config>, ela será Eliminada na tentativa de requisição, e a requisição será efetivada.
Obs.1: Realizar também o teste de devolução manual, requisição automática e devolução automática(para estes últimos, não será possível concluir, pois uma Ordem de Produção com componente configurado deve impedir).
Obs.2: Realizar também testes com ordem tipo Interna, para linha de processo, neste caso testar o apontamento de produção, e será requisitado junto.
Alterar CPAPI022 (GeraSaldo) para inserir a validação abaixo antes de todo o resto.
Se não existe ( um <al-res-op> quando <al-res-op.nr-ord-produ> = p-nr-ord-produ)
então:
Sai da rotina GeraSaldo sem efetuar nada.
Fim-se.
Alterar CPAPI022 (saldoAutomatico) para inserir a validação, caso ainda exista um saldo de Acabado:
FOR EACH saldo-op-config WHERE saldo-op-config.cod-estabel = p-cod-estabel
AND saldo-op-config.it-codigo = p-it-codigo
AND saldo-op-config.cod-refer = p-cod-refer EXCLUSIVE-LOCK
BREAK BY saldo-op-config.nr-ord-produ:
Se não existe ( um <al-res-op> quando <al-res-op.nr-ord-produ> = saldo-op-config.nr-ord-produ) /* Não deve existir saldo-op-config para Ordens de Produto Acabado Pai. */
então:
Eliminar <saldo-op-config>.
Retornar ao laço <saldo-op-config>
Fim-se.
RUN atualizaDisponibilidadeSaldo.
IF AVAIL saldo-op-config THEN
FIND FIRST al-res-op WHERE
al-res-op.nr-ord-res = p-nr-ord-produ AND
al-res-op.it-codigo = p-it-codigo AND
al-res-op.nr-ord-produ = saldo-op-config.nr-ord-produ NO-LOCK NO-ERROR.
Após o laço <saldo-op-config> criar a <tt-reserva-op-config> caso não exista nenhuma e Não precisa de saldo.
Se <l-precisa-saldo> = Não E
não existe (<tt-reserva-op-config> quando rw-reserva = p-rw-reserva
e cod-estabel = p-cod-estabel
e cod-depos = p-cod-depos
e cod-localiz = p-cod-localiz
e lote = p-lote
e it-codigo = p-it-codigo
e cod-refer = p-cod-refer) THEN DO:
criar <tt-reserva-op-config>
rw-reserva = p-rw-reserva
cod-estabel = p-cod-estabel
it-codigo = p-it-codigo
cod-depos = p-cod-depos
cod-refer = p-cod-refer
cod-localiz = p-cod-localiz
lote-serie = p-lote
nr-ord-filha = p-nr-ord-produ
quant-requis = p-quant-requis
Fim-se.
Alterar CPAPI022 (saldoManual) para inserir a validação, caso ainda exista um saldo de Acabado:
Se existe ( um <al-res-op> quando <al-res-op.nr-ord-produ> = p-nr-ord-produ) /* Continua o processo de Saldo Manual*/
então:
Todo código hoje existente....
senão: /* Não deve existir saldo-op-config para Ordens de Produto Acabado Pai. */
Pesquisar um <saldo-op-config>
quando <saldo-op-config.nr-ord-produ> = p-nr-ord-produ.
Se existe <saldo-op-config>
então:
Eliminar <saldo-op-config>
Fim-se.
Fim-se.
Alterar CPAPI022 (VerificaSaldo) desconsiderar verificação de saldo de Acabado:
Se existe ( um <al-res-op> quando <al-res-op.nr-ord-produ> = p-nr-ord-produ) /* Continua o processo de Saldo Manual*/
então:
Todo código hoje existente....
senão: /* Não deve existir saldo-op-config para Ordens de Produto Acabado Pai. */
Pesquisar um <saldo-op-config>
quando <saldo-op-config.nr-ord-produ> = p-nr-ord-produ.
Se existe <saldo-op-config>
então:
Eliminar <saldo-op-config>
Fim-se.
Retornar "OK".
Fim-se.
Alterar CPAPI022 (pi-troca-chave):
Antes da pesquisa <saldo-op-config>, caso <tt-reserva-op-config.nr-ord-filha> = 0, retornar "OK".
Alterar CPAPI022 (pi-devolve-saldo) preencher a tt-reserva-op-config:
Logo após a pesquisa <saldo-op-config>
Se existe <saldo-op-config>
Então:
Se não Existe(um <al-res-op> onde <al-res-op.nr-ord-produ> = <saldo-op-config.nr-ord-produ>)
Então:
Elimine <saldo-op-config>.
Fim-se.
Fim-se.
Depois inserir um senão, quando não existir <saldo-op-config>, criar tt-reserva-op-config com os dados passados por parâmetro.
Se p-de-acum-quant > p-quantidade
Então
p-de-acum-quant = p-de-acum-quant - p-quantidade
de-quantidade = p-quantidade.
Senão /*Caso a qtd a devolver seja menor que a qtd a devolver para este saldo-op-config (tratamento para o caso de devolução parcial)*/
de-quantidade = p-de-acum-quant
p-de-acum-quant = 0.
Fim-se.
criar <tt-reserva-op-config>
rw-reserva = p-row-movto-estoq
cod-estabel = p-cod-estabel
it-codigo = p-it-codigo
cod-depos = p-cod-depos
cod-refer = p-cod-refer
cod-localiz = p-cod-localiz
lote-serie = p-lote-serie
nr-ord-filha = p-num-ord-des
quant-requis = de-quantidade
Alterar CPAPI012 (pi-processa-reservas-positivas), não será possível Requisitar Automaticamente quando Ordem de Produção possuir algum componente item configurado:
Quando é validado se o item é configurado(<item-uni-estab.politica> = 5), inserir uma nova mensagem de erro antes do "NEXT".
Sugestão de mensagem: "A Ordem de Produção 9999, possui item configurado, logo não será possível utilizar este processo."
Utilizar a pi-gera-tt-erro para incluir a mensagem. (verificar a necessidade de preenchimento das variáveis c-erro, c-texto e c-retorno)
Alterar CPAPI012 (pi-processa-devolucao), não será possível Devolução Automaticamente quando Ordem de Produção possuir algum componente item configurado:
Quando é validado se o item é configurado(<item-uni-estab.politica> = 5), inserir uma nova mensagem de erro antes do "NEXT"(verificar ponto onde: Se l-item-config = verdadeiro).
Sugestão de mensagem: "A Ordem de Produção 9999, possui item configurado, logo não será possível utilizar este processo."
Utilizar a pi-gera-tt-erro para incluir a mensagem. (verificar a necessidade de preenchimento das variáveis c-erro, c-texto e c-retorno)
(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. |
---|