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

Esse conteúdo é antigo

Marco Aurélio será relator de ação de Bolsonaro contra lockdown nos estados

Decano da Corte, ministro ficará com relatoria de ação que tenta limitar poderes dos governadores  -
Decano da Corte, ministro ficará com relatoria de ação que tenta limitar poderes dos governadores

Do UOL, em São Paulo

22/03/2021 16h49Atualizada em 22/03/2021 19h38

O ministro do STF (Supremo Tribunal Federal) Marco Aurélio Mello foi definido hoje como relator da ação protocolada pelo presidente Jair Bolsonaro (sem partido) contra toque de recolher e medidas de restrição de circulação de pessoas adotados por estados no combate à pandemia.

Na semana ada, Bolsonaro entrou na corte com uma ADI (Ação Direta de Inconstitucionalidade), pedindo que os governadores dos estados da Bahia e do Rio Grande do Sul, além do Distrito Federal, sejam impedidos de decretar ações restritivas.

O argumento do presidente é que as medidas restritivas são inconstitucionais porque só poderiam ser adotadas com base em lei elaborada pelo Legislativo, e não por decretos de governadores. O atual entendimento do STF, no entanto, dá autonomia a estados e municípios para ações contra a pandemia, sem dispensar o governo federal de centralizá-las.

Atual decano da corte, Marco Aurélio pode tanto decidir sozinho se rejeita ou não a ação do presidente ou se envia ocaso para votação em plenário.

Na semana ada, em entrevista ao UOL, Marco Aurélio disse via o pedido de Bolsonaro como uma atitude que está "na contramão" do que o STF definiu no início da pandemia e que, na avaliação dele, o presidente está "querendo ter hegemonia nas decisões".

O ministro criticou ainda a atitude do presidente diante o pior momento da pandemia no país — com recorde de mortos, atraso na vacinação e falta de leitos e medicação.

"Ele não quer que feche, não quer toque de recolher? Ele quer realmente que todos estejam em atividades plenas, pouco importando esse quadro triste com quase 300 mil mortos. Já somos o primeiro país do mundo em mortes", disse.

Mesmo que a decisão seja coletiva, a tendência é que o STF acompanhe o próprio entendimento a corte sobre a autonomia dos estados e municípios no combate à covid-19.

Estado de sítio

Na semana ada, ao comentar a ação protocolada no STF, Bolsonaro causou preocupação entre autoridades do Judiciário e do Legislativo ao comparar os lockdowns estaduais com o estado de sítio, instrumento que tem que ser solicitado pelo presidente e autorizado pelo Congresso. A reclamação deu a entender que ele poderia fazer valer o seu direito quanto ao estado de exceção.

O presidente do STF, Luiz Fux, ligou para Bolsonaro para esclarecer a questão e chegou a perguntar se era necessário que ele deixasse o Rio de Janeiro, onde se encontrava, para se dirigir à Brasília. Já o presidente do Senado, Rodrigo Pacheco (DEM-MG), disse que não via a "mínima razão" para se cogitar o estado de sítio.

Decretado em caso de guerra ou "comoção grave", o estado de sítio é previsto no artigo 137 da Constituição brasileira. A comparação com o toque de recolher decretado por estados foi chamada de "aberração" e "alienação" por especialistas em direito penal e constitucional ouvidos pelo UOL.