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

Gil vai ao estádio acompanhar Brasil X Suíça e quer 'deixar ofensas pra lá'

Adriano Wilkson, Juca Kfouri e Pedro Lopes

Do UOL, em Doha (QAT)

28/11/2022 11h08Atualizada em 28/11/2022 13h17

Classificação e Jogos

Depois de ser hostilizado por um grupo de apoiadores de Jair Bolsonaro (PL) no jogo de estreia da seleção brasileira, contra a Sérvia, Gilberto Gil chegou cedo ao estádio 974 para acompanhar o duelo entre Brasil x Suíça, às 13h (de Brasília) de hoje (28), pela segunda rodada do Grupo G da Copa do Mundo do Qatar.

Sem ser perturbado, o cantor e compositor de 80 anos foi visto pela equipe de reportagem do UOL Esporte entrando no 974 antes mesmo das 11h (de Brasília), ando o local pela área de hospitalidade e de camarotes do estádio.

Gilberto Gil conversou brevemente com o jornalista Juca Kfouri e falou em 'deixar as ofensas pra lá'. "Melhor deixar para lá", disse o cantor, que não estará presente no terceiro jogo do Brasil na Copa, contra Camarões, na sexta (2). Porém, sua ideia é voltar ao Qatar caso o Brasil vá avançando na torneio.

"Estou indo para Paris amanhã [terça-feira] e, se a seleção fizer bons três próximos jogos, talvez eu volte", complementou Gil.

O cantor já havia marcado presença na estreia da seleção brasileira, quando foi hostilizado por um grupo de apoiadores de Jair Bolsonaro (PL) nos corredores do estádio Lusail Iconic, palco da vitória de 2 a 0 do Brasil sobre a Sérvia.

No último domingo (27), Gilberto Gil se pronunciou nas redes sociais através de um vídeo e agradeceu a solidariedade de amigos e fãs, além de classificar a agressão verbal dos bolsonaristas como 'uma coisa estúpida'.

Família já toma providências

Um dos responsáveis pelas agressões verbais a Gilberto Gil já foi identificado. Trata-se do empresário Ranier Lemache, franqueado da rede de pizzaria Domino's. Ele itiu que esteve com o grupo, mas negou que tenha ofendido o artista.

Apesar de o cantor falar em 'deixar as ofensas para lá', a família de Gilberto Gil informou à reportagem que já tomou providências contra os agressores, embora sem revelar quais.

Conforme contou o UOL Esporte, os torcedores podem pegar até um ano de prisão, de acordo com o artigo 329 do Código Penal do Qatar. A lei de 1971 (com emendas de 2004) estipula também a possibilidade de multa para quem ofender outra pessoa em público.

Procurado pela reportagem, o Comitê Supremo para Entrega e Legado do Qatar informou que não se pronunciará sobre o Tema. A Fifa informou que não se posicionará sobre o tema.

Como foi o ataque de bolsonaristas

O ataque do grupo de bolsonaristas aconteceu em um dos corredores do Lusail Iconic, onde Gilberto Gil caminhava com Flora Gil, sua esposa. Assim que foi reconhecido, o cantor (que nas imagens aparece de azul) ou a ser alvo de ironias e insultos de alguns bolsonaristas.

"Vamo, Bolsonaro. Vamo, Lei Rouanet", iniciaram alguns em tom de ironia enquanto o cantor caminhava em direção às arquibancadas do Lusail.

Pouco depois, os bolsonaristas aram na frente e "chamaram" Gil para se encaminhar às cadeiras. O ex-ministro da Cultura no governo Lula (2003-2008) parou para tirar foto com um fã e não respondeu.

"Vem, vem. Você ajudou o Brasil pra c... Vamo lá. Vai lá. Valeu, Lei Rouanet. Obrigado, filho da p...", finalizaram os brasileiros.

Qual seleção vai ser a campeã da Copa do Mundo do Qatar?

Enquete encerrada

Total de 43743 votos
7,61%
Divulgação/Adidas