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

Série B - 2021

CRB troca de técnico após perder o Campeonato Alagoano e anuncia Allan Aal

Allan Aal, novo técnico do CRB, já ou pelo Paraná  - Gabriel Machado/AGIF
Allan Aal, novo técnico do CRB, já ou pelo Paraná Imagem: Gabriel Machado/AGIF

Bruno Fernandes e Josué Seixas

Colaboração para o UOL, em Maceió

24/05/2021 11h47

Depois de perder o Campeonato Alagoano nos pênaltis para o rival CSA, o CRB decidiu trocar de treinador. Na manhã de hoje (24), o clube anunciou a demissão de Roberto Fernandes e a contratação de Allan Aal, que subiu à elite do Campeonato Brasileiro com o Cuiabá.

A troca aconteceu às vésperas da estreia do CRB na Série B. O time começa sua caminhada na competição neste sábado (29), contra o Remo. Junto com Roberto Fernandes, deixaram o clube o auxiliar Fernando Alves e o preparador Rogério Juidecce.

De acordo com o clube, Aal desembarca em Maceió ainda hoje e já comanda o primeiro treino com o grupo amanhã. Depois do o com o Cuiabá, o técnico assumiu o Guarani e foi demitido após a eliminação nas quartas de final do Campeonato Paulista.

Sob o comando de Roberto Fernandes nesta temporada, o CRB havia sido eliminado da Copa do Nordeste ao ser goleado pelo Bahia nas quartas de final. Ele chegou ao clube em dezembro do ano ado, na reta final da Série B.

No começo deste mês, o técnico ou cerca de uma semana internado com covid-19.

O comunicado em que o CRB anuncia o desligamento de Roberto Fernandes

Na manhã desta segunda-feira (24), a diretoria do Clube de Regatas Brasil decidiu pelo encerramento do contrato com o técnico Roberto Fernandes e da comissão técnica, o auxiliar Fernando Alves e também do preparador Rogério Juidecce.

Fernandes esteve à frente do comando do clube desde dezembro de 2020.

O CRB agradece a dedicação de Roberto Fernandes e sua comissão durante todo esse tempo de trabalho e deseja sucesso na carreira.