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

"Estupro de roupa": fã denuncia dançarino de MC Carol por abuso em show

MC Carol pediu desculpas e afastou o dançarino - Fernando Schlaepfer
MC Carol pediu desculpas e afastou o dançarino Imagem: Fernando Schlaepfer

Da Universa

28/05/2018 15h34

Ansiosa para ver MC Carol no Festival XXXbórnival, em São Paulo, no sábado (26), uma estudante de 23 anos contou que saiu do show, realizado em uma casa noturna, na zona oeste de São Paulo, com uma experiência traumática. 

Em seu perfil no Facebook, ela disse que foi convidada para subir ao palco e dançar ao lado dos assistentes de palco da funkeira, mas que "o que aconteceu ali foi um estupro de roupa, em cima de um palco, muito provavelmente filmado e fotografado". 

Veja também 

Segundo ela, a violência ocorreu enquanto MC Carol cantava o hit "Bateu uma Onda Forte" e seus dançarinos usavam fantasias de macaco. "A partir do momento em que pisei no palco, esse macaco que me puxou começou a ser extremamente bruto comigo, me agarrou e até me arranhou de tanta força que ele usou para me segurar. E força pra que? Pra me colocar em posições sexuais mais esdrúxulas do mundo; de perna aberta, no colo dele, com a bunda virada pra ele... ", relatou a estudante. 

Ela não foi a única pessoa da plateia a subir ao palco para dançar durante a música, mas disse que percebeu ser a única agredida enquanto as outras mal eram tocadas pelos respectivos dançarinos. 

"Eu gritava 'não' para o cara, repetia incessantemente 'não não não' e nada, [ele] só me machucava mais. A própria MC Carol falou 'ei, se a mina não quer deixa ela', mas nada aconteceu. 100% feminista só quando convém", disse, criticando a postura da cantora em referência à música "100% Feminista", com a rapper Karol Conka. 

A estudante conseguiu se livrar da situação e desceu do palco. Naquele momento, ela disse ter ouvido de um membro da equipe de MC Carol: "Essa aí não aguentou". "Nunca me senti tão humilhada em toda minha vida", desabafou. 

Dançarino está afastado

MC Carol divulgou uma nota, por meio de sua assessoria de imprensa, em que pede desculpas à estudante e informa que o assistente de palco está afastado até que a situação seja resolvida. 

"[Os dançarinos] têm dificuldade para me escutar por causa da a máscara de macaco, que tem pelos e é mega quente. Conheço meus dançarinos há dez anos e nunca os vi abusando de ninguém", disse a cantora, em defesa do profissional. 

A estudante registrou boletim de ocorrência e está tomando as medidas legais contra a produção do show.