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

Neto critica Vuaden após SPFC x Santos: 'Falta de vergonha na cara'

Neto, no Os Donos da Bola, da TV Band - Reprodução/TV Band
Neto, no Os Donos da Bola, da TV Band Imagem: Reprodução/TV Band

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

03/05/2022 13h41

Apresentador e comentarista da TV Band, Neto criticou Leandro Vuaden, que apitou a vitória do São Paulo por 2 a 1 sobre o Santos, ontem (2), pelo Campeonato Brasileiro. Na opinião do ídolo corintiano, o árbitro errou ao não marcar pênalti para os santistas em um lance em que Madson caiu na área após disputa com Pablo Maia.

Neto disse que "faltou vergonha na cara" para Leandro Vuaden, opinando que ele deveria ter consultado o VAR. O apresentador, no entanto, disse que a arbitragem foi bem no outro lance polêmico da partida, em que o Santos reclamou de falta e lateral na origem da jogada que acabou com um pênalti para a equipe tricolor.

"Ontem, o Santos foi atropelado pela falta de vergonha na cara do seu Vuaden. Como árbitro. Porque o senhor não foi nem um pouco inteligente na hora do pênalti sobre o Madson. Vai lá, olha. O VAR ajuda a não errar. Só time grande que ganha. Vai lá, olha,: 'Foi pênalti, não vi, o Pablo MAia deu um ippon no Madson'", declarou Neto.

"Em relação ao lance que o mundo está discutindo, para mim, a bola saiu e não foi falta do Alisson em cima do Marcos Leonardo. Quem errou foi o quarto árbitro, que está com a plaqueta. Usa a plaqueta para avisar quem está entrando, saindo. Não fica apontando, seu Zé Ruela, seu Oreiudo. O problema é o bandeira", completou o apresentador.

Situação no Brasileirão

Com a vitória, o São Paulo ganhou cinco posições no Brasileirão e agora é o quinto colocado, com sete pontos após quatro jogos. O Santos vem logo atrás, em sexto, com a mesma pontuação do rival.