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

Globo suspende pagamentos de estaduais e clubes cogitam apressar volta

Cássio ergue a taça do título do Campeonato Paulista conquistado pelo Corinthians em 2018 - Ale Cabral/AGIF
Cássio ergue a taça do título do Campeonato Paulista conquistado pelo Corinthians em 2018 Imagem: Ale Cabral/AGIF

Gabriel Vaquer e Pedro Lopes

Colaboração para o UOL, em Aracaju, e do UOL, em São Paulo

31/03/2020 16h08

Em meio à pandemia do coronavírus, Globo decidiu suspender os pagamentos a clubes de direitos de transmissão dos campeonatos estaduais a partir de abril. Ao longo dos últimos dias, clubes de Bahia e São Paulo têm sido comunicados da decisão. Os campeonatos do Rio Grande do Sul e de Minas Gerais são exceções, já que os valores já tinham sido pagos. O Carioca também terá pagamentos suspensos.

Pessoas ligadas à emissora avaliam que não é viável, no momento, seguir pagando pela transmissão de partidas que não estão ocorrendo e nem têm data para acontecer. Os pagamentos ficarão suspensos até que haja, ao menos, uma previsão de retomada dos jogos. Quando isso ocorrer, o diálogo será retomado com o estabelecimento de um plano de pagamento.

A medida suspende uma das últimas fontes de receita que ainda estavam garantidas para os clubes, e já começa a gerar um movimento de apressar a volta aos gramados, mesmo que de portões fechados. Em contato com o UOL Esporte, representantes de três clubes paulistas confirmam que já existe disposição, principalmente entre clubes de menor expressão, em debater um retorno controlado aos gramados.

Perdendo parte de suas receitas, os clubes do Brasil vêm debatendo medidas de corte de custos. Com os jogadores, há negociações individuais de redução salarial depois que uma negociação coletiva terminou sem acordo. Os clubes também aguardam novas providências do governo, e vêm mantendo reuniões quase diárias para tratar da sua sobrevivência financeira.

Os estaduais não têm data para retorno, e ainda não há qualquer plano concreto para o calendário brasileiro. Em contato com as federações estaduais, a CBF tem prometido que irá priorizar o fim dos estaduais, e pode reduzir o Brasileirão caso não haja alternativa.