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

Chico Barney

OPINIÃO

Texto em que o autor apresenta e defende suas ideias e opiniões, a partir da interpretação de fatos e dados.

Novo programa de Ivete Sangalo na Globo estreia com erro grave

Ivete Sangalo comandará o "Pipoca da Ivete" a partir de 24 de julho - Fábio Rocha / Globo
Ivete Sangalo comandará o 'Pipoca da Ivete' a partir de 24 de julho Imagem: Fábio Rocha / Globo

Colunista do UOL

07/07/2022 04h00

Receba os novos posts desta coluna no seu e-mail

Email inválido

Acompanho empolgado os preparativos para a estreia do novo projeto da principal cantora do Brasil na Globo. Pipoca da Ivete tem tudo para ser uma lufada de ar fresco na programação dominical da TV brasileira.

Fico feliz especialmente com as promessas de que não teremos muitas novidades. Sangalo pretende solidificar sua presença na nova função de apresentadora levando ao público formatos já bem conhecidos. Imprimir sua marca pelo carisma, não por invencionices.

Foi a receita que deu certo para Marcos Mion no Caldeirão, por exemplo. Um programa de auditório sem nenhum constrangimento de ser o que é. Como diferencial, apenas um bom humor simplesmente irrefreável.

Uma telespectadora do Central Splash chamou atenção para o fato de que até pompons a plateia vai erguer para festejar junto com Ivete e seus convidados —como acontecia nas melhores fases do Programa Silvio Santos e congêneres.

Tivemos a oportunidade de perceber esse agradabilíssimo detalhe por conta de um vídeo do colunista Lucas Pasin, que acompanhou parte das gravações do primeiro episódio do novo programa, que deve ir ao ar no dia 24 deste mês.

E é justamente aí que entra o problema que este texto pretende denunciar. Como pode uma atração dessa envergadura ser previamente gravado? A programação de domingo da TV brasileira precisa voltar a ser ao vivo!

Basta ver como fez bem o calor do momento na excelente final da Dança dos Famosos, primeira apresentada dentro do novo Domingão com Huck. Essa temperatura muda completamente a experiência.

Um bom programa de auditório no século 21 precisa se conectar àqueles que estão presentes no estúdio, mas também se fazer valer das diversas possibilidades de interação com quem está no aconchego do lar. Evitar esse subterfúgio no Domingão, no Caldeirão e agora na Pipoca da Ivete é um erro que precisa ser corrigido.

Voltamos a qualquer momento com novas informações.