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

Fluminense

Odair evita culpar Muriel por eliminação do Flu: "Responsabilidade é minha"

Odair Hellmann chamou para si responsabilidade por eliminação do Fluminense na Copa do Brasil - Lucas Mercon/Fluminense FC
Odair Hellmann chamou para si responsabilidade por eliminação do Fluminense na Copa do Brasil Imagem: Lucas Mercon/Fluminense FC

Caio Blois

Do UOL, no Rio de Janeiro

24/09/2020 23h11

O Fluminense acumulou mais uma eliminação vexatória em 2020 ao perder por 3 a 1 para o Atlético-GO e cair da Copa do Brasil na quarta fase. Já são seis anos sem eliminar uma equipe da Série A pela competição. No jogo, o goleiro Muriel teve duas falhas clamorosas, mas o técnico Odair Hellmann evitou culpá-lo e chamou para si a responsabilidade da derrota.

"Não responsabilizo jogador nem grupo. A responsabilidade é minha como treinador pelas decisões. Falhas no futebol acontecem na linha, no gol, futebol é um esporte de erros. Eu como comandante estou atento a todas as situações e tenho como característica ar confiança para os jogadores desempenharem o seu melhor", declarou Odair Hellmann em sua entrevista coletiva após o jogo.

Ainda de acordo com o treinador, o mérito foi do Dragão, que conseguiu traduzir em gols as chances que teve em um jogo equilibrado.

"Criamos oportunidades mas principalmente no segundo tempo, duas situações mais perigosas. O primeiro tempo foi mais truncado, tomamos um gol cedo, o que gerou confiança ao adversário. Retomamos, tentamos colocar a bola no chão e tivemos mais dificuldade que o normal. A produção foi pequena. Criamos, mas não conseguimos ser efetivos. Os jogadores tentaram, mas a equipe adversária foi feliz em conseguir os gols, concretizar as oportunidades em um jogo de poucas chances, então não responsabilizo o grupo ou nenhum jogador individualmente".

O técnico não comparou a eliminação na Copa do Brasil com a queda precoce na Copa Sul-Americana, ainda em fevereiro, justamente por serem momentos muito diferentes da temporada. Questionado se seu trabalho estava em risco, Odair se resumiu a dizer que, no Brasil, o emprego de um treinador "está sempre em avaliação do primeiro ao último dia".

"O trabalho no futebol brasileiro está sempre em avaliação: do primeiro ao último dia. Na Sul-Americana, não tínhamos nem possibilidade de inscrever alguns jogadores, outros lesionados. Hoje a eliminação nos dói muito. Fizemos um jogo para buscar a diferença no Maracanã, porque sabíamos que aqui seria difícil. É doloroso", resumiu.

Os erros individuais, entretanto, foram citados por Odair como "detalhes". Hellmann elogiou a eficiência do Atlético-GO na partida e espera que o elenco tire as falhas como lições para o Campeonato Brasileiro.

"Oferecemos os detalhes para que o adversário aproveitasse, eles foram eficientes e nas chances que tivemos, não conseguimos concluir. Agora é visualizar o Brasileirão para que a gente retome, faça um ótimo campeonato mas que tenhamos que visualizar, pegar as lições desses erros e não cometê-los mais, seguindo mais forte adiante", opinou.

Com as perdas no elenco, Odair Hellmann espera por reforços, mas trabalha o tema internamente. Agora só com o Brasileirão pela frente até fevereiro de 2021, o Fluminense se prepara para enfrentar o Coritiba, na segunda-feira (28), às 20h. No 10º lugar com 14 pontos, o Tricolor venceu apenas uma das últimas seis partidas na competição por pontos corridos.

Confira a íntegra da coletiva de Odair Hellmann:

Fluminense