/** * Display products by manufacturer * * @param $url * @throws CHttpException */ public function actionIndex($url) { $this->model = StoreManufacturer::model()->findByAttributes(array('url' => $url)); if (!$this->model) { throw new CHttpException(404, Yii::t('StoreModule.core', 'Производитель не найден.')); } $query = new StoreProduct(null); $query->attachBehaviors($query->behaviors()); $query->active(); $query->applyManufacturers($this->model->id); $provider = new CActiveDataProvider($query, array('id' => false, 'pagination' => array('pageSize' => $this->allowedPageLimit[0]))); $this->render('index', array('provider' => $provider)); }
/** * @return array of category manufacturers */ public function getCategoryManufacturers() { $cr = new CDbCriteria(); $cr->select = 't.manufacturer_id, t.id'; $cr->group = 't.manufacturer_id'; $cr->addCondition('t.manufacturer_id IS NOT NULL'); //@todo: Fix manufacturer translation $manufacturers = StoreProduct::model()->active()->applyCategories($this->model, null)->with(array('manufacturer' => array('with' => array('productsCount' => array('scopes' => array('active', 'applyCategories' => array($this->model, null), 'applyAttributes' => array($this->getOwner()->activeAttributes), 'applyMinPrice' => array($this->convertCurrency(Yii::app()->request->getQuery('min_price'))), 'applyMaxPrice' => array($this->convertCurrency(Yii::app()->request->getQuery('max_price')))))))))->findAll($cr); $data = array('title' => Yii::t('StoreModule.core', 'Производитель'), 'selectMany' => true, 'filters' => array()); if ($manufacturers) { foreach ($manufacturers as $m) { $m = $m->manufacturer; if ($m) { $model = new StoreProduct(null); $model->attachBehaviors($model->behaviors()); $model->active()->applyCategories($this->model)->applyMinPrice($this->convertCurrency(Yii::app()->request->getQuery('min_price')))->applyMaxPrice($this->convertCurrency(Yii::app()->request->getQuery('max_price')))->applyAttributes($this->getOwner()->activeAttributes)->applyManufacturers($m->id); $data['filters'][] = array('title' => $m->name, 'count' => $model->count(), 'queryKey' => 'manufacturer', 'queryParam' => $m->id); } } } return $data; }