Commit d48d8bc0ba7c3135780371616275c602541a3236
1 parent
1e55b4b8
-
Showing
9 changed files
with
50 additions
and
56 deletions
Show diff stats
common/modules/product/helpers/ProductHelper.php
... | ... | @@ -5,6 +5,7 @@ namespace common\modules\product\helpers; |
5 | 5 | use common\modules\product\models\Brand; |
6 | 6 | use common\modules\product\models\Category; |
7 | 7 | use common\modules\product\models\Product; |
8 | +use common\modules\product\models\ProductVariant; | |
8 | 9 | use yii\base\Object; |
9 | 10 | use Yii; |
10 | 11 | |
... | ... | @@ -69,7 +70,8 @@ class ProductHelper extends Object { |
69 | 70 | public static function getLastProducts($as_object = false) { |
70 | 71 | $last_products = Yii::$app->session->get('last_products', []); |
71 | 72 | if ($as_object) { |
72 | - $last_products = array_reverse(Product::find()->where(['product_id' => $last_products])->all()); | |
73 | + $last_products = array_reverse(Product::find()->where([Product::tableName() .'.product_id' => $last_products])->all()); | |
74 | +// $last_products = array_reverse(Product::find()->joinWith('variants')->where([Product::tableName() .'.product_id' => $last_products])->andWhere(['!=', ProductVariant::tableName() .'.stock', 0])->all()); | |
73 | 75 | } |
74 | 76 | return $last_products; |
75 | 77 | } |
... | ... | @@ -86,6 +88,6 @@ class ProductHelper extends Object { |
86 | 88 | $data = ['akciya' => true]; |
87 | 89 | break; |
88 | 90 | } |
89 | - return Product::find()->where($data)->limit($count)/*->orderBy($sort)*/->all(); | |
91 | + return Product::find()->joinWith('variants')->where($data)->andWhere(['!=', ProductVariant::tableName() .'.stock', 0])->limit($count)/*->orderBy($sort)*/->all(); | |
90 | 92 | } |
91 | 93 | } |
92 | 94 | \ No newline at end of file | ... | ... |
common/modules/product/models/Category.php
... | ... | @@ -134,8 +134,11 @@ class Category extends \yii\db\ActiveRecord |
134 | 134 | } |
135 | 135 | |
136 | 136 | public function getProducts() { |
137 | -// return $this->hasMany(Product::className(), ['product_id' => 'product_id'])->viaTable('product_category', ['category_id' => 'category_id']); | |
138 | - return $this->getRelations('product_categories'); | |
137 | + return $this->hasMany(Product::className(), ['product_id' => 'product_id']) | |
138 | + ->viaTable('product_category', ['category_id' => 'category_id']) | |
139 | + ->with(['variants']) | |
140 | + ->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]); | |
141 | +// return $this->getRelations('product_categories'); | |
139 | 142 | } |
140 | 143 | |
141 | 144 | /** | ... | ... |
common/modules/product/models/Product.php
... | ... | @@ -144,14 +144,24 @@ class Product extends \yii\db\ActiveRecord |
144 | 144 | */ |
145 | 145 | public function getVariant() |
146 | 146 | { |
147 | -// return ProductVariant::find()->filterWhere([ProductVariant::tableName() .'.product_id' => Product::tableName() .'.product_id'])->where('>', ProductVariant::tableName() .'.stock', 0); | |
148 | 147 | return $this->hasOne(ProductVariant::className(), ['product_id' => 'product_id']); |
149 | 148 | } |
150 | 149 | |
150 | + /** | |
151 | + * @return \yii\db\ActiveQuery | |
152 | + */ | |
153 | + public function getEnabledVariant() | |
154 | + { | |
155 | + return $this->hasOne(ProductVariant::className(), ['product_id' => 'product_id'])->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]); | |
156 | + } | |
151 | 157 | public function getVariantPrice() { |
152 | 158 | return $this->variant->price; |
153 | 159 | } |
154 | 160 | |
161 | + public function getEnabledVariantPrice() { | |
162 | + return $this->enabledVariant->price; | |
163 | + } | |
164 | + | |
155 | 165 | /** |
156 | 166 | * @return \yii\db\ActiveQuery |
157 | 167 | */ |
... | ... | @@ -162,14 +172,7 @@ class Product extends \yii\db\ActiveRecord |
162 | 172 | |
163 | 173 | public function getEnabledVariants() |
164 | 174 | { |
165 | - /*$result = []; | |
166 | - foreach ($this->variants as $variant) { | |
167 | - if (is_null($variant->stock) || $variant->stock > 0) { | |
168 | - $result[] = $variant; | |
169 | - } | |
170 | - } | |
171 | - return $result;*/ | |
172 | - return $this->hasMany(ProductVariant::className(), ['product_id' => 'product_id'])->where(['!=', ProductVariant::tableName() .'.stock', 0]); | |
175 | + return $this->hasMany(ProductVariant::className(), ['product_id' => 'product_id'])->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]); | |
173 | 176 | } |
174 | 177 | |
175 | 178 | public function setVariants($variants) { | ... | ... |
console/controllers/ImportController.php
... | ... | @@ -416,7 +416,7 @@ class ImportController extends Controller { |
416 | 416 | |
417 | 417 | while (($data = fgetcsv ($handle, 10000, ";")) !== FALSE) { |
418 | 418 | $j++; |
419 | -// if ($j > 10) { | |
419 | +// if ($j > 1) { | |
420 | 420 | // return TRUE; |
421 | 421 | // } |
422 | 422 | |
... | ... | @@ -429,14 +429,20 @@ class ImportController extends Controller { |
429 | 429 | |
430 | 430 | // данные строк |
431 | 431 | $modification_code = @$data[0]; |
432 | - $price = floatval(@$data[1]); | |
433 | - $price_promo = floatval(@$data[2]); | |
432 | + $_price = floatval(@$data[1]); | |
433 | + $_price_promo = floatval(@$data[2]); | |
434 | 434 | $count = intval(@$data[3]); |
435 | 435 | $city_name = @$data[4]; |
436 | 436 | $product_title = @$data[5]; |
437 | 437 | |
438 | + // @todo refactory this code | |
439 | + $price = $_price_promo > 0 ? $_price_promo : $_price; | |
440 | + $price_promo = $_price_promo > 0 ? $_price : $_price_promo; | |
441 | + | |
442 | + $modification_code = trim($modification_code); | |
443 | + | |
438 | 444 | if (empty ($modification_code)) { |
439 | - CONTINUE; | |
445 | + continue; | |
440 | 446 | } |
441 | 447 | // товары в пути |
442 | 448 | if (empty ($city_name)) |
... | ... | @@ -446,28 +452,28 @@ class ImportController extends Controller { |
446 | 452 | Yii::getAlias('@uploadFilePricesAway') |
447 | 453 | ); |
448 | 454 | |
449 | -// $this->stdout("Товар $product_title в пути\n"); | |
455 | + $this->stdout("~ Товар $product_title в пути\n"); | |
450 | 456 | |
451 | - CONTINUE; | |
457 | + continue; | |
452 | 458 | } |
453 | 459 | |
454 | - if ( ($productVariant = ProductVariant::find()->filterWhere(['ilike', 'sku', trim($modification_code)])->one()) === null ) { | |
460 | + if ( ($productVariant = ProductVariant::find()->filterWhere(['sku' => $modification_code])->one()) === null ) { | |
455 | 461 | // 'Нет даной модификации в базе'; |
456 | 462 | $this->saveNotFoundRecord ( |
457 | 463 | [$modification_code, $product_title], |
458 | 464 | Yii::getAlias('@uploadFilePricesNoVariant') |
459 | 465 | ); |
460 | 466 | |
461 | -// $this->stdout("Для товара $product_title (#$modification_code) не найдено соотвествия\n"); | |
467 | + $this->stdout("- Для товара $product_title (#$modification_code) не найдено соотвествия\n"); | |
462 | 468 | |
463 | - CONTINUE; | |
469 | + continue; | |
464 | 470 | } |
465 | 471 | |
466 | 472 | $quantity = 0; |
467 | 473 | |
468 | 474 | // ===== Set stock ==== |
469 | 475 | if ( $city_name ) { |
470 | - if ( ($stock = Stock::find()->filterWhere(['ilike', 'name', trim($city_name)])->one()) === null ) { | |
476 | + if ( ($stock = Stock::find()->filterWhere(['name' => trim($city_name)])->one()) === null ) { | |
471 | 477 | // Create stock |
472 | 478 | $stock = new Stock(); |
473 | 479 | $stock->name = trim($city_name); |
... | ... | @@ -484,7 +490,7 @@ class ImportController extends Controller { |
484 | 490 | |
485 | 491 | $productVariant->save(); |
486 | 492 | |
487 | -// $this->stdout("Товар $product_title успешно сохранен\n"); | |
493 | + $this->stdout("+ Товар $product_title успешно сохранен\n"); | |
488 | 494 | } |
489 | 495 | fclose ($handle); |
490 | 496 | ... | ... |
frontend/controllers/CatalogController.php
... | ... | @@ -108,20 +108,6 @@ class CatalogController extends \yii\web\Controller |
108 | 108 | |
109 | 109 | if ( !empty($filter['options']) ) { |
110 | 110 | $params['options'] = $filter['options']; |
111 | - /*$optionQuery = TaxOption::find(); | |
112 | - $optionQuery->select('tax_option_id'); | |
113 | - $optionQuery->innerJoinWith('group'); | |
114 | - foreach ($filter['options'] as $option_key => $option_values) { | |
115 | - $optionQuery->orWhere([ | |
116 | - 'tax_group_id' => $option_key, | |
117 | - 'alias' => $filter['options'] | |
118 | - ]); | |
119 | - } | |
120 | - $options = ->where(['in', 'alias', $filter['options']])->all(); | |
121 | - $params['options'] = []; | |
122 | - foreach ($options as $option) { | |
123 | - $params['options'][] = $option->tax_option_id; | |
124 | - }*/ | |
125 | 111 | } |
126 | 112 | |
127 | 113 | if ( !empty($filter['prices']) ) { | ... | ... |
frontend/models/ProductFrontendSearch.php
... | ... | @@ -54,14 +54,10 @@ class ProductFrontendSearch extends Product { |
54 | 54 | } else { |
55 | 55 | $query = Product::find(); |
56 | 56 | } |
57 | - $query->joinWith(['variant', 'brand', 'brand.brandName', 'category', 'category.categoryName']); | |
57 | + $query->joinWith(['variant', 'image', 'brand', 'brand.brandName', 'category', 'category.categoryName']); | |
58 | 58 | |
59 | 59 | $query->groupBy('product.product_id'); |
60 | 60 | |
61 | -// if (empty($_GET['sort']) || ($_GET['sort'] != 'price' && $_GET['sort'] != '-price')) { | |
62 | -// $query->groupBy('product.product_id'); | |
63 | -// } | |
64 | - | |
65 | 61 | $dataProvider = new ActiveDataProvider([ |
66 | 62 | 'query' => $query, |
67 | 63 | 'pagination' => [ | ... | ... |
frontend/views/catalog/product.php
... | ... | @@ -13,7 +13,7 @@ $this->title = $product->fullname; |
13 | 13 | //} |
14 | 14 | $this->params['breadcrumbs'][] = ['label' => 'Каталог', 'url' => ['catalog/category']]; |
15 | 15 | $this->params['breadcrumbs'][] = ['label' => $product->category->categoryName->value, 'url' => ['catalog/category', 'category' => $product->category]]; |
16 | -$this->params['breadcrumbs'][] = $product->fullname .' #'. $product->variant->sku; | |
16 | +$this->params['breadcrumbs'][] = $product->fullname .' #'. $product->enabledVariant->sku; | |
17 | 17 | |
18 | 18 | $this->registerJs (' |
19 | 19 | |
... | ... | @@ -96,8 +96,7 @@ $this->registerJs (" |
96 | 96 | <h1><?= $product->fullname ?></h1> |
97 | 97 | <div class="begin">Цветовые решения</div> |
98 | 98 | <ul class="product_mod"> |
99 | - <?php foreach ($product->variants as $variant): ?> | |
100 | - <?php if ($variant->quantity == 0) continue;?> | |
99 | + <?php foreach ($product->enabledVariants as $variant): ?> | |
101 | 100 | <li> |
102 | 101 | <a id='m<?= $variant->product_variant_id ?>' href="#<?=$variant->product_variant_id ?>" |
103 | 102 | data-cost="<?= $variant->price ?>" |
... | ... | @@ -166,7 +165,7 @@ $this->registerJs (" |
166 | 165 | <div class="content"> |
167 | 166 | <div class="pic"> |
168 | 167 | <center> |
169 | - <a href="#" rel="shadowbox[gal]" id="picoriginal"><?= \common\components\artboximage\ArtboxImageHelper::getImage($product->variant->imageUrl, 'product_view',['id'=>'pic'])?></a> | |
168 | + <a href="#" rel="shadowbox[gal]" id="picoriginal"><?= \common\components\artboximage\ArtboxImageHelper::getImage($product->enabledVariant->imageUrl, 'product_view',['id'=>'pic'])?></a> | |
170 | 169 | </center> |
171 | 170 | </div> |
172 | 171 | <ul class="product_colors"> | ... | ... |
frontend/views/catalog/product_item.php
... | ... | @@ -5,8 +5,8 @@ use yii\helpers\Url; |
5 | 5 | <li class="item"> |
6 | 6 | <div class="boxitem"> |
7 | 7 | <div class="pixbox"> |
8 | - <a href="<?= Url::to(['catalog/product', 'product' => $product,'#' => 'm' .$product->variant->product_variant_id]) ?>"> | |
9 | - <?= \common\components\artboximage\ArtboxImageHelper::getImage($product->variant->imageUrl, 'list')?> | |
8 | + <a href="<?= Url::to(['catalog/product', 'product' => $product,'#' => 'm' .$product->enabledVariant->product_variant_id]) ?>"> | |
9 | + <?= \common\components\artboximage\ArtboxImageHelper::getImage($product->enabledVariant->imageUrl, 'list')?> | |
10 | 10 | </a> |
11 | 11 | </div> |
12 | 12 | <?php if(!empty($product->is_top) || !empty($product->is_new) || !empty($product->akciya)) :?> |
... | ... | @@ -25,7 +25,7 @@ use yii\helpers\Url; |
25 | 25 | <a href="<?= Url::to([ |
26 | 26 | 'catalog/product', |
27 | 27 | 'product' => $product, |
28 | - '#' => 'm' .$product->variant->product_variant_id]) | |
28 | + '#' => 'm' .$product->enabledVariant->product_variant_id]) | |
29 | 29 | ?>" |
30 | 30 | class="name"><?= $product->fullname ?> |
31 | 31 | </a> |
... | ... | @@ -35,12 +35,12 @@ use yii\helpers\Url; |
35 | 35 | echo '<div class="cost-block">'; |
36 | 36 | echo '<p class="cost">'; |
37 | 37 | // есть скидка |
38 | - if ($product->variant->price_old != 0 && $product->variant->price_old != $product->variant->price) | |
38 | + if ($product->enabledVariant->price_old != 0 && $product->enabledVariant->price_old != $product->enabledVariant->price) | |
39 | 39 | { |
40 | - echo '<strike><span id=\'old_cost\'>'.$product->variant->price_old.'</span> грн.</strike> '; | |
40 | + echo '<strike><span id=\'old_cost\'>'.$product->enabledVariant->price_old.'</span> грн.</strike> '; | |
41 | 41 | } |
42 | 42 | |
43 | - echo $product->variant->price.' <span>грн.</span></p>'; | |
43 | + echo $product->enabledVariant->price.' <span>грн.</span></p>'; | |
44 | 44 | |
45 | 45 | echo '</div>'; |
46 | 46 | |
... | ... | @@ -49,13 +49,12 @@ use yii\helpers\Url; |
49 | 49 | <a href="<?= Url::to([ |
50 | 50 | 'catalog/product', |
51 | 51 | 'product' => $product, |
52 | - '#' => 'm' .$product->variant->product_variant_id]) | |
52 | + '#' => 'm' .$product->enabledVariant->product_variant_id]) | |
53 | 53 | ?>" class="link_buy">Купить</a> |
54 | 54 | |
55 | 55 | <div class="mycarousel"> |
56 | 56 | <ul class="jcarousel jcarousel-skin-tango"> |
57 | 57 | <?php foreach ($product->enabledVariants as $variant) : ?> |
58 | - <?php if ($variant->quantity == 0) continue;?> | |
59 | 58 | <?php if (!empty($variant->image)) :?> |
60 | 59 | <li> |
61 | 60 | <a href="<?= Url::to([ | ... | ... |
frontend/views/site/index.php
... | ... | @@ -30,7 +30,7 @@ echo '<div class="home_banner_up">'; |
30 | 30 | echo '</div>' |
31 | 31 | ?> |
32 | 32 | |
33 | -<?= \frontend\widgets\Rubrics::widget(['wrapper' => 'rubrics', 'includes' => [136,137,138,139,140]])?> | |
33 | +<?= \frontend\widgets\Rubrics::widget(['wrapper' => 'rubrics', 'includes' => [130,131,132,133,134]])?> | |
34 | 34 | |
35 | 35 | <?= \common\modules\product\widgets\specialProducts::widget(['type' => 'promo'])?> |
36 | 36 | <?= \common\modules\product\widgets\specialProducts::widget(['type' => 'new'])?> | ... | ... |