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

Prefeitos ampliam toque de recolher de Campinas para Região Metropolitana

 Prefeitos se reuniram hoje e rejeitaram lockdown e antecipação de feriados  - Arthur Trevisoni / Agemcamp
Prefeitos se reuniram hoje e rejeitaram lockdown e antecipação de feriados Imagem: Arthur Trevisoni / Agemcamp

Letícia Simionato

Colaboração para o UOL

19/03/2021 16h31Atualizada em 19/03/2021 17h05

Os 20 prefeitos das cidades que fazem parte da RMC (Região Metropolitana de Campinas) decidiram que vão adotar o toque de recolher anunciado por Campinas ontem (18). A medida vale a partir de hoje (19), no período das 20h às 5h, e prevê que quem for flagrado em festas ou reuniões familiares com mais de dez pessoas receberá multa de R$ 3 mil. O responsável pode ser processado com base no Código Penal, sendo condenado em até um ano de prisão.

Segundo a Agência Metropolitana de Campinas (Agemcamp), durante a reunião, os chefes do Executivo descartaram adotar o lockdown - ao menos até o fim da Fase Emergencial do Plano São Paulo, que vai até o dia 31 deste mês - e antecipar feriados, como fez a capital. Uma nova reunião do Conselho foi marcada para a próxima quarta, às 9h, de forma virtual, para avaliar o cenário da pandemia do novo coronavírus.

"Entendemos que antecipar feriados poderia provocar o deslocamento das pessoas para outras cidades aqui mesmo da região, que são cidades turísticas. Por isso, optamos em não adotar essa medida. Por fim, temos que ter prudência com relação ao lockdown, já que é preciso avaliar os efeitos que surtirão com a Fase Emergencial do Plano São Paulo," afirmou Gustavo Reis, prefeito de Jaguariúna e presidente em exercício do Conselho de Desenvolvimento da RMC.

Atualmente, 20 municípios fazem parte da RMC: Americana, Artur Nogueira, Campinas, Cosmópolis, Engenheiro Coelho, Holambra, Hortolândia, Indaiatuba, Itatiba, Jaguariúna, Monte Mor, Morungaba, Nova Odessa, Paulínia, Pedreira, Santa Bárbara d'Oeste, Santo Antônio de Posse, Sumaré, Valinhos e Vinhedo.

Fase emergencial no estado

Desde segunda-feira (15), o estado de São Paulo está na fase emergencial do Plano São Paulo. Essa é a etapa mais restritiva contra a covid-19 adotada pelo governador João Doria (PSDB) até então. Mais rígida que a fase vermelha, a medida inclui o que o governo chamou de "toque de recolher" entre 20h e 5h e proibição de eventos religiosos e esportivos até o dia 30 de março.

O país registrou 2.659 novas mortes por covid-19 nas últimas 24 horas, a terceira maior marca desde março de 2020. O recorde foi verificado na terça-feira (16), com 2.798 vítimas. No total, 287.795 pessoas morreram em decorrência da doença desde o início da pandemia. O levantamento é do consórcio de veículos de imprensa do qual o UOL faz parte com base nos dados fornecidos pelas secretarias estaduais de saúde.