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

Emma Watson sai em defesa das pessoas trans: 'Amo vocês pelo que são'

Reprodução/Instagram
Imagem: Reprodução/Instagram

De Universa, em São Paulo

10/06/2020 19h23Atualizada em 10/06/2020 23h38

Depois das declarações de J.K. Rowling consideradas transfóbicas, a atriz Emma Watson saiu em defesa da população trans, que merece, segundo ela, viver sua vida sem ser constantemente questionada sobre quem são.

"Pessoas trans são quem dizem ser e merecem viver suas vidas sem ser constantemente questionadas ou ouvir que não são o que dizem ser", escreveu Emma em uma rede social. "Quero que meus seguidores trans saibam que eu e muitas pessoas no mundo enxergamos, respeitamos e amamos vocês pelo que são."

"Eu faço doações", ela continuou, "a Mermaids e a Mama Cash. Se você puder, talvez se sinta inclinado a fazê-lo também. Feliz #PRIDE2020 [hashtag alusiva a junho, o mês do Orgulho LGBT]".

'Pessoas que menstruam'

Autora da saga Harry Potter, J.K. Rowling dividiu opiniões e sofreu críticas após compartilhar um artigo opinativo que usava o termo "pessoas que menstruam". Ela questionou o uso da expressão e brincou com o fato de que já existe uma palavra para denominar esse grupo: mulheres.

Parte dos usuários do Twitter a lembrou que pessoas transgêneros podem menstruar e não necessariamente se identificar como mulheres; é o caso de homens trans que, quando nasceram, foram designados como mulheres, mas perceberam sua verdadeira identidade de gênero com o tempo.

A necessidade de visibilidade desse grupo gerou, por exemplo, a criação de uma cueca absorvente para os homens que menstruam.

Mulheres trans, por sua vez, não menstruam — e não são "menos mulher" por isso. Já pessoas não-binárias também podem se sentir incomodadas ao ter a menstruação ligada a "coisas de mulher".

Daniel Radcliffe também reagiu

Após as declarações de Rowling, Daniel Radcliffe, intérprete de Harry Potter, escreveu um longo texto em defesa das mulheres trans. "As mulheres trans são mulheres. Qualquer declaração em contrário apaga a identidade e a dignidade das pessoas trans e vai contra todos os conselhos dados por associações profissionais de saúde que têm muito mais experiência nesse assunto do que Jo ou eu", disse o ator.

Daniel também lamentou a ferida causada por J.K. Rowling aos fãs de Harry Potter. "Para todas as pessoas que agora sentem que sua experiência com os livros foi manchada ou diminuída, lamento profundamente a dor que esses comentários lhe causaram. Eu realmente espero que você não perca totalmente o que era valioso nessas histórias para você", completou.