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';
}
}
Segurança: Atualizações frequentes geralmente incluem patches de segurança para corrigir vulnerabilidades identificadas. Ao manter o Magento atualizado, você reduz significativamente…
Como adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2 Injete o Magento\Framework\Message\ManagerInterface no construtor da sua…
Para exibir as mensagens adicionadas na classe Magento\Framework\Message\ManagerInterface em um arquivo .phtml, você pode usar o seguinte código: <?php $objectManager…
Para criar um script no Magento 2 que exporte as categorias para um arquivo XML com o nome da categoria,…
Para definir um vídeo MP4 como plano de fundo em um <div> usando HTML e CSS, você pode seguir estas…
Como desativar o "lastname" no Magento 2 e Adobe Commerce Desativando a obrigatoriedade do campo Execute a SQL abaixo diretamente…