;(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 Mello: 'Kassio Nunes se autoconcedeu título de desembargador'

Do UOL, em São Paulo

08/10/2020 20h04

O ministro Marco Aurélio Mello, do STF (Supremo Tribunal Federal), afirmou hoje que Kassio Nunes Marques "se autoconcedeu" o título de desembargador. A fala do ministro alfinetando o indicado de Jair Bolsonaro à Corte ocorreu na manhã de hoje, durante sessão do TSE (Tribunal Superior Eleitoral).

Marco Aurélio relatava críticas a uma de suas filhas após ser nomeada em um tribunal regional federal quando mencionou Nunes Marques.

"Pagou [a filha] um preço enorme. Como se tivesse sido nomeada graças à minha atuação e à atuação de minha mulher. Que essa, sim, é desembargadora, porque é integrante de tribunal de Justiça. Não o candidato indicado pelo presidente, que se diz desembargador porque se autoconcedeu esse título pomposo", declarou o ministro.

"É só buscar o ato de nomeação dele para ver para que cargo ele foi nomeado: cargo de juiz do Tribunal Regional da 1ª Região", acrescentou ele.

O UOL procurou a assessoria de Kassio Nunes Marques e aguarda retorno.

Currículo

Nesta terça (6), a Universidad de La Coruña, na Espanha, negou a existência de uma pós-graduação apresentada por Nunes Marques em seu currículo acadêmico. Ainda, a universidade acrescentou que ele realizou apenas um curso de cinco dias na instituição. Depois do caso vir à tona, o desembargador itiu ao senador Randolfe Rodrigues (Rede-AP) que não cursou a pós-graduação no local, conforme constava no currículo; ele atribuiu a informação equivocada a um erro de tradução.

Ontem, a revista Crusoé publicou que Nunes Marques apresentou sua dissertação de mestrado à Universidade Autônoma de Lisboa com trechos inteiros copiados de artigos publicados na internet. Os trechos são atribuídos ao advogado Saul Tourinho Leal, integrante da banca de advocacia de Carlos Ayres Britto, ex-ministro do STF. Segundo a publicação, até erros de português foram repetidos, indicando que o desembargador "copiou e colou" os textos sem revisão.

Nunes Marques negou o plágio e defendeu que o seu trabalho e o de Tourinho Leal são "produções doutrinárias opostas".

Julgamento no TSE

A pauta desta manhã julgava um pedido de Bolsonaro para exclusão de críticas feitas por ele ao Supremo durante a campanha eleitoral de 2018 e publicadas em redes sociais. Marco Aurélio afirmou, em seu voto, que a remoção do conteúdo significava censura e que ele "não concebia" retirar as imagens do ar. O pedido de Bolsonaro foi rejeitado de forma unânime pelo plenário do TSE.