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

Rodrigo Mattos

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.

Decisão sobre Vasco impacta dívidas de SAFs na CBF e resolve transfer ban

Torcida do Vasco celebra aprovação da venda da SAF para a 777 Partners - Bruno Braz/UOL Esporte
Torcida do Vasco celebra aprovação da venda da SAF para a 777 Partners Imagem: Bruno Braz/UOL Esporte

Colunista do UOL

09/03/2023 04h00

Receba os novos posts desta coluna no seu e-mail

Email inválido

Uma decisão na Justiça do Rio em processo sobre o Vasco terá impacto nas dívidas das SAFs no tribunal da CBF. São débitos esportivos cobrados por jogadores ou outros times. Pela decisão, as SAFs terão de pagar essas pendências de forma parcelada à parte de outros credores na Justiça.

Como consequência, essa medida ajudará os clubes a resolver as punições por transfer ban - proibição de contratar e registrar jogadores. Isso, obviamente, se o entendimento for consolidado nos tribunais. Restará resolver as dívidas da Fifa que também podem gerar transfer ban - a entidade internacional não costuma aceitar parcelamentos.

Antes mesmo de ser SAF, o Vasco aderiu ao RCE (Regime Centralizado de Execução) para juntar todas as suas dívidas trabalhistas e cíveis. Havia a dúvida, assim como outras SAFs, sobre os débitos esportivos. O clube chegou a sofrer um transfer ban porque não podia pagar a dívida porque isso iria ferir o RCE ao priorizar determinados credores.

O Vasco tem 36 cobranças no CNRD (tribunal esportivo da CBF) já com decisão definitiva, isto é, débitos do clube. Na CBF, a SAF apresentou-se como sucessora das pendências do clube. Até porque a legislação das SAFs obriga que as novas empresas sejam responsáveis pelos compromissos esportivos do clube.

Em janeiro, o Vasco pediu na Justiça comum do Rio que os seus débitos no tribunal da CBF fossem pagos por meio de um parcelamento separado. Seu objetivo é que fosse feito de forma paralela com regras similares às do RCE.

No início de março, o juiz Rubens Vieira Junior, do 2o Núcleo de Justiça 4.0, concedeu o parcelamento para o Vasco. "Por normas internas da CNRD os débitos lá quitados serão objeto de parcelametno no mesmo prazo de 6 anos que o Plano de Pagamento apresentado no RCE pelo CLUB DE REGATAS VASCO DA GAMA, fls. 3685/3686.?

Sua decisão repetiu o que já tinha ocorrido na Justiça do Trabalho. Assim, todas as dívidas vascaínas no tribunal esportivo serão pagas em um sistema à parte. O juiz completou: "com o prosseguimento dos procedimentos e do plano de quitação paralelo perante os órgãos da CBF e sua CNRD, inclusive diante da decisão trazida pela CNRD.?

Perguntado, o Vasco SAF não informou o valor dos débitos, nem os prazos de pagamento para os débitos.