*/ class Mage_Reports_Model_Resource_Customer_Orders_Collection extends Mage_Reports_Model_Resource_Order_Collection { protected function _construct() { parent::_construct(); $this->_useAnalyticFunction = true; } /** * Join fields * * @param string $from * @param string $to * @return Mage_Reports_Model_Resource_Customer_Orders_Collection */ protected function _joinFields($from = '', $to = '') { $this->joinCustomerName() ->groupByCustomer() ->addOrdersCount() ->addAttributeToFilter('created_at', array('from' => $from, 'to' => $to, 'datetime' => true)); return $this; } /** * Set date range * * @param string $from * @param string $to * @return Mage_Reports_Model_Resource_Customer_Orders_Collection */ public function setDateRange($from, $to) { $this->_reset() ->_joinFields($from, $to); return $this; } /** * Set store filter to collection * * @param array $storeIds * @return Mage_Reports_Model_Resource_Customer_Orders_Collection */ public function setStoreIds($storeIds) { if ($storeIds) { $this->addAttributeToFilter('store_id', array('in' => (array)$storeIds)); $this->addSumAvgTotals(1) ->orderByOrdersCount(); } else { $this->addSumAvgTotals() ->orderByOrdersCount(); } return $this; } }