2013-02-08 55 views
0

我必須通過排序在Magento 1.7.0.2客戶羣爲了,我嘗試按照Magento的維基:排序順序按客戶羣在Magento 1.7

http://www.magentocommerce.com/wiki/5_-_modules_and_development/admin/sort_order_by_customer_groups

但它沒有工作。

我將app/code/core/Mage/Adminhtml/Block/Sales/Order/Grid.php複製到app/code/local/Mage/Adminhtml/Block/Sales/Order/Grid.php以不觸及magento核心。

我這個代碼添加到該功能

protected function _prepareColumns(){ 

$this->addColumn('customer_group_id', array(
       'header'=> Mage::helper('customer')->__('Customer Group'), 
       'width' => '80px', 
       'index' => 'group_id', 
       'renderer' => new Mage_Adminhtml_Block_Sales_Order_Renderer_CustomerGroup(), 
       'type' => 'options', 
       'options' => Mage_Adminhtml_Block_Sales_Order_Renderer_CustomerGroup::getCustomerGroupsArray(), 
     )); 

// now the code original 
} 

其次,在同一文件中我添加此覆蓋功能

protected function _addColumnFilterToCollection($column) { 

     if ($this->getCollection()) { 
      $field = ($column->getFilterIndex()) ? $column->getFilterIndex() : $column->getIndex(); 
      if ($column->getFilterConditionCallback()) { 
       call_user_func($column->getFilterConditionCallback(), $this->getCollection(), $column); 
      } 
      else { 
       $cond = $column->getFilter()->getCondition(); 
       if ($field && isset($cond)) { 
        if (in_array('NULL', array_values($cond))) { 
         $this->getCollection()->addFieldToFilter($field, array('null' => true)); 
        } 
        else {      
         $this->getCollection()->addFieldToFilter($field, $cond); 
        } 
       } 
      } 
     } 
     return $this; 
    } 

第三,在Grid.php我修改這個功能:

protected function _prepareCollection() 
    { 
     $collection = Mage::getResourceModel($this->_getCollectionClass()); 

     $collection->getSelect()->joinLeft(
      array('ce'=>'customer_entity'), 
      'ce.entity_id=main_table.customer_id', 
      array('ce.group_id') 
     ); 
     $this->setCollection($collection); 
     return parent::_prepareCollection(); 
    } 

現在我在app/code/local/Mage/Adminhtml/Block/Sales/Order/Renderer/CustomerGroup.php中創建這個文件wi個這樣的代碼:

class Mage_Adminhtml_Block_Sales_Order_Renderer_CustomerGroup 
extends Mage_Adminhtml_Block_Widget_Grid_Column_Renderer_Abstract { 

    // Holds an associative array with customer_group_id and the associated label 
    private static $_customerGroups = array(); // "singleton" 

    public static function getCustomerGroupsArray() { 
     // Make sure the static property is only populated once 
     if (count(self::$_customerGroups) == 0) { 
      $customer_group = new Mage_Customer_Model_Group(); 
      $customer_groups = $customer_group->getCollection()->toOptionHash(); 
      self::$_customerGroups = $customer_groups; 
     } 

     return self::$_customerGroups; 
    } 

    // Transforms the customer_group_id into corresponding label 
    public function render(Varien_Object $row) 
    { 
     $val = $this->_getValue($row); 
     $customer_groups = self::getCustomerGroupsArray(); 
     return isset($customer_groups[$val]) ? $customer_groups[$val] : false; 
    } 

} 

我有此錯誤:

:5:{I 0,S:92:「SQLSTATE [42S22]:柱未找到:1054未知列 'customer_group_id' in'where clause'「; i:1; s:5645:」#0 MyProjectFolder \ lib \ Varien \ Db \ Statement \ Pdo \ Mysql.php(111):Zend_Db_Statement_Pdo - > _ execute(Array)

謝謝提前 !

+0

嘗試在你的第一個代碼通過更換GROUP_ID到customer_group_id適合的列名,或者添加一個別名 – dagfr 2013-02-08 14:22:27

回答

0

我發現在Magento論壇解決方案,有人給了我正確的解決方案:

protected function _prepareCollection() 
{ 
     $collection = Mage::getResourceModel($this->_getCollectionClass()); 

     $collection->getSelect()->join(
      array('oe'=>'sales_flat_order'), 
      'oe.entity_id=main_table.entity_id', 
      array('oe.customer_group_id') 
     ); 
     $this->setCollection($collection); 
     return parent::_prepareCollection(); 
}