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

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

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';
 
	}
}

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.