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

Prefeitura de SP anuncia vale uniforme no valor de R$ 387 a partir de 18/01

Prefeito Bruno Covas já havia feito promessa sobre uniforme na campanha à reeleição - ROBERTO CASIMIRO/ESTADÃO CONTEÚDO
Prefeito Bruno Covas já havia feito promessa sobre uniforme na campanha à reeleição Imagem: ROBERTO CASIMIRO/ESTADÃO CONTEÚDO

Ana Carla Bermúdez, Felipe Oliveira e Rafael Bragança

Do UOL, em São Paulo, e Colaboração para o UOL, em São Paulo

16/12/2020 14h42Atualizada em 16/12/2020 15h25

A Prefeitura de São Paulo anunciou hoje que adotará permanentemente um novo modelo de fornecimento de uniformes escolares para alunos da rede municipal de ensino. Após ter que dar um vale uniforme de R$ 215 no início do ano por causa de uma licitação cancelada, a gestão de Bruno Covas (PSDB) disponibilizará R$ 387,10 por cada aluno para que as próprias famílias adquiram o uniforme em estabelecimentos credenciados para o ano letivo de 2021.

O crédito será liberado a partir de 18 de janeiro do ano que vem e será disponibilizado por meio de um aplicativo. Na avaliação de Covas, o valor ajudará a cidade a "reativar o comércio local" no contexto da pandemia de covid-19.

O prefeito, reeleito recentemente, já havia antecipado a intenção de implementar o vale uniforme durante a campanha. O investimento anunciado pela istração no programa é de R$ 373 milhões.

Os estabelecimentos que disponibilizarão os uniformes podem solicitar o cadastramento por meio da Secretaria de Educação.

"Realizamos em 2019 um pregão para adquirir de forma centralizada esses itens. Esse pregão foi revogado pelas razões que já expus, baixa qualidade do material, sobretudo", explicou o prefeito paulistano, acrescentando que no novo modelo a gestão municipal "deixa de fazer aquisição centralizada dos itens", que incluem também o material escolar.

Enquanto 650 mil alunos serão beneficiados com o novo vale uniforme, a estimativa é de que um milhão e 81 mil alunos recebam o auxílio para compra de material escolar, que terá valor variando de R$ 33,40 a R$ 122,10, de acordo com a etapa do ensino em que o aluno estiver matriculado. O montante de alunos é maior porque inclui também as crianças matriculadas em creches estaduais.

Quanto ao uniforme, segundo o programa apresentado pela Prefeitura, as famílias terão o direito de comprar cinco camisetas, cinco pares de meias, uma jaqueta, uma calça, um blusão, uma bermuda e um par de tênis para os alunos. A escolha dos itens, entretanto, fica a critérios dos pais.

Com as aulas presenciais ainda suspensas para a maioria dos estudantes da rede municipal, o governo paulistano trabalha com a expectativa de iniciar o ano letivo em 2021 em 4 de fevereiro, mas ainda não sabe se terá alterações quanto à forma de ensino, presencial ou remoto.