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

STF nega transferência de Adélio Bispo de presídio para hospital psiquiátrico

Adélio Bispo logo após ser detido ao tentar matar o então candidato à Presidência Jair Bolsonaro, em Juiz de Fora (MG), em 6 de setembro de 2018 - Guilherme Leite/Folhapress
Adélio Bispo logo após ser detido ao tentar matar o então candidato à Presidência Jair Bolsonaro, em Juiz de Fora (MG), em 6 de setembro de 2018 Imagem: Guilherme Leite/Folhapress

Redação

São Paulo

05/08/2021 11h11Atualizada em 05/08/2021 12h33

Por unanimidade, a Segunda Turma do Supremo Tribunal Federal (STF), em sessão virtual, manteve decisão que negou transferir Adélio Bispo, autor do atentado contra Jair Bolsonaro na campanha de 2018, para um hospital de custódia e tratamento psiquiátrico em Minas Gerais. Com a decisão, Adélio permanecerá na Penitenciária Federal de Campo Grande, onde está detido desde setembro de 2018.

No julgamento, os ministros analisaram um habeas corpus impetrado pela defesa de Adélio contra decisão do Superior Tribunal de Justiça (STJ) que o manteve na Penitenciária Federal de Campo Grande. Na ocasião, a corte entendeu que o local cumpria as exigências legais para o caso, uma vez que conta com Unidade Básica de Saúde e com atendimento médico psiquiátrico.

Ao Supremo, a defesa reiterou o argumento da inadequação do estabelecimento e a existência de vagas no Hospital Psiquiátrico Judiciário Jorge Vaz, em Barbacena (MG), e a presença de outros estabelecimentos adequados em Minas Gerais. As informações foram divulgadas pela corte.

O relator do recurso, ministro Kassio Nunes Marques, já havia negado a transferência do esfaqueador de Bolsonaro para o hospital psiquiátrico - e reforçou seu entendimento perante a Segunda Turma.

O ministro ponderou que o Código Penal estabelece, em regra, que a medida de segurança deve ser cumprida em hospital de custódia e tratamento psiquiátrico, mas que, na falta desse tipo de local ou na inexistência de vaga, a pena poderá ser cumprida em outro estabelecimento adequado.

Na avaliação do relator, as instâncias ordinárias deram cumprimento ao disposto Código Penal, considerando que, na falta de vagas em hospital de custódia e tratamento psiquiátrico ou de outro estabelecimento adequado em Minas Gerais, Adélio foi transferido para o estabelecimento federal, onde, segundo os autos, recebe tratamento em conformidade com a lei.