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

Marcel Rizzo

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.

Mesmo com Guto demitido, Brasileiro-21 tem baixo número de troca de técnico

Guto Ferreira foi demitido do Ceará com o time na oitava colocação da Série A - Gil Gomes/AGIF
Guto Ferreira foi demitido do Ceará com o time na oitava colocação da Série A Imagem: Gil Gomes/AGIF

Colunista do UOL

30/08/2021 12h30

A demissão de Guto Ferreira, anunciada na noite de domingo (29) pela diretoria do Ceará, foi a 10ª troca de treinador entre os 20 times que participam da Série A do Brasileiro. É o segundo número mais baixo após 18 rodadas desde 2006, quando o torneio ou a ter 38 rodadas com 20 participantes.

A CBF incluiu no regulamento para esta temporada um limite de troca de treinadores: uma equipe só pode ter dois técnicos durante a competição, ou seja, só pode demitir uma vez. Caso o profissional se demita não é contabilizado, mas há uma brecha: o chamado "comum acordo", quando o clube anuncia que a decisão foi supostamente tomada em conjunto. Nesse caso a alteração também não entra na conta.

Não foi o caso de Guto Ferreira, já que o Ceará anunciou que o demitiu apesar de o time estar na oitava colocação do Brasileirão. A coluna apurou que havia um desgaste do treinador com alguns jogadores já há alguns meses — em junho, o presidente Robinson de Castro chegou a gravar um vídeo em que conversava com Guto e com o meia Vina, negando atritos.

Após 18 rodadas, quase todo o primeiro turno, somente em 2012 havia tido tão poucas trocas de treinadores, com nove — em 2019 houve as mesmas dez. Mas dois anos atrás ocorreu disparada nas mudanças do meio para o fim da competição, o que é comum já que muitos clubes optam por "sangue novo" na reta final quando estão lutando contra o rebaixamento ou por vagas nas competições da Conmebol — Libertadores e Sul-Americana.

As trocas computadas não são apenas por demissões e na conta entra quando o técnico decide sair, como Lisca que pediu demissão do América-MG para assumir o Vasco na Série B. A maioria continua sendo por decisão do clube ou o comum acordo que pode driblar a regra da CBF.

A confederação brasileira tentava desde 2018 regulamentar a substituição de treinadores no Brasileirão, mas os clubes rejeitavam. Os cartolas alegavam que é uma ingerência na istração das equipes e diferente, por exemplo, de limitar quantidade de jogadores ou adotar um prazo para esses atletas serem inscritos. Isso está na regra, mas engloba mais de 30 profissionais por elenco, e não apenas um como é o caso do treinador.

Para 2021, porém, houve o consentimento da cartolagem para inclusão da limitação de uma troca, desde que apenas em caso de demissões, o que abre brecha para o tal "comum acordo".

MUDANÇAS DE TÉCNICOS NO BRASILEIRO ATÉ A RODADA 18 (A PARTIR DE 2006, PONTOS CORRIDOS COM 20 TIMES E 38 RODADAS)
2021 - 10
2020 - 15 (27 no total)
2019 - 10 (26 no total)
2018 - 19 (29 no total)
2017 - 14 (23 no total)
2016 - 13 (29 no total)
2015 - 15 (32 no total)
2014 - 18 (23 no total)
2013 - 15 (24 no total)
2012 - 9 (19 no total)
2011 - 12 (21 no total)
2010 - 18 (32 no total)
2009 - 17 (22 no total)
2008 - 18 (27 no total)
2007 - 16 (32 no total)
2006 - 15 (33 no total)