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

Quatro cidades do Grande ABC descartam volta às aulas em 2020

Salas de aula seguirão sem alunos no Grande ABC até 2021  - iStock
Salas de aula seguirão sem alunos no Grande ABC até 2021 Imagem: iStock

Do UOL, em São Paulo

11/08/2020 12h50

As sete cidades que compõem a região conhecida como Grande ABC paulista se reuniram hoje para debater a retomada das aulas nas redes particulares e públicas.

O debate do Consórcio Intermunicipal do Grande ABC, presidido pelo prefeito de Rio Grande da Serra, Gabriel Maranhão (Cidadania-SP), estabeleceu que as escolas particulares só retomarão suas atividades junto com as instituições de ensino públicas.

"Acabamos agora a assembleia com os sete prefeitos do ABC, e a determinação é que as escolas particulares só retornam quando as municipais também retornarem", disse Maranhão em entrevista à Globonews.

Santo André, Mauá, Ribeirão Pires e Rio Grande da Serra já determinaram que o retorno das aulas só ocorrerá em 2021. São Bernardo, São Caetano e Diadema seguirão avaliando a evolução dos seus índices epidemiológicos e as determinações do governo de São Paulo para uma nova comunicação até 30 de setembro.

A decisão vai de encontro com o plano do governador João Doria (PSDB-SP), que pretende reabrir as escolas em 7 de outubro.

"Os dois grandes fatores (para a decisão) foram o grande índice de pais que não querem retornar às aulas esse ano e também o índice de evolução da pandemia", explicou Maranhão, anunciando também que os professores devem contar com as salas de aulas para ajudar na produção de conteúdo das aulas remotas.

"É muito prazeroso ver nossos professores se reinventando, dando aulas via internet, e vai ter um rodízio dos professores para que essas aulas sejam dadas pela internet e nas salas de aulas, para que tenham uma melhor estrutura de ensino", afirmou o prefeito de Rio Grande da Serra.

Errata: este conteúdo foi atualizado
Diferentemente do informado no texto, apenas quatro cidades, e não todas as sete, decidiram que as aulas serão retomadas apenas em 2021: Santo André, Mauá, Ribeirão Pires e Rio Grande da Serra. São Bernardo, São Caetano e Diadema seguirão avaliando a evolução dos seus índices epidemiológicos até 30 de setembro. A informação foi corrigida.