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

Por unanimidade, STF mantém decisão sobre implantação de renda básica

Até agora, cinco ministros acompanharam o voto do ministro Gilmar Mendes, relator do caso, que rejeitou os argumentos do governo - Agência STF
Até agora, cinco ministros acompanharam o voto do ministro Gilmar Mendes, relator do caso, que rejeitou os argumentos do governo Imagem: Agência STF

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

22/11/2021 16h44Atualizada em 22/11/2021 22h59

De forma unânime, os 10 ministros do Supremo Tribunal Federal (STF) mantiveram a decisão em que, em abril, já haviam determinado que o governo federal implemente, a partir de 2022, programa de renda básica para os brasileiros em situação de pobreza e extrema pobreza, com renda per capita menor que R$ 178 e R$ 89, respectivamente.

Todos os ministros acompanharam o voto do relator, ministro Gilmar Mendes, que rejeitou os argumentos do governo.

"Verifico que as alegações das partes são impertinentes e decorrem de mero inconformismo com a decisão adotada por este Tribunal, uma vez que as partes não trouxeram argumentos suficientes a infirmá-la, visando apenas à rediscussão da matéria, já decidida de acordo com a jurisprudência desta Corte", declarou Mendes, em seu voto.

A Advocacia-Geral da União (AGU) alegava que não seria possível cumprir a determinação por problemas de ordem fiscal e eleitoral, que proíbe a criação e ampliação de benefícios sociais pela istração pública em ano de eleições. Os ministros analisam dois recursos. "Ante o exposto, rejeito os dois embargos de declaração, realçando desde já que, caso opostos, por quaisquer das partes, novos embargos declaratórios, estes serão tidos como protelatórios, com futura condenação em litigância de má-fé", concluiu o ministro do STF.

O STF já havia determinado que o governo federal fixasse valor e começasse a pagar a renda básica de cidadania a partir de 2022. A decisão foi em resposta a um pedido da Defensoria Pública da União que cobrava a regulamentação de uma lei de 2005 que previa o pagamento do benefício. O órgão afirmou que, ados mais de 17 anos da promulgação da lei que criou o Programa Renda Básica de Cidadania, o Poder Executivo ainda não havia regulamentado o benefício.

Questão antiga

Sancionada em 2005 pelo então presidente Luiz Inácio Lula da Silva, a lei prevê que todos os brasileiros no país e estrangeiros que morem há pelo menos cinco anos no Brasil recebam um benefício monetário anual.

A lei diz que caberá ao Executivo estipular o valor do benefício e prevê o pagamento de parcelas mensais, de mesmo valor, para todos os cidadãos, a fim de atender "às despesas mínimas de cada pessoa com alimentação, educação e saúde, considerando para isso o grau de desenvolvimento do País e as possibilidades orçamentárias".

Essa regulamentação, no entanto, nunca foi publicada —e, por isso, não está em vigor. Diante da falta de regra, a Defensoria Pública da União acionou o STF e apontou omissão do Executivo em nome de um morador de rua. O voto com adesão da maioria no julgamento estende o direito à faixa de renda considerada "extrema pobreza" no país.