Nesse vídeo demonstraremos a utilização da função RptStatus, que serve para abrir uma tela com uma régua simples de processamento.
Abaixo o código fonte desenvolvido para o exemplo em vídeo acima:
//Bibliotecas
#Include "TOTVS.ch"
#Include "TopConn.ch"
/*/{Protheus.doc} User Function zExe427
Abre uma régua simples de processamento
@type Function
@author Atilio
@since 29/03/2023
@obs
Função RptStatus
Parâmetros
Bloco de código que será executado
Título da janela
Mensagem que ficará em exibição
Retorno
Função não tem retorno
**** Apoie nosso projeto, se inscreva em https://www.youtube.com/TerminalDeInformacao ****
/*/
User Function zExe427()
Local aArea := FWGetArea()
RptStatus({|| fExemplo()}, "Aguarde...", "Executando rotina...")
FWRestArea(aArea)
Return
Static Function fExemplo()
Local aArea := FWGetArea()
Local nAtual := 0
Local nTotal := 0
Local cQryAux := ""
//Executa a consulta
cQryAux := " SELECT " + CRLF
cQryAux += " BM_GRUPO, " + CRLF
cQryAux += " BM_DESC " + CRLF
cQryAux += " FROM " + CRLF
cQryAux += " " + RetSQLName("SBM") + " SBM " + CRLF
cQryAux += " WHERE " + CRLF
cQryAux += " BM_FILIAL = '" + FWxFilial('SBM') + "' " + CRLF
cQryAux += " AND SBM.D_E_L_E_T_ = ' ' " + CRLF
TCQuery cQryAux New Alias "QRY_AUX"
//Conta quantos registros existem, e seta no tamanho da regua
Count To nTotal
SetRegua(nTotal)
//Percorre todos os registros da query
QRY_AUX->(DbGoTop())
While ! QRY_AUX->(EoF())
//Incrementa a mensagem na regua
nAtual++
IncRegua()
Sleep(100)
QRY_AUX->(DbSkip())
EndDo
QRY_AUX->(DbCloseArea())
FWRestArea(aArea)
Return
Bom pessoal, por hoje é só.
Abraços e até a próxima.