;(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
Logo Pagbenk Seu dinheiro rende mais
Topo

Pão de Açúcar lança site de venda de vinhos, que entrega em São Paulo em 4h

Pão de Açúcar Adega inaugura loja de bebidas em São Paulo - Divulgação
Pão de Açúcar Adega inaugura loja de bebidas em São Paulo Imagem: Divulgação

Colaboração para o UOL, em São Paulo

17/12/2018 11h48

O Pão de Açúcar lançou um site para venda de bebidas, com destaque para vinhos --mercado que já conta com marcas como Wine.com e Evino. O Pão de Açúcar Adega fará entregas em todo o Brasil, inclusive em cidades em que o grupo não tem lojas. O tempo de entrega varia de acordo com o local, mas para a capital paulista a promessa é de até quatro horas.

A plataforma também conta com uma loja física em São Paulo, no bairro dos Jardins, inaugurada na quinta-feira (13). O Viva Vinhos, programa de s da rede, estará integrado à novidade. 

São quase 2.000 rótulos à disposição no site e cerca de 1.400 na loja física, de 16 diferentes países, com preços entre R$ 40 e R$ 8.000. 

"Lançamos a plataforma pensando em um consumidor multicanal que tem cada vez mais interesse em se relacionar com as marcas em diversas interfaces", disse Frederic Garcia, diretor-executivo dos Formatos de Proximidade, Postos e Drogarias da empresa.

Segundo dados da companhia, o Pão de Açúcar espera fechar o ano de 2018 com cerca de 12 milhões de garrafas vendidas -número que cresce cerca de 10% ao ano.

James Delivery

O Pão de Açúcar firmou, na última semana, um acordo para a compra da startup brasileira James Delivery, de encomenda e entrega de produtos, como parte dos investimentos para avançar no canal online de varejo alimentar. 

Com 18 funcionários e uma base de 700 entregadores ativos, o James Delivery opera apenas em Curitiba (PR) e Balneário Camboriú (SC), por enquanto, mas o grupo espera expandir o serviço para todas as regiões em que atua de forma relevante até o fim de 2019.

Descubra quatro maneiras para abrir um vinho sem saca-rolha

Universa