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

Ex-GSI não estava com golpistas, mas errou no 8/1, diz Humberto Costa

Colaboração para o UOL, em São Paulo

21/04/2023 19h00

O senador Humberto Costa (PT-PE) afirmou em entrevista ao UOL News desta sexta-feira (21) que acredita que o ex-ministro do GSI, Gonçalves Dias, não estava atuando junto com golpistas nos atos antidemocráticos do dia 8 de janeiro. Imagens de Dias andando pelo Palácio do Planalto durante os ataques foram divulgadas nesta semana pela CNN.

Pelo que conheço Dias, conheço há muito tempo, não acredito que estivesse mancomunado com alguém que quisesse dar um golpe de estado no Brasil, muito pelo contrário. O que acho que ele errou foi em termos de avaliação politica, em termos de exercer o que era sua função.

Segundo Humberto Costa, o presidente Lula (PT) pediu as imagens a Dias, mas o general afirmou que algumas câmeras não estavam funcionando.

O general disse primeiro que algumas das câmeras, que são mostradas agora filmando pessoas, não estavam funcionando. Depois, disse também que naquelas imagens não havia nada relevante, foi uma decisão dele. O que o governo falhou? Falhou no sentido de não dizer: 'confiamos em você, mas a gente quer ter o e a gente quer divulgar'.

GSI: Vazamento de imagens foi planejado e MI irá mostrar envolvimento de bolsonaristas, diz Costa

Humberto Costa também afirmou que a divulgação das imagens do ex-chefe do GSI foi planejada, citando que apenas Dias tem o rosto exposto no vídeo.

Aquelas pessoas que faziam parte do GSI, à exceção do general Gonçalves Dias, apareceram nesses vídeos com suas identidades preservadas. Lógico que isso não se sustenta, os vídeos originais estão lá. Vamos saber quem são essas pessoas e se essas pessoas são originárias do antigo GSI. Isso demonstra que foi planejado.

Humberto Costa ainda afirmou que as informações que surgirão com as investigações e a MI devem mostrar o envolvimento de pessoas próximas ao ex-presidente Jair Bolsonaro nos atos golpistas.

Muita coisa que vai surgir e vai reforçar a argumentação que havia um envolvimento de gente muito próxima ao ex-presidente Bolsonaro, ao ex-chefe do GSI, [general] Heleno, portanto acredito que vai rolar para onde for e vai bater neles novamente.

Dal Piva: 8/1 é a chance do Brasil fazer militares responderem por seus crimes

A colunista do UOL Juliana Dal Piva afirmou ao UOL News que as investigações realizadas sobre os atos golpistas do dia 8 de janeiro abrem a perspectiva de quebrar uma tradição de militares não serem responsabilizados por crimes no Brasil.

A questão está num problema histórico para o Brasil, que é punir militares, investigar militares. O Brasil não fez justiça aos crimes cometidos por agentes públicos, sobretudo militares na ditadura militar. (...) Esse episódio gravíssimo agora talvez vá ter consequências e também cria um marco para o Brasil para fazer com que os militares respondam por atos quando eles cometerem crimes.

***

O UOL News vai ao ar de segunda a sexta-feira em três edições: às 8h, às 12h e às 18h.

O programa é sempre ao vivo. Quando: de segunda a sexta, às 8h, às 12h e 18h.

Onde assistir: Ao vivo na home UOL, UOL no YouTube e Facebook do UOL.

Veja a íntegra do programa: