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

Janaina Paschoal critica Toffoli por suspender inquéritos com dados do Coaf

Luciana Quierati

Do UOL, em São Paulo

16/07/2019 13h40Atualizada em 17/07/2019 08h29

A deputada estadual Janaina Paschoal (PSL-SP) criticou hoje, em postagem no Twitter, a decisão do presidente do STF (Supremo Tribunal Federal), Dias Toffoli, de atender pedido do senador Flávio Bolsonaro (PSL-RJ) e suspender inquéritos que tenham partido de dados compartilhados por órgãos de controle como o Coaf (Conselho de Controle de Atividades Financeiras).

A decisão de Toffoli, tomada ontem, beneficia o filho do presidente Jair Bolsonaro (PSL), porque paralisa a investigação que está sendo realizada pelo Ministério Público do Rio de Janeiro e envolve o ex-assessor Fabrício Queiroz.

"Ainda é cedo para avaliar, mas a decisão prolatada pelo Ministro Toffoli, na data de hoje, pode significar uma derrota considerável na guerra contra a corrupção e um primeiro o para anular processos e até condenações. Preocupante!", escreveu a deputada na rede social.

A deputada fez outra série de posts questionando a dimensão da decisão de Toffoli.

"Dúvida de ordem técnico-jurídica: se, a partir da decisão do Ministro Tófolli (sic), o COAF e a Receita não podem enviar indícios de crime ao Ministério Público Federal, o que deverão fazer com tais indícios?", questionou. "Muitos inquéritos em trâmite na Polícia Federal se iniciaram por representações ministeriais oriundas de notificações do COAF e da Receita Federal. Se entendi bem a decisão do Ministro vai parar tudo."

Incomodada com as respostas de alguns seguidores, Janaina pediu que parem com "essa xaropada de direita e esquerda".

Tema de repercussão nacional

A defesa de Flávio alegou ao Supremo que está sendo discutido na corte um tema de repercussão geral que trata justamente da possibilidade, ou não, de órgãos de controle compartilharem dados sem prévia autorização judicial e que todos os casos com essa controvérsia deveriam ser suspensos.

"O MPRJ [Ministério Público do Rio] utilizou-se do Coaf para criar 'atalho' e se furtar ao controle do Poder Judiciário. Sem autorização do Judiciário, foi realizada devassa, DE MAIS DE UMA DÉCADA, nas movimentações bancárias e financeiras do requerente [Flávio] em flagrante burla às regras constitucionais garantidoras do sigilo bancário e fiscal", escreveu a defesa.

Toffoli concordou com o argumento, justificando sua decisão como forma de evitar que processos venham a ser anulados no futuro, assim que o STF deliberar sobre a questão.

As investigações do caso envolvendo Queiroz tiveram origem em relatórios do Coaf que apontaram movimentações consideradas atípicas em suas contas: R$ 1,2 milhão de janeiro de 2016 a janeiro de 2017 - o que seria incompatível com os rendimentos do assessor de Flávio, então deputado estadual.