Blame view

common/modules/product/models/Product.php 18.4 KB
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;

db09c8fd   Yarik   Default variant
13
      use common\modules\product\behaviors\DefaultVariantBehavior;

36d1807a   Yarik   Big commit.
14
15
16
17
18
19
20
      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
21
      use yii\web\Request;

36d1807a   Yarik   Big commit.
22
      

d8c1a2e0   Yarik   Big commit artbox
23
      /**

36d1807a   Yarik   Big commit.
24
       * This is the model class for table "{{%product}}".

cc658b4c   Yarik   Big commit
25
26
27
       * @property integer              $brand_id

       * @property integer              $product_id

       * @property Category             $category

93c267f7   Yarik   Multilanguage big...
28
29
       * @property Category[]           $categories

       * @property ProductVariant[]     $variants

cc658b4c   Yarik   Big commit
30
       * @property ProductVariant       $variant

cc658b4c   Yarik   Big commit
31
32
33
34
35
36
       * @property boolean              $is_top

       * @property boolean              $is_new

       * @property boolean              $akciya

       * @property ProductToRating      $averageRating

       * @property array                $properties

       * @property ProductVariant       $enabledVariant

93c267f7   Yarik   Multilanguage big...
37
       * @property ProductVariant[]     $enabledVariants

cc658b4c   Yarik   Big commit
38
       * @property string               $video

cc658b4c   Yarik   Big commit
39
40
       * @property TaxOption[]          $options

       * @property Brand                $brand

cc658b4c   Yarik   Big commit
41
42
       * @property ProductSpec          $productSpec

       * @property ProductCertificate[] $productCertificates

d55d2fe0   Yarik   Multilanguage
43
       * * From language behavior *

af036678   Yarik   Image behaviors
44
45
46
47
48
49
50
       * @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
51
       * @method string           getOwnerKey()

af036678   Yarik   Image behaviors
52
       * @method void             setOwnerKey( string $value )

d55d2fe0   Yarik   Multilanguage
53
       * @method string           getLangKey()

af036678   Yarik   Image behaviors
54
       * @method void             setLangKey( string $value )

d55d2fe0   Yarik   Multilanguage
55
56
57
       * @method ActiveQuery      getLangs()

       * @method ActiveQuery      getLang( integer $language_id )

       * @method ProductLang[]    generateLangs()

af036678   Yarik   Image behaviors
58
       * @method void             loadLangs( Request $request )

72a992f5   Yarik   Import browser v1.0
59
60
61
       * @method bool             linkLangs()

       * @method bool             saveLangs()

       * @method bool             getTransactionStatus()

d55d2fe0   Yarik   Multilanguage
62
       * * End language behavior *

af036678   Yarik   Image behaviors
63
64
65
66
67
68
69
70
       * * 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
71
       */

36d1807a   Yarik   Big commit.
72
      class Product extends \yii\db\ActiveRecord

d8c1a2e0   Yarik   Big commit artbox
73
      {

36d1807a   Yarik   Big commit.
74
75
76
77
          

          /** @var array $_variants */

          public $_variants = [];

          

af036678   Yarik   Image behaviors
78
          public $imagesUpload = [];

36d1807a   Yarik   Big commit.
79
          

cc658b4c   Yarik   Big commit
80
81
          public $certificateUpload = [];

          

36d1807a   Yarik   Big commit.
82
83
84
85
86
87
          /**

           * @inheritdoc

           */

          public function behaviors()

          {

              return [

af036678   Yarik   Image behaviors
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
                  '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...
109
110
                      'class'  => MultipleImgBehavior::className(),

                      'links'  => [

af036678   Yarik   Image behaviors
111
112
                          'product_id' => 'product_id',

                      ],

740819d4   Yarik   Images fix
113
114
115
                      'conditions' => [

                          'product_variant_id' => NULL,

                      ],

4e55ce81   Yarik   Another one admin...
116
                      'model'  => ProductImage::className(),

af036678   Yarik   Image behaviors
117
                      'config' => [

4e55ce81   Yarik   Another one admin...
118
                          'caption'       => 'image',

af036678   Yarik   Image behaviors
119
                          'delete_action' => '/product/manage/delimg',

4e55ce81   Yarik   Another one admin...
120
                          'id'            => 'product_image_id',

af036678   Yarik   Image behaviors
121
122
                      ],

                  ],

36d1807a   Yarik   Big commit.
123
124
125
                  [

                      'class' => FilterBehavior::className(),

                  ],

af036678   Yarik   Image behaviors
126
                  'language'      => [

d55d2fe0   Yarik   Multilanguage
127
128
                      'class' => LanguageBehavior::className(),

                  ],

c3c1539f   Yarik   Tax Option fix
129
130
131
                  'techSpec' => [

                      'class' => TechBehavior::className(),

                  ],

4a427d3b   Yarik   remove default va...
132
133
134
  //                'defaultVariant' => [

  //                    'class' => DefaultVariantBehavior::className(),

  //                ],

36d1807a   Yarik   Big commit.
135
              ];

d8c1a2e0   Yarik   Big commit artbox
136
          }

36d1807a   Yarik   Big commit.
137
138
139
140
141
142
          

          /**

           * @inheritdoc

           */

          public static function tableName()

          {

248f559f   Yarik   Import browser be...
143
              return 'product';

d8c1a2e0   Yarik   Big commit artbox
144
          }

36d1807a   Yarik   Big commit.
145
146
147
148
149
150
151
152
153
154
155
156
          

          /**

           * @inheritdoc

           */

          public function rules()

          {

              return [

                  [

                      [ 'brand_id' ],

                      'integer',

                  ],

                  [

36d1807a   Yarik   Big commit.
157
158
159
160
161
                      [

                          'categories',

                          'variants',

                          'options',

                          'imagesUpload',

cc658b4c   Yarik   Big commit
162
                          'certificateUpload',

36d1807a   Yarik   Big commit.
163
164
165
166
167
                      ],

                      'safe',

                  ],

                  [

                      [

36d1807a   Yarik   Big commit.
168
169
170
171
172
173
174
175
176
177
178
179
180
                          'video',

                      ],

                      'safe',

                  ],

                  [

                      [

                          'is_top',

                          'is_new',

                          'akciya',

                      ],

                      'boolean',

                  ],

              ];

d8c1a2e0   Yarik   Big commit artbox
181
          }

36d1807a   Yarik   Big commit.
182
183
184
185
186
187
188
          

          /**

           * @inheritdoc

           */

          public function attributeLabels()

          {

              return [

93c267f7   Yarik   Multilanguage big...
189
190
191
                  'product_id' => Yii::t('product', 'ID'),

                  'brand_id'   => Yii::t('product', 'Brand'),

                  'categories' => Yii::t('product', 'Categories'),

36d1807a   Yarik   Big commit.
192
                  // relation behavior field

93c267f7   Yarik   Multilanguage big...
193
                  'category'   => Yii::t('product', 'Category'),

36d1807a   Yarik   Big commit.
194
                  // relation behavior field

93c267f7   Yarik   Multilanguage big...
195
196
197
198
199
200
201
                  '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.
202
              ];

d8c1a2e0   Yarik   Big commit artbox
203
          }

36d1807a   Yarik   Big commit.
204
          

36d1807a   Yarik   Big commit.
205
206
207
208
209
210
211
          /**

           * @return \yii\db\ActiveQuery

           */

          public function getBrand()

          {

              return $this->hasOne(Brand::className(), [ 'brand_id' => 'brand_id' ]);

          }

36d1807a   Yarik   Big commit.
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
263
264
265
266
267
268
269
          

          /**

           * @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...
270
              return empty( $this->brand ) ? $this->lang->name : $this->brand->lang->name . ' ' . $this->lang->name;

36d1807a   Yarik   Big commit.
271
272
          }

          

af036678   Yarik   Image behaviors
273
274
275
          /**

           * @return ActiveQuery

           */

36d1807a   Yarik   Big commit.
276
277
278
279
280
281
          public function getCategories()

          {

              return $this->hasMany(Category::className(), [ 'category_id' => 'category_id' ])

                          ->viaTable('product_category', [ 'product_id' => 'product_id' ]);

          }

          

36d1807a   Yarik   Big commit.
282
283
284
285
          public function getCategoriesNames()

          {

              $result = [];

              foreach($this->categories as $category) {

93c267f7   Yarik   Multilanguage big...
286
                  $result[] = $category->lang->name;

d8c1a2e0   Yarik   Big commit artbox
287
              }

36d1807a   Yarik   Big commit.
288
              return $result;

d8c1a2e0   Yarik   Big commit artbox
289
          }

36d1807a   Yarik   Big commit.
290
291
292
293
          

          public function getVariantsWithFilters()

          {

              return $this->hasMany(ProductVariant::className(), [ 'product_id' => 'product_id' ])

96410438   Yarik   Project admin com...
294
                          ->joinWith('lang', true, 'INNER JOIN')

36d1807a   Yarik   Big commit.
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
                          ->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...
316
317
318
          /**

           * @return TaxGroup[]

           */

36d1807a   Yarik   Big commit.
319
320
321
          public function getProperties()

          {

              $groups = $options = [];

4e55ce81   Yarik   Another one admin...
322
323
324
              foreach($this->getOptions()

                           ->with('lang')

                           ->all() as $option) {

36d1807a   Yarik   Big commit.
325
                  $options[ $option->tax_group_id ][] = $option;

d8c1a2e0   Yarik   Big commit artbox
326
              }

36d1807a   Yarik   Big commit.
327
328
              foreach(TaxGroup::find()

                              ->where([ 'tax_group_id' => array_keys($options) ])

4e55ce81   Yarik   Another one admin...
329
                              ->with('lang')

36d1807a   Yarik   Big commit.
330
331
332
333
                              ->all() as $group) {

                  if(!empty( $options[ $group->tax_group_id ] )) {

                      $group->_options = $options[ $group->tax_group_id ];

                      $groups[] = $group;

d8c1a2e0   Yarik   Big commit artbox
334
                  }

36d1807a   Yarik   Big commit.
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
              }

              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
359
                  }

d8c1a2e0   Yarik   Big commit artbox
360
              }

36d1807a   Yarik   Big commit.
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
              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
376
          

8c4b7f44   Yarik   Import browser be...
377
378
379
          public function afterSave($insert, $changedAttributes)

          {

              parent::afterSave($insert, $changedAttributes);

af036678   Yarik   Image behaviors
380
381
              

              if(!empty( $this->categories )) {

8c4b7f44   Yarik   Import browser be...
382
383
                  $categories = Category::findAll($this->categories);

                  $this->unlinkAll('categories', true);

af036678   Yarik   Image behaviors
384
                  foreach($categories as $category) {

8c4b7f44   Yarik   Import browser be...
385
386
387
                      $this->link('categories', $category);

                  }

              }

af036678   Yarik   Image behaviors
388
389
              

              if(!empty( $this->options )) {

8c4b7f44   Yarik   Import browser be...
390
                  $options = TaxOption::findAll($this->options);

af036678   Yarik   Image behaviors
391
392
                  $this->unlinkAll('options', true);

                  foreach($options as $option) {

8c4b7f44   Yarik   Import browser be...
393
394
395
                      $this->link('options', $option);

                  }

              }

af036678   Yarik   Image behaviors
396
397
              

              if(!empty( $this->_variants )) {

8c4b7f44   Yarik   Import browser be...
398
                  $todel = [];

af036678   Yarik   Image behaviors
399
400
                  foreach($this->variants ? : [] as $_variant) {

                      $todel[ $_variant->product_variant_id ] = $_variant->product_variant_id;

8c4b7f44   Yarik   Import browser be...
401
                  }

af036678   Yarik   Image behaviors
402
403
                  foreach($this->_variants as $_variant) {

                      if(!is_array($_variant)) {

8c4b7f44   Yarik   Import browser be...
404
405
                          return;

                      }

af036678   Yarik   Image behaviors
406
407
408
                      if(!empty( $_variant[ 'product_variant_id' ] )) {

                          unset( $todel[ $_variant[ 'product_variant_id' ] ] );

                          $model = ProductVariant::findOne($_variant[ 'product_variant_id' ]);

8c4b7f44   Yarik   Import browser be...
409
410
411
                      } else {

                          $model = new ProductVariant();

                      }

af036678   Yarik   Image behaviors
412
413
                      $_variant[ 'product_id' ] = $this->product_id;

                      $model->load([ 'ProductVariant' => $_variant ]);

8c4b7f44   Yarik   Import browser be...
414
415
416
                      $model->product_id = $this->product_id;

                      $model->save();

                  }

af036678   Yarik   Image behaviors
417
418
                  if(!empty( $todel )) {

                      ProductVariant::deleteAll([ 'product_variant_id' => $todel ]);

36d1807a   Yarik   Big commit.
419
                  }

d8c1a2e0   Yarik   Big commit artbox
420
              }

d8c1a2e0   Yarik   Big commit artbox
421
          }

36d1807a   Yarik   Big commit.
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
          

          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
448
449
              }

          }

36d1807a   Yarik   Big commit.
450
451
452
453
454
455
456
457
458
          

          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
459
          }

36d1807a   Yarik   Big commit.
460
461
462
463
          

          public function getAverageRating()

          {

              return $this->hasOne(ProductToRating::className(), [ 'product_id' => 'product_id' ]);

d8c1a2e0   Yarik   Big commit artbox
464
          }

36d1807a   Yarik   Big commit.
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
          

          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...
490
491
                          ->joinWith('taxGroup.lang', true, 'INNER JOIN')

                          ->joinWith('lang', true, 'INNER JOIN');

d8c1a2e0   Yarik   Big commit artbox
492
          }

cc658b4c   Yarik   Big commit
493
494
495
496
497
498
499
500
501
502
          

          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
503
      }