d8c1a2e0
Yarik
Big commit artbox
|
1
|
<?php
|
36d1807a
Yarik
Big commit.
|
2
3
4
|
namespace common\modules\product\models;
|
af036678
Yarik
Image behaviors
|
5
6
|
use common\behaviors\MultipleImgBehavior;
use common\behaviors\SaveMultipleFileBehavior;
|
c3c1539f
Yarik
Tax Option fix
|
7
|
use common\behaviors\TechBehavior;
|
cc658b4c
Yarik
Big commit
|
8
9
|
use common\models\ProductCertificate;
use common\models\ProductSpec;
|
36d1807a
Yarik
Big commit.
|
10
11
|
use common\models\ProductToRating;
use common\modules\comment\models\CommentModel;
|
d55d2fe0
Yarik
Multilanguage
|
12
|
use common\modules\language\behaviors\LanguageBehavior;
|
36d1807a
Yarik
Big commit.
|
13
14
15
16
17
18
19
|
use common\modules\product\behaviors\FilterBehavior;
use common\modules\rubrication\models\TaxGroup;
use common\modules\rubrication\models\TaxOption;
use Yii;
use yii\db\ActiveQuery;
use yii\db\ActiveRecord;
use yii\helpers\ArrayHelper;
|
d55d2fe0
Yarik
Multilanguage
|
20
|
use yii\web\Request;
|
36d1807a
Yarik
Big commit.
|
21
|
|
d8c1a2e0
Yarik
Big commit artbox
|
22
|
/**
|
36d1807a
Yarik
Big commit.
|
23
|
* This is the model class for table "{{%product}}".
|
cc658b4c
Yarik
Big commit
|
24
25
26
|
* @property integer $brand_id
* @property integer $product_id
* @property Category $category
|
93c267f7
Yarik
Multilanguage big...
|
27
28
|
* @property Category[] $categories
* @property ProductVariant[] $variants
|
cc658b4c
Yarik
Big commit
|
29
|
* @property ProductVariant $variant
|
cc658b4c
Yarik
Big commit
|
30
31
32
33
34
35
|
* @property boolean $is_top
* @property boolean $is_new
* @property boolean $akciya
* @property ProductToRating $averageRating
* @property array $properties
* @property ProductVariant $enabledVariant
|
93c267f7
Yarik
Multilanguage big...
|
36
|
* @property ProductVariant[] $enabledVariants
|
cc658b4c
Yarik
Big commit
|
37
|
* @property string $video
|
cc658b4c
Yarik
Big commit
|
38
39
|
* @property TaxOption[] $options
* @property Brand $brand
|
cc658b4c
Yarik
Big commit
|
40
41
|
* @property ProductSpec $productSpec
* @property ProductCertificate[] $productCertificates
|
d55d2fe0
Yarik
Multilanguage
|
42
|
* * From language behavior *
|
af036678
Yarik
Image behaviors
|
43
44
45
46
47
48
49
|
* @property ProductLang $lang
* @property ProductLang[] $langs
* @property ProductLang $object_lang
* @property string $ownerKey
* @property string $langKey
* @property ProductLang[] $model_langs
* @property bool $transactionStatus
|
d55d2fe0
Yarik
Multilanguage
|
50
|
* @method string getOwnerKey()
|
af036678
Yarik
Image behaviors
|
51
|
* @method void setOwnerKey( string $value )
|
d55d2fe0
Yarik
Multilanguage
|
52
|
* @method string getLangKey()
|
af036678
Yarik
Image behaviors
|
53
|
* @method void setLangKey( string $value )
|
d55d2fe0
Yarik
Multilanguage
|
54
55
56
|
* @method ActiveQuery getLangs()
* @method ActiveQuery getLang( integer $language_id )
* @method ProductLang[] generateLangs()
|
af036678
Yarik
Image behaviors
|
57
|
* @method void loadLangs( Request $request )
|
72a992f5
Yarik
Import browser v1.0
|
58
59
60
|
* @method bool linkLangs()
* @method bool saveLangs()
* @method bool getTransactionStatus()
|
d55d2fe0
Yarik
Multilanguage
|
61
|
* * End language behavior *
|
af036678
Yarik
Image behaviors
|
62
63
64
65
66
67
68
69
|
* * From multipleImage behavior
* @property ProductImage $image
* @property ProductImage[] $images
* @method ActiveQuery getImage()
* @method ActiveQuery getImages()
* @method array getImagesConfig()
* @method array getImagesHTML( string $preset )
* * End multipleImage behavior
|
d8c1a2e0
Yarik
Big commit artbox
|
70
|
*/
|
36d1807a
Yarik
Big commit.
|
71
|
class Product extends \yii\db\ActiveRecord
|
d8c1a2e0
Yarik
Big commit artbox
|
72
|
{
|
36d1807a
Yarik
Big commit.
|
73
74
75
76
|
/** @var array $_variants */
public $_variants = [];
|
af036678
Yarik
Image behaviors
|
77
|
public $imagesUpload = [];
|
36d1807a
Yarik
Big commit.
|
78
|
|
cc658b4c
Yarik
Big commit
|
79
80
|
public $certificateUpload = [];
|
36d1807a
Yarik
Big commit.
|
81
82
83
84
85
86
|
/**
* @inheritdoc
*/
public function behaviors()
{
return [
|
af036678
Yarik
Image behaviors
|
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
'images' => [
'class' => SaveMultipleFileBehavior::className(),
'name' => 'imagesUpload',
'directory' => 'products',
'column' => 'image',
'links' => [
'product_id' => 'product_id',
],
'model' => ProductImage::className(),
],
'certificates' => [
'class' => SaveMultipleFileBehavior::className(),
'name' => 'certificateUpload',
'directory' => 'certificates',
'column' => 'link',
'links' => [
'product_id' => 'product_id',
],
'model' => ProductCertificate::className(),
],
'multipleImage' => [
|
4e55ce81
Yarik
Another one admin...
|
108
109
|
'class' => MultipleImgBehavior::className(),
'links' => [
|
af036678
Yarik
Image behaviors
|
110
111
|
'product_id' => 'product_id',
],
|
4e55ce81
Yarik
Another one admin...
|
112
|
'model' => ProductImage::className(),
|
af036678
Yarik
Image behaviors
|
113
|
'config' => [
|
4e55ce81
Yarik
Another one admin...
|
114
|
'caption' => 'image',
|
af036678
Yarik
Image behaviors
|
115
|
'delete_action' => '/product/manage/delimg',
|
4e55ce81
Yarik
Another one admin...
|
116
|
'id' => 'product_image_id',
|
af036678
Yarik
Image behaviors
|
117
118
|
],
],
|
36d1807a
Yarik
Big commit.
|
119
120
121
|
[
'class' => FilterBehavior::className(),
],
|
af036678
Yarik
Image behaviors
|
122
|
'language' => [
|
d55d2fe0
Yarik
Multilanguage
|
123
124
|
'class' => LanguageBehavior::className(),
],
|
c3c1539f
Yarik
Tax Option fix
|
125
126
127
|
'techSpec' => [
'class' => TechBehavior::className(),
],
|
36d1807a
Yarik
Big commit.
|
128
|
];
|
d8c1a2e0
Yarik
Big commit artbox
|
129
|
}
|
36d1807a
Yarik
Big commit.
|
130
131
132
133
134
135
|
/**
* @inheritdoc
*/
public static function tableName()
{
|
248f559f
Yarik
Import browser be...
|
136
|
return 'product';
|
d8c1a2e0
Yarik
Big commit artbox
|
137
|
}
|
36d1807a
Yarik
Big commit.
|
138
139
140
141
142
143
144
145
146
147
148
149
|
/**
* @inheritdoc
*/
public function rules()
{
return [
[
[ 'brand_id' ],
'integer',
],
[
|
36d1807a
Yarik
Big commit.
|
150
151
152
153
154
|
[
'categories',
'variants',
'options',
'imagesUpload',
|
cc658b4c
Yarik
Big commit
|
155
|
'certificateUpload',
|
36d1807a
Yarik
Big commit.
|
156
157
158
159
160
|
],
'safe',
],
[
[
|
36d1807a
Yarik
Big commit.
|
161
162
163
164
165
166
167
168
169
170
171
172
173
|
'video',
],
'safe',
],
[
[
'is_top',
'is_new',
'akciya',
],
'boolean',
],
];
|
d8c1a2e0
Yarik
Big commit artbox
|
174
|
}
|
36d1807a
Yarik
Big commit.
|
175
176
177
178
179
180
181
|
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
|
93c267f7
Yarik
Multilanguage big...
|
182
183
184
|
'product_id' => Yii::t('product', 'ID'),
'brand_id' => Yii::t('product', 'Brand'),
'categories' => Yii::t('product', 'Categories'),
|
36d1807a
Yarik
Big commit.
|
185
|
// relation behavior field
|
93c267f7
Yarik
Multilanguage big...
|
186
|
'category' => Yii::t('product', 'Category'),
|
36d1807a
Yarik
Big commit.
|
187
|
// relation behavior field
|
93c267f7
Yarik
Multilanguage big...
|
188
189
190
191
192
193
194
|
'image' => Yii::t('product', 'Image'),
'images' => Yii::t('product', 'Images'),
'video' => Yii::t('product', 'Video embeded'),
'variants' => Yii::t('product', 'Variants'),
'is_top' => Yii::t('product', 'Is top'),
'is_new' => Yii::t('product', 'Is new'),
'akciya' => Yii::t('product', 'Is promo'),
|
36d1807a
Yarik
Big commit.
|
195
|
];
|
d8c1a2e0
Yarik
Big commit artbox
|
196
|
}
|
36d1807a
Yarik
Big commit.
|
197
|
|
36d1807a
Yarik
Big commit.
|
198
199
200
201
202
203
204
|
/**
* @return \yii\db\ActiveQuery
*/
public function getBrand()
{
return $this->hasOne(Brand::className(), [ 'brand_id' => 'brand_id' ]);
}
|
36d1807a
Yarik
Big commit.
|
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
|
/**
* @return \yii\db\ActiveQuery
*/
public function getVariant()
{
return $this->hasOne(ProductVariant::className(), [ 'product_id' => 'product_id' ]);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getEnabledVariant()
{
return $this->hasOne(ProductVariant::className(), [ 'product_id' => 'product_id' ])
->andOnCondition([
'!=',
ProductVariant::tableName() . '.stock',
0,
]);
}
public function getVariantPrice()
{
return $this->variant->price;
}
public function getEnabledVariantPrice()
{
return $this->enabledVariants[ 0 ]->price;
}
/**
* @return \yii\db\ActiveQuery
*/
public function getVariants()
{
return $this->hasMany(ProductVariant::className(), [ 'product_id' => 'product_id' ]);
}
public function getEnabledVariants()
{
return $this->hasMany(ProductVariant::className(), [ 'product_id' => 'product_id' ])
->andOnCondition([
'!=',
ProductVariant::tableName() . '.stock',
0,
])
->joinWith('image');
}
public function setVariants($variants)
{
$this->_variants = $variants;
}
public function getFullName()
{
|
93c267f7
Yarik
Multilanguage big...
|
263
|
return empty( $this->brand ) ? $this->lang->name : $this->brand->lang->name . ' ' . $this->lang->name;
|
36d1807a
Yarik
Big commit.
|
264
265
|
}
|
af036678
Yarik
Image behaviors
|
266
267
268
|
/**
* @return ActiveQuery
*/
|
36d1807a
Yarik
Big commit.
|
269
270
271
272
273
274
|
public function getCategories()
{
return $this->hasMany(Category::className(), [ 'category_id' => 'category_id' ])
->viaTable('product_category', [ 'product_id' => 'product_id' ]);
}
|
36d1807a
Yarik
Big commit.
|
275
276
277
278
|
public function getCategoriesNames()
{
$result = [];
foreach($this->categories as $category) {
|
93c267f7
Yarik
Multilanguage big...
|
279
|
$result[] = $category->lang->name;
|
d8c1a2e0
Yarik
Big commit artbox
|
280
|
}
|
36d1807a
Yarik
Big commit.
|
281
|
return $result;
|
d8c1a2e0
Yarik
Big commit artbox
|
282
|
}
|
36d1807a
Yarik
Big commit.
|
283
284
285
286
|
public function getVariantsWithFilters()
{
return $this->hasMany(ProductVariant::className(), [ 'product_id' => 'product_id' ])
|
96410438
Yarik
Project admin com...
|
287
|
->joinWith('lang', true, 'INNER JOIN')
|
36d1807a
Yarik
Big commit.
|
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
|
->with([
'filters',
'image',
]);
}
/**
* @return ActiveQuery
*/
public function getCategory()
{
return $this->hasOne(Category::className(), [ 'category_id' => 'category_id' ])
->viaTable('product_category', [ 'product_id' => 'product_id' ]);
}
public function getOptions()
{
return $this->hasMany(TaxOption::className(), [ 'tax_option_id' => 'option_id' ])
->viaTable('product_option', [ 'product_id' => 'product_id' ]);
}
|
4e55ce81
Yarik
Another one admin...
|
309
310
311
|
/**
* @return TaxGroup[]
*/
|
36d1807a
Yarik
Big commit.
|
312
313
314
|
public function getProperties()
{
$groups = $options = [];
|
4e55ce81
Yarik
Another one admin...
|
315
316
317
|
foreach($this->getOptions()
->with('lang')
->all() as $option) {
|
36d1807a
Yarik
Big commit.
|
318
|
$options[ $option->tax_group_id ][] = $option;
|
d8c1a2e0
Yarik
Big commit artbox
|
319
|
}
|
36d1807a
Yarik
Big commit.
|
320
321
|
foreach(TaxGroup::find()
->where([ 'tax_group_id' => array_keys($options) ])
|
4e55ce81
Yarik
Another one admin...
|
322
|
->with('lang')
|
36d1807a
Yarik
Big commit.
|
323
324
325
326
|
->all() as $group) {
if(!empty( $options[ $group->tax_group_id ] )) {
$group->_options = $options[ $group->tax_group_id ];
$groups[] = $group;
|
d8c1a2e0
Yarik
Big commit artbox
|
327
|
}
|
36d1807a
Yarik
Big commit.
|
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
|
}
return $groups;
}
public function getActiveProperties($category_id)
{
$groups = $options = [];
foreach($this->options as $option) {
$options[ $option->tax_group_id ][] = $option;
}
$taxGroups = TaxGroup::find()
->joinWith('categories')
->where([
'tax_group.tax_group_id' => array_keys($options),
'tax_group.display' => true,
'category.category_id' => $category_id,
])
->all();
foreach($taxGroups as $group) {
if(!empty( $options[ $group->tax_group_id ] )) {
$group->_options = $options[ $group->tax_group_id ];
$groups[] = $group;
|
d8c1a2e0
Yarik
Big commit artbox
|
352
|
}
|
d8c1a2e0
Yarik
Big commit artbox
|
353
|
}
|
36d1807a
Yarik
Big commit.
|
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
|
return $groups;
}
public function getStocks()
{
return $this->hasMany(Stock::className(), [ 'stock_id' => 'stock_id' ])
->viaTable(ProductStock::tableName(), [ 'product_id' => 'product_id' ]);
}
public function getQuantity()
{
return ProductStock::find()
->where([ 'product_id' => $this->product_id ])
->sum('quantity');
}
|
af036678
Yarik
Image behaviors
|
369
|
|
8c4b7f44
Yarik
Import browser be...
|
370
371
372
|
public function afterSave($insert, $changedAttributes)
{
parent::afterSave($insert, $changedAttributes);
|
af036678
Yarik
Image behaviors
|
373
374
|
if(!empty( $this->categories )) {
|
8c4b7f44
Yarik
Import browser be...
|
375
376
|
$categories = Category::findAll($this->categories);
$this->unlinkAll('categories', true);
|
af036678
Yarik
Image behaviors
|
377
|
foreach($categories as $category) {
|
8c4b7f44
Yarik
Import browser be...
|
378
379
380
|
$this->link('categories', $category);
}
}
|
af036678
Yarik
Image behaviors
|
381
382
|
if(!empty( $this->options )) {
|
8c4b7f44
Yarik
Import browser be...
|
383
|
$options = TaxOption::findAll($this->options);
|
af036678
Yarik
Image behaviors
|
384
385
|
$this->unlinkAll('options', true);
foreach($options as $option) {
|
8c4b7f44
Yarik
Import browser be...
|
386
387
388
|
$this->link('options', $option);
}
}
|
af036678
Yarik
Image behaviors
|
389
390
|
if(!empty( $this->_variants )) {
|
8c4b7f44
Yarik
Import browser be...
|
391
|
$todel = [];
|
af036678
Yarik
Image behaviors
|
392
393
|
foreach($this->variants ? : [] as $_variant) {
$todel[ $_variant->product_variant_id ] = $_variant->product_variant_id;
|
8c4b7f44
Yarik
Import browser be...
|
394
|
}
|
af036678
Yarik
Image behaviors
|
395
396
|
foreach($this->_variants as $_variant) {
if(!is_array($_variant)) {
|
8c4b7f44
Yarik
Import browser be...
|
397
398
|
return;
}
|
af036678
Yarik
Image behaviors
|
399
400
401
|
if(!empty( $_variant[ 'product_variant_id' ] )) {
unset( $todel[ $_variant[ 'product_variant_id' ] ] );
$model = ProductVariant::findOne($_variant[ 'product_variant_id' ]);
|
8c4b7f44
Yarik
Import browser be...
|
402
403
404
|
} else {
$model = new ProductVariant();
}
|
af036678
Yarik
Image behaviors
|
405
406
|
$_variant[ 'product_id' ] = $this->product_id;
$model->load([ 'ProductVariant' => $_variant ]);
|
8c4b7f44
Yarik
Import browser be...
|
407
408
409
|
$model->product_id = $this->product_id;
$model->save();
}
|
af036678
Yarik
Image behaviors
|
410
411
|
if(!empty( $todel )) {
ProductVariant::deleteAll([ 'product_variant_id' => $todel ]);
|
36d1807a
Yarik
Big commit.
|
412
|
}
|
d8c1a2e0
Yarik
Big commit artbox
|
413
|
}
|
d8c1a2e0
Yarik
Big commit artbox
|
414
|
}
|
36d1807a
Yarik
Big commit.
|
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
|
public function recalculateRating()
{
/**
* @var ProductToRating $averageRating
*/
$average = $this->getComments()
->joinWith('rating')
->select([ 'average' => 'avg(artbox_comment_rating.value)::float' ])
->scalar();
if(!$average) {
$average = 0;
}
$averageRating = $this->averageRating;
if(!empty( $averageRating )) {
$averageRating->value = $average;
} else {
$averageRating = new ProductToRating([
'product_id' => $this->product_id,
'value' => $average,
]);
}
if($averageRating->save()) {
return true;
} else {
return false;
|
d8c1a2e0
Yarik
Big commit artbox
|
441
442
|
}
}
|
36d1807a
Yarik
Big commit.
|
443
444
445
446
447
448
449
450
451
|
public function getComments()
{
return $this->hasMany(CommentModel::className(), [ 'entity_id' => 'product_id' ])
->where([
'artbox_comment.entity' => self::className(),
'artbox_comment.status' => CommentModel::STATUS_ACTIVE,
'artbox_comment.artbox_comment_pid' => NULL,
]);
|
d8c1a2e0
Yarik
Big commit artbox
|
452
|
}
|
36d1807a
Yarik
Big commit.
|
453
454
455
456
|
public function getAverageRating()
{
return $this->hasOne(ProductToRating::className(), [ 'product_id' => 'product_id' ]);
|
d8c1a2e0
Yarik
Big commit artbox
|
457
|
}
|
36d1807a
Yarik
Big commit.
|
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
|
public function getTaxGroupsByLevel($level)
{
$categories = ArrayHelper::getColumn($this->categories, 'category_id');
return TaxGroup::find()
->distinct()
->innerJoin('tax_group_to_category', 'tax_group_to_category.tax_group_id = tax_group.tax_group_id')
->andWhere([ 'tax_group_to_category.category_id' => $categories ])
->andWhere([ 'level' => $level ]);
}
public function setCategories($values)
{
$this->categories = $values;
}
public function setOptions($values)
{
$this->options = $values;
}
public function getFilters()
{
return $this->hasMany(TaxOption::className(), [ 'tax_option_id' => 'option_id' ])
->viaTable('product_option', [ 'product_id' => 'product_id' ])
|
96410438
Yarik
Project admin com...
|
483
484
|
->joinWith('taxGroup.lang', true, 'INNER JOIN')
->joinWith('lang', true, 'INNER JOIN');
|
d8c1a2e0
Yarik
Big commit artbox
|
485
|
}
|
cc658b4c
Yarik
Big commit
|
486
487
488
489
490
491
492
493
494
495
|
public function getProductSpec()
{
return $this->hasOne(ProductSpec::className(), [ 'product_id' => 'product_id' ]);
}
public function getProductCertificates()
{
return $this->hasMany(ProductCertificate::className(), [ 'product_id' => 'product_id' ]);
}
|
d8c1a2e0
Yarik
Big commit artbox
|
496
|
}
|