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

Carioca - 2022

TJD abre inquérito para apurar canto homofóbico de rubro-negros no Fla-Flu

Arrascaeta é marcado por Nino no clássico Flamengo x Fluminense - Gilvan de Souza/Flamengo
Arrascaeta é marcado por Nino no clássico Flamengo x Fluminense Imagem: Gilvan de Souza/Flamengo

Do UOL, no Rio de Janeiro (RJ)

04/03/2022 11h34

O Tribunal de Justiça Desportiva do Rio de Janeiro (TJD-RJ) abriu inquérito para apurar fatos referentes a cantos homofóbicos praticados pela torcida do Flamengo no clássico com o Fluminense, no último dia 6, pelo Campeonato Carioca.

Um vídeo que circula na internet mostram rubro-negros na arquibancada no Nilton Santos cantando "que palhaçada, esse pó de arroz, tricolor v..., a maquiagem, dá o c.. depois".

"Considerando os fatos noticiados através do e-mail encaminhado ao Tribunal de Justiça Desportiva do Futebol do Estado do Rio de Janeiro, que seguem em anexo, sobre "cantos homofóbicos" praticados pela torcida do Flamengo, em tese, ocorridos em jogo "Flamengo x Fluminense", do campeonato carioca, determino, na forma do art. 81 CBJD, a instauração de inquérito", diz documento assinado por Renata Mansur Bacelar, presidente do órgão.

O artigo 81 Código Brasileiro de Justiça Desportiva (CBJD) aponta que "o inquérito tem por fim apurar a existência de infração disciplinar e determinar a sua autoria, para subsequente instauração da ação cabível, podendo ser determinado de ofício pelo Presidente do Tribunal competente (STJD ou TJD), ou a requerimento da Procuradoria ou da parte interessada".

Denúncia de injúria racial contra Gabigol

Gabigol, atacante do Flamengo, aponta ter sido chamado de "macaco" por torcedores do Fluminense - Reprodução Twitter - Reprodução Twitter
Imagem: Reprodução Twitter

Um outro fato desta mesma partida está sendo investigado pelo TJD-RJ. Após o clássico, Gabigol, atacante do Flamengo, divulgou vídeo em uma rede social em que aponta ter sido chamado de "macaco" ao sair do gramado do estádio Nilton Santos.

À época, a pedido do Fluminense, o TJD-RJ abriu inquérito para apurar a denúncia, e ainda está em fase de investigação. Ontem (3), André Valentim, procurador do órgão, entrou com um pedido de medida cautelar para que a homologação do possível título e a entrega do troféu não aconteçam neste sábado, em Volta Redonda, em caso de vitória do Fluminense sobre o Resende.

Com 24 pontos, o Tricolor depende apenas de um triunfo para não ser mais alcançado neste primeiro turno do Campeonato Carioca. O pedido ainda precisa ser aceito por Renata Mansur.

Segundo o procurador, há a possibilidade de o clube das Laranjeiras perder três pontos em julgamento sob o artigo 243-G, que fala em "praticar ato discriminatório, desdenhoso ou ultrajante, relacionado a preconceito em razão de origem étnica, raça, sexo, cor, idade, condição de pessoa idosa ou portadora de deficiência".

Dentre as possíveis pena, cita-se que "caso a infração prevista neste artigo seja praticada simultaneamente por considerável número de pessoas vinculadas a uma mesma entidade de prática desportiva, esta também será punida com a perda do número de pontos atribuídos a uma vitória no regulamento da competição".