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