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

Castro toma posse neste sábado e fala em diálogo para pacificar o Rio

Cláudio Castro assumiu o governo do Rio em agosto de 2020, quando Witzel foi afastado - ADRIANO ISHIBASHI/ESTADÃO CONTEÚDO
Cláudio Castro assumiu o governo do Rio em agosto de 2020, quando Witzel foi afastado Imagem: ADRIANO ISHIBASHI/ESTADÃO CONTEÚDO

Do UOL, em São Paulo

30/04/2021 22h31

Cláudio Castro (PSC) tomará posse como governador do estado do Rio de Janeiro neste sábado (1º). Ele vai assumir definitivamente o comando do estado após o Tribunal Especial Misto ter decidido pelo impeachment de Wilson Witzel. Castro defendeu o diálogo como forma de pacificar o Rio.

Em nota enviada à imprensa, a equipe de Cláudio Castro afirmou que ele "manterá sua premissa histórica do diálogo para superar os desafios de pacificar o Rio de Janeiro e unir esforços no enfrentamento à covid-19, à fome, à pobreza e pela geração de empregos".

Cláudio Castro vai assumir efetivamente o governo do Rio de Janeiro em uma cerimônia de posse na Alerj (Assembleia Legislativa do Rio de Janeiro) às 10h. Ele prestará o juramento constitucional e á o termo de posse. Mais tarde, às 14h, Castro fará um pronunciamento no Palácio da Guanabara, sede oficial do governo do estado.

Cláudio Castro é o governador em exercício no Rio desde 28 de agosto de 2020, quando Wilson Witzel, seu companheiro de chapa nas eleições de 2018, foi afastado do cargo por conta do processo de impeachment. Castro também é investigado por corrupção.

Presidente da Alerj diz que é 'hora de virar a página'

O presidente da Alerj, André Ceciliano (PT), divulgou um comunicado sobre o impeachment de Wilson Witzel. Segundo ele, "não é um capítulo feliz para o Rio de Janeiro ter o primeiro governador da história do Brasil destituído do cargo". Porém, o deputado afirmou que Witzel "escreveu o seu próprio destino".

"A hora agora é de virar essa página e seguir trabalhando em conjunto para o Rio superar os seus graves problemas, agravados após 14 meses de pandemia", defendeu.