*/ class Mage_Adminhtml_Block_Dashboard_Tab_Customers_Most extends Mage_Adminhtml_Block_Dashboard_Grid { public function __construct() { parent::__construct(); $this->setId('customersMostGrid'); } protected function _prepareCollection() { $collection = Mage::getResourceModel('reports/order_collection'); /* @var $collection Mage_Reports_Model_Mysql4_Order_Collection */ $collection ->groupByCustomer() ->addOrdersCount() ->joinCustomerName(); $storeFilter = 0; if ($this->getParam('store')) { $collection->addAttributeToFilter('store_id', $this->getParam('store')); $storeFilter = 1; } else if ($this->getParam('website')){ $storeIds = Mage::app()->getWebsite($this->getParam('website'))->getStoreIds(); $collection->addAttributeToFilter('store_id', array('in' => $storeIds)); } else if ($this->getParam('group')){ $storeIds = Mage::app()->getGroup($this->getParam('group'))->getStoreIds(); $collection->addAttributeToFilter('store_id', array('in' => $storeIds)); } $collection->addSumAvgTotals($storeFilter) ->orderByTotalAmount(); $this->setCollection($collection); return parent::_prepareCollection(); } protected function _prepareColumns() { $this->addColumn('name', array( 'header' => $this->__('Customer Name'), 'sortable' => false, 'index' => 'name' )); $this->addColumn('orders_count', array( 'header' => $this->__('Number of Orders'), 'sortable' => false, 'index' => 'orders_count', 'type' => 'number' )); $baseCurrencyCode = (string) Mage::app()->getStore((int)$this->getParam('store'))->getBaseCurrencyCode(); $this->addColumn('orders_avg_amount', array( 'header' => $this->__('Average Order Amount'), 'align' => 'right', 'sortable' => false, 'type' => 'currency', 'currency_code' => $baseCurrencyCode, 'index' => 'orders_avg_amount' )); $this->addColumn('orders_sum_amount', array( 'header' => $this->__('Total Order Amount'), 'align' => 'right', 'sortable' => false, 'type' => 'currency', 'currency_code' => $baseCurrencyCode, 'index' => 'orders_sum_amount' )); $this->setFilterVisibility(false); $this->setPagerVisibility(false); return parent::_prepareColumns(); } public function getRowUrl($row) { return $this->getUrl('*/customer/edit', array('id'=>$row->getCustomerId())); } }