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!

È stato utile?

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

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a magento.stackexchange
scroll top