#Include 'Protheus.ch'
#Include 'FWMVCDef.ch'
User Function GPEA050AUTO()
Local aArea := GetArea()
Local aDadSRA := {}
Local aDadSRF := {}
Local cMatricula := "999999"
Private oModel //Modelo
Private aRotina
Private lGp050Auto := .T. //Variável que define se é inserção automática
oModel := FWLoadModel("GPEA050") //Carrega o modelo
oModel:SetOperation(MODEL_OPERATION_INSERT) //Seta operação de inclusão
oModel:Activate() //Ativa o modelo
dbSelectArea("SRA")
dbSetOrder(1)
If !dbSeek( xFilial("SRA") + cMatricula)
Alert("Funcionário não localizado.")
Return()
Endif
oModel:LoadValue("GPEA050_SRA" , "RA_MAT" , SRA->RA_MAT )
oModel:LoadValue("GPEA050_SRA" , "RA_NOME" , SRA->RA_NOME)
oModel:LoadValue("GPEA050_SRA" , "RA_ADMISSA" , SRA->RA_ADMISSA)
oModel:SetValue("GPEA050_SRF", "RF_FILIAL" , SRA->RA_FILIAL)
oModel:SetValue("GPEA050_SRF", "RF_MAT" , SRA->RA_MAT)
oModel:SetValue("GPEA050_SRF", "RF_DATABAS" , CTOD('01/10/2017'))
oModel:SetValue("GPEA050_SRF", "RF_PD" , '129')
oModel:SetValue("GPEA050_SRF", "RF_DIASDIR" , '30')
oModel:SetValue("GPEA050_SRF", "RF_DATAFIM" , CTOD('30/09/2018'))
oModel:SetValue("GPEA050_SRF", "RF_STATUS" , '1')
//Validação e Gravação do Modelo
If oModel:VldData()
oModel:CommitData()
MsgInfo("Registro INCLUIDO!", "Atenção")
Else
aErro := oModel:GetErrorMessage()
cArqErrAuto := "Id do formulário de origem:"+ ' [' + AllToChar( aErro[1] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Id do campo de origem: " + ' [' + AllToChar( aErro[2] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Id do formulário de erro: " + ' [' + AllToChar( aErro[3] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Id do campo de erro: " + ' [' + AllToChar( aErro[4] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Id do erro: " + ' [' + AllToChar( aErro[5] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Mensagem do erro: " + ' [' + AllToChar( aErro[6] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Mensagem da solução: " + ' [' + AllToChar( aErro[7] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Valor atribuído: " + ' [' + AllToChar( aErro[8] ) + ']' + Chr(13) + Chr(10)
cArqErrAuto += "Valor anterior: " + ' [' + AllToChar( aErro[9] ) + ']' + Chr(13) + Chr(10)
Alert ('Falha no ExecAuto MVC: ' + (Chr(13) + Chr(10)) + cArqErrAuto)
EndIf
oModel:DeActivate()
oModel:Destroy()
oModel := NIL
RestArea(aArea)
Return()