;(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
Logo Pagbenk Seu dinheiro rende mais
Topo

Procon-SP acompanhará transferência de contratos entre Amil e A.P.S.

O Procon-SP vai acompanhar a transferência dos contratos de planos de saúde da Amil Assistência de Saúde Médica Internacional para a A.P.S Assistência Personalizada à Saúde - iStock
O Procon-SP vai acompanhar a transferência dos contratos de planos de saúde da Amil Assistência de Saúde Médica Internacional para a A.P.S Assistência Personalizada à Saúde Imagem: iStock

12/01/2022 13h54Atualizada em 12/01/2022 13h57

O Procon-SP vai acompanhar a transferência dos contratos de planos de saúde da Amil Assistência de Saúde Médica Internacional para a A.P.S Assistência Personalizada à Saúde. Depois de terem sido notificadas para explicar a operação, as operadoras informaram que não haverá prejuízos para os beneficiários.

Segundo o Procon-SP, apesar dessa resposta, as operadoras não prestaram todos os esclarecimentos de forma direta. Pelo menos 300 mil usuários de planos de saúde individuais e familiares da Amil que residem em São Paulo, no Rio de Janeiro e Paraná am a ser atendidos pela operadora A.P.S. a partir deste mês.

A notificação pedia esclarecimentos sobre as medidas adotadas para a manutenção integral do atendimento e dos valores dos planos (contratos) e se foi estipulado prazo mínimo para a ocorrência de redução, redimensionamento, descredenciamento dos prestadores de serviços. Os questionamentos foram feitos com base no histórico de transferências de carteira, ocorridas no mercado de saúde suplementar, que geraram reclamações relativas a reduções de redes credenciadas e reajustes diversos dos estabelecidos.

De acordo com o diretor executivo do Procon-SP, Fernando Capez, as empresas Amil e A.P.S. deveriam explicar como a empresa conseguirá manter a qualidade dos atendimentos e de que forma os consumidores não terão os os dificultados ou mais burocratizados com essa alteração, considerando o aumento do número de beneficiários.

"É o mesmo contrato, com as mesmas obrigações, e a Amil mantém a responsabilidade solidária em relação aos consumidores. Qualquer mudança nas condições de atendimento ou contratuais só poderá ser feita mediante expressa concordância do segurado, sob pena de nulidade", disse Capez.

As operadoras também foram questionadas sobre como e com que antecedência consumidores e prestadores de serviço foram comunicados a respeito da transferência, se foram criados canais específicos de atendimento para afetados pela mudança, se já existem registros de queixas e, em caso positivo, que medidas foram tomadas para resolver os problemas.

Segundo o Procon, as operadoras informaram que não haveria necessidade de estabelecer canais próprios de atendimento, pois não "há problema para ser solucionado".