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

Mauricio Stycer

OPINIÃO

Texto em que o autor apresenta e defende suas ideias e opiniões, a partir da interpretação de fatos e dados.

Ataque de Bolsonaro a Vera deveria ter sido condenado pelos apresentadores

Colunista do UOL

29/08/2022 00h45Atualizada em 29/08/2022 10h59

No animado primeiro debate com candidatos à Presidência em 2022, com análise de pedidos de resposta em tempo real, faltou agilidade aos promotores do evento para analisar o ataque do presidente Jair Bolsonaro à jornalista Vera Magalhães. Na minha opinião, cabia não apenas oferecer a palavra a Vera para responder às ofensas, caso ela desejasse, como também uma condenação oficial, por parte dos apresentadores, à atitude do presidente.

Vera Magalhães questionou Ciro Gomes sobre a cobertura vacinal do Brasil e perguntou ao candidato se as desinformações sobre o imunizante contra a covid-19, que inclusive foram disseminadas por Bolsonaro, podem ter tido impacto na queda vacinal no país. A jornalista não disse nenhuma mentira, como foi cabalmente demonstrado pela I da Covid.

Ao comentar a pergunta, após Ciro, Bolsonaro disse: "Vera, eu acho que eu não podia esperar outra coisa de você. Acho que você dorme pensando em mim. Você tem alguma paixão em mim. Não pode tomar partido num debate como esse. Fazer acusações mentirosas a meu respeito. Você é uma vergonha para o jornalismo brasileiro".

A resposta desrespeitosa, ao vivo, não deveria ter ado em branco num evento jornalístico. Simone Tebet e Soraya Thronicke logo manifestaram solidariedade a Vera. Quase uma hora depois, também Ciro e Lula se solidarizaram com a jornalista.

Num debate em que a questão de gênero acabou se tornando um dos temas mais importantes, foi positivo ver tantas mulheres fazendo perguntas, mas também chamou a atenção a falta de jornalistas negros entre os entrevistadores e apresentadores.

Band, TV Cultura, UOL e Folha optaram por um formato convencional, que estimula, por um lado, a troca de ideias (e ofensas) entre os candidatos e, por outro, tenta levantar temas relevantes por meio de perguntas dos jornalistas. Ainda que muito previsível, abre espaço para surpresas e mostra a capacidade de improvisação dos candidatos.

O modelo funcionou relativamente bem, na minha opinião. Mais importante, neste momento, foi ter colocado os seis principais candidatos num mesmo palco, submetendo-os a uma prática republicana.

Atualizado às 11h: As regras do debate vetam réplicas de jornalistas e inibem comentários dos apresentadores. Mas, como lembraram Tales Faria e Kennedy Alencar no UOL Eleições, já houve situações em que as empresas de comunicação, citadas em comentários de candidatos, se apressaram em divulgar notas de esclarecimento ao vivo, ainda durante os debates ou entrevistas. Por esse motivo, acho que caberia muito bem o registro de um protesto dos apresentadores do debate sobre a fala de Bolsonaro.