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

Esse conteúdo é antigo

Apesar do programa do Ministério, SP reafirma que vacinará em janeiro

Jean Gorinchteyn esteve em Brasília, no evento de ontem do Ministério da Saúde - MISTER SHADOW/ASI/ESTADÃO CONTEÚDO
Jean Gorinchteyn esteve em Brasília, no evento de ontem do Ministério da Saúde Imagem: MISTER SHADOW/ASI/ESTADÃO CONTEÚDO

Colaboração para o UOL

17/12/2020 10h17

Ontem o Ministério da Saúde sinalizou claramente que pode utilizar a vacina CoronaVac, produzida pelo Instituto Butantan em parceria com o laboratório chinês SinoVac, no (PNI) Programa Nacional de Imunização. Mas isso não satisfez o governo de São Paulo. O Secretário Estadual de Saúde, Jean Gorinchteyn, criticou a falta de data para iniciar a vacinação. Ele reafirmou que São Paulo vai aplicar o imunizante a partir de 25 de janeiro, conforme foi anunciado no PEI (Plano Estadual de Imunização).

Ontem o Ministro da Saúde, Eduardo Pazuello, estimou que a vacinação deve começar em fevereiro. Mas não quis apresentar uma data, porque prefere esperar algum registro da Anvisa (Agência Nacional de Vigilância Sanitária). A CoronaVac ainda não foi certificada. Mas o Instituto Butantan prometeu que vai entregar todos documentos necessários na semana que vem. A Anvisa já informou que, depois disso, deve dar uma resposta em no máximo 10 dias. Jean esperava que, com isso, o Ministério fizesse o planejamento de uma data.

"Não recebemos a informação sobre a data de imunização. Mas precisamos vacinar. Esse vírus infelizmente tem vindo de forma mais importante agora, nas últimas semanas, compremetendo mais pessoas e ceifando mais vidas. Estaremos aptos pra ingressar no PNI. Mas enquanto ele não inicia, iniciaremos em São Paulo. Não podemos perder vidas e continuar sobrecarregando unidades hospitalares. Aguardar um dia é muito. O que dirá um mês, 2 meses? Será irresponsável aguardar. Iniciaremos no dia 25 de janeiro sim", prometeu Jean, em entrevista à CNN Brasil.

Jean deixou claro que o principal entrave é a falta de compromisso do Ministério de pagar pelas vacinas.

"Precisamos que o Ministério não reflita só a intenção. Tem o custo operacional das vacinas. Precisamos enviar isso pra Sinovac. O Butantan se dispôs a colocar essas vacinas desde julho. E propusemos mais, a possibilidade de ter até julho 100 milhões de doses", lembrou Jean.

O Secretário foi perguntado como ficaria o PEI se o Ministério quiser comprar 46 milhões de doses da CoronaVac. Jean afirmou que não será um problema.

"Temos 60 milhões de doses até fevereiro. Isso está contratualizado com Butantan e Sinovac. Nessa nossa 1ª fase, que se estenderá de 25 de janeiro até 28 março, precisaremos de 18 milhões de doses para grupos de risco. Dessa forma isso não impactará nas doses subsequentes que poderão ser distribuídas para os ministérios. Já recebemos partes das vacinas, 120 mil. Temos mais insumos que chegaram e que chegarão amanhã. Dessa maneira estamos preparando para ter produção de 1 milhão de doses por dia. Teremos as 46 milhões de doses em janeiro. E 60 milhões de doses até fevereiro", calculou Jean.