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

Polícia dispersa 352 pontos de aglomeração em SP durante a noite

28.mar.2021 - Agentes da Vigilância Sanitária em conjunto com a Polícia Civil fecham bares clandestinos no bairro do Brás, zona leste de São Paulo, durante a madrugada. Bares e festas não podem funcionar na atual Fase Emergencial do Plano SP para evitar a disseminação da covid-19  - AGÊNCIA DE FOTOGRAFIA/ESTADÃO CONTEÚDO
28.mar.2021 - Agentes da Vigilância Sanitária em conjunto com a Polícia Civil fecham bares clandestinos no bairro do Brás, zona leste de São Paulo, durante a madrugada. Bares e festas não podem funcionar na atual Fase Emergencial do Plano SP para evitar a disseminação da covid-19 Imagem: AGÊNCIA DE FOTOGRAFIA/ESTADÃO CONTEÚDO

Luís Adorno

Do UOL, em São Paulo

28/03/2021 13h11Atualizada em 28/03/2021 13h11

A força-tarefa montada pelo governo de São Paulo contra pontos de aglomeração em meio à pandemia dispersou 352 pontos de aglomeração na capital paulista entre a noite de ontem e a madrugada de hoje. A força-tarefa integra servidores das polícias, da Vigilância Sanitária, do Procon e da Prefeitura de São Paulo.

Segundo o Comitê de Blitze, 196 estabelecimentos foram vistoriados. Desse total, 26 foram autuados pelo descumprimento da fase emergencial do Plano São Paulo. Dois eventos também foram encerrados no Brás, na região central.

"As reuniões aconteciam em dois locais distintos na rua Doutor Costa Valente. Os organizadores foram levados até o 78° Distrito Policial, onde foram autuados por infração de medida sanitária preventiva", afirmou o governo paulista por meio de nota.

Em outro endereço na mesma rua, os responsáveis por um bar foram autuados pelos agentes do comitê da Blitze pela identificação de pessoas sem máscaras, de uso obrigatório.

Nas ações, a PM prendeu 13 pessoas, sendo sete delas procuradas pela Justiça. "Ao todo, 10.186 veículos foram vistoriados e 113 deles, produto de furto e roubo, foram recuperados e serão restituídos aos seus proprietários", disse o governo.

Comitê de Blitze

A força-tarefa que verifica possíveis locais que estejam descumprindo as medidas sanitárias previstas foi criada em 12 de março em parceria entre o governo estadual e a prefeitura da capital.

Qualquer pessoa pode denunciar festas clandestinas e funcionamento irregular de serviços não essenciais pelo telefone 0800-771-3541 e também no site www.procon.sp.gov.br ou pelo e-mail [email protected], do Centro de Vigilância Sanitária.

102 pontos de aglomeração entre sexta e sábado

A força-tarefa do governo paulista flagrou, entre a noite de sexta-feira e a madrugada de ontem, 102 pontos de aglomeração na cidade de São Paulo. Ao todo, 221 dispersões precisaram ser feitas entre sexta e sábado, de acordo com balanço do Comitê de Blitze.

Entre os 102 pontos de aglomeração identificados pela força-tarefa, estava uma casa noturna no centro da capital, que previa a presença de 250 pessoas na noite da inspeção, de acordo com o governo paulista. O nome do local não foi divulgado, mas a força-tarefa afirma que a festa foi encerrada e que a casa noturna foi autuada e interditada.

Além da balada, um salão de beleza na região de Pinheiros, zona oeste da cidade, foi autuado e interditado. A atividade não é permitida na fase emergencial do Plano São Paulo de contingência. Uma outra empresa, de segurança privada, no Jabaquara, zona sul, também foi autuada, inclusive pela identificação de pessoas sem máscaras, de uso obrigatório.