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

Linn questiona Natália ser alvo novamente e argumenta: 'Isso é tiro no pé'

BBB 22: Linn da Quebrada questiona por que Natália segue sendo o alvo da casa - Reprodução/Globoplay
BBB 22: Linn da Quebrada questiona por que Natália segue sendo o alvo da casa Imagem: Reprodução/Globoplay

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

14/02/2022 13h38

Linn da Quebrada, sister do "BBB 22" (TV Globo), comentou os votos em Natália, que está enfrentando mais um paredão. Em um papo sobre jogo com Bárbara, Jessilane e Larissa, Lina questionou a modelo ser alvo por mais uma semana:

Eu acho estranho a casa ficar indicando toda vez a Natália. Inclusive, estrategicamente, a gente viu em outros programas o quanto isso é, na maioria das vezes, um tiro no pé. Linn da Quebrada

"Eu votei na Natália uma vez, que foi na primeira semana, porque eu realmente tive uma coisa com ela, uma tretinha", comentou Bárbara. "Bomba", brincou Jessilane.

"É, ainda mais na prmeira semana que a gente quase não tem motivo", seguiu a gaúcha.

"É, mais eu digo da insistência às vezes, de ser a única opção. Isso que me faz repensar mais, tipo assim, se a gente com 17 pessoas, as nossas únicas opções permanecem as mesmas? Acho que é um movimento da gente ter que se repensar também, né", reforçou Lina.

"Toda vez eu troquei, essa foi a única vez que eu repeti meu voto, que foi no Lucas por causa do aconteceu ali, e, porque eu sabia que a Nat teria vários votos. Nem se eu não soubesse, eu não iria nela", afirmou Bárbara.

Jessilane, então, analisou a formação do paredão:

De toda forma, eu já acho que teve uma movimentação maior porque sete pessoas foram votadas. Significa que não teve concentração de votos, além dos votos que foi considerado na Natália. A não ser que, tipo, foi a Natália, mais uma pessoa e o resto espalhado, aí sim ainda está tendo uma concentração pesada. Ou seja, se tinham 17 votos, seis indo na Natália, sobram 11 votos para distribuir por seis pessoas. Jessilane

Quem você quer eliminar do 'BBB 22'?

Enquete encerrada

Total de 243944 votos
72,54%
Reprodução/Instagram @bbb