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

Resistência, monstro e estalecadas: a jornada de Cezar como líder no BBB 23

BBB 23: Cezar teve altos e baixos em sua liderança - Reprodução/Globoplay
BBB 23: Cezar teve altos e baixos em sua liderança Imagem: Reprodução/Globoplay

Colaboração para Splash, em São Paulo

23/02/2023 22h34Atualizada em 23/02/2023 22h35

A semana de liderança de Cezar no BBB 23 (Globo) foi bastante atípica. Do líder ao Monstro, do Vip à Xepa, de 2.000 estalecas para 0.

Relembre os acontecimentos que marcaram a semana de Black.

15 horas de resistência

BBB 23: Cezar ficou 15 horas na Prova do Líder - Reprodução/Globoplay - Reprodução/Globoplay
BBB 23: Tadeu explica momento que Cezar Black teria 'dormido' na Prova do Líder
Imagem: Reprodução/Globoplay

A liderança de Cezar Black foi conquistada com muito suor. A maior prova de resistência da edição até agora consegrou Black como líder da semana, após aguentar com Aline Wirley mais de 15 horas num carrinho de compras.

No seu VIP, ele colocou Aline, Gustavo, Key, Fred Nicácio e Gabriel Santana.

Castigo do Monstro

BBB 23: Alface colocou o líder Cezar no monstro - Reprodução/Globoplay - Reprodução/Globoplay
Alface colocou o líder Cezar no monstro: "Não me leve a mal / Hoje é carnaval"
Imagem: Reprodução/Globoplay

No dia seguinte à coroação de Cezar, rolou a Prova do Anjo. O grande vencedor foi Ricardo, com quem Black tem uma rivalidade na casa. Na hora de distribuir o Castigo do Monstro, Ricardo escolheu Cristian e Cezar.

Além de sair do VIP, Cezar perdeu 300 das 1.000 estalecas que ganhou pela Prova do Líder. As comidas e bebidas do Quarto do Líder também foram retiradas.

Cear não gostou nada, e ficou chateado porque havia feito compras no VIP para fazer um bolo no seu aniversário, que acontecerá na sexta-feira.

Zero estalecas

BBB 23: Produção zera estalecas de todos os brothers - Reprodução/Globo - Reprodução/Globo
BBB 23: Produção zera estalecas de todos os brothers
Imagem: Reprodução/Globo

Além de tudo isso, na liderança de Black, o Big Boss se mostrou descontente com a falta de cuidado dos brothers com o microfone. Por isso, as estalecas de todos os participantes foram zeradas, incluindo as de Cezar.

Big Fone - ou quase

BBB 23: Guimê atende terceiro Big Fone - Reprodução/Globoplay - Reprodução/Globoplay
BBB 23: Guimê atende terceiro Big Fone
Imagem: Reprodução/Globoplay

No final de seu reinado, o terceiro Big Fone da edição tocou. Existem dois telefones no jardim: os dois tocam, o primeiro a atender bloqueia o segundo.

Cezar estava na piscina quando o Big Fone tocou, e correu para atender. Porém, MC Guimê atendeu primeiro. O cantor achou que não estava ouvindo, mas foi ele quem pegou o telefone primeiro, bloqueando o que foi atendido por Cezar.

Guimê conquistou o Poder Supremo, e pode trocar um participante do Paredão.

ENQUETE UOL BBB 23: Você gostou que MC Guimê atendeu o Big Fone?

Enquete encerrada

Total de 5730 votos
63,60%
Reprodução/Globo