Blame view

common/modules/product/models/Product.php 12.7 KB
3f2bc3d0   Administrator   first commit
1
2
3
4
5
  <?php

  

  namespace common\modules\product\models;

  

  use common\behaviors\Slug;

c7852657   Karnovsky A   -
6
  use common\modules\rubrication\models\TaxGroup;

3f2bc3d0   Administrator   first commit
7
8
9
10
  use common\modules\rubrication\models\TaxOption;

  use Yii;

  use common\modules\relation\relationBehavior;

  use yii\db\ActiveQuery;

868680ca   Karnovsky A   -
11
  use yii\db\ActiveRecord;

ccc7a9d3   Karnovsky A   Karnovsky 12052016
12
13
  use yii\helpers\Html;

  use yii\web\UploadedFile;

3f2bc3d0   Administrator   first commit
14
15
16
17
  

  /**

   * This is the model class for table "{{%product}}".

   *

3f2bc3d0   Administrator   first commit
18
   * @property string $name

3f2bc3d0   Administrator   first commit
19
   * @property integer $brand_id

ccc7a9d3   Karnovsky A   Karnovsky 12052016
20
   * @property integer $product_id

3f2bc3d0   Administrator   first commit
21
22
   * @property Category $category

   * @property array $categories

ccc7a9d3   Karnovsky A   Karnovsky 12052016
23
   * @property array of ProductVariant $variants

3f2bc3d0   Administrator   first commit
24
   * @property ProductVariant $variant

3f2bc3d0   Administrator   first commit
25
26
   * @property ProductImage $image

   * @property array $images

ccc7a9d3   Karnovsky A   Karnovsky 12052016
27
28
   * @property boolean $is_top

   * @property boolean $is_new

dc2cd017   Karnovsky A   -
29
   * @property boolean $akciya

e9f291a5   Karnovsky A   Similar products ...
30
31
32
   * @property array $properties

   * @property ProductVariant $enabledVariant

   * @property array $enabledVariants

3f2bc3d0   Administrator   first commit
33
34
35
36
37
38
39
40
   */

  class Product extends \yii\db\ActiveRecord

  {

      /** @var array $_variants */

      public $_variants = [];

  

      /** @var array $_images */

      public $imagesUpload = [];

83be3cfb   Karnovsky A   -
41
      public $variantImagesUpload = [];

3f2bc3d0   Administrator   first commit
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
      /**

       * @inheritdoc

       */

      public function behaviors()

      {

          return [

              [

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

                  'relations' => [

                      'product_categories' => 'entity1', // Product category

                      'product_option' => 'entity1' // Product category

                  ]

              ],

              [

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

                  'in_attribute' => 'name',

                  'out_attribute' => 'alias',

                  'translit' => true

              ]

          ];

      }

  

      /**

       * @inheritdoc

       */

      public static function tableName()

      {

          return '{{%product}}';

      }

  

      /**

       * @inheritdoc

       */

      public function rules()

      {

          return [

067092f7   Karnovsky A   -
78
  //            [['categories'], 'required'],

3f2bc3d0   Administrator   first commit
79
80
81
              [['brand_id'], 'integer'],

              [['name'], 'string', 'max' => 150],

              [['alias'], 'string', 'max' => 250],

ccc7a9d3   Karnovsky A   Karnovsky 12052016
82
              [['categories', 'variants', 'options', 'imagesUpload'], 'safe'],

dc2cd017   Karnovsky A   -
83
  //            [['imagesUpload'], 'file', 'skipOnEmpty' => false, 'extensions' => 'png, jpg, gif', 'maxFiles' => 50],

3f2bc3d0   Administrator   first commit
84
              [['description', 'video'], 'safe'],

dc2cd017   Karnovsky A   -
85
              [['is_top', 'is_new', 'akciya'], 'boolean'],

3f2bc3d0   Administrator   first commit
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
  //            [['product_id'], 'exist', 'skipOnError' => true, 'targetClass' => Product::className(), 'targetAttribute' => ['product_id' => 'product_id']],

          ];

      }

  

      /**

       * @inheritdoc

       */

      public function attributeLabels()

      {

          return [

              'product_id' => Yii::t('product', 'ID'),

              'name' => Yii::t('product', 'Name'),

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

              'categories' => Yii::t('product', 'Categories'), // relation behavior field

              'category' => Yii::t('product', 'Category'), // relation behavior field

              'image' => Yii::t('product', 'Image'),

              'images' => Yii::t('product', 'Images'),

ccc7a9d3   Karnovsky A   Karnovsky 12052016
103
104
105
106
107
              'description' => Yii::t('product', 'Description'),

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

dc2cd017   Karnovsky A   -
108
              'akciya' => Yii::t('product', 'Is promo'),

3f2bc3d0   Administrator   first commit
109
110
111
          ];

      }

  

02e6c2ba   Karnovsky A   -
112
113
114
115
      public function getUrl() {

          return '/product/'. $this->alias;

      }

  

3f2bc3d0   Administrator   first commit
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getBrand()

      {

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

      }

  

      /**

       * @return \yii\db\ActiveQuery

       */

      public function getImage()

      {

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

      }

  

      /**

dc2cd017   Karnovsky A   -
133
134
135
136
137
       * fetch stored image url

       * @return string

       */

      public function getImageUrl()

      {

4902c747   Karnovsky A   -
138
139
          $image = empty($this->variant) ? null : $this->variant->image;

          return !empty($image) ? $image->imageUrl : '/images/no_photo.png';

dc2cd017   Karnovsky A   -
140
141
142
      }

  

      /**

3f2bc3d0   Administrator   first commit
143
144
145
146
       * @return \yii\db\ActiveQuery

       */

      public function getImages()

      {

1e55b4b8   Karnovsky A   -
147
          return $this->hasMany(ProductImage::className(), ['product_id' => 'product_id'])->where(['product_variant_id' => null]);

3f2bc3d0   Administrator   first commit
148
149
      }

  

3f2bc3d0   Administrator   first commit
150
151
152
153
154
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getVariant()

      {

0a93b48a   Karnovsky A   -
155
          return $this->hasOne(ProductVariant::className(), ['product_id' => 'product_id']);

3f2bc3d0   Administrator   first commit
156
157
      }

  

d48d8bc0   Karnovsky A   -
158
159
160
161
162
163
164
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getEnabledVariant()

      {

          return $this->hasOne(ProductVariant::className(), ['product_id' => 'product_id'])->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]);

      }

e9f291a5   Karnovsky A   Similar products ...
165
  

3f2bc3d0   Administrator   first commit
166
167
168
      public function getVariantPrice() {

          return $this->variant->price;

      }

1e55b4b8   Karnovsky A   -
169
  

d48d8bc0   Karnovsky A   -
170
      public function getEnabledVariantPrice() {

c7852657   Karnovsky A   -
171
          return $this->enabledVariants[0]->price;

d48d8bc0   Karnovsky A   -
172
173
      }

  

3f2bc3d0   Administrator   first commit
174
175
176
177
178
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getVariants()

      {

0a93b48a   Karnovsky A   -
179
          return $this->hasMany(ProductVariant::className(), ['product_id' => 'product_id']);

3f2bc3d0   Administrator   first commit
180
181
      }

  

1e55b4b8   Karnovsky A   -
182
183
      public function getEnabledVariants()

      {

d48d8bc0   Karnovsky A   -
184
          return $this->hasMany(ProductVariant::className(), ['product_id' => 'product_id'])->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]);

1e55b4b8   Karnovsky A   -
185
186
      }

  

c7852657   Karnovsky A   -
187
188
189
190
191
192
193
      /*

       * Get variants grouped by type

       */

      public function getEnabledVariantsGrouped()

      {

          $variants = [];

          foreach ($this->enabledVariants as $variant) {

a57c9f4d   Karnovsky A   -
194
              $variants[$variant->product_variant_type_id ? $variant->product_variant_type_id : 1][] = $variant;

c7852657   Karnovsky A   -
195
196
197
198
          }

          if (empty($variants)) {

              return [];

          }

a57c9f4d   Karnovsky A   -
199
          $ids = array_keys($variants);

c7852657   Karnovsky A   -
200
          $variants_type = [];

a57c9f4d   Karnovsky A   -
201
          foreach(ProductVariantType::find()->select(['product_variant_type_id', 'name2'])->where(['product_variant_type_id' => $ids])->all() as $variant_type) {

c7852657   Karnovsky A   -
202
203
204
205
206
207
              $variant_type->_variants = $variants[$variant_type->product_variant_type_id];

              $variants_type[] = $variant_type;

          }

          return $variants_type;

      }

  

3f2bc3d0   Administrator   first commit
208
209
210
211
212
213
214
215
216
217
      public function setVariants($variants) {

          $this->_variants = $variants;

      }

  

      public function getFullName()

      {

          return empty($this->brand) ? $this->name : $this->brand->name .' '. $this->name;

      }

  

      public function getCategories() {

ccc7a9d3   Karnovsky A   Karnovsky 12052016
218
219
          return $this->hasMany(Category::className(), ['category_id' => 'category_id'])->viaTable('product_category', ['product_id' => 'product_id']);

  //        return $this->getRelations('product_categories');

3f2bc3d0   Administrator   first commit
220
221
222
223
224
225
226
227
228
229
230
      }

  

      public function getCategoriesNames() {

          $result = [];

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

              $result[] = $category->name;

          }

          return $result;

      }

  

      public function getCategory() {

ccc7a9d3   Karnovsky A   Karnovsky 12052016
231
          return $this->hasOne(Category::className(), ['category_id' => 'category_id'])->viaTable('product_category', ['product_id' => 'product_id']);

3f2bc3d0   Administrator   first commit
232
233
234
      }

  

      public function getOptions() {

c7852657   Karnovsky A   -
235
          return $this->hasMany(TaxOption::className(), ['tax_option_id' => 'option_id'])->viaTable('product_option', ['product_id' => 'product_id']);

2e3229c3   Karnovsky A   Import check
236
237
238
239
240
241
242
243
244
245
246
247
248
249
      }

  

      public function getProperties() {

          $groups = $options = [];

          foreach ($this->options as $option) {

              $options[$option->tax_group_id][] = $option;

          }

          foreach (TaxGroup::find()->where(['tax_group_id' => array_keys($options)])->all() as $group) {

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

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

                  $groups[] = $group;

              }

          }

          return $groups;

3f2bc3d0   Administrator   first commit
250
251
      }

  

5ee9ab1f   Karnovsky A   -
252
253
254
255
      public function getStocks() {

          return $this->hasMany(Stock::className(), ['stock_id' => 'stock_id'])->viaTable(ProductStock::tableName(), ['product_id' => 'product_id']);

      }

  

3f2bc3d0   Administrator   first commit
256
257
258
259
260
261
262
263
264
      /**

       * @inheritdoc

       * @return ProductQuery the active query used by this AR class.

       */

      public static function find()

      {

          return new ProductQuery(get_called_class());

      }

  

1e55b4b8   Karnovsky A   -
265
266
267
268
269
270
      public function getQuantity() {

          return ProductStock::find()

              ->where(['product_id' => $this->product_id])

              ->sum('quantity');

      }

  

3f2bc3d0   Administrator   first commit
271
272
273
274
      public function afterSave($insert, $changedAttributes)

      {

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

  

ccc7a9d3   Karnovsky A   Karnovsky 12052016
275
276
277
278
279
280
281
282
283
284
285
286
  //        $images = UploadedFile::getInstance($this, 'imagesUpload');

  //        var_dump($images);exit;

  

  //        if (!empty($this->imagesUpload)) {

  //            if (!is_array($this->imagesUpload)) {

  //                $this->imagesUpload = [$this->imagesUpload];

  //            }

  //            foreach($this->imagesUpload as $image) {

  //                $image->saveAs((Yii::getAlias('@frontend/web/storage/products/original/' . $image->baseName .'_'. uniqid() . '.' . $image->extension)));

  //            }

  //

  //

3f2bc3d0   Administrator   first commit
287
288
  //        }

  

4902c747   Karnovsky A   -
289
290
291
292
          if (!empty($this->_variants)) {

              $todel = [];

              foreach ($this->variants ?: [] as $_variant) {

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

3f2bc3d0   Administrator   first commit
293
              }

4902c747   Karnovsky A   -
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
              foreach ($this->_variants as $_variant) {

                  if (!is_array($_variant)) {

                      return;

                  }

                  if (!empty($_variant['product_variant_id'])) {

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

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

                  } else {

                      $model = new ProductVariant();

                  }

                  $_variant['product_id'] = $this->product_id;

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

                  $model->product_id = $this->product_id;

                  $model->save();

              }

              if (!empty($todel)) {

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

3f2bc3d0   Administrator   first commit
311
              }

c9d723d7   Karnovsky A   -
312
          }

3f2bc3d0   Administrator   first commit
313
      }

ccc7a9d3   Karnovsky A   Karnovsky 12052016
314
  

868680ca   Karnovsky A   -
315
316
317
318
319
320
      public function beforeDelete() {

          ProductImage::deleteAll(['product_id' => $this->product_id]);

          ProductCategory::deleteAll(['product_id' => $this->product_id]);

          ProductVariant::deleteAll(['product_id' => $this->product_id]);

      }

  

83be3cfb   Karnovsky A   -
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
      public function variantImagesUpload()

      {

          if ($this->validate()) {

              $images = [];

              foreach ($this->variantImagesUpload as $product_variant_id => $image) {

                  $imageName = $image->baseName .'.'. $image->extension;

                  $i = 0;

                  while(file_exists(Yii::getAlias('@imagesDir/products/' . $imageName))) {

                      $i++;

                      $imageName = $image->baseName .'_'. $i .'.'. $image->extension;

                  }

  

                  $image->saveAs(Yii::getAlias('@imagesDir/products/' .$imageName));

                  $images[$product_variant_id] = $imageName;

              }

              return $images;

          } else {

              return false;

          }

      }

  

ccc7a9d3   Karnovsky A   Karnovsky 12052016
342
343
344
345
346
347
348
      public function imagesUpload()

      {

          if ($this->validate()) {

              $images = [];

              foreach ($this->imagesUpload as $image) {

                  $imageName = $image->baseName .'.'. $image->extension;

                  $i = 0;

83be3cfb   Karnovsky A   -
349
                  while(file_exists(Yii::getAlias('@imagesDir/products/' . $imageName))) {

ccc7a9d3   Karnovsky A   Karnovsky 12052016
350
351
352
353
                      $i++;

                      $imageName = $image->baseName .'_'. $i .'.'. $image->extension;

                  }

  

83be3cfb   Karnovsky A   -
354
                  $image->saveAs(Yii::getAlias('@imagesDir/products/' .$imageName));

ccc7a9d3   Karnovsky A   Karnovsky 12052016
355
356
357
358
359
360
361
362
363
364
365
366
                  $images[] = $imageName;

              }

              return $images;

          } else {

              return false;

          }

      }

  

      public function getImagesHTML() {

          $op = [];

          if ($this->images) {

              foreach ($this->images as $image) {

83be3cfb   Karnovsky A   -
367
                  $op[] = \common\components\artboximage\ArtboxImageHelper::getImage($image->imageUrl, 'admin_thumb');

ccc7a9d3   Karnovsky A   Karnovsky 12052016
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
              }

          }

          return $op;

      }

  

      public function getImagesConfig() {

          $op = [];

          if ($this->images) {

              foreach ($this->images as $image) {

                  $op[] = [

                      'caption' => $image->image,

                      'width' => '120px',

                      'url' => \yii\helpers\Url::to(['/product/manage/delimg', 'id' => $image->product_image_id]),

                      'key' => $image->product_image_id,

                      'extra' => [

                          'id' => $image->product_image_id,

                      ],

                  ];

              }

          }

          return $op;

      }

3f2bc3d0   Administrator   first commit
390
  }