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

Não Me Perturbe: app permite cadastrar números contra chamadas indesejadas

App Não Me Perturbe permite cadastro para evitar chamada de telemarketing de telecomunicação e financeiras - SDI Productions/iStock
App Não Me Perturbe permite cadastro para evitar chamada de telemarketing de telecomunicação e financeiras Imagem: SDI Productions/iStock

De Tilt, em São Paulo

25/03/2023 15h46Atualizada em 26/03/2023 17h05

Ninguém gosta de receber chamadas indesejadas no telefone. Para ajudar a evitar esta chateação, o app Não Me Perturbe facilita que pessoas façam um cadastro para evitar ligações de telemarketing de empresas de telecomunicações e de oferta de crédito consignado.

Liberado nesta semana para iOS e Android, o app Não Me Perturbe foi desenvolvido pela Conexis, associação que representa as operadoras de telecomunicações, e é uma versão mais simples de um cadastro que já era possível fazer por meio do site naomeperturbe.com.br, ativo desde 2019.

Como funciona

  • É necessário baixar o app Não Me Perturbe (disponível para Android e iPhone)
  • Na sequência, você precisa fazer um cadastro com número de telefone e e-mail
  • Com o cadastro feito, faça no serviço e clique em Novo bloqueio
  • Aí, você deve colocar o seu telefone e escolher os serviços de telecomunicações e de instituições financeiras que você não quer receber chamadas de telemarketing
  • Clique em Enviar

O app avisa que a efetivação do bloqueio é de até 30 dias após a data de solicitação.

Mais de 10 milhões de pessoas cadastradas

Segundo a Conexis, mais de 11 milhões de pessoas já estão cadastradas do Não Me Perturbe.

A iniciativa, criada em 2019, faz parte de medidas de "autorregulação do setor", segundo comunicado de imprensa. Na prática, após ouvir as reclamações de consumidores, as empresas aram a se mobilizar para evitar chamadas de telemarketing irritantes.

Vale ressaltar que o cadastro serve apenas para oferta de crédito consignado e para ofertas de serviços de telecomunicações das empresas que aderiram à Não Me Perturbe.

As empresas que fazem parte do cadastro Não Me Perturbe são:

  • Telecomunicações: Algar Telecom, Sercomtel, Claro, Vivo, Sky, Oi, e Tim.
  • Financeiras: Agibank, Sicoob, Banco Alfa, C6 Consig, Banco do Brasil, Banco Master, Banpará, Banrisul, Bradesco, Bradesco Financiamentos, Caixa, BRB, Banco BMG, Cetelem, BV, CCB, CCB Brasil Financeira, Digio, Daycoval, Alfa Financeira, Itaú, Itaú Consignados, Inter, Facta Financeira, Mercantil, Mercantil do Brasil, Banco Pan, Paraná Banco, Safra, Santander, Sicredi e Zema Financeira