Produtos randômicos – Magento

Como criar uma listagem de produtos randômicos no

produtos randômicos no Magento

Além da listagem randômica, irei ensinar como filtrar os produtos utilizando categorias.

1° – Preparando a “collection”

$_productCollection = Mage::getModel('catalog/product')->getCollection()
             ->addAttributeToSelect('*')
             ->addAttributeToFilter('status', 1)
             ->addAttributeToFilter('visibility', 4)  
             ->addStoreFilter();

Primeiro passo é a “collection” base que iremos utilizar para trazer nossos produtos.

Nela estou filtrando o status “habilitado” e a visibilidade 4, que significa “Catálogo e Busca”.

2° – Adicionando as categorias

Nessa primeira parte, estou preparando o array “conditions” com as condições para utilizar na nossa Query.

Repare que na variável “catfilters” estou passando um array com os IDs de cada categoria que será incluída na busca.

            $catfilters = array(1,20,32,44);
            $conditions = array();
            foreach ($catfilters as $categoryId) {
                if (is_numeric($categoryId)) {
                    $conditions[] = "{{table}}.category_id = $categoryId";
                }
            }

Segunda parte.

            $_productCollection->distinct(true)
                ->joinField('category_id', 'catalog/category_product', null, 'product_id = entity_id', implode(" OR ", $conditions), 'inner');        

Nesta segunda parte, estou utilizando o método “implode” com separador ” or “, para adicionar as categorias na condição dessa nossa “collection”.

Método “implode”, irá converter o array em uma unica string, separando cada elemento do array com ” or ” na string gerada.

3° – Definindo um limite e página para consulta.

 $_productCollection->setPageSize($limit)->setCurPage($page);

A variável “limit” no método “setPageSize” é a quantidade de registro que você deseja, já a “page” no método “setCurPage” é a página que será retornada, no caso você pode passar 1 para retornar os primeiros registros.

4° – Parte final, ordenando aleatoriamente.

$_productCollection->getSelect()->order(new Zend_Db_Expr('RAND()'));

Utilizando o método “order”, defino que a ordenação da minha consulta será randômica utilizando classe do Zend “Zend_Db_Expr”, que trará a expressão correta.

Pronto, para percorrer os registros, basta utilizar um “foreach”, igual exemplo abaixo.

foreach ($_productCollection as $_product){

// $_product->getName()

// $_product->getProductUrl()

// Mage::helper('catalog/image')->init($_product, 'small_image')->resize(170) 

}

Os campos do produto você pode acessar diretamente no objeto “_product”.

No código tem alguns exemplos comentando.

Obs. Caso você não queira filtrar as categorias dos produtos randômicos, basta pular o passo 2°.

 

 

Resumo
Como criar uma lista de Produtos randômicos no Magento
Nome do Artigo
Como criar uma lista de Produtos randômicos no Magento
Descrição
Criando uma lista de Produtos randômicos no Magento e adicionando um filtro para buscar apenas os produtos de um determinado grupo de categorias
Autor
Editor
Roger Mauricio Takemiya
Logo do Editor

Dúvidas? Faça um comentário logo abaixo ou envie uma mensagem clicando aqui.

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *