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

Mauro Cezar Pereira

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.

Campeonato Carioca deve, enfim, reunir Fla, Flu, Botafogo e Vasco no final

Cano fez o gol do Flu: 1 a 0 na Portuguesa - Mailson Santana/Fluminense FC
Cano fez o gol do Flu: 1 a 0 na Portuguesa Imagem: Mailson Santana/Fluminense FC

14/02/2022 04h00

Receba os novos posts desta coluna no seu e-mail

Email inválido

No ano ado o Vasco ficou em quinto, o Botafogo em sétimo lugar. Flamengo, com a melhor campanha, e Fluminense, que veio em seguida na classificação, jogaram, respectivamente, contra Volta Redonda e Portuguesa nas semifinais do Campeonato Carioca.

No ano anterior os rubro-negros fizeram o duelo semifinal contra o mesmo adversário de 2021, enquanto os tricolores derrotavam os botafoguenses na mesma fase. Os vascaínos ficaram pelo caminho e não alcançaram a fase decisiva, com péssima campanha.

Veja mais análises de Mauro Cezar no Posse de Bola:

Em 2019 o Flamengo ou pelo Fluminense na semi, enquanto o Vasco eliminava o Bangu. O Botafogo foi o grande que não avançou até a etapa decisiva na ocasião. Os três títulos mais recentes foram conquistados pelos flamenguistas, que buscam um inédito tetra.

A última vez em que os quatro grandes se enfrentaram nas semifinais do Campeonato do Rio de Janeiro foi em 2018, quando os alvinegros surpreenderam os rubro-negros e os vascaínos eliminaram os tricolores. Na final, título para o clube da estrela solitária, nos pênaltis.

Agora, com o Fluminense em primeiro (15 pontos), sendo seguido pelos três principais rivais, todos com 13; a chance de mata-mata envolvendo o quarteto é grande. Até porque atrás deles aparecem Audax, Madureira e Portuguesa, todos seis pontos atrás e a oito do líder.

Pelo menos as finais prometem ser mais interessantes nesse modorrento certame que precisa ser revisto. Como todos os Estaduais.

Siga Mauro Cezar no Twitter

Siga Mauro Cezar no Instagram

Siga Mauro Cezar no Facebook

Inscreva-se no Canal Mauro Cezar no YouTube