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

Danilo Lavieri

REPORTAGEM

Texto que relata acontecimentos, baseado em fatos e dados observados ou verificados diretamente pelo jornalista ou obtidos pelo o a fontes jornalísticas reconhecidas e confiáveis.

Queda de rendimento da defesa preocupa Palmeiras e faz Abel analisar trocas

Abel Ferreira e Renan conversam durante treino do Palmeiras - Cesar Greco/Palmeiras
Abel Ferreira e Renan conversam durante treino do Palmeiras Imagem: Cesar Greco/Palmeiras

Colunista do UOL

14/09/2021 12h15

Receba os novos posts desta coluna no seu e-mail

Email inválido

Depois da derrota para o Flamengo, o Palmeiras voltou a ter um clima de apreensão tanto internamente, com seus diretores e membros da comissão, quanto externamente, com a torcida. O que mais chama a atenção dos que trabalham no dia a dia do clube foi a queda de rendimento da defesa, até então base de um time extremamente competitivo.

A última vez que o Alviverde conseguiu não ser vazado no Brasileirão foi em junho, no 0 a 0 com o São Paulo. O detalhe é que nesse jogo o juiz ainda anulou um tento do rival que é lembrado até hoje por parte da torcida são-paulina como erro de arbitragem. De lá para cá, foram 11 gols sofridos em cinco jogos.

Foram três sofridos contra Flamengo e Fortaleza, dois contra Cuiabá e Atlético-MG e um contra o Athletico, a única vitória dessa sequência.

O estilo de jogo preferido de Abel Ferreira para o elenco que tem em mãos é de um jogo com uma marcação forte, roubadas de bola em todo o campo e uma transição rápida para o ataque. Quando sai atrás no placar, o time tem dificuldades de criar por conta da retração do adversário e, normalmente, não consegue a virada.

Por conta dessa queda, a semana será de testes para o técnico até o jogo contra a Chapecoense, no fim de semana. O objetivo, claro, é ganhar da equipe catarinense, mas o principal é ver evolução do time já de olho no confronto pela semifinal da Libertadores contra o Atlético-MG, no dia 21 de setembro.

Nos treinos, ele testará mudanças como Gabriel Menino escalado pela direita, Renan e Kusevic fazendo dupla com Gustavo Gómez e até mesmo uma eventual volta de Felipe Melo ao setor. É bastante improvável que Jorge tenha a sua estreia promovida logo no mata-mata. As mudanças, no entanto, não são uma certeza. Abel tem receio de "colocar Luan na fogueira", como já aconteceu em outros momentos da temporada.

Mais à frente, Danilo ainda tem uma excelente avaliação no setor de marcação, mas Zé Rafael está sendo observado de perto. Não se descarta a ideia de atuar com dois volantes mais marcadores e apenas um meia mais solto.

Pensando no Atlético-MG, o principal objetivo do treinador vai ser armar uma equipe que segure a criação do adversário com Nacho Fernández e, claro, não dê liberdade para Hulk, com um segundo homem na marcação do atacante sempre em que ele estiver no terço final de campo.

Siga também as opiniões de Danilo Lavieri no Twitter e no Instagram