;(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();
})();
Carlos Bolsonaro critica Mourão pelo terceiro dia consecutivo
O vereador Carlos Bolsonaro, na Câmara Municipal do Rio de Janeiro Imagem: Divulgação/Câmara Municipal do Rio de Janeiro
Em São Paulo
25/04/2019 10h35
No terceiro dia seguido de críticas públicas contra o vice-presidente Hamilton Mourão, o vereador carioca Carlos Bolsonaro (PSC-RJ) publicou hoje, no Twitter, um comentário sobre declarações do líder do partido do vice (PRTB), Levy Fidelix.
Fidelix comentava a atuação de Mourão durante o governo de transição. O filho do presidente Jair Bolsonaro fala em "interesse crocodilal". Na imagem compartilhada por Carlos, uma notícia informa que Mourão teria poder para intervir onde achasse necessário e, por ter sido eleito vice-presidente, poderia agir sem pedir licença a ninguém. São declarações de Levy.
"O que se vê desde a época da transição é um interesse crocodilal em situações desnecessárias", escreveu Carlos nesta quinta. "Aos que pedem para eu parar, digo que se informar ou não é uma escolha e estamos todos no mesmo barco chamado Brasil, mas nos recuperando."
Esta cartinha está até bem elegante. O que se vê desde a época da transição é um "interesse" "crocodilal" em situações desnecessárias. Aos que pedem para eu parar, digo que se informar ou não é uma escolha e estamos todos no mesmo barco chamado Brasil, mas nos recuperando! https://t.co/Ruzs27YexQ
Ontem, após dizer que não estava apenas "reclamando" do vice no Twitter, Carlos ironizou possíveis associações de suas críticas a Mourão a um suposto apoio a pedidos de impeachment. "Dou gargalhadas quando algum ser tenta induzir que busco impeachment de quem quer que seja. Informar e mostrar a verdade de posicionamentos inadequados e anteriores a qualquer crítica por mim revelada virou motivo para distorções e fake news."
Carlos Bolsonaro tem feito diversas publicações contra Mourão. Também na quarta, replicou um vídeo do youtuber Bernardo Küster intitulado "General Mourão: o traidor?", com o comentário: "Vice contraria ministros e agenda que elegeu Bolsonaro presidente".
Ainda na quarta, respondeu ao próprio Fidelix, depois que ele compartilhou um vídeo em que o deputado Otoni de Paula (PSC-RJ) critica quem "patrocina" rusgas entre o vice e o presidente Jair Bolsonaro. Carlos não é citado nem no vídeo e nem no tuíte do presidente do PRTB.
"Suas posturas nunca foram novidades para ninguém. Não enganam ninguém. Bichinhos característicos, lamentavelmente!", escreveu Carlos. Em resposta a um seguidor que compartilhou o vídeo e escreveu "esse é o culpado, articulando nas costas do Presidente", Carlos respondeu: "Precisa desenhar?"
Entorno
Outros aliados e pessoas próximas de Jair Bolsonaro também estão envolvidos nas rusgas públicas entre Mourão e Carlos. Na quarta, o o jornal O Estado de S. Paulo publicou uma entrevista com o deputado federal Eduardo Bolsonaro (PSL-SP), irmão de Carlos, em que o parlamentar endossa as críticas do irmão. Para ele, as declarações de Mourão têm causado "ruído" e Carlos está "apenas reagindo".
ID: {{comments.info.id}}
URL: {{comments.info.url}}
Ocorreu um erro ao carregar os comentários.
Por favor, tente novamente mais tarde.
{{comments.total}} Comentário
{{comments.total}} Comentários
Seja o primeiro a comentar
Essa discussão está encerrada
Não é possivel enviar novos comentários.
Essa área é exclusiva para você, , ler e comentar.
Só s do UOL podem comentar
Ainda não é ? Assine já.
Se você já é do UOL, faça seu .
O autor da mensagem, e não o UOL, é o responsável pelo comentário. Reserve um tempo para ler as Regras de Uso para comentários.