EXECAUTO VEIXX000 - Entrada de Veículos

Produto:

Protheus

Versões:

Todas

Ocorrência:

Rotina Automática - VEIXX000 Entrada de Veículos (Execauto)

Ambiente:

SIGAVEI - Veículos

Descrição:Rotina automática que permite a entrada de veículos).
Parâmetros:
NomeTipoDescriçãoConteúdo Default
ExpA1ArrayArray contendo os dados do cabeçalho da Entrada de Veículos.
ExpA2

Array

Array contendo os itens da Entrada de Veículos.
ExpA3ArrayArray contendo a forma de pagamento da Entrada de Veículos. Caso não haja, informe um array vazio.
ExpN1NuméricoOpção desejada: 3-Inclusão; 5-Cancelamento.
ExpC1Caractere

Tipo de Entrada desejado:

"0"=Normal (entrada por compra)
"1"=Ped.Fabrica
"2"=Remessa
"3"=Transferencia
"4"=Consignacao
"5"=Devolucao
"6"=Frete
"7"=Retorno de Remessa
"8"=Retorno de Consignacao


ExpA4ArrayUso interno
ExpL1LógicoBooleano que define se deve exibir mensagens padrão da rotina..t.
ExpA5BooleanoArray contendo as informações da nota fiscal já gerada. Caso não haja, não informe nenhum conteúdo.{.t.,"",""}
ExpC2Caractere

Tipo do Documento a ser considerado:

"1" = Gera nota fiscal de Entrada - SD1/SF1
"2" = Gera movimentacao interna - SD3
"3" = Nao gera movimentacao de entrada Back Office (Nota Fiscal de Entrada / Mov. Interna de Estoque)
Neste caso o veiculo pode ser importado do mercado internacional e a nota fiscal já foi digitada no BackOffice
"4" = Nao gera movimentacao de entrada Back Office (Nota Fiscal de Entrada / Mov. Interna de Estoque)
Neste caso o veiculo foi produzido pela montadora através de uma Ordem de Produção no PCP

"1"

Passo a passo:

//Inclusão de uma entrada de veículos por compra gerando nota fiscal

#include "totvs.ch"

User Function INTVX0NF()
Local xAutoCab := {} // Campos Cabecalho
Local xAutoItens := {} // Campos Itens
Local xAutoIt := {}
//Local xTIPDOC

Local aParParamBox := {}
Local aRetParamBox := {}

AADD( aParParamBox , { 1 , RetTitle("F1_DOC") , Space(TamSX3("F1_DOC" )[1]) , "" , "" , "" , "" , 60 , .T. } ) // 1
AADD( aParParamBox , { 1 , RetTitle("F1_SERIE") , Space(TamSX3("F1_SERIE" )[1]) , "" , "" , "" , "" , 40 , .T. } ) // 2
AADD( aParParamBox , { 1 , RetTitle("F1_FORNECE") , Space(TamSX3("F1_FORNECE")[1]) , "" , "" , "" , "" , 40 , .T. } ) // 3
AADD( aParParamBox , { 1 , RetTitle("F1_LOJA") , Space(TamSX3("F1_LOJA" )[1]) , "" , "" , "" , "" , 40 , .T. } ) // 4
AADD( aParParamBox , { 1 , RetTitle("VV1_CHASSI") , Space(TamSX3("VV1_CHASSI")[1]) , "" , "" , "" , "" , 120 , .T. } ) // 5
//AADD( aParParamBox , { 2 , RetTitle("VVF_TIPDOC") , 2 , {"1=NF","3=Integracao SIGAEIC"} , 80 , "", .T. } ) // 6

If ! ParamBox(aParParamBox,"Entrada Veiculo - NF",@aRetParamBox,,,,,,,, .f., .f.)
Return
EndIf

//xTIPDOC := IIf (aRetParamBox[6] == 1 , "1" , "3" )

//cNota := "1812110021 00001601"
cNota := aRetParamBox[1] + aRetParamBox[2] + aRetParamBox[3] + aRetParamBox[4]
//cNota := FMX_INPUTBOX("Numero da nota fiscal de entrada", Space(TamSX3("F1_DOC")[1] + TamSX3("F1_SERIE")[1]))
//cNota := FMX_INPUTBOX("Numero da nota fiscal de entrada", cNota )
// F1_DOC+F1_SERIE+F1_FORNECE+F1_LOJA+F1_TIPO

SF1->(dbSetOrder(1))
If ! SF1->(dbSeek(xFilial("SF1") + cNota ))
MsgStop("Nota fiscal não encontrada")
Return
EndIf

cPergunta := "Nota: " + SF1->F1_SERIE + " - " + SF1->F1_DOC + CHR(13) + CHR(10) + ;
"Fornecedor: " + sf1->F1_FORNECE + " - " + sf1->F1_LOJA

If ! MsgYesNo("Confirma importacao da nota fiscal " + chr(13) + chr(10) + chr(13) + chr(10) + cPergunta )
Return
EndIf


aAdd(xAutoCab,{"VVF_CLIFOR" ,"F" ,Nil})
aAdd(xAutoCab,{"VVF_FORPRO" ,"0" ,Nil})
aAdd(xAutoCab,{"VVF_OPEMOV" ,"0" ,Nil})
aAdd(xAutoCab,{"VVF_DATMOV" ,dDataBase ,Nil})
aAdd(xAutoCab,{"VVF_DATEMI" ,SF1->F1_EMISSAO ,Nil})
aAdd(xAutoCab,{"VVF_CODFOR" ,SF1->F1_FORNECE ,Nil})
aAdd(xAutoCab,{"VVF_LOJA" ,SF1->F1_LOJA ,Nil})
aAdd(xAutoCab,{"VVF_FORPAG" ,RetCondVei() ,Nil})
aAdd(xAutoCab,{"VVF_ESPECI" ,SF1->F1_ESPECIE ,Nil})
aAdd(xAutoCab,{"VVF_NUMNFI" ,SF1->F1_DOC ,Nil})
aAdd(xAutoCab,{"VVF_SERNFI" ,SF1->F1_SERIE ,Nil})
aAdd(xAutoCab,{"VVF_NATURE" ,'1010101 ' ,Nil})
// aAdd(xAutoCab,{"VVF_VALMOV" ,SF1->F1_VALBRUT ,Nil})
aAdd(xAutoCab,{"VVF_CHVNFE" ,SF1->F1_CHVNFE ,Nil})

xAutoItens:= {} // Campos Itens

VV1->(dbSetOrder(2))

SD1->(dbSetOrder(1))
SD1->(dbSeek(xFilial("SD1") + cNota))
While !SD1->(Eof()) .and. SD1->D1_FILIAL == xFilial("SD1") .and. SD1->(D1_DOC+D1_SERIE+D1_FORNECE+D1_LOJA) == cNota

//cChassi := "CHASSI_MVC_EXECAUTO_001 "
cChassi := aRetParamBox[5]

VV1->(dbSeek(xFilial("VV1") + cChassi))

xAutoIt := {}
aAdd(xAutoIt,{"VVG_CHASSI" ,VV1->VV1_CHASSI ,Nil})
aAdd(xAutoIt,{"VVG_CODTES" ,SD1->D1_TES ,Nil})
aAdd(xAutoIt,{"VVG_LOCPAD" ,VV1->VV1_LOCPAD ,Nil})
aAdd(xAutoIt,{"VVG_VALUNI" ,SD1->D1_TOTAL ,Nil})
aAdd(xAutoIt,{"VVG_PICOSB" ,"0" ,Nil}) // Pis/Cof Subs
aAdd(xAutoItens,xAutoIt)

SD1->(dbSkip())
End

Private lMsHelpAuto := .t.
Private lMsErroAuto := .f.

cBkpFunName := FunName()
nBkpModulo := nModulo
SetFunName('VEIXA001')
nModulo := 11
MSExecAuto( { |a,b,c,d,e,f,g,h,i| VEIXX000(a,b,c,d,e,f,g,h,i) }, xAutoCab,xAutoItens,{} ,3 ,"0" , ,.f. , ,"3" )
SetFunName(cBkpFunName)
nModulo := nBkpModulo

If lMsErroAuto
MostraErro()
Else
MsgInfo("Movimento criado com sucesso")
EndIf


Return


//Cancelamento de uma entrada de veículos

#include "totvs.ch"

User Function DELVX0NF()
Local xAutoCab := {} // Campos Cabecalho
Local xAutoItens := {} // Campos Itens
Local xAutoIt := {}

Local aParParamBox := {}
Local aRetParamBox := {}

AADD( aParParamBox , { 1 , RetTitle("F1_DOC") , Space(TamSX3("F1_DOC" )[1]) , "" , "" , "" , "" , 40 , .T. } )
AADD( aParParamBox , { 1 , RetTitle("F1_SERIE") , Space(TamSX3("F1_SERIE" )[1]) , "" , "" , "" , "" , 40 , .T. } )
AADD( aParParamBox , { 1 , RetTitle("F1_FORNECE") , Space(TamSX3("F1_FORNECE")[1]) , "" , "" , "" , "" , 40 , .T. } )
AADD( aParParamBox , { 1 , RetTitle("F1_LOJA") , Space(TamSX3("F1_LOJA" )[1]) , "" , "" , "" , "" , 40 , .T. } )

If ! ParamBox(aParParamBox,"Entrada Veiculo - NF",@aRetParamBox,,,,,,,, .f., .f.)
Return
EndIf

// F1_DOC+F1_SERIE+F1_FORNECE+F1_LOJA+F1_TIPO
//cNota := "1812110021 00001601"
cNota := aRetParamBox[1] + aRetParamBox[2] + aRetParamBox[3] + aRetParamBox[4]
//cNota := FMX_INPUTBOX("Numero da nota fiscal de entrada", Space(TamSX3("F1_DOC")[1] + TamSX3("F1_SERIE")[1]))
//cNota := FMX_INPUTBOX("Numero da nota fiscal de entrada", cNota )

SF1->(dbSetOrder(1))
If ! SF1->(dbSeek(xFilial("SF1") + cNota ))
MsgStop("Nota fiscal não encontrada")
Return
EndIf

cPergunta := "Nota: " + SF1->F1_SERIE + " - " + SF1->F1_DOC + CHR(13) + CHR(10) + ;
"Fornecedor: " + sf1->F1_FORNECE + " - " + sf1->F1_LOJA

cNumTraDig := ""
If ! MsgYesNo("Confirma Cancelamento da nota fiscal " + chr(13) + chr(10) + chr(13) + chr(10) + cPergunta )
Return
EndIf

If !Empty(cNumTraDig)
aAdd(xAutoCab, { 'VVF_NUMTRA' , cNumTraDig , NIL } )
Else
aAdd(xAutoCab, { 'VVF_CODFOR' , SF1->F1_FORNECE , NIL } )
aAdd(xAutoCab, { 'VVF_LOJA' , SF1->F1_LOJA , NIL } )
aAdd(xAutoCab, { 'VVF_NUMNFI' , SF1->F1_DOC , NIL } )
aAdd(xAutoCab, { 'VVF_SERNFI' , SF1->F1_SERIE , NIL } )
EndIf

Private lMsHelpAuto := .t.
Private lMsErroAuto := .f.
MSExecAuto(;
{ |a,b,c,d,e,f,g,h,i| ;
VEIXX000(a ,b ,c ,d ,e ,f ,g ,h ,i ) },;
xAutoCab,{} ,{} ,5 ,"0" , ,.f. , , )
If lMsErroAuto
MostraErro()
Else
MsgInfo("Movimento cancelado com sucesso.")
EndIf


Return

Observações:

Esta rotina de Execução Automática se aplica as rotinas abaixo:

Entrada Por Compra (VEIXA001)

Entr. Por Remessa (VEIXA003)

Entr Retorno Remes (VEIXA006)

Entr. devol. Venda (VEIXA002)

Entr. Por Consig. (VEIXA005)

Entrada Por Transf (VEIXA004)

Entr Remess Consig (VEIXA008)

Entr. Ret. Consig. (VEIXA007)