Histórico da Página
...
Bloco de código | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
#include "PROTHEUS.ch" User Function MNTNG() Local cId := PARAMIXB[1] //Indica o momento da chamada do PE Local oWS := PARAMIXB[2] //Objeto com referência ao webservice Local oParser Local aArea Local aAreaSTJ Local nInput := 0 Local aDate Local cType Local lIsDone Local cTask Local cCode Local nAmount Local cOrder Local cPlan Local aDate Local lOk If cId == "CREATE_VALID_ORDER" .OR. cId == "UPDATE_VALID_ORDER" //valida inclusão e alteração da ordem //Bloco a seguir realiza validações dos insumos If FWJsonDeserialize(oWS:GetContent(),@oParser) //Parse da string no formato Json If AttIsMemberOf( oParser, "inputs" ) .And. Len( oParser:inputs ) > 0 cOrder := IIf( AttIsMemberOf( oParser, 'code' ), oParser:code, '' ) cPlan := IIf( AttIsMemberOf( oParser, 'plan' ), oParser:plan, '000000' ) //Bloco abaixo realiza validações nos insumos For nInput := 1 To Len( oParser:inputs ) oInput := oParser:inputs[ nInput ] cType := IIf( AttIsMemberOf( oInput , 'type' ), oInput:type, '' ) lIsDone := IIf( AttIsMemberOf( oInput , 'isDone'), oInput:isDone, .F. ) //Neste exemplo haverá validações somente para produtos realizados If cType != "P" .Or. !lIsDone Loop EndIf aDate := { dDatabase, '08:00' } lOk := .T. If AttIsMemberOf( oInput, "startDate" ) aDate := StrTokArr( oInput:startDate, " " ) ElseIf AttIsMemberOf( oInput, "date" ) aDate := StrTokArr( oInput:date, " " ) EndIf aDate := { STOD( aDate[1] ), aDate[2] } //Neste exemplo haverá validações somente quando informar data anterior a data atual If aDate[1] >= dDatabase Loop EndIf cTask := IIf( AttIsMemberOf( oInput , 'task'), oInput:task, '' ) cCode := IIf( AttIsMemberOf( oInput , 'code'), oInput:code, '' ) nAmount := IIf( AttIsMemberOf( oInput , 'amount'), oInput:amount, 0 ) If cId == "CREATE_VALID_ORDER" lOk := .F. Else /*Trecho abaixo verifica se o insumo já está gravado no banco caso exista não há necessidade de validação*/ dbSelectArea("STL") dbSetOrder( 1 ) If !dbSeek( xFilial('STL') + PADR( cOrder, Len( STL->TL_ORDEM ) )+ ; PADR( cPlan, Len( STL->TL_PLANO ) ) + PADR( cTask, Len( STL->TL_TAREFA ) ) + ; cType + PADR( cCode, Len( STL->TL_CODIGO ) ) ) lOk := .F. Else lOk := .F. //Verificação abaixo para garantir que o insumo não existe no banco While !STL->( Eof() ) .AND. STL->TL_FILIAL + STL->TL_ORDEM + STL->TL_PLANO +; STL->TL_TAREFA + STL->TL_TIPOREG + STL->TL_CODIGO == xFilial('STL') + PADR( cOrder, Len( STL->TL_ORDEM ) )+ ; PADR( cPlan, Len( STL->TL_PLANO ) ) + PADR( cTask, Len( STL->TL_TAREFA ) ) + ; cType + PADR( cCode, Len( STL->TL_CODIGO ) ) If Val( STL->TL_SEQRELA ) > 0 ; //verifica se é insumo realizado .And. nAmount == STL->TL_QUANTID //comparação de quantidade lOk := .T. //já está gravado e não há necessidade de validar Exit EndIf dbSelectArea("STL") dbSkip() EndDo EndIf EndIf If !lOk Return 'Não é permitido realizar insumos do tipo produto com a data retroativa. ' + ; 'Verifique o insumo/produto ' + cCode + ' data ' + Dtoc( aDate[1] ) EndIf Next nInput EndIf EndIf ElseIf cId == "CANCEL_VALID" //valida cancelamento da ordem If FWJsonDeserialize(oWS:GetContent(),@oParser) //Parse da string no formato Json If Empty( oParser:message )//verifica campo observação foi passado vazio Return "A observação do cancelamento é obrigatória." EndIf EndIf ElseIf cId == "FINISH_VALID_ORDER" If FWJsonDeserialize(oWS:GetContent(), @oParser) If Empty( oParser:observation ) //verifica campo observação foi passado vazio Return "Campo observação deve ser informado." EndIf EndIf ElseIf cId == "FINISHED_ORDER" If FWJsonDeserialize(oWS:GetContent(), @oParser) aArea := GetArea() aAreaSTJ := STJ->(GetArea()) dbSelectArea("STJ") dbSetOrder(1) If dbSeek(xFilial("STJ") + oParser:order + oParser:plan) Reclock("STJ", .F.) STJ->TJ_DTPRINI := STJ->TJ_DTMRINI STJ->TJ_HOPRINI := STJ->TJ_HOMRINI STJ->TJ_DTPRFIM := STJ->TJ_DTMRFIM STJ->TJ_HOPRFIM := STJ->TJ_HOMRFIM MsUnlock() Endif RestArea(aAreaSTJ) RestArea(aArea) Endif ElseIf cId == "FILTER_PRODUCT" //adiciona filtro para busca de produtos Return " AND B1_GRUPO = '97'" ElseIf cId == "DESCRIPTION_LOCALIZATION" // Altera descrição de localização do bem cCodBem := PARAMIXB[3] dbSelectArea("ST9") dbSetOrder(1) If dbSeek( xFilial("ST9") + cCodBem ) .And. !Empty( ST9->T9_CLIENTE + ST9->T9_LOJACLI ) cAddress := Posicione("SA1",1,xFilial("SA1") + ST9->T9_CLIENTE + ST9->T9_LOJACLI,"SA1->A1_END") EndIf Return Alltrim( cAddress ) EndIf Return |
...
Visão Geral
Import HTML Content
Conteúdo das Ferramentas
Tarefas