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

'Ainda tá muito difícil de entender', diz irmão de Marília Mendonça

Gustavo se emocionou ao falar do luto e agradeceu irmã pelo incentivo à carreira - Reprodução/TV Globo
Gustavo se emocionou ao falar do luto e agradeceu irmã pelo incentivo à carreira Imagem: Reprodução/TV Globo

De Splash, em São Paulo

06/12/2021 11h27Atualizada em 06/12/2021 12h24

O cantor João Gustavo, dupla com Dom Vittor, revelou um dos momentos em que mais sentiu falta da irmã Marília Mendonça. Ontem, a morte da cantora em um acidente aéreo completou um mês.

Gustavo, como se assume artisticamente, disse a Fátima Bernardes que ainda não compreende totalmente a morte de Marília. Ao falar do luto, ele descreveu uma noite sozinho e que sentiu falta do produtor Henrique Bahia, do tio Abicieli Silveira — assessor de Marília — e da irmã.

Na nossa primeira viagem para cá para gravar o 'Fantástico'. Sai e jantei com os meninos, tomamos nossa cerveja. Cheguei no quarto e esperei alguém me chamar para ir para o show. Quem fazia isso era o Henrique Bahia. Meu tio Silveira ficava no quarto comigo. Me vi sozinho no escuro. Desabei, com saudade. A dor está virando saudade dentro de mim. Não sinto raiva, tenho que entender que isso é uma realidade. A saudade vai ficar para sempre e é inevitável. Gustavo no 'Encontro'

João Gustavo - Reprodução/TV Globo - Reprodução/TV Globo
João Gustavo diz 'seguir forte' pela irmã Marília Mendonça
Imagem: Reprodução/TV Globo

O músico agradeceu ao jeito 'mandona' da irmã por incentivar sua carreira.

"Ainda ta muito difícil para entender. Às vezes paro e penso: ela estava comigo, conversou, me deu conselho e um dia depois aconteceu. Seguimos forte por ela. Trabalhamos por ela porque era um sonho dela também. Marília era mandona, quando entrou no projeto, ela gostava de mandar também. Mas ela não sabia falar muito bem, ela mandava. Não era uma coisa ruim. A gente escutava muito ela", disse ele.

O caçula de Dona Ruth se emocionou ao ver um recado da mãe ao vivo na TV Globo.

A dupla Dom Vittor e Gustavo lançou "Calculista", com participação da rainha da sofrência.

Dom contou que eles tinham receio de gravar com Marília e surgirem comentários de que eles usavam o sucesso da irmã de Gustavo. O feat veio após trabalhos solos.

Lançada há três dias, a canção ou a marca de um milhão de views no videoclipe no YouTube.

Junior Campi, produtor e baterista da cantora, ainda lembrou como ela fazia questão de conhecer todos da banda e saber do cotidiano de cada um. Franco, integrante da banda e multi-instrumentista, se emocionou e contou que recebeu um vídeo de Marília o elogiando.