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

Fátima Bernardes se despede do 'Encontro' em discurso emocionante

Fátima Bernardes foi pintada com várias palavras no programa especial de 10 anos do "Encontro" (TV Globo) - Reprodução/TV Globo
Fátima Bernardes foi pintada com várias palavras no programa especial de 10 anos do "Encontro" (TV Globo) Imagem: Reprodução/TV Globo

De Splash, em São Paulo

24/06/2022 11h54

Fátima Bernardes iniciou o "Encontro" (TV Globo) de hoje, edição comemorativa de 10 anos do programa, com um discurso emocionante em tom de despedida.

A apresentadora vai se despedir da atração na semana que vem. Ela comandará a nova temporada do "The Voice Brasil" (TV Globo).

"2566 Encontros. Sim, você aí do outro lado da telinha e eu estamos completando 10 anos juntos nesse horário, nesse espaço. Quantas histórias que nunca vou esquecer. Você certamente também tem os seus momentos inesquecíveis. E é assim porque nós fizemos esse programa juntos. A plateia aqui, o público à distância nos contaram muitos sonhos, realizações", iniciou Fátima, que aparecia sendo pintada com palavras como "amor", "família" e "encontro".

Quantos temas para debate vocês sugeriram. Aprendemos tanto, vivemos reencontros que pareciam impossíveis. Quanto amor espalhamos, quanto amor recebemos. Não deixamos que a diversidade, o respeito, a luta contra o racismo e pela inclusão de todos saíssem da nossa pauta. Fátima Bernardes

Ela continuou: "Vimos artistas serem consagrados, novos ritmos de música surgirem, tivemos despedidas também. Nesse palco, eu voltei a dançar. Usamos do humor para enfrentar momentos nem sempre fáceis. Tentamos destrinchar notícias complicadas. Quantos desafios, quantas alegrias, quanta arte já ou por aqui. Nossa luta vai continuar, cheia de fé em todas as crenças que nos levem para um mundo melhor".

"Quando saí do Jornal Nacional para construir o Encontro, acreditei na nossa parceria para seguir em frente e, no final desse mês, farei o mesmo novamente. Direi um 'até breve' sempre acreditando na conexão forte que criamos em tantos anos de convivência", concluiu a apresentadora.

Mudanças

O próximo mês será marcado por várias mudanças no entretenimento da emissora. Fátima Bernardes deixará o "Encontro" para apresentar o "The Voice". O programa diário ará para o comando de Patrícia Poeta e Manoel Soares.

O "É de Casa", por sua vez, será apresentado por Maria Beltrão, Thiago Oliveira, Rita Batista e Talitha Morete. Andréia Sadi substituiu a jornalista no "Estúdio i", da GloboNews.

As alterações vão impactar até o "Mais Você", que terá o horário invertido com o do "Encontro". Em 4 de julho, quando estreará com os novos apresentadores, o "Encontro" ará a ser exibido logo após o "Bom Dia Brasil", direto de São Paulo, repercutindo as principais notícias do dia com matérias, bate-papos e convidados, além das atrações musicais.

No "Mais Você", Ana Maria Braga vai preencher o período que antecede o almoço com dicas culinárias, entrevistas, frases inspiradoras e a crítica bem-humorada dos assuntos que impactam a rotina da população.

Além da mudança da ordem dos programas na grade, o horário da primeira edição dos telejornais locais será padronizado, com início às 11h45 em todo o Brasil.

A programação ainda vai ganhar um novo programa nas tardes de domingo, apresentado por Ivete Sangalo.