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.