Utilizaremos o ponto de entrada em MVC através do id BUTTONBAR MODELVLDACTIVE, que será executado antes da abertura da janela do cadastro.
No exemplo abaixo, iremos retratar o caso em que o usuário deseja não efetuar alterações no momento da cópia a cópia de alguns campos de um cliente já cadastrado, alterando o conteúdo do campo de Maior Saldo (A1_MSALDO).
Exemplo:
Bloco de código |
---|
language | js |
---|
linenumbers | true |
---|
|
#Include "TOTVS.ch"
#Include "FWMVCDEF.ch"
User Function CRMA980()
Local aParam := PARAMIXB // PARÂMETROSParâmetros PASSADOSpassados PARApara Oo PONTOponto (SEMPREsempre VARIAMvariam)
Local xRet := .T. // RETORNORetorno LÓGICOlógico PARApara PROSSEGUIMENTOprosseguimento DAda ROTINArotina
Local oObj := NIL // OBJETOObjeto QUEque ARMAZENARÁarmazenará Oo MODELOmodelo TOTALtotal
Local cIdPonto := "" // IDId DOdo MOMENTOmomento DAda CHAMADAchamada DOdo PONTOponto
Local cIdModel := "" // QUAL MODELO OU SUBMODELO ESTÁ ATIVO
Qual modelo ou submodelo está ativo
Local aCpoNoCopy := {}
If (aParam != NIL)
oObj := aParam[1]
cIdPonto := aParam[2]
cIdModel := aParam[3]
If cIDPonto == // VERIFICA SE O MOMENTO DA CHAMADA É QUANDO O ID IGUAL A BUTTONBAR"MODELVLDACTIVE" .And. oObj:GetOperation() == MODEL_OPERATION_INSERT
aAdd(aCpoNoCopy, "A1_MSALDO")
// E SE A OPERAÇÃO DE INCLUSÃO É PROVENIENTE DE UMA CÓPIAaAdd(aCpoNoCopy, "A1_MCOMPRA")
aAdd(aCpoNoCopy, "A1_PRICOM")
If (cIdPonto == "BUTTONBAR" .And. oObj:IsCopy())aAdd(aCpoNoCopy, "A1_ULTCOM")
// PROCURA O SUBMODELO SA1MASTER E INSERE NO CAMPO INFORMADO O CONTEÚDO DESEJADOaAdd(aCpoNoCopy, "A1_SALDUP")
oObj:GetModel("SA1MASTER"):LoadValue("A1_MSALDO", 0)
aAdd(aCpoNoCopy, "A1_SALPED")
//Define RECUPERAquais Acampos VIEWdo ATIVAsubmodelo Enão ATUALIZAserão (NECESSÁRIOcopiados PARAno EXIBIÇÃOprocesso DOde CONTEÚDO)
cópia do submodelo.
oView := FwViewActive()
oView:Refresh()
oObj:GetModel("SA1MASTER"):SetFldNoCopy(aCpoNoCopy)
EndIf
EndIf
Return (xRet) |