;(function() { window.createMeasureObserver = (measureName) => { var markPrefix = `_uol-measure-${measureName}-${new Date().getTime()}`; performance.mark(`${markPrefix}-start`); return { end: function() { performance.mark(`${markPrefix}-end`); performance.measure(`uol-measure-${measureName}`, `${markPrefix}-start`, `${markPrefix}-end`); performance.clearMarks(`${markPrefix}-start`); performance.clearMarks(`${markPrefix}-end`); } } }; /** * Gerenciador de eventos */ window.gevent = { stack: [], RUN_ONCE: true, on: function(name, callback, once) { this.stack.push([name, callback, !!once]); }, emit: function(name, args) { for (var i = this.stack.length, item; i--;) { item = this.stack[i]; if (item[0] === name) { item[1](args); if (item[2]) { this.stack.splice(i, 1); } } } } }; var runningSearch = false; var hadAnEvent = true; var elementsToWatch = window.elementsToWatch = new Map(); var innerHeight = window.innerHeight; // timestamp da última rodada do requestAnimationFrame // É usado para limitar a procura por elementos visíveis. var lastAnimationTS = 0; // verifica se elemento está no viewport do usuário var isElementInViewport = function(el) { var rect = el.getBoundingClientRect(); var clientHeight = window.innerHeight || document.documentElement.clientHeight; // renderizando antes, evitando troca de conteúdo visível no chartbeat-related-content if(el.className.includes('related-content-front')) return true; // garante que usa ao mínimo 280px de margem para fazer o lazyload var margin = clientHeight + Math.max(280, clientHeight * 0.2); // se a base do componente está acima da altura da tela do usuário, está oculto if(rect.bottom < 0 && rect.bottom > margin * -1) { return false; } // se o topo do elemento está abaixo da altura da tela do usuário, está oculto if(rect.top > margin) { return false; } // se a posição do topo é negativa, verifica se a altura dele ainda // compensa o que já foi scrollado if(rect.top < 0 && rect.height + rect.top < 0) { return false; } return true; }; var asynxNextFreeTime = () => { return new Promise((resolve) => { if(window.requestIdleCallback) { window.requestIdleCallback(resolve, { timeout: 5000, }); } else { window.requestAnimationFrame(resolve); } }); }; var asyncValidateIfElIsInViewPort = function(promise, el) { return promise.then(() => { if(el) { if(isElementInViewport(el) == true) { const cb = elementsToWatch.get(el); // remove da lista para não ser disparado novamente elementsToWatch.delete(el); cb(); } } }).then(asynxNextFreeTime); }; // inicia o fluxo de procura de elementos procurados var look = function() { if(window.requestIdleCallback) { window.requestIdleCallback(findByVisibleElements, { timeout: 5000, }); } else { window.requestAnimationFrame(findByVisibleElements); } }; var findByVisibleElements = function(ts) { var elapsedSinceLast = ts - lastAnimationTS; // se não teve nenhum evento que possa alterar a página if(hadAnEvent == false) { return look(); } if(elementsToWatch.size == 0) { return look(); } if(runningSearch == true) { return look(); } // procura por elementos visíveis apenas 5x/seg if(elapsedSinceLast < 1000/5) { return look(); } // atualiza o último ts lastAnimationTS = ts; // reseta status de scroll para não entrar novamente aqui hadAnEvent = false; // indica que está rodando a procura por elementos no viewport runningSearch = true; const done = Array.from(elementsToWatch.keys()).reduce(asyncValidateIfElIsInViewPort, Promise.resolve()); // obtém todos os elementos que podem ter view contabilizados //elementsToWatch.forEach(function(cb, el) { // if(isElementInViewport(el) == true) { // // remove da lista para não ser disparado novamente // elementsToWatch.delete(el); // cb(el); // } //}); done.then(function() { runningSearch = false; }); // reinicia o fluxo de procura look(); }; /** * Quando o elemento `el` entrar no viewport (-20%), cb será disparado. */ window.lazyload = function(el, cb) { if(el.nodeType != Node.ELEMENT_NODE) { throw new Error("element parameter should be a Element Node"); } if(typeof cb !== 'function') { throw new Error("callback parameter should be a Function"); } elementsToWatch.set(el, cb); } var setEvent = function() { hadAnEvent = true; }; window.addEventListener('scroll', setEvent, { capture: true, ive: true }); window.addEventListener('click', setEvent, { ive: true }); window.addEventListener('resize', setEvent, { ive: true }); window.addEventListener('load', setEvent, { once: true, ive: true }); window.addEventListener('DOMContentLoaded', setEvent, { once: true, ive: true }); window.gevent.on('allJSLoadedAndCreated', setEvent, window.gevent.RUN_ONCE); // inicia a validação look(); })();
  • AssineUOL
Logo Pagbenk Seu dinheiro rende mais
Topo

Com novos saques, aplicativo do FGTS lidera ranking em loja virtual

Aplicativo do FGTS desbanca WhatsApp e vira o mais baixado do Brasil - Reprodução/App Store
Aplicativo do FGTS desbanca WhatsApp e vira o mais baixado do Brasil Imagem: Reprodução/App Store

Agência Brasil

16/09/2019 08h13

O aplicativo do Fundo de Garantia do Tempo de Serviço (FGTS) figura na primeira colocação na lista de "top apps" gratuitos da Play Store, loja virtual de programas para dispositivos móveis do sistema operacional Android. O programa do fundo e o da Caixa estão entre os principais, juntamente com opções populares como Whatsapp, Facebook, Instagram e Kwai.

Os "top apps" são uma das categorias da loja virtual Play Store. O ranking é definido por critérios próprios e não públicos do Google, conglomerado controlador da loja. A posição do ranking não é dada, assim, pelo número de s. O aplicativo do FGTS, por exemplo, marcava até a data da publicação 60 mil s. Já Facebook e Whatsapp chegavam à casa dos 90 milhões de carregamentos.

Por meio dele é possível consultar o valor disponível para saque imediato, canal de pagamento, extrato, saldo e tirar dúvidas sobre o benefício. Para instalar, é necessário dar informações como F, nome, data de nascimento e cadastrar uma senha. O site da Caixa traz um o-a-o para o procedimento.

O aplicativo foi atualizado no início do mês. Entre os novos recursos incluídos está a consulta do processo de saque imediato e adesão a ele. A ferramenta também ou a disponibilizar informações e permitir consulta para o saque aniversário.

Na Play Store, na escala de 1 a 5 o app possuía média de 3,2. A nota é dada pelos usuários que fazem o carregamento de cada app. Nos comentários, muitas pessoas reclamavam que a atualização da versão havia vindo com problemas (ou bug, no linguajar popular utilizado para equipamentos e serviços de informática).

Diante das reclamações, a Caixa respondeu no espaço de comentários que havia enfrentado problemas mas que o procedimento de cadastramento havia sido corrigido e que poderia ser novamente realizado para viabilizar a instalação e o uso do app.

Saque imediato

O app ganha popularidade no contexto do início dos saques imediatos do FGTS anunciados pelo governo federal. No primeiro sábado, a Caixa registrou 12 milhões de transações relacionadas ao pagamento. Já foram creditados quase R$ 5 bilhões nas contas de trabalhadores atendidos com o benefício.