Como criar uma listagem de 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 Framework “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°.

