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

São Paulo

São Paulo deve receber R$ 6 milhões do Barcelona por jovem promessa

Gustavo Maia se destacou pelo São Paulo na Copinha - Rubens Chiri/saopaulofc.net
Gustavo Maia se destacou pelo São Paulo na Copinha Imagem: Rubens Chiri/saopaulofc.net

José Eduardo Martins e Thiago Fernandes

Do UOL, em São Paulo

09/07/2020 04h00

O São Paulo espera receber ainda nesta semana 1 milhão de euros (cerca de R$ 6,1 milhões na cotação atual) referente à opção de compra do Barcelona pelo atacante Gustavo Maia. A expectativa é de que até a próxima quarta-feira (15) os espanhóis fechem a transação em definitivo e tenham de desembolsar mais 3,5 milhões de euros (R$ 21,2 milhões) — sendo que ainda está sendo negociado como esse pagamento seria parcelado.

Pessoas ligadas ao jovem atleta de 19 anos já dão a transação como certa. A ideia é de o jogador se apresentar entre agosto e setembro ao clube espanhol. Além do Barcelona, outras equipes da Europa já demonstraram interesse no jovem no mercado da bola. O Atlético de Madri e o Liverpool chegaram a sondar pessoas próximas do garoto da base tricolor.

Nas últimas semanas, representantes do jogador conversaram com os espanhóis e com dirigentes do Tricolor. Por causa da pandemia do novo coronavírus e da crise financeira, o Barcelona demorou mais do que o esperado para efetivar o pagamento da opção de compra, que já havia sido fechada no início do ano.

Com contrato até 30 de junho 2022, Maia foi um dos destaques do São Paulo na Copinha. Ele marcou três gols em sete partidas da competição. O jovem foi um dos novatos na lista de relacionados para a partida contra o Botafogo-SP, pelo Campeonato Paulista, quando o treinador Fernando Diniz poupou os principais atletas do elenco.

Para o São Paulo, a verba que chegará pode ajudar a minimizar os problemas financeiros. O clube, que já havia fechado 2019 com déficit de R$ 156 milhões, cortou os salários dos jogadores em 50% durante a pandemia.

São Paulo