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

Ataque em escola deixa ao menos 11 mortos na Rússia

Do UOL, em São Paulo*

11/05/2021 07h24

Ao menos 11 pessoas morreram hoje em um ataque a uma escola de Kazan, cidade da região central da Rússia, informaram as agências de notícias Interfax e Ria Novosti. Um dos atiradores foi morto.

Este é o pior tiroteio em uma escola russa desde 2018. Incidentes violentos em estabelecimentos escolares e envolvendo alunos são relativamente raros no país, onde há um controle rígido de armas, mas estão em alta nos últimos anos.

Segundo os serviços de socorro, citados pelas agências Tass e Ria Novosti, nove das onze vítimas eram estudantes. Ao menos 32 pessoas ficaram feridas. Mais de 20 ambulâncias foram enviadas ao local para socorrer as vítimas.

"As forças de segurança prenderam um adolescente, suspeito de ser o autor dos tiros", informou uma fonte policial. Um dirigente do Tartaristão, a república muçulmana da Rússia cuja capital é Kazan, detalhou que o detido tem 19 anos e possui autorização de porte de arma.

A imprensa russa informa que um segundo suspeito, que se escondeu dentro da escola, foi morto pelos policiais que invadiram o local. "Ouvimos uma explosão na escola e vimos muita fumaça", declarou uma testemunha, não identificada, citada pela Ria Novosti. Uma professora, entrevistada pela Tass, confirmou que estava na sala de aula quando ouviu "primeiro uma explosão e depois os tiros".

As autoridades do Tartaristão anunciaram o reforço das medidas de segurança em todas as escolas da cidade. Kazan tem 1,2 milhões de habitantes e fica a cerca de 700 km a leste de Moscou.

Tiroteios precedentes

O tiroteio de Kazan lembra o ocorrido em outubro de 2018. Há três anos, 19 pessoas foram mortas por um estudante do ensino médio em um liceu de Kertch, cidade da península ucraniana da Crimeia, anexada pela Rússia em 2014. Na época, o presidente Vladimir Putin denunciou a "globalização" que influenciou esse tipo de tiroteio, estimando ser um fenômeno proveniente dos Estados Unidos.

A Rússia também viveu um drama em uma escola em novembro de 2019, quando um estudante matou um colega e feriu três, antes de se suicidar, em Blagovechtchensk, pequena cidade do extremo oriente russo, na fronteira com a China.

As autoridades russas garantem que evitaram nos últimos anos dezenas de projetos de ataques contra estabelecimentos escolares, envolvendo principalmente adolescentes. Em fevereiro de 2020, os Serviços de Segurança (FSB) detiveram dois jovens de 15 anos e nacionalidade russa que faziam nas redes sociais apologia à violência a ao suicídio. De acordo com os investigadores, eles planejavam atacar uma escola em Saratov, nas margens do rio Volga.

O país tem também um histórico de tiroteios em instalações militares, envolvendo recrutas que foram vítimas de trote. Em novembro de 2020, três militares foram mortos por um colega na região de Voronej, no Oeste do país, e um ano depois que oito pessoas morreram em uma base militar da Sibéria.

Um tiroteio na sede do FSB de Moscou em dezembro de 2019 continua até hoje sem explicação. O atirador solitário conseguiu matar dois agentes dos serviços de inteligência, antes de ser abatido.

*Com informações das agências AFP e RFI.