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

Avião da FAB que levava ajuda humanitária ao Haiti sofre pane em terra

22.08.2021 -- Carga da missão de apoio ao Haiti sendo embarcada na aeronave KC-390 Millennium, da FAB - Ministério da Defesa
22.08.2021 -- Carga da missão de apoio ao Haiti sendo embarcada na aeronave KC-390 Millennium, da FAB Imagem: Ministério da Defesa

Do UOL, em São Paulo

22/08/2021 18h32

O avião da Força Aérea Brasileira (FAB) que decolou na manhã de hoje (22) para transportar a missão humanitária do Brasil ao Haiti, atingido por terremoto em 14 de agosto, sofreu uma pane em solo no início da tarde, enquanto fazia uma parada já prevista no sul do Pará.

A aeronave precisará ser trocada, o que vai atrasar a chegada da ajuda brasileira ao Haiti. A previsão é que o segundo avião prossiga ainda hoje para Boa Vista (RR) e decole amanhã rumo a Porto Príncipe, capital do Haiti.

"O pouso técnico na Base Aérea do Cachimbo, localizada no sul do Pará, ocorreu normalmente e já estava previsto originalmente na rota. Por uma questão técnica, houve a necessidade da troca por outra aeronave do mesmo tipo, realizando-se a transposição da carga e dos ageiros naquela localidade", informou o Ministério da Defesa, por nota.

Na sexta-feira (20), o primeiro-ministro do Haiti, Ariel Henry, disse que "quase 700 mil pessoas precisam de assistência humanitária emergencial" após o terremoto. O sismo, de magnitude 7.2 na escala Richter, deixou mais de 2,2 mil mortos e 300 desaparecidos. Grandes áreas terão que ser reconstruídas.

Avião de transporte da missão humanitária brasileira

A aeronave que apresentou problema é a KC-390 Millennium. Segundo o Ministério da Defesa, é o maior avião desenvolvido no Brasil, fruto de parceria entre a FAB e a Embraer.

O avião decolou da base aérea de Brasília levando 32 bombeiros —a maioria especialistas em busca e salvamento e ações pós-desastre, além de um especialista em sismologia— e cerca de 10,5 toneladas de equipamentos de emergência, medicamentos e insumos de saúde.

Fazem parte da carga cinco kits de medicamentos e insumos para emergência em saúde, com capacidade total de atendimento de 50 mil pessoas, além de medicamentos de farmácia básica e insulina. "Tudo identificado com base nas necessidades prioritárias e atuais da população haitiana", segundo anúncio do Ministério da Defesa.

A missão humanitária brasileira será comandada pelo Corpo de Bombeiros Militar do Distrito Federal, com apoio do Corpo de Bombeiros Militar de Minas Gerais e da Força Nacional de Segurança Pública.

Em uma cerimônia realizada antes do embarque, o presidente Jair Bolsonaro (sem partido) disse que os membros da missão "orgulham a todos nós brasileiros".

"Uma vez mais, o povo haitiano se vê em necessidade de ajuda. Prontamente, o Governo Federal se mobilizou para oferecer necessária ação humanitária com meios de pessoal e material, além do apoio afetivo, vital neste momento de dor", disse o Ministro da Defesa, Walter Souza Braga Netto.