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

Mion explica ausência de Romeo, filho autista, em viagem: 'Ele sofre muito'

Marcos Mion e o filho, Romeo - Reprodução/Instagram @marcosmion
Marcos Mion e o filho, Romeo Imagem: Reprodução/Instagram @marcosmion

Colaboração para Splash, em Pernambuco

02/07/2022 16h45Atualizada em 03/07/2022 07h33

O apresentador Marcos Mion, 43, usou seu Instagram ontem para explicar a ausência de seu filho, Romeo, que é autista, em uma viagem feita com os outros filhos, Donatella e Stefano.

"Esse é um vídeo muito especial que fala sobre uma coisa muito íntima minha, mas toda viagem eu explico", começa o apresentador.

Ponto básico e pacífico. Romeo é autista, só essa informação já deveria ser o suficiente pra todo mundo entender que o funcionamento do Romeo é diferente, pra galera não julgar precocemente. São necessárias uma série de adaptações para ele se desenvolver, pra ele se adaptar a nós neurotípicos. Marcos Mion

Mion explica, então, que tudo que tira Romeo de sua zona de conforto é um incômodo para o filho.

"Tudo que causa surpresa e que tira os pés dele do chão da segurança gera pânico e crise de sentimentos", diz.

Ele destaca o quanto se sentir confortável é importante para que Romeo consiga "se encaixar socialmente".

"O que faz ele conseguir isso (se controlar) é principalmente o poder de controlar o resultado dos acontecimentos, não ser surpreendido, ou seja, ele domina a rotina do dia, todo dia da semana é igual da semana seguinte", explica.

Tudo que quebra a rotina, que tira ele da zona de conforto, que causa surpresa, gera pânico, gera estresse, desespero, gera crise. Marcos Mion

No vídeo de 15 minutos, ele conta ainda uma situação que ou com Romeo durante uma viagem a Nova York, onde ele teve uma crise em uma livraria.

Mion explica então que, uma vez por ano, organiza uma viagem com Romeo, para algum lugar em que ele já se sente confortável. O apresentador aponta ainda que os comentários sobre a ausência dele "não são legais".

"Eu vejo os comentários: "sem o Romeo não tem graça". Nem eu consigo ver a gente sem ele, mas o que eu consigo menos ainda e vê-lo sofrer. Ele sofre muito em situações como essas. Por isso, a conscientização é muito importante. Do meu lado, morrendo de saudades, não é a coisa mais agradável do mundo ler esses comentários. A realidade, muitas vezes, é dura", diz.

Mion diz ainda que, para aplacar a saudade, faz chamada de vídeo com o filho duas vezes ao dia durante as viagens.