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

Lucas Pasin

REPORTAGEM

Texto que relata acontecimentos, baseado em fatos e dados observados ou verificados diretamente pelo jornalista ou obtidos pelo o a fontes jornalísticas reconhecidas e confiáveis.

Virginia Fonseca é acusada de não entregar curso para virar influenciador

Virginia Fonseca doará o lucro de sua marca de beleza - Reprodução / Instagram
Virginia Fonseca doará o lucro de sua marca de beleza Imagem: Reprodução / Instagram

Colunista do UOL

16/08/2022 04h00

Receba os novos posts desta coluna no seu e-mail

Email inválido

Virginia Fonseca é alvo de uma ação movida por uma comerciante de Governador Valadares (MG), que alega ter sido vítima de golpe após comprar um curso para se tornar um fenômeno da internet, promovido pela influenciadora, em parceria com a empresa Plonu Empreendimento Comerciais e Desenvolvimento Empresarial.

A comerciante diz que comprou o curso e não recebeu o produto. Além de pedir o dobro do valor pago (R$ 930,40), ela também quer ser indenizada por danos morais em 20 salários mínimos (R$ 24.240). A ação foi aberta em 12 de julho no Juizado Especial Cível de Governador Valadares. A audiência está marcada para 14 de setembro.

De acordo com o documento, a que esta coluna de Splash teve o, no dia 30 de maio de 2021, a comerciante comprou o curso, que havia sido divulgado nas redes sociais da influenciadora, que tem atualmente quase 39 milhões de seguidores.

"Os itens ficam sob a chancela e 'indiscutível influência'. Afinal, sem a intermediação da influenciadora digital, a autora [da ação] não teria comprado o curso, uma vez que soube da oferta por meio das redes sociais de Virgínia", alega. "Foram feitas várias tentativas de solução amigável desse conflito, sem, no entanto, sucesso algum. Desde a data da compra até o presente, já se ou um ano", diz também o documento.

Segundo a ação, a promessa era "transformar pessoas comuns nos próximos fenômenos da internet", com a divulgação de um vídeo de 17 minutos em que Virgínia falava dos benefícios. O conteúdo não está mais disponível, uma vez que o site do curso foi removido. A autora registrou boletim de ocorrência ao perceber que não havia recebido o produto.

"O valor acima pode parecer pouco, mas compra um sonho, como o da autora, que trabalha com venda de calçados pela internet, e tem o sonho de se tornar uma influencer digital, assim como a Ré", informa o documento na Justiça.

Esta coluna de Splash entrou em contato com Virginia Fonseca, que, por meio de sua assessoria de imprensa, enviou uma nota: "A equipe jurídica de Virgínia Fonseca informa que até o presente momento a mesma não foi citada/notificada em relação ao referido processo e, por essa razão, não irá se manifestar sobre o assunto, reservando-se ao direito de fazê-lo oportunamente nos autos da ação."

Representantes da Plonu Empreendimento Comerciais e Desenvolvimento Empresarial também foram procurados, mas não retornaram. O espaço segue em aberto.

Site divulgava curso de como ser influenciador com Virginia Fonseca - Reprodução - Reprodução
Site divulgava curso de como ser influenciador com Virginia Fonseca
Imagem: Reprodução