Blame view

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

3f2bc3d0   Administrator   first commit
30
31
32
33
34
35
36
37
   */

  class Product extends \yii\db\ActiveRecord

  {

      /** @var array $_variants */

      public $_variants = [];

  

      /** @var array $_images */

      public $imagesUpload = [];

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

3f2bc3d0   Administrator   first commit
39
40
41
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
      /**

       * @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   -
75
  //            [['categories'], 'required'],

3f2bc3d0   Administrator   first commit
76
77
78
              [['brand_id'], 'integer'],

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

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

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

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

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

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

3f2bc3d0   Administrator   first commit
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
  //            [['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
100
101
102
103
104
              '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   -
105
              'akciya' => Yii::t('product', 'Is promo'),

3f2bc3d0   Administrator   first commit
106
107
108
          ];

      }

  

02e6c2ba   Karnovsky A   -
109
110
111
112
      public function getUrl() {

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

      }

  

3f2bc3d0   Administrator   first commit
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
      /**

       * @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   -
130
131
132
133
134
       * fetch stored image url

       * @return string

       */

      public function getImageUrl()

      {

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

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

dc2cd017   Karnovsky A   -
137
138
139
      }

  

      /**

3f2bc3d0   Administrator   first commit
140
141
142
143
       * @return \yii\db\ActiveQuery

       */

      public function getImages()

      {

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

3f2bc3d0   Administrator   first commit
145
146
      }

  

3f2bc3d0   Administrator   first commit
147
148
149
150
151
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getVariant()

      {

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

3f2bc3d0   Administrator   first commit
153
154
      }

  

d48d8bc0   Karnovsky A   -
155
156
157
158
159
160
161
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getEnabledVariant()

      {

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

      }

3f2bc3d0   Administrator   first commit
162
163
164
      public function getVariantPrice() {

          return $this->variant->price;

      }

1e55b4b8   Karnovsky A   -
165
  

d48d8bc0   Karnovsky A   -
166
      public function getEnabledVariantPrice() {

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

d48d8bc0   Karnovsky A   -
168
169
      }

  

3f2bc3d0   Administrator   first commit
170
171
172
173
174
      /**

       * @return \yii\db\ActiveQuery

       */

      public function getVariants()

      {

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

3f2bc3d0   Administrator   first commit
176
177
      }

  

1e55b4b8   Karnovsky A   -
178
179
      public function getEnabledVariants()

      {

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

1e55b4b8   Karnovsky A   -
181
182
      }

  

c7852657   Karnovsky A   -
183
184
185
186
187
188
189
      /*

       * Get variants grouped by type

       */

      public function getEnabledVariantsGrouped()

      {

          $variants = [];

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

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

c7852657   Karnovsky A   -
191
192
193
194
          }

          if (empty($variants)) {

              return [];

          }

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

c7852657   Karnovsky A   -
196
          $variants_type = [];

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

c7852657   Karnovsky A   -
198
199
200
201
202
203
              $variant_type->_variants = $variants[$variant_type->product_variant_type_id];

              $variants_type[] = $variant_type;

          }

          return $variants_type;

      }

  

3f2bc3d0   Administrator   first commit
204
205
206
207
208
209
210
211
212
213
      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
214
215
          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
216
217
218
219
220
221
222
223
224
225
226
      }

  

      public function getCategoriesNames() {

          $result = [];

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

              $result[] = $category->name;

          }

          return $result;

      }

  

      public function getCategory() {

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

3f2bc3d0   Administrator   first commit
228
229
230
      }

  

      public function getOptions() {

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

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

3f2bc3d0   Administrator   first commit
233
234
      }

  

5ee9ab1f   Karnovsky A   -
235
236
237
238
      public function getStocks() {

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

      }

  

3f2bc3d0   Administrator   first commit
239
240
241
242
243
244
245
246
247
      /**

       * @inheritdoc

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

       */

      public static function find()

      {

          return new ProductQuery(get_called_class());

      }

  

1e55b4b8   Karnovsky A   -
248
249
250
251
252
253
      public function getQuantity() {

          return ProductStock::find()

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

              ->sum('quantity');

      }

  

3f2bc3d0   Administrator   first commit
254
255
256
257
      public function afterSave($insert, $changedAttributes)

      {

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

  

ccc7a9d3   Karnovsky A   Karnovsky 12052016
258
259
260
261
262
263
264
265
266
267
268
269
  //        $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
270
271
  //        }

  

4902c747   Karnovsky A   -
272
273
274
275
          if (!empty($this->_variants)) {

              $todel = [];

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

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

3f2bc3d0   Administrator   first commit
276
              }

4902c747   Karnovsky A   -
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
              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
294
              }

c9d723d7   Karnovsky A   -
295
          }

3f2bc3d0   Administrator   first commit
296
      }

ccc7a9d3   Karnovsky A   Karnovsky 12052016
297
  

868680ca   Karnovsky A   -
298
299
300
301
302
303
      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   -
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
      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
325
326
327
328
329
330
331
      public function imagesUpload()

      {

          if ($this->validate()) {

              $images = [];

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

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

                  $i = 0;

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

ccc7a9d3   Karnovsky A   Karnovsky 12052016
333
334
335
336
                      $i++;

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

                  }

  

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

ccc7a9d3   Karnovsky A   Karnovsky 12052016
338
339
340
341
342
343
344
345
346
347
348
349
                  $images[] = $imageName;

              }

              return $images;

          } else {

              return false;

          }

      }

  

      public function getImagesHTML() {

          $op = [];

          if ($this->images) {

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

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

ccc7a9d3   Karnovsky A   Karnovsky 12052016
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
              }

          }

          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;

      }

c7852657   Karnovsky A   -
373
374
375
376
377
378
379
380
381
382
383
384
385
386
  

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