Magento

Produtos mais visualizados no Magento – Criando uma lista

Tutorial com código fonte para montar uma lista com os produtos mais visualizados no nos últimos 90 dias.

Exemplo com filtro por período (nos últimos 90 dias)

No código abaixo, estou buscando os produtos mais visualizados nos últimos 90 dias.

/*Qtd de produtos */$qtdProdutos = 5; 
    
$storeId = Mage::app()->getStore()->getId(); 

/* Data atual */$hoje = time();

/* 90 dias atrás.. altere o 90 para quantidade que você desejar */$ultimo = $hoje - (60*60*24*90);
 
$de = date("Y-m-d", $ultimo);
$ate = date("Y-m-d", $hoje);

    
/* Adiciono os filtros na minha collection */$products = Mage::getResourceModel('reports/product_collection')
        ->addAttributeToSelect('*')        
        ->setStoreId($storeId)
        ->addStoreFilter($storeId)
        ->addViewsCount($de, $ate)
        ->setPageSize($qtdProdutos); 
    

   
foreach($products as $product){
 echo $product->getName();
}

Lembrando, se você for carregar o código em um arquivo externo, fora do Magento utilize:

/* Atenção com o caminho completo até o Mage.php */require_once 'app/Mage.php';
umask(0);
Mage::app('default');

Outro fato importante sobre o código é que ele depende que as estatísticas dos relatórios do Magento estejam atualizadas.

Como atualizar as estatísticas: http://docs.magento.com/m1/ce/user_guide/store-operations/reports-refresh.html

Se você não deseja filtrar os mais visualizados por um período, utilize o exemplo abaixo:

$qtdProdutos = 5; 
    
$id_loja = Mage::app()->getStore()->getId();       
    

$productsCollection = Mage::getResourceModel('reports/product_collection')
        ->addAttributeToSelect('*')        
        ->setStoreId($id_loja)
        ->addStoreFilter($id_loja)
        ->addViewsCount()
        ->setPageSize($qtdProdutos); 
    
Mage::getSingleton('catalog/product_status')
            ->addVisibleFilterToCollection($productsCollection);

Mage::getSingleton('catalog/product_visibility')
            ->addVisibleInCatalogFilterToCollection($productsCollection);
   
   
foreach($products as $product){
 echo $product->getName();
}

 

Resumo
Nome do Artigo
Produtos mais visualizados no Magento
Descrição
Tutorial de como montar uma lista com os produtos mais visualizados no Magento
Autor
Editor
Roger Mauricio Takemiya
Logo do Editor

Ver comentários

  • Roger por favor.. Preciso de ajuds para criar uma listagem filtrando por atributos personalizados, como faço? Muito obrigado!

    • Julia, boa tarde,

      É bem simples, na "collection" utilize o seguinte método: addAttributeToFilter(), exemplo:
      $collection->addAttributeToFilter('codigo_atributo', '678678');

      Primeiro campo é o código do atributo personalizado / customizado e o segundo o valor.

Post Recentes

Por que devo sempre manter o Magento 2 atualizado?

Segurança: Atualizações frequentes geralmente incluem patches de segurança para corrigir vulnerabilidades identificadas. Ao manter o Magento atualizado, você reduz significativamente…

4 semanas atrás

Adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2

Como adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2 Injete o Magento\Framework\Message\ManagerInterface no construtor da sua…

1 mês atrás

Exibir mensagens erro/sucesso da Classe: Magento\Framework\Message\ManagerInterface

Para exibir as mensagens adicionadas na classe Magento\Framework\Message\ManagerInterface em um arquivo .phtml, você pode usar o seguinte código: <?php $objectManager…

1 mês atrás

Exportar as categorias do Magento 2 em um XML

Para criar um script no Magento 2 que exporte as categorias para um arquivo XML com o nome da categoria,…

2 meses atrás

Colocar um video como Background utilizando HTML + CSS

Para definir um vídeo MP4 como plano de fundo em um <div> usando HTML e CSS, você pode seguir estas…

4 meses atrás

Desativar o “lastname” no Magento 2

Como desativar o "lastname" no Magento 2 e Adobe Commerce Desativando a obrigatoriedade do campo Execute a SQL abaixo diretamente…

4 meses atrás