Magento - 如何检索捆绑的选项图像

时间:2012-07-03 20:46:29

标签: image magento options

我一直致力于我的第一次magento部署。建立了一个非常自定义的主题......现在处理一些非标准的自定义:

我的主要产品类型之一是办公椅,我将其设置为捆绑产品。此产品类型有多种选择(约100种面料选项,手臂式,腰部,头枕等),我需要能够在目录/产品/视图页面上显示每种产品的图像。

作为捆绑产品(并且我不会讨论这是否是正确的产品类型 - 我们在可配置和捆绑之间进行辩论 - 每个产品都是从一些简单的产品组装而成的产品(作为选项)。这些简单的产品可以上传图像,我已经这样做了。 我现在想要检索媒体文件夹中的网址...

经过一些狩猎 - 这些似乎是必不可少的元素:

主题/../模板/目录/产品/视图/ options.phtml

<?php $_options = Mage::helper('core')->decorateArray($this->getOptions()) ?>
<dl>
    <?php foreach($_options as $_option): ?>
        <?php echo $this->getOptionHtml($_option) ?>
    <?php endforeach; ?>
</dl>

主题/../模板/束/目录/产品/视图/类型/捆/选项/ select.phtml

<?php /* @var $this Mage_Bundle_Block_Catalog_Product_View_Type_Bundle_Option_Select */ ?>
<?php $_option      = $this->getOption(); ?>
<?php $_selections  = $_option->getSelections(); ?>

我发现终于找到了 getSelections()

class Mage_Bundle_Model_Resource_Price_Index extends Mage_Core_Model_Resource_Db_Abstract
{ ...


    /**
        * Retrieve bundle options with selections and prices by product
       *
        * @param int $productId
        * @return array
        */
       public function getSelections($productId)
       {
           $options = array();
           $read = $this->_getReadAdapter();
           $select = $read->select()
               ->from(
                   array('option_table' => $this->getTable('bundle/option')),
                   array('option_id', 'required', 'type')
               )
               ->join(
                   array('selection_table' => $this->getTable('bundle/selection')),
                   'selection_table.option_id=option_table.option_id',
                   array('selection_id', 'product_id', 'selection_price_type',
                       'selection_price_value', 'selection_qty', 'selection_can_change_qty')
               )
               ->join(
                   array('e' => $this->getTable('catalog/product')),
                   'e.entity_id=selection_table.product_id AND e.required_options=0',
                   array()
               )
               ->where('option_table.parent_id=:product_id');

           $query = $read->query($select, array('product_id' => $productId));
           while ($row = $query->fetch()) {
               if (!isset($options[$row['option_id']])) {
                   $options[$row['option_id']] = array(
                       'option_id'     => $row['option_id'],
                       'required'      => $row['required'],
                       'type'          => $row['type'],
                       'selections'    => array()
                   );
               }
               $options[$row['option_id']]['selections'][$row['selection_id']] = array(
                   'selection_id'      => $row['selection_id'],
                   'product_id'        => $row['product_id'],
                   'price_type'        => $row['selection_price_type'],
                   'price_value'       => $row['selection_price_value'],
                   'qty'               => $row['selection_qty'],
                   'can_change_qty'    => $row['selection_can_change_qty']
               );
           }

           return $options;
       }

所以我们返回一个包含selection_idproduct_idprice_type等的数组...但没有任何内容涉及该选择的图片网址...

鉴于:

class Mage_Catalog_Helper_Product extends Mage_Core_Helper_Url
{ ...
public function getImageUrl($product)
        {
            $url = false;
            if (!$product->getImage()) {
                $url = Mage::getDesign()->getSkinUrl('images/no_image.jpg');
            }
            elseif ($attribute = $product->getResource()->getAttribute('image')) {
               $url = $attribute->getFrontend()->getUrl($product);
           }
           return $url;
       }

我试图在主题/../ template / bundle / catalog / product / view / type /中构建一个带有refs的js对象,每个选择的图像url都是这样的束/选项/ select.phtml

var option_set_<?php echo $_option->getId() ?> = {};
<?php foreach ($_selections as $_selection): ?>
    option_set_<?php echo $_option->getId() ?>._<?php echo $_selection->getSelectionId() ?> = '<?php echo $_selection->getImageUrl(); ?>';
<?php endforeach; ?>

$_selection显然没有正确输入,因为它只是将我弹回占位符图形。

假设这些选项可以作为产品输入(或以某种方式从 selection_id 获得简单的产品,似乎这样的东西可以工作。我不确定是否会这样做&#39 ;正是我想要管理这个功能的方式,但如果我能得到一堆网址 - 那么我就会开展业务

奇怪的是,这个主题上的互联网基本上是无声的。显然,没有人需要为他们的产品选项显示图像(或者更确切地说,唯一的解决方案是付费扩展 - 这将是最后的手段)。

我怎么能搞清楚这个?

耶稣传教基督。 Mage会变得更复杂吗?


更新

让这个工作:

<?php echo $this->helper('catalog/image')->init($_selection, 'small_image')->resize(40,40); ?>

如果有人需要此修复程序,我选择的答案也可以正常工作。

1 个答案:

答案 0 :(得分:3)

$ _selections中的product_id表示所选简单产品的ID。 所以要做的就是:

  1. 获取$ _selections的product_id,
  2. 通过此product_id
  3. 加载产品
  4. 将生成的产品对象提供给Mage_Catalog_Helper_Product :: getImageUrl。