;(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
Topo

Thaís Oyama

Paulo Guedes está cada dia mais parecido com Bolsonaro

Jair Bolsonaro e Paulo Guedes: unidos na desorientação - SERGIO LIMA/AFP
Jair Bolsonaro e Paulo Guedes: unidos na desorientação Imagem: SERGIO LIMA/AFP

Colunista do UOL

30/09/2020 11h23

Paulo Guedes chegou ao governo como o mago que transformou o estatista-corporativista Jair Bolsonaro em um liberal de nascença.

Aos poucos, foi ficando claro que a varinha de condão do ministro tinha poderes limitados.

Ela falhou, por exemplo, na tentativa de encantar o presidente com o projeto de reforma da Previdência - Bolsonaro fez corpo mole no processo, Guedes saiu dele insatisfeito e nunca se conformou com a derrota do seu plano de capitalização nos moldes chilenos.

Mais tarde, o Posto Ipiranga assistiu em silêncio ao governo dinamitar seu projeto de reformas. A istrativa, em especial, Bolsonaro empurrou o quanto pôde com a barriga. Já a tributária, quando finalmente saiu, acabou sem outra das obsessões de Guedes, a nova MF.

Com a pandemia e as ambições eleitorais do chefe, o ministro viu as burras do Tesouro se esgarçarem de vez. Em uma de suas derrotas mais doloridas, assistiu ao Congresso aprovar o projeto de ajuda financeira a estados e municípios com uma única contrapartida, a do congelamento dos salários do funcionalismo público até 2021 - regra que o próprio Executivo agora vive tentando driblar.

A tudo isso Guedes assistiu calado.

Diante do imperativo de criar o Bolsa-Família-do-Bolsonaro, porém, o ministro mudou de comportamento.
No lugar de apenas resignar-se, ou a agir de forma proativa para burlar os seus próprios princípios.

Tendo tomado pito público porque as primeiras alternativas apresentadas para financiar o programa "tiravam do pobre para dar ao paupérrimo", o ministro resolveu propor uma marotagem na forma de calote no pagamento dos precatórios.

O mercado, seu maior aliado, respondeu na hora e com um mau-humor tamanho que o secretário do Tesouro, Bruno Funchal, já fala em risco de rebaixamento do Brasil nas agências de classificação de risco.

Bolsonaro quer fazer sua omelete sem quebrar nenhum ovo.

E, para isso, o seu ministro da Economia já está topando qualquer coisa.

Começa a crescer a impressão de que a mágica deu errado.

A varinha de condão de Guedes não apenas falhou em converter Bolsonaro, mas está fazendo o mago ficar cada dia mais parecido com ele.