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

Histórico

Fefito

OPINIÃO

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

And Just Like That transforma Miranda em uma personagem irreconhecível

Cynthia Nixon em episódio da série And Just Like That  - Divulgação/HBO Max
Cynthia Nixon em episódio da série And Just Like That Imagem: Divulgação/HBO Max

Colunista do UOL

26/06/2023 12h38

À medida em que Sex and the City evoluiu, suas protagonistas ganharam cada vez mais nuances, a ponto de assumirem características que as transformaram em estereótipos em conversa de bar. Não raro, se ouvia alguém dizer que era "mais Carrie" ou "mais Samantha". Depois de uma primeira temporada muito bem-sucedida, And Just Like That, parece, no entanto, ter deixado de lado a memória de muitas destas figuras queridas pelo público. E o maior exemplo disso é Miranda, vivida por Cynthia Nixon, que, atualmente, em nada lembra a mulher vigorosa que conquistou a audiência da série.

Quem assistiu à primeira leva de episódios sabe que a advogada cansou da vida workaholic e decidiu ouvir os próprios desejos: pediu divórcio e partiu para uma relação com uma pessoa não-binárie. Ocorre que essa jornada de autodescoberta ou a ser contada em tom completamente atrapalhado, transformando por vezes Miranda numa espécie de alívio cômico do seriado, que em nada lembra a mulher obstinada que conhecemos. Agora, a personagem abriu mão de tudo e tem experimentado uma vida sem trabalho, de experiências sem muito sentido, muito graças a seu amor por Che Diaz (Sara Ramirez). É muito bem vindo que ela e a viver um romance inserido na comunidade LGBTQIAPN+, mas isso não apaga toda a sua história ou personalidade.

Enquanto novas figuras, inseridas para tornar a série mais inclusiva, ganham mais espaço, Miranda vai se tornando uma protagonista insípida, rumando para a caricatura. Uma pena, já que cabia a ela um dos papéis mais complexos e fomentadores de debate na época de Sex and the City, a mulher de carreira incrível que tentava ter uma vida amorosa e uma família ao mesmo tempo em que só avançava no mercado de trabalho. Agora, a personagem tornou-se apenas um arremedo do que já foi. Uma pena.