Magento 2

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

Como montar uma Collection com produtos no Magento 2 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

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás