Commit 865853392105a844d92d0be5601da92037b29749
Merge remote-tracking branch 'origin/master'
Showing
8 changed files
with
76 additions
and
27 deletions
Show diff stats
common/modules/product/models/BrandQuery.php
| ... | ... | @@ -31,4 +31,15 @@ class BrandQuery extends \yii\db\ActiveQuery |
| 31 | 31 | { |
| 32 | 32 | return parent::one($db); |
| 33 | 33 | } |
| 34 | + | |
| 35 | + /** | |
| 36 | + * Select brand by alias | |
| 37 | + * @param $slug | |
| 38 | + * @return $this | |
| 39 | + */ | |
| 40 | + public function byAlias($alias) | |
| 41 | + { | |
| 42 | + $this->andFilterWhere(['alias' => $alias]); | |
| 43 | + return $this; | |
| 44 | + } | |
| 34 | 45 | } | ... | ... |
common/modules/product/models/Category.php
| ... | ... | @@ -82,11 +82,12 @@ class Category extends \yii\db\ActiveRecord |
| 82 | 82 | [['name'], 'required'], |
| 83 | 83 | [['parent_id', 'depth', 'category_name_id', 'product_unit_id'], 'integer'], |
| 84 | 84 | [['path', 'meta_desc', 'seo_text'], 'string'], |
| 85 | - [['image', 'meta_title'], 'string', 'max' => 255], | |
| 85 | + [['meta_title'], 'string', 'max' => 255], | |
| 86 | 86 | [['meta_robots'], 'string', 'max' => 50], |
| 87 | 87 | [['alias', 'name'], 'string', 'max' => 250], |
| 88 | 88 | [['populary'], 'boolean'], |
| 89 | 89 | [['group_to_category'], 'safe'], |
| 90 | + // [['image'], 'file', 'skipOnEmpty' => false, 'extensions' => 'png, jpg, gif'], | |
| 90 | 91 | // [['product_unit_id'], 'exist', 'skipOnError' => true, 'targetClass' => ProductUnit::className(), 'targetAttribute' => ['product_unit_id' => 'product_unit_id']], |
| 91 | 92 | ]; |
| 92 | 93 | } | ... | ... |
common/modules/product/widgets/views/submenu.php
| ... | ... | @@ -8,7 +8,13 @@ |
| 8 | 8 | <div class="content_items"> |
| 9 | 9 | <?php foreach($populary as $_item) :?> |
| 10 | 10 | <div class="content_item"><a href="<?= \yii\helpers\Url::to(['catalog/category', 'alias' => $_item->alias])?>"> |
| 11 | - <div valign="top" class="picture"><img valign="top" src="<?= $_item->image?>"></div> | |
| 11 | + <div valign="top" class="picture"> | |
| 12 | + <?php if (empty($_item->image)) :?> | |
| 13 | + <img valign="top" src="/images/no_photo.png"> | |
| 14 | + <?php else :?> | |
| 15 | + <img valign="top" src="<?= $_item->image?>"> | |
| 16 | + <?php endif?> | |
| 17 | + </div> | |
| 12 | 18 | <div class="title"><?= $_item->name?></div> |
| 13 | 19 | </a></div> |
| 14 | 20 | <?php endforeach?> |
| ... | ... | @@ -24,7 +30,13 @@ |
| 24 | 30 | <div class="content_items"> |
| 25 | 31 | <?php foreach($item['children'] as $_item) :?> |
| 26 | 32 | <div class="content_item"><a href="<?= \yii\helpers\Url::to(['/catalog/category', 'alias' => $_item['item']->alias])?>"> |
| 27 | - <div valign="top" class="picture"><img valign="top" src="<?= $_item['item']->image?>"></div> | |
| 33 | + <div valign="top" class="picture"> | |
| 34 | + <?php if (empty($_item['item']->image)) :?> | |
| 35 | + <img valign="top" src="/images/no_photo.png"> | |
| 36 | + <?php else :?> | |
| 37 | + <img valign="top" src="<?= $_item['item']->image?>" alt="<?= $_item['item']->name?>"> | |
| 38 | + <?php endif?> | |
| 39 | + </div> | |
| 28 | 40 | <div class="title"><?= $_item['item']->name?></div> |
| 29 | 41 | </a></div> |
| 30 | 42 | <?php endforeach?> | ... | ... |
frontend/config/main.php
| ... | ... | @@ -47,6 +47,7 @@ return [ |
| 47 | 47 | 'enablePrettyUrl' => true, |
| 48 | 48 | 'showScriptName' => false, |
| 49 | 49 | 'rules' => [ |
| 50 | +// 'catalog' => 'catalog/category', | |
| 50 | 51 | 'catalog/<alias:[A-Za-z0-9_-]+>' => 'catalog/category', |
| 51 | 52 | 'product/<alias:[A-Za-z0-9_-]+>' => 'catalog/product', |
| 52 | 53 | 'brand' => 'catalog/brands', | ... | ... |
frontend/controllers/CatalogController.php
| ... | ... | @@ -20,6 +20,10 @@ use yii\web\HttpException; |
| 20 | 20 | |
| 21 | 21 | class CatalogController extends \yii\web\Controller |
| 22 | 22 | { |
| 23 | + public function actionSearch() { | |
| 24 | + | |
| 25 | + } | |
| 26 | + | |
| 23 | 27 | public function actionCategory($alias) |
| 24 | 28 | { |
| 25 | 29 | $category = CategorySearch::findByAlias($alias); |
| ... | ... | @@ -116,14 +120,31 @@ class CatalogController extends \yii\web\Controller |
| 116 | 120 | |
| 117 | 121 | // Options |
| 118 | 122 | if (($options = \Yii::$app->request->get('option')) != false) { |
| 119 | - $query->innerJoin(ProductOption::tableName(), ProductOption::tableName() .'.product_id='. Product::tableName() .'.product_id'); | |
| 120 | - $query->innerJoin(TaxOption::tableName(), TaxOption::tableName() .'.tax_option_id='. ProductOption::tableName() .'.option_id'); | |
| 121 | - foreach($options as $group_alias => $option_alias) { | |
| 123 | +// $query->innerJoin(ProductOption::tableName(), ProductOption::tableName() .'.product_id='. Product::tableName() .'.product_id'); | |
| 124 | +// $query->innerJoin(TaxOption::tableName(), TaxOption::tableName() .'.tax_option_id='. ProductOption::tableName() .'.option_id'); | |
| 125 | + foreach($options as $group_alias => $options_alias) { | |
| 126 | + if (!is_array($options_alias)) { | |
| 127 | + $options_alias = [$options_alias]; | |
| 128 | + } | |
| 129 | + foreach($options_alias as &$option_alias) { | |
| 130 | + $option_alias = "'". $option_alias ."'"; | |
| 131 | + } | |
| 122 | 132 | $group = TaxGroup::find()->where(['like', 'alias', $group_alias])->one(); |
| 123 | 133 | if (!$group) { |
| 124 | 134 | continue; |
| 125 | 135 | } |
| 126 | - $query->andWhere([TaxOption::tableName() .'.tax_group_id' => $group->tax_group_id, TaxOption::tableName() .'.alias' => $option_alias]); | |
| 136 | + $query->andWhere(Product::tableName() .'.product_id IN (SELECT product_id FROM product_option INNER JOIN tax_option ON tax_option.tax_option_id = product_option.option_id WHERE tax_option.alias IN ('. implode(',', $options_alias) .'))'); | |
| 137 | + } | |
| 138 | + } | |
| 139 | + | |
| 140 | + if (($_brands = \Yii::$app->request->get('brand')) != false && is_array($_brands) && count($_brands) > 0) { | |
| 141 | + $_brands = Brand::find()->where(['in', 'alias', $_brands])->all(); | |
| 142 | + $bids = []; | |
| 143 | + foreach ($_brands as $brand) { | |
| 144 | + $bids[] = $brand->brand_id; | |
| 145 | + } | |
| 146 | + if (count($bids)) { | |
| 147 | + $query->andWhere([Product::tableName() .'.brand_id' => $bids]); | |
| 127 | 148 | } |
| 128 | 149 | } |
| 129 | 150 | ... | ... |
frontend/views/catalog/products.php
| ... | ... | @@ -55,8 +55,8 @@ $this->params['breadcrumbs'][] = $category->name; |
| 55 | 55 | <div class="price_filter"> |
| 56 | 56 | <?php foreach($brands as $brand) :?> |
| 57 | 57 | <div class="checkbox"> |
| 58 | - <label><input type="checkbox" name="think" value="ruuki" /></label> | |
| 59 | - <a href="<?= \yii\helpers\Url::to(['catalog/brand', 'alias' => $brand->alias])?>"><?= $brand->name?> (<?= $brand->getProducts()->count()?>)</a> | |
| 58 | + <label><input type="checkbox" name="brand[]" value="<?= $brand->alias?>"<?= isset($_GET['brand']) && in_array($brand->alias, $_GET['brand']) ? ' checked' : ''?> /></label> | |
| 59 | + <a href="#<?php /*= \yii\helpers\Url::to(['brand', 'alias' => $brand->alias])*/?>"><?= $brand->name?><!-- (<?php /*= $brand->getProducts()->count()*/?>)--></a> | |
| 60 | 60 | </div> |
| 61 | 61 | <?php endforeach?> |
| 62 | 62 | <!--<div class="checkbox see_all"> |
| ... | ... | @@ -186,6 +186,10 @@ $this->params['breadcrumbs'][] = $category->name; |
| 186 | 186 | <div class="cat_p_catalog_list"> |
| 187 | 187 | <div class="title"><?= $category->name?> <span>(<?= $all_count?>)</span></div> |
| 188 | 188 | |
| 189 | + <?php if (empty($products)) :?> | |
| 190 | + <h2>По данному запросу товары не найдены.</h2><br> | |
| 191 | + <p>Показать <a href="<?= \yii\helpers\Url::to(['catalog/category', 'alias' => $category->alias])?>">все товары из категории "<?= $category->name?>"</a></p> | |
| 192 | + <?php else :?> | |
| 189 | 193 | <!-- sort menu --> |
| 190 | 194 | <div class="sort_menu"> |
| 191 | 195 | |
| ... | ... | @@ -243,7 +247,7 @@ $this->params['breadcrumbs'][] = $category->name; |
| 243 | 247 | |
| 244 | 248 | <?php if ($pages->totalCount > $pages->pageSize) :?> |
| 245 | 249 | <!-- LOAD MORE BUTTON --> |
| 246 | - <button class="load_more_btn">Загрузить еще <?= $per_page?> товара</button> | |
| 250 | + <!--button class="load_more_btn">Загрузить еще <?= $per_page?> товара</button--> | |
| 247 | 251 | |
| 248 | 252 | <div class="show_pages"> |
| 249 | 253 | Страница: |
| ... | ... | @@ -257,27 +261,18 @@ $this->params['breadcrumbs'][] = $category->name; |
| 257 | 261 | <?php endif?> |
| 258 | 262 | <hr> |
| 259 | 263 | |
| 264 | + <?php if(!empty($category->description)) :?> | |
| 260 | 265 | <div class="description"> |
| 261 | - <h2>Преимущества металлочерепицы:</h2> | |
| 262 | - <p> | |
| 263 | - На рынке стройматериалов представлено множество кровельных покрытий, от привычного всем рубероида до современной гибкой черепицы на основе стекловолоконных композитов. Все они имеют свои преимущества и сферы применения. Но металлочерепица на протяжении многих лет удерживает лидерские позиции по уровню продаж, и этzо объясняется несколькими причинами: | |
| 264 | - </p> | |
| 265 | - <h4>Кровля из металлочерепицы</h4> | |
| 266 | - <p class="margin_bottom_20"> | |
| 267 | - <span class="bold">1. Малый вес.</span> Эта характеристика дает ощутимую финансовую выгоду. Вам не придется усиливать стропильные конструкции, значит, удастся сэкономить на пиломатериалах. Легкость металлочерепицы для кровли упрощает транспортировку и монтаж, позволяет отказаться от дорогостоящих услуг подъемной и грузовой спецтехники. | |
| 268 | - </p> | |
| 269 | - <p class="margin_bottom_20"> | |
| 270 | - <span class="bold">2. Прочность.</span> В отличие от рулонных и гибких материалов, металлочерепица устойчива к механическим повреждениям. Ее крайне сложно поцарапать и практически невозможно сломать. Высокие технические характеристики говорят и о хорошей несущей способности материала. | |
| 271 | - </p> | |
| 272 | - <p class="margin_bottom_20"> | |
| 273 | - <span class="bold">3. Эстетичность.</span> Металлочерепица придает крыше законченный, аккуратный вид. Дом выглядит просто роскошно. Подбирая оригинальные цветовые сочетания, дизайнерам удается с помощью | |
| 274 | - </p> | |
| 266 | + <?= $category->description?> | |
| 275 | 267 | |
| 276 | 268 | <div class="empty_padding_400"></div> |
| 277 | 269 | </div> |
| 270 | + <?php endif?> | |
| 278 | 271 | </div> |
| 279 | 272 | </div> |
| 280 | 273 | </div> |
| 274 | + | |
| 275 | + <?php endif?> | |
| 281 | 276 | </div> |
| 282 | 277 | </div> |
| 283 | 278 | ... | ... |
frontend/views/layouts/main.php
| ... | ... | @@ -54,9 +54,11 @@ AppAsset::register($this); |
| 54 | 54 | <?= Html::a(Html::img('/images/bau_logo.png',['border'=>'0']), ['/'],['class'=>'head_up_cell bau_logo'])?> |
| 55 | 55 | <div class="head_up_cell srch"> |
| 56 | 56 | <div class="search_head"> |
| 57 | - <div class="srch_head_desc">Введите запрос <a href="#">Шифер</a> <a href="#">Рубероид</a></div> | |
| 58 | - <input type="text" name="search_head"> | |
| 59 | - <button><div class="search_img"></div></button> | |
| 57 | + <form action="<?= Url::to('catalog')?>"> | |
| 58 | + <div class="srch_head_desc">Введите запрос <a href="#" onclick="$('#search-head').val('Шифер');return false;">Шифер</a> <a href="#" onclick="$('#search-head').val('Рубероид');return false;">Рубероид</a></div> | |
| 59 | + <input type="text" name="word" id="search-head"> | |
| 60 | + <button><div class="search_img"></div></button> | |
| 61 | + </form> | |
| 60 | 62 | </div> |
| 61 | 63 | </div> |
| 62 | 64 | <div class="head_up_cell phn"> | ... | ... |
frontend/web/css/concat_all.css
| ... | ... | @@ -43,6 +43,11 @@ |
| 43 | 43 | display: inline-block; |
| 44 | 44 | float: left; |
| 45 | 45 | } |
| 46 | +.cat_p_filter_bar:before { | |
| 47 | + display: block; | |
| 48 | + content: ''; | |
| 49 | + clear: both; | |
| 50 | +} | |
| 46 | 51 | |
| 47 | 52 | .cat_p_filter_bar .filter_list ul { |
| 48 | 53 | list-style: none; |
| ... | ... | @@ -190,6 +195,7 @@ |
| 190 | 195 | width: 700px; |
| 191 | 196 | padding-right: 10px; |
| 192 | 197 | display: inline-block; |
| 198 | + min-height: 20em; | |
| 193 | 199 | } |
| 194 | 200 | |
| 195 | 201 | .cat_p_catalog_list ul { | ... | ... |