Magento 2

Collection de Produtos já com o Status do Estoque no Magento 2

Como montar uma Collection com produtos no já incluindo a situação em estoque de cada item

Código Fonte:

$collection = $collection->addAttributeToSelect(array(
        'name'    
    ))
    ->addPriceData()
    ->addAttributeToFilter('status', ['in' => $productStatus->getVisibleStatusIds()])
    ->setVisibility($productVisibility->getVisibleInSiteIds());
    
$collection->getSelect()->joinLeft(
        array('_inv' => $collection->getResource()->getTable('cataloginventory_stock_status')),
        "_inv.product_id = e.entity_id and _inv.website_id=$websiteId and _inv.stock_id=$stockId",
        array('stock_status')
    );

$collection->addExpressionAttributeToSelect('in_stock', 'IFNULL(_inv.stock_status,0)', array())
    ->addExpressionAttributeToSelect('qty', 'IFNULL(_inv.qty,0)', array())
    ->addAttributeToFilter('in_stock', array('eq' => 1));
    
$collection->load();

Na linha:

$collection->addExpressionAttributeToSelect(‘in_stock', ‘IFNULL(_inv.stock_status,0)', array())
->addExpressionAttributeToSelect(‘qty', ‘IFNULL(_inv.qty,0)', array())
->addAttributeToFilter(‘in_stock', array(‘eq' => 1));

Já estamos filtrando para retornar apenas os produtos que estão em estoque (in_stock = 1)

Caso você queira que retorne todos os itens, comente essa parte.

A checagem do estoque você poderá fazer depois, item á item:

foreach($collection as $p) {

 $data = $p->getData();

        $stock = 'in stock';

 if( $data['stock_status'] == 0 ){
             $stock = 'out of stock';
 
 }
}

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…

1 mês 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