Árvore de páginas

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.
Propriedades de página

CONTEÚDO

  1. Dados Gerais
  2. Exemplo de utilização
    1. Inclusão
    2. Alteração
    3. Exclusão
  3. Outras Informações
  4. Tabelas utilizada


01. DADOS GERAIS

...

O Easy Import Control (SIGAEIC) disponibiliza a utilização de rotinas automáticas para a manutenção de Purchase Orders. Para isso, deve ser utilizado um rdmake que faça a chamada via Execauto da rotina EICPO400, responsável pela manutenção dos POs. Esta rotina espera receber um array com os dados da Capa do Purchase Order, e outro com os dados dos Itens. Também deve ser enviada a opção desejada, como Incluir, Alterar, ou Excluir.

Informações
titleImportante

Ao incluir um Purchase Order via rotina automática, o mesmo não poderá sofrer alterações via tela no Protheus. Qualquer alteração ou exclusão que venha a ser necessária ser executada para um Purchase Order inserido via rotina automática, deverá ser feita via rotina automática.


Abaixo iremos abordar algumas características de cada opção.

Deck of Cards
idExemplos
Card
id1
labelInclusão

...

Para efetuar a inclusão de um Purchase Order via rotina automática,

...

existem

...

duas

...

possibilidades que podem ser abordadas. A primeira opção é o envio dos dados de inclusão, já informando uma Solicitação de Importação previamente cadastrada. A segunda forma

...

de Incçusão, é não informar um código para a Solicitação de Importação, neste caso

...

o sistema efetuará o

...

#Include

cadastro da Solicitação de forma automática para os itens enviados na execução da Inclusão.

Informações
titleImportante
  1. Quando não for informado o número da Solicitação de Importação (W3_SI_NUM), a sequência dos itens do Purchase Order será a informada no campo W3_REG;
  2. Quando for informada a Solicitação de Importação, o campo W3_REG deve corresponder a sequência do item na Solicitação de Importação (W1_REG);
Bloco de código
languagepy
themeEclipse
titleModelo de Inclusão do Purchase Order por rotina automática
linenumberstrue
collapsetrue
#Include 'Protheus.ch'
#Include 'Totvs.ch'
#Include 'Tbiconn.ch'
 
User Function PO400Auto()
 
Local aCab  := {} //Array com os dados da Capa do Purchase Order 

Local aItem := {} //Array com os dados dos Itens do Purchase Order

Local nOpc:= 3 //Opção a ser executada. 3-Inclusão
 
Private lMsErroAuto := .F.
Private lMsHelpAuto := .T.
 
   RPCSetEnv("99", "01", NIL, NIL, "EIC", NIL, {"SW2", "SW3"})
    
   //Capa do Purchase Order
   AADD(aCab,{"W2_PO_NUM"  , "PO-
0001
0003" 				, NIL})
   AADD(aCab,{"W2_PO_DT"   , dDataBase     			, NIL})
   AADD(aCab,{"W2_FORN"    , "0001  "              	, NIL})

   AADD(aCab,{"W2_FORLOJ"  , "01"                  	, NIL})
   AADD(aCab,{"W2_COMPRA"  , "GEN"                 	, NIL})
   AADD(aCab,{"W2_IMPORT"  , "GN"                  	, NIL})
   AADD(aCab,{"W2_AGENTE"  , "GN "                 	, NIL})
   AADD(aCab,{"W2_TIPO_EM" , "GN"                  	, NIL})
   AADD(aCab,{"W2_ORIGEM"  , "SPO"                	, NIL})
   AADD(aCab,{"W2_DEST"    , "GRU"                 	, NIL})
   AADD(aCab,{"W2_INCOTER" , "CIF"                 	, NIL})
   AADD(aCab,{"W2_FREPPCC" , "PP"                  	, NIL})
   AADD(aCab,{"W2_COND_PA" , "GN   "               	, NIL})
   AADD(aCab,{"W2_MOEDA"   , "US$"                 	, NIL})
   AADD(aCab,{"W2_DT_PAR"  , dDataBase             	, NIL})
   AADD(aCab,{"W2_PARID_U" , 1.000000              	, NIL})
   AADD(aCab,{"W2_E_LC"    , "2"                   	, NIL})
 
   //Dados para os Itens do Purchase Order
   aAdd(aItem,{;

      {"W3_COD_I"  ,  "GEN-00"     
   , NIL},;
             
      {"W3_CC"     ,  "GEN00"         , NIL},;             

      {"W3_REG"    ,  1             
  , NIL},;
             
      {"W3_PRECO"  ,  100.00000       , NIL},;                 

      {"W3_FABR"   ,  "0001  "        , NIL},;

      {"W3_FABLOJ" ,  "01"            , NIL},;               

      {"W3_FORN"   ,  "0001  "        , NIL},;

      {"W3_FORLOJ" ,  "01"            , NIL},;               

      {"W3_QTDE"   ,  10.000          , NIL},;             

      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  
1
2.
00000000
70000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL}
,;
})
      //{"W3_
SALDO
SI_
Q
NUM" ,  
0.000
"4748-1",     NIL}}) //A SI deve ser informada 
, NIL},; {"W3_SI_NUM" , "SI0001" , NIL}})
quando já possuir a solicitação gerada no sistema. QUando não informada, será gerada de forma automática
 
   aAdd(aItem,{;

      {"W3_COD_I"  ,  "GEN-00"     
   , NIL},;
             
      {"W3_CC"     ,  "GEN00"         , NIL},;
             
      {"W3_REG"    ,  2            
   , NIL},;             

      {"W3_PRECO"  ,  100.00000       , NIL},;                 

      {"W3_FABR"   ,  "0001  "        , NIL},;

      {"W3_FABLOJ" ,  "01"            , NIL},;               

      {"W3_FORN"   ,  "0001  "        , NIL},;

      {"W3_FORLOJ" ,  "01"            , NIL},;
               
      {"W3_QTDE"   ,  15.000          , NIL},;             

      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  
1
3.
00000000
10000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL
},;
}})
      //{"W3_
SALDO
SI_
Q
NUM" ,  
0.000
"4748-2",     NIL}}) //A SI deve ser informada 
, NIL},; {"W3_SI_NUM" , "SI0001" , NIL}})
quando já possuir a solicitação gerada no sistema. QUando não informada, será gerada de forma automática

   MSExecAuto({|a,b,c,d| EICPO400(a,b,c,d)}, NIL, aCab, aItem, nOpc)
 
   If lMsErroAuto
 
      MostraErro()
   Else
      MsgInfo("Ok - P.O.")
   EndIf      
 

RPCClearEnv()
 
Return Nil

...

codelanguagepy
Card
id
2
label
themeEclipse
titleModelo de Alteração do Purchase Order por rotina automática
linenumberstrue
collapsetrue
Alteração

Ao realizar a alteração de um Purchase Order, obrigatoriamente deverá ser informado, além do código do PO nas informações da Capa, os dados de número da SI (Solicitação de Importação), Código do Produto, Centro de Custo e Reg para os Itens.

Durante uma alteração, também será possível adicionar novos itens ao PO ou até mesmo retirar itens já vinculados ao PO. 

Informações
titleImportante
  1. Para todas as alterações do PO, será sempre obrigatório o envio de uma Solicitação de Importação e a sequência do item (W3_REG). Ao informar uma SI com uma sequência (W3_REG) que não exista, a alteração do PO efetuará a inclusão deste item na SI e o vinculará no PO. Também é possível enviar uma SI e um REG de um registro que já exista na SI, desta forma este item somente será adicionado ao PO.
  2. Para o envio de uma Alteração do PO, para a exclusão de Itens (O item será desmarcado do PO, sendo desvinculado do mesmo e seu saldo devolvido à SI) será obrigatório o envio da opção "AUTDELETA" com o conteúdo "S".
Bloco de código
languagepy
themeEclipse
titleModelo de Alteração do Purchase Order por rotina automática com Adição de um novo item
linenumberstrue
collapsetrue
#Include 'Protheus.ch'
#Include 'Totvs.ch'
#Include 'Tbiconn.ch'
   
User Function 1PO400Auto()
   
Local aCab  := {} //Array com os dados da Capa do Purchase Order
Local aItem := {} //Array com os dados dos Itens do Purchase Order
  
Local nOpc:= 4 //Opção a ser executada. 4-Alteração
   
Private lMsErroAuto := .F.
Private lMsHelpAuto := .T.
   
   RPCSetEnv("99", "01", NIL, NIL, "EIC", NIL, {"SW2", "SW3"})
      
   //Capa do Purchase Order
#Include 'Protheus.ch' #Include 'Totvs.ch' #Include 'Tbiconn.ch' User Function PO400Auto() Local aCab := {} //Array com os dados da Capa do Purchase Order Local aItem := {} //Array com os dados dos Itens do Purchase Order Local nOpc:= 4 //Opção a ser executada. 4-Alteração Private lMsErroAuto := .F. Private lMsHelpAuto := .T. RPCSetEnv("99", "01", NIL, NIL, "EIC", NIL, {"SW2", "SW3"}) //Capa do Purchase Order AADD(aCab,{"W2_PO_NUM" , "PO-0001" , NIL}) AADD(aCab,{"W2_PO_DT" , dDataBase , NIL}) AADD(aCab,{"W2_FORN" , "0001 " , NIL}) AADD(aCab,{"W2_FORLOJ" , "01" , NIL}) AADD(aCab,{"W2_COMPRA" , "GEN" , NIL})

   AADD(aCab,{"W2_PO_
IMPORT
NUM"  , "
GN
PO-0004"         
, NIL})
   AADD(aCab,{"W2_
AGENTE
PO_DT"   , dDataBase 
"GN
   
"
          , NIL})
   AADD(aCab,{"W2_
TIPO_EM
FORN"    , "
GN"
GEN-00"               , NIL})
   AADD(aCab,{"W2_
ORIGEM
FORLOJ"  , "
SPO"
00"                   , NIL})
   AADD(aCab,{"W2_
DEST
COMPRA"  
, "
GRU
GEN"                  , NIL})
   AADD(aCab,{"W2_
INCOTER
IMPORT"  , "
CIF"
GN"                   , NIL})
   AADD(aCab,{"W2_
FREPPCC
AGENTE"  , "
PP"
GN2"                  , NIL})
   AADD(aCab,{"W2_
COND
TIPO_
PA
EM" , "GN"           
"
        , NIL})
   AADD(aCab,{"W2_
MOEDA
ORIGEM"  
, "
US$
SPO"                  , NIL})
   AADD(aCab,{"W2_
DT_PAR
DEST"    , 
dDataBase
"GRU"      
,
 
NIL})
  
AADD(aCab,{"W2_PARID_U"
 
,
 
1.000000
       , NIL})
   AADD(aCab,{"W2_
E_LC
INCOTER" , "CIF"    
,
  
"2"
            , NIL})
   
//Dados para os Itens do Purchase Order aAdd(aItem,{; {"W3_COD_I" , "GEN-00
AADD(aCab,{"W2_FREPPCC" , "PP"   
  
,
 
NIL},;
             , NIL})
   
AADD(aCab,{"
W3
W2_COND_
CC
PA"
 
,
 "
GEN00"
GN   "     
,
 
NIL},;
          , NIL})
   
AADD(aCab,{"W2_MOEDA"   
, 
{
"
W3_REG
US$"    
,
  
1
           
 
, NIL}
,;
)
   AADD(aCab,{"W2_DT_PAR"  , dDataBase            
  , NIL})
   AADD(aCab,{"
W3
W2_PARID_
PRECO
U" 
,
, 1.000000        
100.00000
       , NIL}
,;
)
   AADD(aCab,{"W2_E_LC"    , "2"             
      
{"W3_FABR"
 , NIL})
 
,
  
"0001

  
"
 //Dados para os Itens do Purchase Order
 
, NIL},;
  aAdd(aItem,{;
      {"W3_COD_
FABLOJ
I"  ,  "
01"
PA-001"        
, NIL},;
           

      {"W3_
FORN
CC"     ,  "GEN00"
0001
  
"
       
, NIL},;           
      {"W3_
FORLOJ
REG"    ,  1   
"01"
            , NIL},;
           
      {"W3_
QTDE
PRECO"
  ,  
10
101.
000
00000       , 
, NIL
NIL},;               
      {"W3_
DT_EMB
FABR"   ,  
dDataBase
"GEN-01"        , NIL},;
      {"W3_
DT_ENTR
FABLOJ" ,  
dDataBase
"00"            , NIL},;             
      {"W3_
PESOL
FORN"   ,  
1.00000000
"GEN-00"        , NIL},;
      {"W3_
PESO_BR
FORLOJ" ,  "00"    
1.000000
        , NIL},;             
      {"W3_
SALDO_Q"
QTDE"   ,  
0
11.000
          , NIL},;
         
{"
  
      {"W3_
SI
DT_
NUM
EMB" ,  dDataBase    
"SI0001"
   , NIL}
}) aAdd(aItem
,
{
;

      {"W3_
COD
DT_
I
ENTR",  
,
dDataBase  
"GEN-00"
   
  , NIL},;
      {"W3_PESOL"  ,  2.90000000      , NIL},;
      {"W3_PESO_
CC
BR"
,  
"GEN00"
1.000000        , NIL},;
      {"W3_SI_NUM" ,  
"SITET1",     NIL}})
   
   
{"W3_REG"
aAdd(aItem,{;
    
,
  
2
{"W3_COD_I"  ,  
"PA-001"      
  , NIL},;
           
      {"W3_
PRECO
CC"     ,  "GEN00"  
100.00000
       , NIL},;           

      {"W3_
FABR
REG"    ,  2    
"0001
   
"
        , NIL},;           
      {"W3_
FABLOJ
PRECO"  ,  
"01"
102.00000       
, NIL},;               

      {"W3_
FORN
FABR"   ,  "
0001
GEN-01"        , NIL},;

      {"W3_
FORLOJ
FABLOJ" ,  "
01
00"            , NIL},;             
      {"W3_FORN"   ,  "GEN-00"        , NIL},;
      {"W3_
QTDE
FORLOJ" ,  
,
"00"  
15.000
          , NIL},;
             
      {"W3_
DT_EMB
QTDE"   ,  45.000   
dDataBase
       , NIL},;           
      {"W3_DT_
ENTR
EMB" ,  dDataBase       , NIL},;
      {"W3_DT_
PESOL
ENTR",  
,
dDataBase 
1.00000000
      , NIL},;
      {"W3_
PESO_BR
PESOL"  ,  
1
3.
000000
30000000      , NIL},;

      {"W3_
SALDO
PESO_
Q
BR",  
0
1.
000
000000        
, NIL},;
      {"W3_SI_NUM" ,  "
SI0001"
SITET1",    
,
 NIL}})
   
  
MSExecAuto({|a,b,c,d|
 
EICPO400(a,b,c,d)},
 
NIL,
 
aCab,
 aAdd(aItem,
nOpc)
{;
    
If
 
lMsErroAuto
 {"W3_COD_I"  ,  "GEN-00"   
MostraErro()
   
Else
  , NIL},;   
MsgInfo("Ok
  
-
 
P.O.")
   
EndIf
  
     
RPCClearEnv() Return Nil
  • Exclusão

Bloco de código
languagepy
themeEclipse
titleModelo de Exclusão do Purchase Order por rotina automática
linenumberstrue
collapsetrue
#Include 'Protheus.ch' #Include 'Totvs.ch' #Include 'Tbiconn.ch' User Function PO400Auto() Local aCab := {} //Array com os dados da Capa do Purchase Order Local aItem := {} //Array com os dados dos Itens do Purchase Order Local nOpc:= 5 //Opção a ser executada. 5-Exclusão Private lMsErroAuto := .F. Private lMsHelpAuto := .T. RPCSetEnv("99", "01", NIL, NIL, "EIC", NIL, {"SW2", "SW3"}) //Capa do Purchase Order AADD(aCab,{"W2_PO_NUM" , "PO-0001" , NIL}) AADD(aCab,{"W2_PO_DT" , dDataBase , NIL}) AADD(aCab,{"W2_FORN" , "0001 " , NIL}) AADD(aCab,{"W2_FORLOJ" , "01
 {"W3_CC"     ,  "GEN00"         , NIL},;           
      {"W3_REG"    ,  3               , NIL},; //Item novo a ser adicionado na Alteração.
      {"W3_PRECO"  ,  103.00000       , NIL},;               
      {"W3_FABR"   ,  "GEN-01"        , NIL},;
      {"W3_FABLOJ" ,  "00"            , NIL}
)
,;             
   
AADD(aCab,
   {"
W2
W3_
COMPRA
FORN"   ,  "GEN-00"
        , NIL}
)
,;
      
AADD(aCab,
{"
W2
W3_
IMPORT
FORLOJ" , 
,
 "
GN
00"            , NIL}
)
,;   
AADD(aCab,{"W2_AGENTE"
  
, "GN
 
"
       

  
,
 
NIL})
   
AADD(aCab,
{"
W2
W3_
TIPO_EM
QTDE"   , 
"GN"
 10.000          , NIL}
) AADD(aCab,{"W2_ORIGEM"
,;  
,
 
"SPO"
        
  
,
 
NIL})
   
AADD(aCab,
{"
W2
W3_DT_
DEST
EMB"
 ,
"GRU"
  
dDataBase       , NIL}
)
,;
      
AADD(aCab,
{"
W2
W3_DT_
INCOTER
ENTR"
, 
"CIF"
 
dDataBase       
, NIL}
)
,;
     
AADD(aCab,
 {"
W2
W3_
FREPPCC
PESOL"  , 
"PP"
 3.30000000      , NIL}
)
,;
      
AADD(aCab,
{"
W2
W3_
COND
PESO_
PA
BR"
, 
"GN
 
1.000000 
"
       
, NIL}
)
,;
      
AADD(aCab,
{"
W2
W3_SI_
MOEDA
NUM" 
, 
,
 "
US$
SITET1"
        
, NIL}})
AADD(aCab,{"W2_DT_PAR" , dDataBase , NIL}) AADD(aCab,{"W2_PARID_U" , 1.000000 , NIL}) AADD(aCab,{"W2_E_LC" , "2" , NIL}) //Dados para os Itens do Purchase Order aAdd(aItem,{; {"W3_COD_I" , "GEN-00" , NIL},; {"W3_CC" , "GEN00" , NIL},; {"W3_REG" , 1
 //Solicitação que será adicionado o novo item. O W3_REG deve ter um núemro que ainda não existe na SI
  
  
   MSExecAuto({|a,b,c,d| EICPO400(a,b,c,d)}, NIL, aCab, aItem, nOpc)
   
   If lMsErroAuto
      MostraErro()
   Else
      MsgInfo("Ok - P.O.")
   EndIf    
   
RPCClearEnv()
   
Return Nil
Bloco de código
languagepy
themeEclipse
titleModelo de Alteração do Purchase Order por rotina automática com Exclusão de item
linenumberstrue
collapsetrue
#Include 'Protheus.ch'
#Include 'Totvs.ch'
#Include 'Tbiconn.ch'
   
User Function 1PO400Auto()
   
Local aCab  := {} //Array com os dados da Capa do Purchase Order
Local aItem := {} //Array com os dados dos Itens do Purchase Order
  
Local nOpc:= 4 //Opção a ser executada. 4-Alteração
   
Private lMsErroAuto := .F.
Private lMsHelpAuto := .T.
   
   RPCSetEnv("99", "01", NIL, NIL, "EIC", NIL, {"SW2", "SW3"})
      
   //Capa do Purchase Order
   AADD(aCab,{"W2_PO_NUM"  , "PO-0004"         , 
NIL})
 
  
, NIL},;
AADD(aCab,{"W2_PO_DT"   , dDataBase             
 , NIL})
   
AADD(aCab,{"
W3
W2_
PRECO
FORN"    , "GEN-00"        
100.00000
       , NIL}
,;
)
   AADD(aCab,{"W2_FORLOJ"  , "00"               
    , NIL})
   AADD(aCab,{"
W3
W2_
FABR
COMPRA"
  , 
"GEN"
0001
  
"
        
,
 
NIL},;
 
      , NIL})
   AADD(aCab,{"
W3
W2_
FABLOJ
IMPORT"  , 
"
01
GN"                   , NIL}
,;
)
   AADD(aCab,{"W2_AGENTE"  , "GN2"                
  , NIL})
   AADD(aCab,{"
W3_FORN"
W2_TIPO_EM" , "GN"    
,
     
"0001
  
"
        , NIL}
,;
)
   
AADD(aCab,{"
W3
W2_
FORLOJ
ORIGEM"  ,
 "
01
SPO"            
,
 
NIL},;
     , NIL})
   AADD(aCab,{"W2_DEST"    , "GRU"  
      
{"W3_QTDE"
   
,
  
10.000
     , NIL})
   AADD(aCab,{"W2_INCOTER" , 
NIL},;
"CIF"              
    , NIL})
   AADD(aCab,{"
W3
W2_
DT_EMB
FREPPCC" , 
dDataBase
"PP"       
,
 
NIL},;
      
{"W3_DT_ENTR",
  
dDataBase
   , NIL})
   AADD(aCab,
NIL},;
{"W2_COND_PA" , "GN   "      
{"W3_PESOL"
  
,
  
1.00000000
      , NIL}
,;
)
   AADD(aCab,{"W2_MOEDA"   , 
{
"
W3_PESO_BR
US$"
,
  
1.000000
        
,
 
NIL},;
     
  , NIL})
   AADD(aCab,{"
W3
W2_
SALDO
DT_
Q
PAR"  , dDataBase   
0.000
           , NIL}
,;
)
   
AADD(aCab,{"
W3
W2_
SI
PARID_
NUM
U" ,
"SI0001"
 1.000000               , NIL
}
})
   
aAdd
AADD(
aItem,{;
aCab,{"
W3
W2_
COD
E_
I
LC"    , 
"
GEN-00
2"   
   
,
 
NIL},;
             , NIL})
   
   
{"W3_CC" , "GEN00"
//Dados para os Itens do Purchase Order
   aAdd(aItem,{;
      
,
{"W3_COD_I"  ,  "PA-001"        , NIL},;           
      {"W3_CC"     ,  "GEN00"         , NIL},;           
      {"W3_REG"    ,  
2
1             
  , NIL},;
           
      {"W3_PRECO"  ,  
100
101.00000       , NIL},;
               

      {"W3_FABR"   ,  "
0001
GEN-01"        , NIL},;

      {"W3_FABLOJ" ,  "
01
00"            , NIL},;
             

      {"W3_FORN"   ,  "
0001
GEN-00"        , NIL},;

      {"W3_FORLOJ" ,  "
01
00"            , NIL},;
             
      {"W3_QTDE"   ,  
15
11.000          , NIL},;           

      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  
1
2.
00000000
90000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL},;

      {"W3_
SALDO
SI_
Q
NUM" ,  
0.000
"SITET1",     NIL}})
   
   
, NIL},
aAdd(aItem,{;
      {"W3_
SI
COD_
NUM
I"  ,  "
SI0001"
PA-001"   
,
 
NIL}})
   
MSExecAuto({|a,b,c,d|
 
EICPO400(a,b,c,d)}
, NIL},; 
aCab, aItem, nOpc) If lMsErroAuto
          
      {"W3_CC"     ,  "GEN00"         , NIL},;        
MostraErro()
   
Else

      
MsgInfo("Ok - P.O.")
{"W3_REG"    ,  2        
EndIf
       
RPCClearEnv() Return Nil

...

, NIL},;           
      {"W3_PRECO"  ,  102.00000       , NIL},;               
      {"W3_FABR"   ,  "GEN-01"        , NIL},;
      {"W3_FABLOJ" ,  "00"            , NIL},;             
      {"W3_FORN"   ,  "GEN-00"        , NIL},;
      {"W3_FORLOJ" ,  "00"            , NIL},;             
      {"W3_QTDE"   ,  45.000          , NIL},;           
      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  3.30000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL},;
      {"W3_SI_NUM" ,  "SITET1",     NIL}})
   
      aAdd(aItem,{;
      {"W3_COD_I"  ,  "GEN-00"        , NIL},;           
      {"W3_CC"     ,  "GEN00"         , NIL},;           
      {"W3_REG"    ,  3               , NIL},;
      {"W3_PRECO"  ,  103.00000       , NIL},;               
      {"W3_FABR"   ,  "GEN-01"        , NIL},;
      {"W3_FABLOJ" ,  "00"            , NIL},;             
      {"W3_FORN"   ,  "GEN-00"        , NIL},;
      {"W3_FORLOJ" ,  "00"            , NIL},;             
      {"W3_QTDE"   ,  10.000          , NIL},;           
      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  3.30000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL},;
      {"W3_SI_NUM" ,  "SITET1"        , NIL},;
      {"AUTDELETA" ,  "S"             , NIL}}) //Informa que este item deve ser deletado no PO. Seu saldo retornará para o item na SI
  
  
   MSExecAuto({|a,b,c,d| EICPO400(a,b,c,d)}, NIL, aCab, aItem, nOpc)
   
   If lMsErroAuto
      MostraErro()
   Else
      MsgInfo("Ok - P.O.")
   EndIf    
   
RPCClearEnv()
   
Return Nil




Card
id3
labelExclusão

Para a realização da exclusão do Purchase Order via rotina automática, é necessário apenas que seja enviado as informações referente a capa do PO, podendo também, de forma opcional, enviar os dados dos itens.


Bloco de código
languagepy
themeEclipse
titleModelo de Exclusão do Purchase Order por rotina automática
linenumberstrue
#Include 'Protheus.ch'
#Include 'Totvs.ch'
#Include 'Tbiconn.ch'
  
User Function 1PO400Auto()
  
Local aCab  := {} //Array com os dados da Capa do Purchase Order
Local aItem := {} //Array com os dados dos Itens do Purchase Order
 
Local nOpc:= 5 //Opção a ser executada. -Exclusão
  
Private lMsErroAuto := .F.
Private lMsHelpAuto := .T.
  
   RPCSetEnv("99", "01", NIL, NIL, "EIC", NIL, {"SW2", "SW3"})
     
   //Capa do Purchase Order
   AADD(aCab,{"W2_PO_NUM"  , "PO-0004"              , NIL})
   AADD(aCab,{"W2_PO_DT"   , dDataBase              , NIL})
   AADD(aCab,{"W2_FORN"    , "0001  "               , NIL})
   AADD(aCab,{"W2_FORLOJ"  , "01"                   , NIL})
   AADD(aCab,{"W2_COMPRA"  , "GEN"                  , NIL})
   AADD(aCab,{"W2_IMPORT"  , "GN"                   , NIL})
   AADD(aCab,{"W2_AGENTE"  , "GN "                  , NIL})
   AADD(aCab,{"W2_TIPO_EM" , "GN"                   , NIL})
   AADD(aCab,{"W2_ORIGEM"  , "SPO"                  , NIL})
   AADD(aCab,{"W2_DEST"    , "GRU"                  , NIL})
   AADD(aCab,{"W2_INCOTER" , "CIF"                  , NIL})
   AADD(aCab,{"W2_FREPPCC" , "PP"                   , NIL})
   AADD(aCab,{"W2_COND_PA" , "GN   "                , NIL})
   AADD(aCab,{"W2_MOEDA"   , "US$"                  , NIL})
   AADD(aCab,{"W2_DT_PAR"  , dDataBase              , NIL})
   AADD(aCab,{"W2_PARID_U" , 1.000000               , NIL})
   AADD(aCab,{"W2_E_LC"    , "2"                    , NIL})
  
   //Dados para os Itens do Purchase Order
   aAdd(aItem,{;
      {"W3_COD_I"  ,  "GEN-00"        , NIL},;            
      {"W3_CC"     ,  "GEN00"         , NIL},;            
      {"W3_REG"    ,  1               , NIL},;            
      {"W3_PRECO"  ,  100.00000       , NIL},;                
      {"W3_FABR"   ,  "0001  "        , NIL},;
      {"W3_FABLOJ" ,  "01"            , NIL},;              
      {"W3_FORN"   ,  "0001  "        , NIL},;
      {"W3_FORLOJ" ,  "01"            , NIL},;              
      {"W3_QTDE"   ,  10.000          , NIL},;            
      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  2.90000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL}})
  
   aAdd(aItem,{;
      {"W3_COD_I"  ,  "GEN-00"        , NIL},;            
      {"W3_CC"     ,  "GEN00"         , NIL},;            
      {"W3_REG"    ,  2               , NIL},;            
      {"W3_PRECO"  ,  100.00000       , NIL},;                
      {"W3_FABR"   ,  "0001  "        , NIL},;
      {"W3_FABLOJ" ,  "01"            , NIL},;              
      {"W3_FORN"   ,  "0001  "        , NIL},;
      {"W3_FORLOJ" ,  "01"            , NIL},;              
      {"W3_QTDE"   ,  15.000          , NIL},;            
      {"W3_DT_EMB" ,  dDataBase       , NIL},;
      {"W3_DT_ENTR",  dDataBase       , NIL},;
      {"W3_PESOL"  ,  3.30000000      , NIL},;
      {"W3_PESO_BR",  1.000000        , NIL}})

 
   MSExecAuto({|a,b,c,d| EICPO400(a,b,c,d)}, NIL, aCab, aItem, nOpc)
  
   If lMsErroAuto
      MostraErro()
   Else
      MsgInfo("Ok - P.O.")
   EndIf     
  
RPCClearEnv()
  
Return Nil


03. Outras Informações

Ao utilizar a rotina automático do Purchase Order sem a utilização de uma Solicitação de Importação já préviamente cadastrada, o sistema efetuará a inclusão de uma SI de forma automática. Esta Solicitação de Importação inserida de forma automática não poderá sofrer alterações via tela no Protheus, mesmo que o Purchase Order seja excluído.

Caso seja necessária a exclusão de uma SI gerada de forma automática, deverá ser utilizado o ponto de entrada VALIDA_EXCLUSAO, que pode ter sua documentação consultada em: DT PE EICSI400 - Solicitação de Importação


04Tabelas Utilizadas

SW0 - Capa de Solicitação Importação

...