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

Apesar de frituras, Maia elogia Lira sobre parecer da Reforma Tributária

Rodrigo Maia -  Maryanna Oliveira/Agência Câmara
Rodrigo Maia Imagem: Maryanna Oliveira/Agência Câmara

Natália Lázaro

Colaboração para o UOL, em Brasília

25/04/2021 15h52

O ex-presidente da Câmara dos Deputados Rodrigo Maia (DEM-RJ) elogiou seu sucessor e rival, Arthur Lira (PP-AL), sobre a apresentação do texto da Reforma Tributária no Congresso Nacional. Depois de mais de um ano travado, o chefe da Casa anunciou ontem que vai apresentar o parecer inicial no dia 3 de maio.

"Parabéns ao presidente Arthur Lira. O país não pode ser prisioneiro da incompetência do Executivo", escreveu Maia pelo Twitter, em alfinetada ao Planalto.

Nos bastidores, parlamentares alegam que Maia foi um dos principais entraves da Reforma no ano ado, dificultando parecer da relatoria. O ex-presidente da Câmara e Lira se tornaram rivais por conta da eleição no Congresso, em fevereiro deste ano. Enquanto Maia tentou emplacar o aliado Baleia Rossi (MDB-SP), Lira cravou uma guerra pela cadeira e ambos declararam rivalidade durante processo eleitoral.

Longe do cargo e com parecer finalmente anunciado, as dissonâncias com o Executivo foram maiores que a briga da dupla, levando Maia a trocar elogios com o adversário.

Ontem, Lira anunciou que o texto inicial da reforma tributária será apresentado no dia 3 de maio. A Comissão mista que analisa a proposta perdeu validade no fim de março e estava paralisada, desde então. A discussão em torno da reforma tributária está há mais de um ano no Congresso Nacional, com entraves nas negociações devido a apresentação de propostas divergentes entre as duas casas.

Enquanto o Legislativo tem sofrido imes para elaboração do parecer em defesa de seus interesses, o Executivo tem feito pressão para aprovação das pautas governamentais. Assim, o texto tem se arrastado no Congresso e, até hoje, nenhum relatório foi apresentado.