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

Rico rebate após alfinetada de MC Gui: 'Pensava que era cantor, não ator'

A Fazenda 2021: Rico Melquiades e MC Gui se alfinetam na formação da nona roça - Reprodução/PlayPlus
A Fazenda 2021: Rico Melquiades e MC Gui se alfinetam na formação da nona roça Imagem: Reprodução/PlayPlus

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

17/11/2021 00h01Atualizada em 17/11/2021 01h01

Rico Melquiades e MC Gui trocaram alfinetadas na formação da nona roça de "A Fazenda 13" (RecordTV). O funkeiro começou rebatendo a justificativa de voto do humorista na formação da oitava roça, na última semana, afirmando que foi uma tentativa de manchar sua imagem com o público:

Terça-feira ada, ele estava fazendo uma brincadeira com uma pessoa e ele acabou trazendo isso para cá para me desestabilizar ou fazer com que o público entendesse que eu tivesse algo para sabonetar. MC Gui

Depois, o MC Gui criticou a postura de Rico em uma discussão com Valentina durante a eliminação da última quinta-feira, relatando ter se desentendido com o peão após pedir para ele respeitar o momento.

"Ele começou a me atacar de uma forma muito agressiva como outras vezes também. Já fazia muito tempo que a gente não se desentendia desse forma e ele traz sempre umas coisas minhas de fora", disse o funkeiro.

Questionado por Galisteu, Rico então rebateu:

Ô, Dri, eu vou ser breve, eu pensava que ele cantor e não ator, né? Menina, ele soube interpretar bem, viu? Pediu por favor... Rico Melquiades

"Eu, né? Você que fica chorando aí para Mileide: 'Amiga, não se afasta de mim', depois que você humilhou ela", debochou MC Gui. "Lógico, eu choro mesmo, eu tenho sentimento", disparou Rico, que reclamou de ser cortado pelo funkeiro.

"Vem cá, eu esperei você falar e fiquei calado, você pode deixar eu falar?", disse ele. "Eu vou discutir, você não gosta de me cortar quando eu estou falando?", rebateu o MC Gui.

"Então não tenho mais nada para falar, Dri", afirmou Rico. "Obrigado, prefiro nem ouvir sua voz mais, não aguento mais", respondeu o funkeiro.

"MC Gui, você pode não querer ouvir, mas a gente quer ouvir, tá?", declarou Adriane Galisteu, e em seguida o humorista continuou rebatendo o peão:

Ele queria que eu falasse quando ele quisesse. Eu estava discutindo com a Valentina, explicando a questão do poder da outra semana. Aí ele pediu para fazer silêncio e eu disse: 'Oxe, agora vou fazer silêncio quando ele quer?'. [...] As pessoas as aqui nessa casa só querem que eu fale quando eles querem. Eu não posso me expressar, não posso falar a hora que eu quero, fazer nada nessa casa. Tudo o que eu faço é desrespeitoso, se eu falo alto eu estou desrespeitando. Para o MC Gui, tudo o que eu falo é falta de respeito, ele é um santo nessa casa. Rico Melquiades

Ô, Dri, eu só votei nele não foi porque ele falou na hora que eu não queria, foi porque ele me atacou de novo trazendo coisas de fora e também aqui na roça, ele tentou trazer uma brincadeira que ele começou", disse MC Gui, explicando seu voto novamente.

"A gente entendeu sua justificativa", respondeu Galisteu. "Mas ele não entendeu, ele sempre distorce", finalizou o cantor.

A Fazenda 2021: Os looks escolhidos por Adriane Galisteu para o reality

Quem deve se livrar da roça e virar o fazendeiro da semana?

Enquete encerrada

Total de 6402 votos
65,57%
Antonio Chahestian/Record TV