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

Com fim de jogo tenso, Palmeiras bate São Paulo e vai à final da Copinha

Jogadores do Palmeiras comemoram gol contra o São Paulo pela Copinha - Diogo Reis/AGIF
Jogadores do Palmeiras comemoram gol contra o São Paulo pela Copinha Imagem: Diogo Reis/AGIF

Colaboração para o UOL, em São Paulo

22/01/2022 21h04Atualizada em 23/01/2022 09h33

Com um gol de Giovani aos 4 do primeiro tempo, o Palmeiras bateu o São Paulo por 1 a 0 na Arena Barueri, hoje (22). A vitória garantiu o Verdão em sua terceira final de Copinha, vivo na busca pela conquista inédita.

O confronto teve dois tempos bem distintos. Enquanto o Alviverde conseguiu pressionar até o intervalo, o Tricolor conseguiu reagir e pressionou demais na segunda etapa, mas sem conseguir buscar o empate.

O Santos será o adversário da grande final, que acontece nesta terça (25).

Confusão no fim

Já aos 50 da segunda etapa, alguns torcedores do São Paulo invadiram o gramado e tentaram agredir atletas do Palmeiras que estavam no campo de defesa. A polícia agiu rápido e, com a ajuda dos próprios jogadores do São Paulo, conseguiu controlar a torcida.

Após o tumulto, foi encontrada uma faca no gramado e o árbitro levou o item para o quarto árbitro e o delegado da partida. O clima tenso fez com que alguns jogadores não quisessem seguir com o confronto.

Depois de cinco minutos de paralisação, o jogo reiniciou para os dois minutos que ainda faltavam de acréscimos.

Quem foi bem: Giovani

Grande articulador do Palmeiras na partida, o camisa 7 teve uma grande noite, sendo o responsável por criar as melhores chances para seus companheiros no Verdão. Por outro lado, também soube resolver sozinho: desarmando Pablo e batendo para abrir o placar na primeira etapa. Cansado, deixou o campo aos 27 do segundo tempo.

Quem foi mal: Pablo

Muito nervoso, o capitão são-paulino escapou de ser expulso ainda na primeira etapa. Além das reclamações excessivas com a arbitragem, que optou por levar na conversa, ainda deu uma entrada dura em Fabinho no final da primeira etapa, quando recebeu o amarelo. Por fim, falhou feio no gol que abriu o placar, carregando a bola para trás e sendo desarmado por Giovani. Com dores na coxa esquerda, foi substituído aos 31 da segunda etapa.

Endrick sai do banco

Nome que mais chama a atenção da torcida palmeirense, o atacante Endrick começou, mais uma vez, no banco de reservas. Aos 17 do segundo tempo, foi chamado para entrar e teve uma participação discreta. Com o Palestra mais recuado, o camisa 9 pouco fez no ataque.

Atuação do São Paulo: Melhora depois do intervalo

O Tricolor não fez um grande primeiro tempo. Apesar de ameaçar com Vitinho, que parou na trave aos 12 minutos, e Maioli, com um chute forte defendido por Mateus aos 14, o time do Morumbi foi controlado em campo.

Já no segundo tempo, a equipe cresceu ao se lançar ao ataque. O poderio ofensivo cresceu demais e foram 5 grandes oportunidades de empatar com menos de 15 minutos de partida. No entanto, o time parou na defesa alviverde e não conseguiu o empate.

Aos 48 do segundo tempo, Talles aproveitou a bola rebatida e, sozinho, bateu de primeira. Na grande chance da equipe, a bola caprichosamente beliscou a trave e foi para fora.

Atuação do Palmeiras: Blitz funciona

A bola começou a rolar na Arena Barueri e o Palestra se lançou ao ataque. O São Paulo respondeu com um contra-ataque puxado por Caio Matheus, que serviu Vitinho e viu o companheiro acertar a trave aos 11 minutos.

Depois disso, o Palmeiras ou a atuar mais recuado, mas seguiu ameaçando o gol defendido por Young. Aos 34 do primeiro tempo, Gabriel Silva teve a chance de cabecear para o gol, porém mandou em cima do arqueiro.

Cronologia do jogo

Com 4 minutos, Pablo correu par atrás, perdeu a bola para Giovani, que avançou e acertou a rede para abrir o placar para o Palmeiras. O time alviverde continuou melhor na primeira etapa, mesmo recuando no final e tentando explorar as jogadas de contra-ataque.

No segundo tempo, o Tricolor voltou com tudo para buscar o empate e pressionou demais o adversário. O técnico Alex gastou todas alterações, respondendo as trocas do Palmeiras, e conseguiu manter o time no campo ofensivo. Mesmo assim, o setor de criação não foi muito efetivo para proporcionar grandes chances de deixar tudo igual.

Torcida demora para entrar

Pela primeira vez nesta Copinha, a Federação Paulista de Futebol (FPF) optou por cobrar ingressos da torcida são-paulina, única que teve o à Arena Barueri. Mesmo assim, a fila para entrar seguia enorme durante o primeiro tempo e, apenas no intervalo, o estádio ficou bem ocupado. Oficialmente, o duelo teve 11.781 pagantes para uma renda de R$ 292.320,00.

FICHA TÉCNICA

SÃO PAULO 0 x 1 PALMEIRAS

Data: sábado, 22/01

Local: Arena Barueri, em Barueri (SP)

Hora: 19h (de Brasília)

Árbitro: Matheus Delgado Candançan
Assistentes: Daniel Luis Marques e José Lucas Cândido de Souza
VAR: Márcio Henrique de Gois.

Gols: Giovani, aos 4' do primeiro tempo, para o Palmeiras

Cartões amarelos: Lucas Beraldo, Pablo, Nathan (São Paulo); Lucas Sena (Palmeiras)

São Paulo: Young; Nathan, Lucas Beraldo, Guilherme (Patryck) e Petri (Cauê); Pablo (Negrucci), Léo Silva (João Adriano), Vitinho e Caio; Maioli (Talles Wander) e Luizinho. Técnico: Alex.

Palmeiras: Mateus; Garcia, Naves, Lucas Freitas e Vanderlan (Kevin); Fabinho, Pedro Bicalho (Ian) e Jhonatan (Miguel); Gabriel Silva (Endrick), Giovani (Lucas Sena) e Vitinho. Técnico: Paulo Victor.