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

Ministro da Educação ofende a China com tuíte 'racista'

06/04/2020 15h11

Brasília, 6 Abr 2020 (AFP) - A China pediu explicações para o Brasil nesta segunda-feira (6) depois que o ministro da Educação, Abraham Weintraub, relacionou a pandemia do novo coronavírus a um plano desse país asiático em "dominar o mundo", em um tuíte no qual imitava a forma de falar dos chineses.

É o incidente mais recente entre Brasília e Pequim.

"Geopoliticamente, quem podeLá saiL foLtalecido, em teLmos Lelativos, dessa cLise mundial?", escreveu o ministro em seu Twitter no último sábado.

"Quem são os aliados no BLasil do plano infalível do Cebolinha paLa dominaL o mundo?", escreveu, trocando as letras "r" por "l", em uma imitação comumente usada para imitar o sotaque dos chineses.

A Embaixada da China no Brasil considerou as declarações de Weintraub "absurdas e desprezíveis", além de considerá-las com "cunho fortemente racista".

"O lado chinês aguarda uma declaração oficial do lado brasileiro sobre as palavras feitas pelo min. da educação, membro do governo brasileiro", escreveu em seu Twitter o embaixador chinês Yang Wanming.

O comentário feito pelo ministro surge em um momento em que o Brasil, assim como inúmeros países, aguardam equipamentos de proteção vindos da China para lidar com a pandemia da COVID-19.

Weintraub disse em uma entrevista que sugeriu que a China faça mais para ajudar no combate à pandemia.

"Se eles (a China) venderem corretamente os mil respiradores, eu fico de joelhos em frente à embaixada, peço perdão e digo que fui um imbecil", disse o ministro à rádio Bandeirantes.

O ministro da Saúde, Luiz Henrique Mandetta, disse na última semana que o país estava com dificuldades de conseguir ventiladores e outros suprimentos essenciais vindos da China, afirmando que alguns dos pedidos foram cancelados sem nenhuma explicação.

O Brasil, cujo maior parceiro comercial é a China, é o país mais atingido pelo vírus na América Latina, com cerca de 500 mortes e mais de 11.000 infectados até o momento.

Desde que a pandemia surgiu, as relações entre Brasil e China se fragilizaram, principalmente após uma série de tuítes do filho do presidente Jair Bolsonaro, Eduardo, deputado federal por São Paulo.

Na última semana, a série de comentários culminou no cônsul-geral da China no Rio de Janeiro, Li Yang, questionando Eduardo em uma coluna do jornal O Globo: "Você é realmente tão ingênuo e ignorante?", escreveu.

jhb/ft/bn