2013-04-11 2 views
1

특별 가격 세트가있는 모든 제품을 표시하는 페이지를 개발 중입니다.이 스크립트로 제품 반복을 피하는 방법 (Magento)

"정상적인"설정을 사용하면 쉽지만 그룹화 된 제품 만 표시됩니다. 모든 단순 제품은 그룹화 된 제품과 관련된 SKU입니다. 그룹으로 묶인 제품에는 DESKING, 제품 이름 등과 같은 모든 일반 정보가 포함되어 있으며 Simple Products에는 SKU, 가격, VAT 등의 정보가 포함되어 있습니다.

이 점을 염두에두고 모든 간단한 제품 특별 가격이 적용되고 "상위"그룹화 된 제품이로드됩니다.

작동하지만 새로운 문제가 발생합니다. 두 개 이상의 특별 가격 SKU가 포함 된 그룹화 된 제품이 있습니다. 즉, 해당 제품은 페이지에 두 번, 세 번 또는 더 많이 표시됩니다. 내 코드를 고려하면 의미가 있습니다.

<?php $storeId = Mage::app()->getStore()->getStoreId(); ?> 

<?php 
$todayDate = Mage::app()->getLocale()->date()->toString(Varien_Date::DATETIME_INTERNAL_FORMAT); 
$special= Mage::getResourceModel('reports/product_collection') 
    ->addAttributeToSelect('*') 
    ->addAttributeToFilter('visibility', array('neq'=>1)) 
    ->addAttributeToFilter('special_price', array('neq'=>'')) 
    ->addAttributeToFilter('special_from_date', array('date' => true, 'to' => $todayDate)) 
    ->addAttributeToFilter('special_to_date', array('or'=> array(
    0 => array('date' => true, 'from' => $todayDate), 
    1 => array('is' => new Zend_Db_Expr('null'))) 
), 'left') 
    ->addAttributeToSort('special_from_date', 'desc'); 
$special->load(); 
?> 

<div class="cat-misc"> 
    <?php $_columnCount = 4;?> 

    <?php foreach ($special as $_product): ?> 
    <?php if ($i++%$_columnCount==0): ?> 
     <ul class="products-grid"> 
    <?php endif ?> 

     <?php $parentIds = Mage::getModel('catalog/product_type_grouped')->getParentIdsByChild($_product->getId()); ?> 
     <?php if(isset($parentIds[0])):?> 
      <?php foreach ($parentIds as $parentId): ?> 
       <?php $parent = Mage::getModel('catalog/product')->load($parentId); ?> 
       <?php if ($parent->getStoreId() == $storeId): ?> 
        <?php $_product = Mage::getModel('catalog/product')->load($parentId);?> 
        <?php endif; ?> 
       <?php endforeach; ?> 
     <?php endif; ?> 

    <li class="item<?php if(($i-1)%$_columnCount==0): ?> first<?php elseif($i%$_columnCount==0): ?> last<?php endif; ?>"> 

     <div class="produtos_wrapper"> 
      <a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $this->htmlEscape($this->getImageLabel($_product, 'small_image')) ?>" class="product-image"><img src="<?php echo $this->helper('catalog/image')->init($_product, 'small_image')->resize(158, 158); ?>" width="158" height="158" alt="<?php echo $this->htmlEscape($this->getImageLabel($_product, 'small_image')) ?>" /></a> 

      <?php 
      $newFromDate = Mage::getModel('catalog/product')->load($_product->getID())->getNewsFromDate(); 
      $newToDate = Mage::getModel('catalog/product')->load($_product->getID())->getNewsToDate(); 

      $now = date("Y-m-d H:m:s"); 

      if($newFromDate < $now && $newToDate > $now) { 
       echo "<div id='simbolo_novo' class='simbolo_novo'></div>"; 
      } 
      ?> 

      <div class="titulos_wrapper"> 
       <p class="product-name"><a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $this->htmlEscape($_product->getName()) ?>"><?php echo $this->htmlEscape($_product->getName()) ?></a><br /><span class="subtitulo"><?php echo nl2br($_product->getShortDescription()); ?></span> </p> 
       <?php if($_product->getRatingSummary()): ?> 
       <?php echo $this->getReviewsSummaryHtml($_product, 'short') ?> 
       <?php endif; ?> 
      </div> 
     </div> 


     <div class="actions"> 
      <?php if($_product->isSaleable()): ?> 

      <?php else: ?> 
      <p class="availability out-of-stock"><span><?php echo $this->__('Out of stock') ?></span></p> 
      <?php endif; ?> 

      <?php if ($this->helper('wishlist')->isAllow()) : ?> 

      <?php endif; ?> 
      <?php if($_compareUrl=$this->getAddToCompareUrl($_product)): ?> 

      <?php endif; ?> 
      </ul--> 
     </div> 
    </li> 
    <?php if ($i%$_columnCount==0 || $i==$_collectionSize): ?> 
     </ul> 
     <?php endif ?> 

    <?php endforeach; ?> 

    <div class="toolbar-bottom"> 
     <?php echo $this->getToolbarHtml() ?> 
    </div> 
</div> 

내 질문은 그룹화 된 제품을 한 번만 표시하도록 어떻게 제한하겠습니까?

답변

3

귀하는이 방법을 수행 할 수 있습니다

$shown_skus = array() ; //Create an array to trace already displayed products 

foreach($products as $product){ 
    if (!in_array($product['sku'], $shown_skus, true)){ //If there is no sku in array 
    $shown_skus[] = $product['sku'] ; //Add the sku to the array 
    //And display the product as it has not been displayed yet. 
    } 
} 

보고서를하시기 바랍니다 솔루션을 맞는 경우.

+0

안녕하세요 Jari, 내 문제는 그룹화 된 제품이 두 번로드되고 그룹화 된 제품에 SKU가 없기 때문에 필자의 경우 코드가 변경되도록 코드를 변경해야했습니다. 그래서 방금 SKU 대신 ID를 배열에 넣었습니다. 또한 위의로드 상위 스크립트가 있어야했습니다. 고마워요! 정말로 훌륭한 솔루션이었습니다. 그렇게 생각 했어야합니다! :) – pedropeixoto

+0

당신은 오신 것을 환영합니다 ^^ – vikingmaster