Blame view

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

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',

                      ],

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

                          'product_variant_id' => NULL,

                      ],

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

af036678   Yarik   Image behaviors
116
                      'config' => [

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

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

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

af036678   Yarik   Image behaviors
120
121
                      ],

                  ],

36d1807a   Yarik   Big commit.
122
123
124
                  [

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

                  ],

af036678   Yarik   Image behaviors
125
                  'language'      => [

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

                  ],

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

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

                  ],

36d1807a   Yarik   Big commit.
131
              ];

d8c1a2e0   Yarik   Big commit artbox
132
          }

36d1807a   Yarik   Big commit.
133
134
135
136
137
138
          

          /**

           * @inheritdoc

           */

          public static function tableName()

          {

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

d8c1a2e0   Yarik   Big commit artbox
140
          }

36d1807a   Yarik   Big commit.
141
142
143
144
145
146
147
148
149
150
151
152
          

          /**

           * @inheritdoc

           */

          public function rules()

          {

              return [

                  [

                      [ 'brand_id' ],

                      'integer',

                  ],

                  [

36d1807a   Yarik   Big commit.
153
154
155
156
157
                      [

                          'categories',

                          'variants',

                          'options',

                          'imagesUpload',

cc658b4c   Yarik   Big commit
158
                          'certificateUpload',

36d1807a   Yarik   Big commit.
159
160
161
162
163
                      ],

                      'safe',

                  ],

                  [

                      [

36d1807a   Yarik   Big commit.
164
165
166
167
168
169
170
171
172
173
174
175
176
                          'video',

                      ],

                      'safe',

                  ],

                  [

                      [

                          'is_top',

                          'is_new',

                          'akciya',

                      ],

                      'boolean',

                  ],

              ];

d8c1a2e0   Yarik   Big commit artbox
177
          }

36d1807a   Yarik   Big commit.
178
179
180
181
182
183
184
          

          /**

           * @inheritdoc

           */

          public function attributeLabels()

          {

              return [

93c267f7   Yarik   Multilanguage big...
185
186
187
                  'product_id' => Yii::t('product', 'ID'),

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

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

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

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

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

93c267f7   Yarik   Multilanguage big...
191
192
193
194
195
196
197
                  '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.
198
              ];

d8c1a2e0   Yarik   Big commit artbox
199
          }

36d1807a   Yarik   Big commit.
200
          

36d1807a   Yarik   Big commit.
201
202
203
204
205
206
207
          /**

           * @return \yii\db\ActiveQuery

           */

          public function getBrand()

          {

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

          }

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

          /**

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

36d1807a   Yarik   Big commit.
267
268
          }

          

af036678   Yarik   Image behaviors
269
270
271
          /**

           * @return ActiveQuery

           */

36d1807a   Yarik   Big commit.
272
273
274
275
276
277
          public function getCategories()

          {

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

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

          }

          

36d1807a   Yarik   Big commit.
278
279
280
281
          public function getCategoriesNames()

          {

              $result = [];

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

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

d8c1a2e0   Yarik   Big commit artbox
283
              }

36d1807a   Yarik   Big commit.
284
              return $result;

d8c1a2e0   Yarik   Big commit artbox
285
          }

36d1807a   Yarik   Big commit.
286
287
288
289
          

          public function getVariantsWithFilters()

          {

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

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

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

           * @return TaxGroup[]

           */

36d1807a   Yarik   Big commit.
315
316
317
          public function getProperties()

          {

              $groups = $options = [];

4e55ce81   Yarik   Another one admin...
318
319
320
              foreach($this->getOptions()

                           ->with('lang')

                           ->all() as $option) {

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

d8c1a2e0   Yarik   Big commit artbox
322
              }

36d1807a   Yarik   Big commit.
323
324
              foreach(TaxGroup::find()

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

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

36d1807a   Yarik   Big commit.
326
327
328
329
                              ->all() as $group) {

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

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

                      $groups[] = $group;

d8c1a2e0   Yarik   Big commit artbox
330
                  }

36d1807a   Yarik   Big commit.
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
              }

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

d8c1a2e0   Yarik   Big commit artbox
356
              }

36d1807a   Yarik   Big commit.
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
              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
372
          

8c4b7f44   Yarik   Import browser be...
373
374
375
          public function afterSave($insert, $changedAttributes)

          {

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

af036678   Yarik   Image behaviors
376
377
              

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

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

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

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

8c4b7f44   Yarik   Import browser be...
381
382
383
                      $this->link('categories', $category);

                  }

              }

af036678   Yarik   Image behaviors
384
385
              

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

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

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

                  foreach($options as $option) {

8c4b7f44   Yarik   Import browser be...
389
390
391
                      $this->link('options', $option);

                  }

              }

af036678   Yarik   Image behaviors
392
393
              

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

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

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

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

8c4b7f44   Yarik   Import browser be...
397
                  }

af036678   Yarik   Image behaviors
398
399
                  foreach($this->_variants as $_variant) {

                      if(!is_array($_variant)) {

8c4b7f44   Yarik   Import browser be...
400
401
                          return;

                      }

af036678   Yarik   Image behaviors
402
403
404
                      if(!empty( $_variant[ 'product_variant_id' ] )) {

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

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

8c4b7f44   Yarik   Import browser be...
405
406
407
                      } else {

                          $model = new ProductVariant();

                      }

af036678   Yarik   Image behaviors
408
409
                      $_variant[ 'product_id' ] = $this->product_id;

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

8c4b7f44   Yarik   Import browser be...
410
411
412
                      $model->product_id = $this->product_id;

                      $model->save();

                  }

af036678   Yarik   Image behaviors
413
414
                  if(!empty( $todel )) {

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

36d1807a   Yarik   Big commit.
415
                  }

d8c1a2e0   Yarik   Big commit artbox
416
              }

d8c1a2e0   Yarik   Big commit artbox
417
          }

36d1807a   Yarik   Big commit.
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
          

          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
444
445
              }

          }

36d1807a   Yarik   Big commit.
446
447
448
449
450
451
452
453
454
          

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

36d1807a   Yarik   Big commit.
456
457
458
459
          

          public function getAverageRating()

          {

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

d8c1a2e0   Yarik   Big commit artbox
460
          }

36d1807a   Yarik   Big commit.
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
          

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

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

d8c1a2e0   Yarik   Big commit artbox
488
          }

cc658b4c   Yarik   Big commit
489
490
491
492
493
494
495
496
497
498
          

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