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

Mundial de Clubes - 2019

Conheça o filme que inspirou apelido do trio de ataque do Liverpool

Roberto Firmino, Mohamed Salah e Sadio Mané durante ensaio para a final da Liga dos Campeões deste ano - Michael Regan - UEFA/UEFA via Getty Images
Roberto Firmino, Mohamed Salah e Sadio Mané durante ensaio para a final da Liga dos Campeões deste ano Imagem: Michael Regan - UEFA/UEFA via Getty Images

Bruno Grossi

Do UOL, em São Paulo

18/12/2019 04h00

Resumo da notícia

  • Steve Hunter, narrador do canal oficial do Liverpool, criou apelido curioso
  • Ele tem chamado o ataque Salah, Firmino e Mané de "Three Amigos"
  • Esse apelido é uma referência a um filme de comédia de 1986
  • O comediante Steve Martin é um dos protagonistas desse "pastelão"

O entrosamento mostrado em campo por Mohamed Salah, Roberto Firmino e Sadio Mané fez com que o narrador da TV oficial do Liverpool resolvesse criar um apelido especial para eles. A empolgação por um dos gols da vitória sobre o Watford no último fim de semana, a última partida dos titulares antes da viagem para o Mundial de Clubes no Qatar, fez com que o trio fosse batizado de "Three Amigos".

Quando a LFCTV mostrava o replay do primeiro gol marcado por Salah, Hunter fica encantado com o contra-ataque fulminante que começa com um e de Firmino, que estava de costas. O brasileiro acionou Mané, que logo acelerou a jogada para Salah apostar corrida com um zagueiro pela esquerda, cortar para o meio e bater, de direita, no ângulo: "The Three Amigos come by".

A expressão pode ser interpretada como um "Os Três Amigos atacam novamente" e faz referência a um clássico do cinema pastelão lançado há 33 anos. Steve Martin, Chevy Chase e Martin Short eram os protagonistas da comédia "Three Amigos". Os três eram atores famosos por uma série de Velho Oeste homônima ao filme, mas acabaram demitidos por pedirem um aumento salarial.

Cartaz do filme "Three amigos", que gerou apelido para o ataque do Liverpool formado por Salah, Mané e Roberto Firmino - Reprodução - Reprodução
Imagem: Reprodução

Imediatamente após a demissão do estúdio de TV, eles recebem um convite para viajar uma cidade chamada Santo Poco, no México. Ao chegarem no local, encontram uma região que parece ainda presa aos tempos do bangue-bangue e descobrem que a população fez o convite imaginando que os três eram, de fato, justiceiros.

Assim, como Salah, Firmino e Mané agora enfrentam o Monterrey no Mundial, os protagonistas do filme precisam encarar o vilão mexicano "El Guapo". O problema é que eles demoram para entender que tudo aquilo é real, e não uma encenação artística do povoado.

Com piadas, números de dança e músicas, que chegaram a se popularizar nos Estados Unidos, eles desafiam os inimigos e acabam salvando Santo Poco. Uma missão que parece mais desafiadora do que a apresentada ao trio de heróis do Liverpool na tarde de hoje (18), quando o Flamengo estará tranquilo na plateia à espera da final.