Caricamento di una raccolta di prodotti tramite un valore a discesa specifico Attributo
-
13-12-2019 - |
Domanda
Sto cercando di caricare un prodotto virtuale specifico con le sue opzioni personalizzate, ma continuo a ricevere un array vuoto.
Il mio attributo è 'part_identificatore' nel set di attributi 'boach_part' è un attributo di tipo a discesa con diverse opzioni.L'opzione che sto cercando di tirare è "look".
Ecco il mio codice:
$attribute = 'msh_boat_part_identifier';
$boatLookProducts = Mage::getModel('catalog/product')
->getCollection()
->addAttributeToSelect('*')
->addAttributeToFilter($attribute, array('like'=>'Look'))
->load()
->getItems();
foreach($boatLookProducts as $boatLookProduct)
{
$return[] = array(
"id" => (int)$boatLookProduct->getEntityId(),
"name" => $boatLookProduct->getName(),
"type" => "profile",
"shortDesc" => $boatLookProduct->getShortDescription(),
"desc" => $boatLookProduct->getDescription(),
"active" => ($boatLookProduct->getStatus() === "2" ? false : true)
);
}
echo Mage::helper('pb')->ConvertToJson($return);
.
Nella mia query per la raccolta, se cambio l'array su
->addAttributeToFilter($attribute, array('like'=>'%%'))
.
Restituirà con successo tutti i prorisi, ma non riesco a ottenere quello specifico che voglio!
Soluzione
AS part_identifier
è un attributo a discesa, non è possibile filtrare la raccolta dall'etichetta dell'opzione.
Per filtrare una raccolta da un'opzione, è necessario ottenere l'ID dell'etichetta di opzione (valore dell'opzione effettivo).
Quindi è possibile filtrare la raccolta da quell'ID opzione:
// use your own attribute code here
$attributeCode = 'your_attribute_here';
$attributeOption = 'Look';
$attributeDetails = Mage::getSingleton('eav/config')
->getAttribute(Mage_Catalog_Model_Product::ENTITY, $attributeCode);
$options = $attributeDetails->getSource()->getAllOptions(false);
$selectedOptionId = false;
foreach ($options as $option){
// print_r($option) and find all the elements
echo $option['value'];
echo $option['label'];
if ($option['label'] == $attributeOption) {
$selectedOptionId = $option['value'];
}
}
if ($selectedOptionId) {
$products = Mage::getModel('catalog/product')
->getCollection()
->addAttributeToSelect('*')
->addAttributeToFilter($attributeCode, array('eq' => $selectedOptionId))
}
. Altri suggerimenti
Questo è in ritardo e forse nemmeno valido al momento della domanda, anche se ho trovato un modo più conciso facendo:
$attributeOptionId = Mage::getSingleton('eav/config')
->getAttribute(Mage_Catalog_Model_Product::ENTITY, 'your_attribute_code')
->getSource()
->getOptionId('Option Text Value/Label');
.
Quindi lo usi nel filtro di raccolta come al solito