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

Gilmar estipula prazo para governo justificar portaria de Weintraub contra cotas

Paulo Roberto Netto

São Paulo

22/06/2020 18h41

O ministro Gilmar Mendes, do Supremo Tribunal Federal, mandou a Advocacia-Geral da União se manifestar em até 48 horas sobre a portaria do ex-ministro da Educação Abrahram Weintraub contra medida que estimulava as universidades a criarem propostas sobre cotas para negros, indígenas e pessoas com deficiência nos processos seletivos de pós-graduação.

O despacho do ministro foi deferido em uma das três ações que estão sob sua relatoria no Supremo.

A portaria de Weintraub não extinguiu cotas já em vigor e não impede as instituições de adotarem ações afirmativas. Porém, a ação foi vista como política, com o objetivo de desestimular o debate sobre o tema nas instituições. A medida foi assinada pelo ex-ministro horas antes de anunciar sua saída do MEC.

O texto derrubado por Weintraub determinava a criação de comissões para discutir ações afirmativas e previa a participação do MEC nas ações propostas pelas instituições. A medida foi assinada em 2016 pelo então ministro Aloizio Mercadante, no final da gestão Dilma Rousseff.

A ação de Weintraub foi questionada no Supremo por três partidos da oposição: Rede Sustentabilidade, PDT e PSB. Os três alegam 'flagrante retrocesso na garantia de direitos fundamentais', destacando o risco de discussões e propostas de cotas nas universidades serem deixadas de lado.

No Congresso, parlamentares criticaram a medida e dois projetos de decretos legislativos foram elaborados para torná-la sem efeito. O presidente da Câmara, Rodrigo Maia, disse que iria esperar o novo chefe do MEC assumir o cargo para resolver a questão no diálogo.

"Vamos conversar com novo ministro, dialogar com ministro da articulação política para ver se nós podemos resolver isso no diálogo, sem necessidade de aprovação de um projeto de decreto legislativo. O ideal é mostrar para o governo que essa decisão do ministro, já sabendo que ia sair, talvez tenha baixa legitimidade", disse Maia.